/* ════════════════════════════════════════════════
   CATALOG — Cards, Grids, Filters
   ════════════════════════════════════════════════ */

/* ── Grids ── */
.pack-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.grid-4{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:24px}
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px}
@media(max-width:900px){.pack-grid{grid-template-columns:repeat(2,1fr)}}

/* ── Filter Bar — pill tabs con indicador deslizante ── */
.filter-bar{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-bottom:40px;position:relative}
.filt-btn{
  padding:9px 22px;border:1.5px solid var(--cream4);background:var(--white);
  color:var(--mink);font-size:12px;font-weight:600;letter-spacing:.06em;
  text-transform:uppercase;cursor:pointer;font-family:var(--sans);
  transition:all .22s cubic-bezier(.4,0,.2,1);border-radius:30px;
  position:relative;overflow:hidden;
}
.filt-btn::after{
  content:'';position:absolute;inset:0;background:var(--ink);
  transform:scaleX(0);transform-origin:left;transition:transform .22s cubic-bezier(.4,0,.2,1);
  z-index:0;border-radius:30px;
}
.filt-btn span{position:relative;z-index:1}
.filt-btn:hover{border-color:var(--ink);color:var(--gold3)}
.filt-btn:hover::after{transform:scaleX(1)}
.filt-btn.active{
  background:var(--ink);color:var(--gold3);border-color:var(--ink);
  box-shadow:0 4px 16px rgba(44,31,26,.2);
  animation:pillPop .3s cubic-bezier(.34,1.4,.64,1);
}
@keyframes pillPop{0%{transform:scale(.92)}60%{transform:scale(1.06)}100%{transform:scale(1)}}
.filt-btn:active{transform:scale(.96)}

.filter-price-bar{margin-top:-24px;margin-bottom:28px}
.filter-label{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--mink);opacity:.7;align-self:center;white-space:nowrap}
.filt-price-btn{
  padding:7px 16px;border:1.5px solid var(--cream4);background:var(--white);
  color:var(--mink);font-size:11px;font-weight:600;letter-spacing:.05em;
  cursor:pointer;font-family:var(--sans);transition:all .22s cubic-bezier(.4,0,.2,1);border-radius:20px;
}
.filt-price-btn:hover{background:var(--gold3);color:var(--ink);border-color:var(--gold3);transform:translateY(-1px)}
.filt-price-btn.active{background:var(--gold3);color:var(--ink);border-color:var(--gold3);box-shadow:0 4px 12px rgba(201,169,110,.3)}

/* ── Pack Card ── */
.pack-card{
  background:var(--white);border:1px solid rgba(232,212,192,.7);
  border-radius:16px;overflow:hidden;cursor:pointer;position:relative;
  contain:layout style;
  transition:transform .32s cubic-bezier(.34,1.2,.64,1),
             box-shadow .32s cubic-bezier(.4,0,.2,1),
             border-color .22s;
}
.pack-card::before{
  content:'';position:absolute;inset:0;border-radius:16px;
  background:linear-gradient(135deg,rgba(201,169,110,.06),transparent 60%);
  opacity:0;transition:opacity .3s;z-index:0;pointer-events:none;
}
.pack-card:hover{
  transform:translateY(-8px) scale(1.01);
  box-shadow:0 24px 64px rgba(92,74,61,.18),0 4px 16px rgba(92,74,61,.08);
  border-color:var(--gold3);
}
.pack-card:hover::before{opacity:1}
.pack-card:active{transform:translateY(-4px) scale(.99)}

.pack-card-img{
  width:100%;height:240px;
  background:linear-gradient(145deg,var(--pearl),var(--cream2));
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
.pack-card-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to top,rgba(44,31,26,.18) 0%,transparent 50%);
  opacity:0;transition:opacity .3s;z-index:1;pointer-events:none;
}
.pack-card:hover .pack-card-img::after{opacity:1}
.pack-card-img img.pack-real-img{
  width:100%;height:100%;object-fit:cover;position:absolute;inset:0;
  transition:transform .5s cubic-bezier(.4,0,.2,1),opacity .3s;
}
.pack-card:hover .pack-card-img img.pack-real-img{transform:scale(1.06)}

.pack-card-badge{
  position:absolute;top:14px;left:14px;padding:4px 12px;
  font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  z-index:3;border-radius:4px;backdrop-filter:blur(8px);
}
.pack-card-badge.rose{background:rgba(196,132,126,.92);color:#fff}
.pack-card-badge.gold{background:rgba(201,169,110,.92);color:var(--ink)}

.pack-card-wish{
  position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:50%;
  background:rgba(253,250,247,.92);border:1px solid rgba(232,212,192,.6);
  display:flex;align-items:center;justify-content:center;font-size:15px;
  cursor:pointer;z-index:3;transition:all .22s cubic-bezier(.34,1.4,.64,1);
  backdrop-filter:blur(8px);
}
.pack-card-wish:hover{transform:scale(1.2);background:var(--rose3);border-color:var(--rose2)}
.pack-card-wish.active{background:var(--rose3);border-color:var(--rose2);transform:scale(1.1)}

.pack-card-body{padding:20px;display:flex;flex-direction:column;flex:1;position:relative;z-index:1}
.pack-card-name{
  font-family:var(--serif);font-size:18px;font-weight:400;color:var(--mink);
  font-style:italic;line-height:1.2;margin-bottom:4px;
}
.pack-card-sub{font-size:12px;color:var(--mink);margin-bottom:6px;line-height:1.4;opacity:.75}
.pack-card-includes{font-size:11px;color:var(--mink);margin-bottom:12px;line-height:1.5;opacity:.7}
.pack-card-footer{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:auto}
.pack-card-price{font-family:var(--serif);font-size:26px;font-weight:400;color:var(--ink);font-style:italic}

.btn-pack{
  background:var(--ink);color:var(--gold3);border:none;
  padding:10px 20px;font-size:11px;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;cursor:pointer;font-family:var(--sans);
  transition:all .22s cubic-bezier(.4,0,.2,1);border-radius:6px;
  position:relative;overflow:hidden;
}
.btn-pack::after{
  content:'';position:absolute;inset:0;background:rgba(255,255,255,.1);
  transform:translateX(-100%);transition:transform .3s;
}
.btn-pack:hover{background:var(--ink2);transform:translateY(-1px);box-shadow:0 4px 12px rgba(44,31,26,.25)}
.btn-pack:hover::after{transform:translateX(0)}
.btn-pack:active{transform:scale(.96)}

/* ── Cat Card (productos individuales) ── */
.cat-card{
  background:var(--white);border:1px solid rgba(232,212,192,.5);
  border-radius:16px;overflow:hidden;cursor:pointer;position:relative;
  display:flex;flex-direction:column;
  contain:layout style paint;
  transition:transform .28s cubic-bezier(.34,1.2,.64,1),
             box-shadow .28s cubic-bezier(.4,0,.2,1),
             border-color .2s;
}
.cat-card:hover{
  transform:translateY(-6px);
  box-shadow:0 16px 48px rgba(92,74,61,.15),0 2px 8px rgba(92,74,61,.06);
  border-color:rgba(201,169,110,.5);
}
.cat-card:active{transform:translateY(-2px) scale(.99)}
.cat-card.agotado:hover{transform:none;box-shadow:none;border-color:rgba(232,212,192,.5)}

.cat-card-img{
  width:100%;aspect-ratio:1/1;
  background:linear-gradient(145deg,var(--pearl),var(--cream2));
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;flex-shrink:0;
}
.cat-card-img img{
  width:100%;height:100%;object-fit:cover;position:absolute;inset:0;
  transition:transform .5s cubic-bezier(.4,0,.2,1);
}
.cat-card:hover .cat-card-img img{ transform:scale(1.06); }
.cat-card-emoji{font-size:56px;position:relative;z-index:1;transition:transform .3s cubic-bezier(.34,1.4,.64,1)}
.cat-card:hover .cat-card-emoji{transform:scale(1.1) rotate(-3deg)}

/* Quick-view overlay al hover */
.cat-card-quick{
  position:absolute;bottom:0;left:0;right:0;
  background:linear-gradient(to top,rgba(44,31,26,.75),transparent);
  padding:24px 12px 12px;
  display:flex;align-items:center;justify-content:center;
  opacity:0;transform:translateY(6px);
  transition:opacity .25s,transform .25s;z-index:2;
}
.cat-card:hover .cat-card-quick{opacity:1;transform:translateY(0)}
.cat-card-quick-label{
  font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--gold3);display:flex;align-items:center;gap:5px;
}
.cat-card-quick-label::before{content:'👁';font-size:12px}

.cat-card-agotado-badge{
  position:absolute;top:10px;left:10px;
  background:rgba(44,31,26,.82);color:#fff;
  font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  padding:5px 12px;border-radius:20px;z-index:4;
  backdrop-filter:blur(6px);
  border:1px solid rgba(255,255,255,.15);
  display:flex;align-items:center;gap:5px;
  box-shadow:0 2px 8px rgba(0,0,0,.18);
}
.cat-card-agotado-badge::before{content:'✕';font-size:8px;opacity:.7}

.card-wish{
  position:absolute;top:10px;right:10px;width:32px;height:32px;border-radius:50%;
  background:rgba(253,250,247,.9);border:1px solid rgba(232,212,192,.5);
  display:flex;align-items:center;justify-content:center;font-size:14px;
  cursor:pointer;z-index:3;transition:all .2s cubic-bezier(.34,1.4,.64,1);
  backdrop-filter:blur(6px);
}
.card-wish:hover{transform:scale(1.18);background:var(--rose3);border-color:var(--rose2)}
.card-wish.active{background:var(--rose3);border-color:var(--rose2);transform:scale(1.08)}

.cat-card-body{
  padding:12px 14px 14px;
  display:flex;flex-direction:column;flex:1;
  position:relative;z-index:1;
}
.cat-card-stars{font-size:10px;color:var(--gold2);margin-bottom:3px;letter-spacing:.5px}
.cat-card-name-tag{
  font-family:var(--serif);font-size:14px;font-weight:400;font-style:italic;
  color:var(--ink2);line-height:1.3;margin-bottom:10px;flex:1;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.cat-card-footer{
  display:flex;align-items:center;justify-content:space-between;
  gap:6px;margin-top:auto;
}
.cat-card-price{
  font-family:var(--serif);font-size:20px;font-weight:400;
  color:var(--ink);font-style:italic;line-height:1;
}

.cat-card-btn{
  background:var(--ink);color:var(--gold3);border:none;
  padding:8px 14px;font-size:10px;font-weight:700;letter-spacing:.07em;
  text-transform:uppercase;cursor:pointer;font-family:var(--sans);
  border-radius:8px;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap;
}
.cat-card-btn:hover{background:var(--ink2);transform:translateY(-1px);box-shadow:0 4px 10px rgba(44,31,26,.2)}
.cat-card-btn:active{transform:scale(.95)}

.cat-card-btn-wa{
  background:transparent;border:1.5px solid var(--cream4);color:var(--mink);
  padding:7px 9px;font-size:14px;cursor:pointer;border-radius:8px;
  transition:all .2s cubic-bezier(.4,0,.2,1);line-height:1;flex-shrink:0;
}
.cat-card-btn-wa:hover{background:#25d366;color:#fff;border-color:#25d366;transform:scale(1.06)}
.cat-card-btn-wa:active{transform:scale(.95)}

/* ── Botón WA en pack card ── */
.btn-pack-wa{
  background:transparent;border:1.5px solid var(--cream4);color:var(--mink);
  padding:9px 11px;font-size:14px;cursor:pointer;border-radius:6px;
  transition:all .22s cubic-bezier(.4,0,.2,1);line-height:1;flex-shrink:0;
}
.btn-pack-wa:hover{background:#25d366;color:#fff;border-color:#25d366;transform:scale(1.08)}
.btn-pack-wa:active{transform:scale(.95)}

/* ── Badges ── */
.cat-card-prod-badge{
  position:absolute;top:10px;left:10px;padding:4px 10px;
  font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  border-radius:4px;z-index:3;backdrop-filter:blur(8px);
}
.cat-card-prod-badge.rose{background:rgba(196,132,126,.92);color:#fff}
.cat-card-prod-badge.gold{background:rgba(201,169,110,.92);color:var(--ink)}

.cat-card-stock-badge{
  position:absolute;bottom:10px;left:10px;
  background:rgba(239,68,68,.9);color:#fff;
  font-size:10px;font-weight:700;padding:3px 9px;border-radius:20px;
  z-index:3;letter-spacing:.03em;backdrop-filter:blur(4px);
  animation:stockPulse 2s ease-in-out infinite;
}
@keyframes stockPulse{0%,100%{opacity:1}50%{opacity:.75}}

/* ── Catalog Section Headings ── */
.cat-section-block{margin-bottom:48px}
.cat-section-heading{
  display:flex;align-items:center;gap:12px;margin-bottom:20px;
  padding-bottom:12px;border-bottom:1px solid var(--cream4);
}
.cat-section-heading span{
  font-family:var(--serif);font-size:22px;font-weight:400;font-style:italic;color:var(--ink);
}
.cat-section-heading .section-count{
  font-size:11px;font-weight:700;color:var(--mink);
  background:var(--cream2);border:1px solid var(--cream4);
  padding:2px 9px;border-radius:20px;letter-spacing:.04em;
  margin-left:2px;
}
.cat-section-heading::after{
  content:'';flex:1;height:1px;
  background:linear-gradient(to right,var(--cream4),transparent);
}

/* ── Skeleton ── */
.skeleton-card{pointer-events:none}
.skeleton-img,.skeleton-line{
  background:linear-gradient(90deg,var(--cream2) 25%,var(--cream3) 50%,var(--cream2) 75%);
  background-size:200% 100%;animation:shimmer 1.5s infinite;
}
.skeleton-line{border-radius:4px}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ── Empty State ── */
.catalog-empty-state{text-align:center;padding:80px 20px;color:var(--mink)}
.empty-state-icon{font-size:56px;display:block;margin-bottom:16px;animation:emptyBounce 2s ease-in-out infinite}
@keyframes emptyBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.catalog-empty-state p{font-size:15px;margin-bottom:20px;line-height:1.6}
.catalog-empty-state button{
  background:var(--ink);color:var(--gold3);border:none;padding:12px 28px;
  border-radius:8px;font-size:12px;font-weight:700;cursor:pointer;
  font-family:var(--sans);transition:all .22s;letter-spacing:.06em;text-transform:uppercase;
}
.catalog-empty-state button:hover{background:var(--ink2);transform:translateY(-2px);box-shadow:0 6px 16px rgba(44,31,26,.2)}

/* ── Search Results Mobile ── */
.mobile-results.show{display:flex;flex-direction:column;gap:4px}
.search-res-item{
  display:flex;align-items:center;gap:10px;padding:10px 12px;
  background:var(--white);border:1px solid var(--cream4);border-radius:10px;
  cursor:pointer;transition:all .18s;
}
.search-res-item:hover{background:var(--cream2);transform:translateX(4px)}
.search-res-name{font-size:13px;font-weight:600;color:var(--ink)}
.search-res-price{font-size:12px;color:var(--rose2);font-weight:700}

/* ── Catalog Breadcrumb ── */
.catalog-breadcrumb{display:none;align-items:center;gap:8px;padding:10px 0 16px;flex-wrap:wrap}
.catalog-bc-label{font-size:11px;font-weight:700;color:var(--mink);text-transform:uppercase;letter-spacing:.08em}
.catalog-bc-chip{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--rose3);border:1px solid var(--rose);color:var(--rose2);
  font-size:12px;font-weight:600;padding:5px 10px;border-radius:20px;
  animation:chipIn .2s cubic-bezier(.34,1.4,.64,1);
}
@keyframes chipIn{from{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}
.catalog-bc-chip button{background:none;border:none;cursor:pointer;color:var(--rose2);font-size:13px;line-height:1;padding:0;margin-left:2px;transition:color .15s}
.catalog-bc-chip button:hover{color:var(--ink)}

/* ── Product Card (legacy) ── */
.product-card{
  background:var(--white);border-radius:14px;overflow:hidden;cursor:pointer;
  transition:transform .32s cubic-bezier(.34,1.2,.64,1),box-shadow .32s,border-color .22s;
  position:relative;border:1px solid rgba(232,212,192,.6);
}
.product-card:hover{
  box-shadow:0 20px 56px rgba(92,74,61,.16);
  transform:translateY(-6px) scale(1.01);border-color:var(--gold3);
}
.card-img{
  width:100%;aspect-ratio:4/5;
  background:linear-gradient(145deg,var(--pearl),var(--cream2));
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:8px;position:relative;overflow:hidden;
}
.card-img img{
  width:100%;height:100%;object-fit:cover;position:absolute;inset:0;
  transition:transform .55s cubic-bezier(.4,0,.2,1);will-change:transform;
}
.product-card:hover .card-img img{transform:scale(1.07)}
.card-name{font-family:var(--serif);font-size:18px;font-weight:400;color:var(--ink);margin-bottom:4px;font-style:italic;line-height:1.2}
.card-price{font-family:var(--serif);font-size:22px;font-weight:300;color:var(--ink2);font-style:italic}
.btn-card{
  background:var(--ink);color:var(--gold3);border:none;padding:10px 18px;
  font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  cursor:pointer;font-family:var(--sans);transition:all .22s;border-radius:6px;
  white-space:nowrap;-webkit-tap-highlight-color:transparent;
}
.btn-card:hover{background:var(--ink2);transform:translateY(-1px);box-shadow:0 4px 12px rgba(44,31,26,.2)}
.btn-card:active{transform:scale(.96)}

.product-card-body{padding:16px;text-align:center}
.product-card-cat{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--rose2);margin-bottom:4px;font-weight:700}
.product-card-name{font-family:var(--serif);font-size:18px;color:var(--ink);font-style:italic;margin-bottom:8px;line-height:1.2}
.product-card-price{font-family:var(--serif);font-size:22px;color:var(--rose2);font-weight:300}
.product-card-footer{margin-top:16px;display:flex;gap:8px}
.btn-add-cart{
  flex:1;background:var(--ink);color:var(--gold3);border:none;padding:10px;
  font-size:11px;font-weight:600;text-transform:uppercase;border-radius:6px;cursor:pointer;
  transition:all .22s;
}
.btn-add-cart:hover{background:var(--ink2);transform:translateY(-1px)}
.btn-wish{
  width:38px;height:38px;border:1.5px solid var(--cream4);background:var(--white);
  border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;
  transition:all .22s;
}
.btn-wish:hover{background:var(--rose3);border-color:var(--rose2)}

/* ════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════ */
@media(max-width:768px){
  .grid-4{grid-template-columns:repeat(2,1fr);gap:12px}
  .cat-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .cat-section-heading span{font-size:18px}
  .cat-section-block{margin-bottom:36px}
  /* Desactivar hover scale en touch */
  .cat-card:hover,.pack-card:hover,.product-card:hover{transform:none;box-shadow:0 2px 12px rgba(92,74,61,.08)}
  .cat-card:active{transform:scale(.97);box-shadow:0 4px 16px rgba(92,74,61,.12)}
  .pack-card:active{transform:scale(.97)}
  .cat-card-quick{display:none}
}

@media(max-width:600px){
  /* ── Pack grid 2 cols ── */
  .pack-grid{grid-template-columns:repeat(2,1fr);gap:10px;padding:0 2px}
  .pack-card{border-radius:14px}
  .pack-card-img{height:150px}
  .pack-card-body{padding:10px 12px 12px}
  .pack-card-name{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .pack-card-sub{font-size:11px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
  .pack-card-includes{display:none}
  .pack-card-price{font-size:17px}
  .btn-pack{font-size:10px;padding:8px 10px}
  .btn-pack-wa{display:none}

  /* ── Cat card mobile ── */
  .cat-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .cat-card{border-radius:14px}
  .cat-card-img{aspect-ratio:1/1}
  .cat-card-body{padding:10px 11px 12px}
  .cat-card-stars{font-size:9px;margin-bottom:2px}
  .cat-card-name-tag{
    font-size:12px;margin-bottom:8px;
    -webkit-line-clamp:2;
  }
  .cat-card-price{font-size:17px}
  .cat-card-footer{gap:5px}
  /* Botón VER full width en mobile */
  .cat-card-btn{
    flex:1;text-align:center;padding:9px 8px;font-size:10px;
    border-radius:8px;
  }
  .cat-card-btn-wa{display:none}

  /* Badges más pequeños */
  .cat-card-prod-badge{font-size:9px;padding:3px 8px}
  .cat-card-stock-badge{font-size:9px;padding:2px 7px}
  .card-wish{width:30px;height:30px;font-size:13px;top:8px;right:8px}

  /* ── Filters scrollable ── */
  .filter-bar{gap:6px;margin-bottom:20px;justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap;padding-bottom:6px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .filter-bar::-webkit-scrollbar{display:none}
  .filt-btn{flex-shrink:0;padding:8px 16px;font-size:11px;white-space:nowrap}
  .filter-price-bar{margin-top:-12px;margin-bottom:16px;overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px;scrollbar-width:none}
  .filter-price-bar::-webkit-scrollbar{display:none}
  .filt-price-btn{flex-shrink:0;padding:6px 12px;font-size:10px;white-space:nowrap}
  .filter-occasion-bar{overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px;scrollbar-width:none;margin-bottom:20px}
  .filter-occasion-bar::-webkit-scrollbar{display:none}
  .filt-occ-btn{flex-shrink:0;white-space:nowrap}
}

@media(max-width:400px){
  .cat-grid{grid-template-columns:repeat(2,1fr);gap:8px}
  .pack-grid{grid-template-columns:repeat(2,1fr);gap:8px}
  .pack-card-img{height:120px}
  .pack-card-name{font-size:12px}
  .cat-card-name-tag{font-size:11px}
  .cat-card-price{font-size:15px}
  .cat-card-btn{padding:8px 6px;font-size:9px}
}

/* ════════════════════════════════════════════════
   DARK MODE overrides para catalog
   ════════════════════════════════════════════════ */
body.dark-mode .pack-card{background:var(--cream2);border-color:var(--cream4)}
body.dark-mode .pack-card:hover{border-color:var(--gold2);box-shadow:0 24px 64px rgba(0,0,0,.4)}
body.dark-mode .pack-card-img{background:linear-gradient(145deg,var(--cream4),var(--cream2))}
body.dark-mode .pack-card-wish{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.2);color:var(--gold3)}
body.dark-mode .pack-card-wish:hover{background:var(--rose3);border-color:var(--rose2)}
body.dark-mode .pack-card-wish.active{background:var(--rose3);border-color:var(--rose2)}
body.dark-mode .pack-card-name{color:var(--ink)}
body.dark-mode .pack-card-sub{color:var(--mink)}
body.dark-mode .pack-card-price{color:var(--gold3)}
/* Botón VER pack — dorado sobre oscuro */
body.dark-mode .btn-pack{background:var(--gold);color:#1a0e08}
body.dark-mode .btn-pack:hover{background:var(--gold2);box-shadow:0 4px 14px rgba(201,169,110,.3)}
body.dark-mode .btn-pack-wa{border-color:var(--cream4);color:var(--mink)}

body.dark-mode .cat-card{background:var(--cream2);border-color:var(--cream4)}
body.dark-mode .cat-card:hover{border-color:var(--gold2);box-shadow:0 20px 56px rgba(0,0,0,.35)}
body.dark-mode .cat-card-img{background:linear-gradient(145deg,var(--cream4),var(--cream2))}
body.dark-mode .cat-card-name-tag{color:var(--ink)}
body.dark-mode .cat-card-price{color:var(--gold3)}
body.dark-mode .cat-card-stars{color:var(--gold)}
/* Botón VER cat-card — dorado sobre oscuro */
body.dark-mode .cat-card-btn{background:var(--gold);color:#1a0e08}
body.dark-mode .cat-card-btn:hover{background:var(--gold2)}
body.dark-mode .cat-card-btn-wa{border-color:var(--cream4);color:var(--mink)}
body.dark-mode .cat-card-quick{background:linear-gradient(to top,rgba(0,0,0,.7),transparent)}

body.dark-mode .card-wish{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.2);color:var(--gold3)}
body.dark-mode .card-wish:hover{background:var(--rose3);border-color:var(--rose2)}
body.dark-mode .card-wish.active{background:var(--rose3);border-color:var(--rose2)}
body.dark-mode .product-card{background:var(--cream2);border-color:var(--cream4)}
body.dark-mode .card-name{color:var(--ink)}
body.dark-mode .card-price{color:var(--gold3)}
body.dark-mode .btn-card{background:var(--gold);color:#1a0e08}
body.dark-mode .btn-card:hover{background:var(--gold2)}
body.dark-mode .btn-add-cart{background:var(--gold);color:#1a0e08}
body.dark-mode .btn-add-cart:hover{background:var(--gold2)}
body.dark-mode .btn-wish{background:var(--cream2);border-color:var(--cream4)}
body.dark-mode .btn-wish:hover{background:var(--rose3);border-color:var(--rose2)}

body.dark-mode .filt-btn{background:var(--cream2);border-color:var(--cream4);color:var(--mink)}
body.dark-mode .filt-btn:hover,body.dark-mode .filt-btn.active{background:var(--gold);color:#1a0e08;border-color:var(--gold)}
body.dark-mode .filt-price-btn{background:var(--cream2);border-color:var(--cream4);color:var(--mink)}
body.dark-mode .filt-price-btn:hover,body.dark-mode .filt-price-btn.active{background:var(--gold);color:#1a0e08;border-color:var(--gold)}
body.dark-mode .search-res-item{background:var(--cream2);border-color:var(--cream4)}
body.dark-mode .search-res-item:hover{background:var(--cream4)}
body.dark-mode .search-res-name{color:var(--ink)}
body.dark-mode .cat-section-heading{border-color:var(--cream4)}
body.dark-mode .cat-section-heading span{color:var(--ink)}
body.dark-mode .cat-section-heading .section-count{background:var(--cream3);border-color:var(--cream4);color:var(--mink)}

/* ── Filtro por Ocasión ── */
.filter-occasion-bar{margin-top:-20px;margin-bottom:32px}
.filt-occ-btn{
  padding:7px 16px;border:1.5px solid var(--cream4);background:var(--white);
  color:var(--mink);font-size:11px;font-weight:600;letter-spacing:.04em;
  cursor:pointer;font-family:var(--sans);transition:all .22s cubic-bezier(.4,0,.2,1);
  border-radius:20px;white-space:nowrap;
}
.filt-occ-btn:hover{background:var(--rose3);color:var(--rose2);border-color:var(--rose2);transform:translateY(-1px)}
.filt-occ-btn.active{background:var(--rose3);color:var(--rose2);border-color:var(--rose2);box-shadow:0 4px 12px rgba(196,132,126,.2)}
body.dark-mode .filt-occ-btn{background:var(--cream2);border-color:var(--cream4);color:var(--mink)}
body.dark-mode .filt-occ-btn:hover,body.dark-mode .filt-occ-btn.active{background:var(--rose3);border-color:var(--rose2);color:var(--rose2)}

/* ── Fly-to-cart animation ── */
.fly-img{
  position:fixed;z-index:9999;border-radius:50%;
  width:48px;height:48px;object-fit:cover;
  pointer-events:none;box-shadow:0 4px 16px rgba(0,0,0,.25);
  transition:none;
}
@keyframes flyToCart{
  0%{transform:scale(1);opacity:1}
  80%{transform:scale(.4);opacity:.8}
  100%{transform:scale(.1);opacity:0}
}

/* ── Dark mode — badges visibles ── */
body.dark-mode .cat-card-prod-badge.gold{background:rgba(201,169,110,.95);color:#1a0e08}
body.dark-mode .cat-card-prod-badge.rose{background:rgba(196,132,126,.95);color:#fff}
body.dark-mode .pack-card-badge.gold{background:rgba(201,169,110,.95);color:#1a0e08}
body.dark-mode .pack-card-badge.rose{background:rgba(196,132,126,.95);color:#fff}
body.dark-mode .cat-card-stock-badge{background:rgba(239,68,68,.95);color:#fff}
body.dark-mode .nb-badge{background:rgba(255,255,255,.92);color:#1a0e08}
body.dark-mode .nb-badge.gold{background:rgba(201,169,110,.95);color:#1a0e08}
