/* ════════════════════════════════════════════════════════════════════
   products.css — All Products page
   Section map
     1. Hero / page header
     2. Shop layout (sidebar + main)
     3. Sidebar — filter sets, swatches, price range
     4. Active filter chips
     5. Toolbar (count, view-toggle, sort)
     6. Product grid + product card (4/3/2/list views)
     7. Empty state + Load more
     8. Mobile drawer + responsive breakpoints
   ════════════════════════════════════════════════════════════════════ */

/* ── Monochrome palette override (mirrors home.css :root) ──
   Flip the inherited emerald brand tokens to pure black/graphite/snow
   for this page only. Hardcoded emerald hex/rgba literals below are
   swapped in-place. */
.products-page{
  --gold:    #4A4A4A;   /* GRAPHITE — replaces metallic accent */
  --gold-l:  #8A8A8A;   /* STEEL — light accent / dividers */
  --gold-d:  #2A2A2A;   /* deeper graphite */
  --ink:     #000000;   /* PURE BLACK */
  --navy:    #141414;   /* NOIR */
  --cream:   #FAFAFA;   /* SNOW */
  --wine:    #000000;   /* PURE BLACK — interactive solid */
  --wine-d:  #000000;   /* PURE BLACK */
  --border:  #E0E0E0;   /* MIST hairline */
}

/* visually-hidden helper */
.products-page .visually-hidden{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

/* ════════════════════════════════════════════════════════════════════
   1. HERO / PAGE HEADER
   ════════════════════════════════════════════════════════════════════ */
.pp-hero{
  position:relative;overflow:hidden;
  padding:calc(var(--nav-h,100px) + 36px) 24px 56px;
  background:linear-gradient(180deg,#FAFAFA 0%,#F0F0F0 60%,#FAFAFA 100%);
  border-bottom:1px solid rgba(138,138,138,.10);
}
.pp-hero-bg{position:absolute;inset:0;pointer-events:none}
.pp-orb{
  position:absolute;border-radius:50%;
  filter:blur(70px);opacity:.55;
}
.pp-orb-1{
  width:520px;height:520px;left:-140px;top:-200px;
  background:radial-gradient(circle,rgba(138,138,138,.35),transparent 70%);
}
.pp-orb-2{
  width:440px;height:440px;right:-120px;top:30%;
  background:radial-gradient(circle,rgba(138,138,138,.30),transparent 70%);
}
.pp-grid-dots{
  position:absolute;inset:0;opacity:.18;
  background-image:radial-gradient(circle,#4A4A4A 1px,transparent 1.4px);
  background-size:26px 26px;
  mask-image:radial-gradient(ellipse 60% 60% at 50% 50%,#000 0%,transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse 60% 60% at 50% 50%,#000 0%,transparent 75%);
}

.pp-hero-inner{
  position:relative;z-index:1;
  max-width:1280px;margin:0 auto;
  display:flex;flex-direction:column;align-items:center;
  text-align:center;
}
.pp-breadcrumb{
  display:flex;align-items:center;gap:8px;
  font-size:12px;letter-spacing:.05em;color:var(--muted);
  margin-bottom:14px;
}
.pp-breadcrumb a{color:var(--wine);text-decoration:none;font-weight:500}
.pp-breadcrumb a:hover{text-decoration:underline}

.pp-hero-chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 16px;border-radius:100px;
  background:rgba(255,255,255,.7);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  border:1px solid rgba(138,138,138,.22);
  font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  color:var(--wine);
  box-shadow:0 4px 18px rgba(0,0,0,.06);
}
.pp-hero-chip svg{width:13px;height:13px}

.pp-hero-title{
  font-family:'Cormorant Garamond',serif;font-weight:400;
  font-size:clamp(40px,5.6vw,72px);line-height:1.04;color:#000000;
  margin:18px 0 14px;letter-spacing:-.5px;
}
.pp-hero-title em{
  font-style:italic;color:var(--wine);
  background:linear-gradient(90deg,var(--gold),var(--gold-l));
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}
.pp-hero-desc{
  max-width:560px;font-size:15px;line-height:1.7;color:var(--muted);
  margin:0 0 24px;
}
.pp-hero-trust{
  display:flex;flex-wrap:wrap;gap:18px 28px;justify-content:center;
  margin-top:6px;
}
.pp-trust-i{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12px;font-weight:600;letter-spacing:.06em;
  color:var(--wine-d);
}
.pp-trust-i svg{width:16px;height:16px;color:var(--gold-l)}

/* ════════════════════════════════════════════════════════════════════
   2. SHOP LAYOUT
   ════════════════════════════════════════════════════════════════════ */
.pp-shop{padding:48px 24px 96px;background:var(--cream)}
.pp-shop-in{
  max-width:1320px;margin:0 auto;
  display:grid;grid-template-columns:280px 1fr;gap:36px;
  align-items:flex-start;
}

/* mobile-only top bar (hidden on desktop) */
.pp-mobilebar{display:none}

/* ════════════════════════════════════════════════════════════════════
   3. SIDEBAR
   ════════════════════════════════════════════════════════════════════ */
.pp-side{
  position:sticky;top:120px;align-self:flex-start;
  background:#fff;border:1px solid var(--border);border-radius:18px;
  padding:22px 22px 14px;
  box-shadow:0 12px 36px rgba(0,0,0,.04);
  max-height:calc(100vh - 140px);overflow-y:auto;
}
.pp-side::-webkit-scrollbar{width:6px}
.pp-side::-webkit-scrollbar-thumb{background:rgba(138,138,138,.25);border-radius:100px}

.pp-side-head{
  display:flex;align-items:center;justify-content:space-between;
  padding-bottom:16px;margin-bottom:8px;
  border-bottom:1px solid var(--border);
}
.pp-side-title{
  font-family:'Cormorant Garamond',serif;font-weight:500;
  font-size:22px;color:#000000;line-height:1;
}
.pp-side-sub{
  font-size:11.5px;font-weight:500;letter-spacing:.06em;
  color:var(--muted);margin-top:4px;
}
.pp-side-close{
  display:none;width:34px;height:34px;border-radius:50%;cursor:pointer;
  background:#fff;border:1px solid var(--border);color:#000000;
  place-items:center;
}
.pp-side-close svg{width:16px;height:16px}

/* Filter sets (collapsible) */
.pp-fset{padding:14px 0;border-bottom:1px solid var(--border)}
.pp-fset:last-of-type{border-bottom:0}
.pp-fset > .pp-fset-sum{
  list-style:none;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;
  font-family:'Jost',sans-serif;font-size:12px;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;color:#000000;
  padding:4px 0;
}
.pp-fset > .pp-fset-sum::-webkit-details-marker{display:none}
.pp-fset-sum svg{
  width:16px;height:16px;color:var(--muted);
  transition:transform .25s;
}
.pp-fset[open] > .pp-fset-sum svg{transform:rotate(180deg)}
.pp-fset-body{
  padding-top:12px;display:flex;flex-direction:column;gap:8px;
}

/* Browse Collections — two-tier (top-level heading + child checkboxes) */
.pp-fset--browse .pp-fset-body{gap:14px}
.pp-fset-group{display:flex;flex-direction:column;gap:6px}
.pp-fset-group + .pp-fset-group{padding-top:10px;border-top:1px dashed var(--border)}
.pp-fset-group-head{
  font-family:'Cormorant Garamond',serif;font-weight:500;
  font-size:14px;color:#000000;
  margin:0 0 2px;
  letter-spacing:.01em;
}

/* Filter option */
.pp-fopt{
  display:grid;
  grid-template-columns:18px 1fr auto;
  align-items:center;gap:10px;
  padding:6px 4px;border-radius:8px;
  cursor:pointer;font-size:13px;color:#000000;
  transition:background .2s,color .2s;
}
.pp-fopt:hover{background:rgba(138,138,138,.06)}
.pp-fopt input{
  position:absolute;opacity:0;pointer-events:none;
}
.pp-fopt-box{
  width:18px;height:18px;border-radius:5px;
  border:1.5px solid var(--border);background:#fff;
  display:grid;place-items:center;
  transition:background .2s,border-color .2s;
}
.pp-fopt-box svg{
  width:12px;height:12px;fill:none;stroke:#fff;stroke-width:2.5;
  opacity:0;transform:scale(.6);
  transition:opacity .2s,transform .2s;
}
.pp-fopt input:checked + .pp-fopt-box{
  background:var(--wine);border-color:var(--wine);
}
.pp-fopt input:checked + .pp-fopt-box svg{opacity:1;transform:scale(1)}
.pp-fopt input:focus-visible + .pp-fopt-box{
  outline:2px solid var(--gold-l);outline-offset:2px;
}
.pp-fopt-lbl{font-weight:500;line-height:1.2}
.pp-fopt-n{
  font-size:11px;font-weight:600;color:var(--muted);
  padding:2px 8px;border-radius:100px;background:rgba(138,138,138,.08);
}
.pp-fopt input:checked ~ .pp-fopt-lbl{font-weight:600;color:var(--wine-d)}

/* swatch variant */
.pp-fopt--sw{grid-template-columns:18px 18px 1fr auto}
.pp-swatch{
  width:18px;height:18px;border-radius:50%;
  background:linear-gradient(135deg,var(--s1),var(--s2));
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.12),0 1px 3px rgba(0,0,0,.1);
}

/* Price */
.pp-price-readout{
  display:flex;align-items:center;justify-content:space-between;
  font-size:13px;font-weight:600;color:#000000;
  margin-bottom:14px;
}
.pp-price-dash{color:var(--muted);margin:0 8px}
.pp-range{
  position:relative;height:36px;
  display:flex;align-items:center;
  margin-bottom:12px;
}
.pp-range input[type="range"]{
  position:absolute;left:0;right:0;width:100%;
  -webkit-appearance:none;appearance:none;
  background:transparent;pointer-events:none;
  z-index:2;height:36px;margin:0;
}
.pp-range input[type="range"]::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;
  width:18px;height:18px;border-radius:50%;
  background:#fff;border:2px solid var(--wine);
  cursor:pointer;pointer-events:auto;
  box-shadow:0 2px 8px rgba(74,74,74,.25);
  transition:transform .2s;
}
.pp-range input[type="range"]::-webkit-slider-thumb:hover{transform:scale(1.15)}
.pp-range input[type="range"]::-moz-range-thumb{
  width:18px;height:18px;border-radius:50%;
  background:#fff;border:2px solid var(--wine);
  cursor:pointer;pointer-events:auto;
  box-shadow:0 2px 8px rgba(74,74,74,.25);
}
.pp-range-track{
  position:absolute;left:0;right:0;top:50%;height:4px;
  transform:translateY(-50%);
  background:var(--border);border-radius:100px;
  z-index:1;
}
.pp-range-fill{
  position:absolute;left:0;right:0;top:0;bottom:0;
  background:linear-gradient(90deg,var(--gold),var(--wine));
  border-radius:100px;
}

.pp-price-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.pp-price-chip{
  font-family:'Jost',sans-serif;font-size:11px;font-weight:600;
  padding:6px 10px;border-radius:100px;cursor:pointer;
  background:rgba(138,138,138,.08);color:var(--wine-d);
  border:1px solid transparent;
  transition:background .2s,border-color .2s,color .2s;
}
.pp-price-chip:hover{background:rgba(138,138,138,.16)}
.pp-price-chip.is-active{
  background:var(--wine);color:#fff;border-color:var(--wine);
}

/* mobile only Apply button */
.pp-side-apply{display:none}

/* ════════════════════════════════════════════════════════════════════
   4. ACTIVE FILTER CHIPS
   ════════════════════════════════════════════════════════════════════ */
.pp-active-wrap{
  padding-bottom:14px;margin-bottom:4px;
  border-bottom:1px solid var(--border);
}
.pp-active-row{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:8px;
}
.pp-active-lbl{
  font-size:10.5px;font-weight:700;letter-spacing:.18em;
  text-transform:uppercase;color:var(--muted);
}
.pp-clear-all{
  background:none;border:0;padding:0;cursor:pointer;
  font-family:'Jost',sans-serif;font-size:11.5px;font-weight:600;
  color:var(--wine);letter-spacing:.04em;
  border-bottom:1px solid currentColor;line-height:1.2;
  transition:color .2s;
}
.pp-clear-all:hover{color:var(--gold)}
.pp-active-chips{display:flex;flex-wrap:wrap;gap:6px}
.pp-chip{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 8px 5px 12px;border-radius:100px;
  background:rgba(74,74,74,.08);color:var(--wine-d);
  font-size:11.5px;font-weight:500;
  border:1px solid rgba(74,74,74,.16);
}
.pp-chip-x{
  width:18px;height:18px;border-radius:50%;cursor:pointer;
  background:rgba(74,74,74,.18);border:0;color:var(--wine-d);
  display:grid;place-items:center;
  transition:background .2s,transform .2s;
}
.pp-chip-x:hover{background:var(--wine);color:#fff;transform:rotate(90deg)}
.pp-chip-x svg{width:10px;height:10px;fill:none;stroke:currentColor;stroke-width:2.5}

/* ════════════════════════════════════════════════════════════════════
   5. TOOLBAR
   ════════════════════════════════════════════════════════════════════ */
.pp-toolbar{
  display:flex;align-items:center;justify-content:space-between;
  gap:18px;flex-wrap:wrap;
  padding:0 4px 22px;margin-bottom:22px;
  border-bottom:1px solid var(--border);
}
.pp-tool-left,.pp-tool-right{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
}
.pp-result-count{
  font-size:13.5px;font-weight:500;color:#000000;
}
.pp-result-count em{
  font-style:normal;font-weight:700;color:var(--wine);
}
.pp-active-inline{
  display:flex;flex-wrap:wrap;gap:6px;
}

/* View toggle */
.pp-view-toggle{
  display:inline-flex;align-items:center;
  background:#fff;border:1px solid var(--border);border-radius:100px;
  padding:3px;gap:2px;
}
.pp-view-btn{
  width:32px;height:32px;border-radius:100px;cursor:pointer;
  background:transparent;border:0;color:var(--muted);
  display:grid;place-items:center;
  transition:background .2s,color .2s;
}
.pp-view-btn svg{width:14px;height:14px}
.pp-view-btn:hover{color:var(--wine-d)}
.pp-view-btn.is-active{background:var(--wine);color:#fff}

/* Sort — label + custom .bv-dd dropdown */
.pp-sort{
  display:inline-flex;align-items:center;gap:12px;
}
.pp-sort-lbl{
  font-size:11px;font-weight:700;letter-spacing:.18em;
  text-transform:uppercase;color:var(--muted);
}

/* ─── Compact pill variant of the shared .bv-dd dropdown ─── */
.pp-sort-dd{position:relative;min-width:210px}
.pp-sort-dd .bv-dd-btn{
  display:inline-flex;align-items:center;justify-content:space-between;gap:14px;
  min-height:44px;
  padding:10px 18px 10px 22px;
  background:#fff;border:1px solid var(--border);border-radius:100px;
  font-family:'Jost',sans-serif;font-size:13px;font-weight:600;
  color:#000000;letter-spacing:.01em;
  box-shadow:0 1px 2px rgba(0,0,0,.04);
  transition:border-color .22s,box-shadow .22s,background .22s,transform .22s;
}
.pp-sort-dd .bv-dd-btn:hover{
  border-color:rgba(74,74,74,.55);
  box-shadow:0 4px 14px -4px rgba(0,0,0,.12);
}
.pp-sort-dd .bv-dd-btn:focus-visible,
.pp-sort-dd.open .bv-dd-btn{
  border-color:var(--wine);
  box-shadow:0 0 0 3px rgba(74,74,74,.14),0 4px 14px -4px rgba(0,0,0,.12);
}
.pp-sort-dd .bv-dd-display{
  flex:1 1 auto;min-width:0;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  text-align:left;
}
.pp-sort-dd .bv-dd-arrow{
  flex-shrink:0;
  width:14px;height:14px;
  stroke:var(--muted);stroke-width:2;fill:none;
  transition:transform .3s cubic-bezier(.22,.61,.36,1),stroke .22s;
}
.pp-sort-dd.open .bv-dd-arrow{stroke:var(--wine);transform:rotate(180deg)}

.pp-sort-dd .bv-dd-list{
  position:absolute;
  top:calc(100% + 10px);
  left:auto;right:0;
  min-width:240px;
  padding:6px;
  margin:0;
  list-style:none;
  background:#fff;
  border-radius:16px;border:1px solid var(--border);
  box-shadow:
    0 24px 60px -18px rgba(0,0,0,.18),
    0 8px 20px -8px rgba(0,0,0,.10);
  max-height:320px;
  overflow:hidden auto;
  opacity:0;
  transform:translateY(-6px) scale(.98);
  pointer-events:none;
  z-index:200;
  transition:opacity .2s ease,transform .2s ease;
}
.pp-sort-dd.open .bv-dd-list{
  opacity:1;
  transform:none;
  pointer-events:auto;
}
.pp-sort-dd .bv-dd-item{cursor:pointer}
.pp-sort-dd .bv-dd-list::-webkit-scrollbar{width:6px}
.pp-sort-dd .bv-dd-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:100px}
.pp-sort-dd .bv-dd-item{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:11px 14px;
  font-family:'Jost',sans-serif;font-size:13px;font-weight:500;
  color:#000000;
  border-bottom:0;
  border-radius:10px;
  transition:background .15s,color .15s,padding-left .2s;
}
.pp-sort-dd .bv-dd-item:hover{
  background:var(--cream);color:var(--wine);
  padding-left:18px;
}
.pp-sort-dd .bv-dd-item.selected{
  background:rgba(74,74,74,.08);color:var(--wine);font-weight:600;
}
.pp-sort-dd .bv-dd-item.selected::after{
  content:'';flex-shrink:0;width:14px;height:14px;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%234A4A4A' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-size:contain;background-repeat:no-repeat;background-position:center;
}

/* Mobile variant — fills the available toolbar width */
.pp-sort-dd--m{width:100%;min-width:0}
.pp-sort-dd--m .bv-dd-btn{
  width:100%;min-height:48px;padding:12px 18px 12px 22px;
}
.pp-sort-dd--m .bv-dd-list{left:0;right:0;min-width:0}

/* ════════════════════════════════════════════════════════════════════
   6. PRODUCT GRID + PRODUCT CARD
   ════════════════════════════════════════════════════════════════════ */
.pp-grid{
  display:grid;gap:24px;
}
.pp-grid--4{grid-template-columns:repeat(4,1fr)}
.pp-grid--3{grid-template-columns:repeat(3,1fr)}
.pp-grid--2{grid-template-columns:repeat(2,1fr)}
.pp-grid--list{grid-template-columns:1fr;gap:18px}

.pp-card{
  position:relative;display:flex;flex-direction:column;
  background:#fff;border:1px solid var(--border);border-radius:16px;
  overflow:hidden;text-decoration:none;color:inherit;
  transition:transform .35s cubic-bezier(.2,.7,.2,1),box-shadow .35s,border-color .35s;
  animation:pp-card-in .45s cubic-bezier(.22,1,.36,1) both;
}
@keyframes pp-card-in{
  from{opacity:0;transform:translateY(14px) scale(.97)}
  to  {opacity:1;transform:none}
}
.pp-card:hover{
  transform:translateY(-6px);
  box-shadow:0 20px 44px rgba(0,0,0,.12);
  border-color:rgba(74,74,74,.30);
}

.pp-card-img{
  position:relative;aspect-ratio:1/1;overflow:hidden;background:#F0F0F0;
}
.pp-card-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1s cubic-bezier(.2,.7,.2,1),opacity .35s;
}
.pp-card:hover .pp-card-img img{transform:scale(1.08)}
/* second image preview on hover */
.pp-card-img .pp-card-img--2{
  position:absolute;inset:0;opacity:0;
}
.pp-card:hover .pp-card-img--2{opacity:1}

.pp-card-badge{
  position:absolute;top:12px;left:12px;z-index:2;
  font-family:'Jost',sans-serif;
  font-size:9.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  padding:6px 12px;border-radius:100px;
  background:#fff;color:var(--wine);
  border:1px solid var(--border);
  box-shadow:0 2px 10px rgba(0,0,0,.06);
}
.pp-card-badge--trend{background:linear-gradient(135deg,#E0E0E0,#8A8A8A);color:#000000;border-color:transparent}
.pp-card-badge--best{background:linear-gradient(135deg,var(--wine),var(--gold-l));color:#fff;border-color:transparent}

.pp-card-wish{
  position:absolute;top:12px;right:12px;z-index:2;
  width:38px;height:38px;border-radius:50%;cursor:pointer;
  background:rgba(255,255,255,.96);border:1px solid var(--border);
  display:grid;place-items:center;color:#000000;
  transition:all .25s;
}
.pp-card-wish svg{width:16px;height:16px;fill:none;transition:fill .25s,stroke .25s}
.pp-card-wish:hover{background:var(--wine);border-color:var(--wine);color:#fff;transform:scale(1.08)}
.pp-card-wish:hover svg{fill:#fff}
.pp-card-wish.is-on{
  background:var(--wine);border-color:var(--wine);color:#fff;
  animation:pp-heart-pop .45s cubic-bezier(.34,1.56,.64,1) both;
}
.pp-card-wish.is-on svg{fill:#fff;stroke:#fff}
@keyframes pp-heart-pop{
  0%{transform:scale(.9)} 50%{transform:scale(1.25)} 100%{transform:scale(1.08)}
}

.pp-card-overlay{
  position:absolute;left:0;right:0;bottom:0;z-index:2;
  display:flex;justify-content:center;align-items:flex-end;gap:8px;
  padding:18px;
  background:linear-gradient(to top,rgba(20,20,20,.78) 0%,transparent 100%);
  opacity:0;transition:opacity .3s;pointer-events:none;
}
.pp-card:hover .pp-card-overlay,
.pp-card:focus-within .pp-card-overlay{opacity:1}
.pp-card-quick{
  pointer-events:auto;
  padding:10px 18px;border:0;cursor:pointer;border-radius:100px;
  background:rgba(74,74,74,.92);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  color:#fff;font-family:'Jost',sans-serif;
  font-size:10.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  transform:translateY(8px);
  transition:transform .3s,background .2s,box-shadow .25s;
  box-shadow:0 6px 18px rgba(20,20,20,.35);
}
.pp-card:hover .pp-card-quick{transform:translateY(0)}
.pp-card-quick:hover{background:var(--gold)}
@media (hover:none){
  .pp-card-overlay{opacity:1}
  .pp-card-quick{transform:none}
}

/* Body */
.pp-card-body{
  padding:16px 18px 18px;display:flex;flex-direction:column;gap:4px;
  flex:1;
}
.pp-card-cat{
  font-family:'Jost',sans-serif;
  font-size:9.5px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold);
}
.pp-card-name{
  font-family:'Cormorant Garamond',serif;
  font-size:18px;font-weight:500;color:#000000;line-height:1.25;
}
.pp-card-sub{font-size:12px;color:var(--muted);margin-bottom:4px}
.pp-card-rating{
  display:inline-flex;align-items:center;gap:5px;font-size:11.5px;
  color:var(--muted);margin:2px 0 6px;
}
.pp-card-rating .pp-stars{
  display:inline-flex;color:var(--gold);
}
.pp-card-rating .pp-stars svg{width:12px;height:12px;fill:currentColor}
.pp-card-rating .pp-rvw{color:var(--muted);font-weight:500}
.pp-card-foot{
  margin-top:auto;
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding-top:6px;
}
.pp-card-price{
  font-family:'Cormorant Garamond',serif;
  font-size:20px;font-weight:600;color:#000000;letter-spacing:.01em;
}
.pp-card-add{
  display:inline-flex;align-items:center;gap:6px;
  height:36px;padding:0 14px;border-radius:100px;cursor:pointer;
  background:var(--cream);border:1px solid var(--border);
  color:var(--wine);font-family:'Jost',sans-serif;
  font-size:10.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  transition:background .25s,border-color .25s,color .25s,transform .25s;
}
.pp-card-add svg{width:13px;height:13px;fill:none}
.pp-card-add:hover{
  background:var(--wine);border-color:var(--wine);color:#fff;
}

/* Quantity stepper — shown after item is added to cart */
.pp-card-qty{
  display:inline-flex;align-items:center;
  height:36px;padding:3px;border-radius:100px;
  background:var(--wine);border:1px solid var(--wine);color:#fff;
  box-shadow:0 6px 16px rgba(74,74,74,.18);
  animation:pp-qty-pop .28s cubic-bezier(.34,1.56,.64,1) both;
}
@keyframes pp-qty-pop{
  0%{transform:scale(.85);opacity:0}
  100%{transform:scale(1);opacity:1}
}
.pp-qty-btn{
  width:28px;height:28px;border-radius:50%;cursor:pointer;
  background:rgba(255,255,255,.12);border:0;color:#fff;
  display:grid;place-items:center;
  transition:background .2s,transform .15s;
}
.pp-qty-btn svg{width:13px;height:13px;fill:none;stroke:currentColor}
.pp-qty-btn:hover{background:rgba(255,255,255,.28)}
.pp-qty-btn:active{transform:scale(.92)}
.pp-qty-dec svg{width:12px;height:12px}
.pp-qty-num{
  min-width:28px;padding:0 6px;
  text-align:center;
  font-family:'Jost',sans-serif;font-size:13px;font-weight:700;
  color:#fff;letter-spacing:.02em;line-height:1;
  font-variant-numeric:tabular-nums;
}

/* List view */
.pp-grid--list .pp-card{
  flex-direction:row;align-items:stretch;
}
.pp-grid--list .pp-card-img{
  width:260px;flex-shrink:0;aspect-ratio:1/1;
}
.pp-grid--list .pp-card-body{padding:24px 28px}
.pp-grid--list .pp-card-name{font-size:24px}
.pp-grid--list .pp-card-price{font-size:24px}
.pp-grid--list .pp-card-add{padding:0 22px;height:42px;font-size:11px}
.pp-grid--list .pp-card-desc{
  display:block;font-size:13px;color:var(--muted);line-height:1.65;
  margin:6px 0 8px;max-width:560px;
}
.pp-card-desc{display:none}

/* ════════════════════════════════════════════════════════════════════
   7. EMPTY STATE + LOAD MORE
   ════════════════════════════════════════════════════════════════════ */
.pp-empty{
  text-align:center;padding:64px 24px;
  border:1px dashed var(--border);border-radius:18px;
  background:#FAFAFA;margin-top:8px;
}
.pp-empty-glyph{
  width:64px;height:64px;border-radius:50%;
  background:rgba(138,138,138,.08);color:var(--wine);
  display:grid;place-items:center;margin:0 auto 14px;
}
.pp-empty-glyph svg{width:28px;height:28px}
.pp-empty h3{
  font-family:'Cormorant Garamond',serif;font-weight:500;
  font-size:24px;color:#000000;margin-bottom:8px;
}
.pp-empty p{font-size:14px;color:var(--muted);margin-bottom:18px}
.pp-btn-ghost{
  display:inline-flex;align-items:center;justify-content:center;
  padding:11px 22px;border-radius:100px;cursor:pointer;
  background:#fff;border:1px solid var(--wine);
  color:var(--wine);font-family:'Jost',sans-serif;
  font-size:11.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  transition:background .25s,color .25s;
}
.pp-btn-ghost:hover{background:var(--wine);color:#fff}

.pp-loadmore-wrap{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  margin-top:36px;
}
.pp-loadmore{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 32px;border-radius:100px;cursor:pointer;
  background:#fff;border:1px solid var(--wine);
  color:var(--wine);font-family:'Jost',sans-serif;
  font-size:11.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  transition:background .25s,color .25s,transform .25s,box-shadow .25s;
}
.pp-loadmore svg{width:14px;height:14px;transition:transform .25s}
.pp-loadmore:hover{
  background:var(--wine);color:#fff;transform:translateY(-2px);
  box-shadow:0 14px 32px rgba(74,74,74,.22);
}
.pp-loadmore:hover svg{transform:translateY(2px)}
.pp-loadmore-meta{
  font-size:12px;color:var(--muted);letter-spacing:.04em;
}
.pp-loadmore[hidden]{display:none}

/* ════════════════════════════════════════════════════════════════════
   8. MOBILE DRAWER + RESPONSIVE
   ════════════════════════════════════════════════════════════════════ */
.pp-side-backdrop{
  position:fixed;inset:0;z-index:998;
  background:rgba(20,20,20,.55);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  opacity:0;transition:opacity .3s;pointer-events:none;
}
.pp-side-backdrop.is-open{opacity:1;pointer-events:auto}

@media(max-width:1200px){
  .pp-shop-in{grid-template-columns:240px 1fr;gap:24px}
  .pp-grid--4{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:980px){
  .pp-shop-in{grid-template-columns:1fr;gap:18px}
  .pp-mobilebar{
    display:flex;align-items:center;justify-content:space-between;
    gap:12px;padding:0 0 14px;
  }
  .pp-mfilters{
    display:inline-flex;align-items:center;gap:8px;
    padding:12px 18px;border-radius:100px;cursor:pointer;
    background:#fff;border:1px solid var(--border);
    color:#000000;font-family:'Jost',sans-serif;
    font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
    position:relative;
  }
  .pp-mfilters svg{width:16px;height:16px}
  .pp-mfilters-dot{
    width:8px;height:8px;border-radius:50%;background:var(--wine);
    display:inline-block;
  }
  .pp-msort{flex:1;max-width:240px}

  /* Sidebar becomes a drawer */
  .pp-side{
    position:fixed;top:0;left:0;height:100dvh;width:min(360px,88vw);
    z-index:999;border-radius:0 18px 18px 0;
    padding:22px 22px 100px;max-height:none;
    transform:translateX(-105%);
    transition:transform .35s cubic-bezier(.22,1,.36,1);
    box-shadow:0 22px 60px rgba(0,0,0,.25);
  }
  .pp-side.is-open{transform:none}
  .pp-side-close{display:grid}
  .pp-side-apply{
    display:block;
    position:absolute;left:18px;right:18px;bottom:18px;
  }
  .pp-btn-apply{
    width:100%;padding:14px;border-radius:100px;cursor:pointer;
    background:var(--wine);color:#fff;border:0;
    font-family:'Jost',sans-serif;font-size:12px;font-weight:700;
    letter-spacing:.16em;text-transform:uppercase;
    box-shadow:0 12px 28px rgba(74,74,74,.28);
  }

  .pp-tool-left,.pp-tool-right{gap:10px}
  .pp-sort{display:none}            /* mobile uses the top-bar dropdown */
  .pp-view-toggle{display:none}     /* mobile keeps it simple */
}
@media(max-width:720px){
  .pp-grid--4,.pp-grid--3{grid-template-columns:repeat(2,1fr);gap:14px}
  .pp-grid--2{grid-template-columns:repeat(2,1fr);gap:14px}
  .pp-grid--list .pp-card{flex-direction:column}
  .pp-grid--list .pp-card-img{width:100%;aspect-ratio:1/1}
  .pp-grid--list .pp-card-desc{display:none}
  .pp-hero{padding:calc(var(--nav-h,100px) + 24px) 18px 40px}
  .pp-shop{padding:32px 16px 80px}
  .pp-card-wish{width:32px;height:32px;top:8px;right:8px}
  .pp-card-wish svg{width:14px;height:14px}
  .pp-card-add{padding:0 10px;height:32px;font-size:9.5px}
  .pp-card-add span{display:none}
  .pp-card-qty{height:32px;padding:2px}
  .pp-qty-btn{width:26px;height:26px}
  .pp-qty-btn svg{width:11px;height:11px}
  .pp-qty-num{min-width:22px;font-size:12px}
  .pp-card-name{font-size:16px}
  .pp-card-price{font-size:17px}
  .pp-toolbar{padding-bottom:16px;margin-bottom:18px}
}
@media(max-width:440px){
  .pp-grid--4,.pp-grid--3,.pp-grid--2{grid-template-columns:1fr}
  .pp-card-img{aspect-ratio:4/3}
}
