/* ==============================================
   PRODUCTS — Filtros, grid y tarjetas de producto
   ============================================== */

.filters { display: flex; gap: 0.5rem; margin-bottom: 2rem; flex-wrap: wrap; }
.f-btn { padding: 0.45rem 1.1rem; border: 2px solid var(--border); background: white; border-radius: 2rem; font-family: 'Nunito', sans-serif; font-size: 0.72rem; font-weight: 800; letter-spacing: 0.06em; text-transform: uppercase; color: var(--mid); cursor: pointer; transition: all 0.2s; }
.f-btn:hover { border-color: var(--pink); color: var(--pink); }
.f-btn.active { background: var(--pink); color: white; border-color: var(--pink); }

.products-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(210px, 1fr)); gap: 1.2rem; }
.product-card { background: white; border-radius: 1rem; overflow: hidden; border: 1.5px solid var(--border); transition: transform 0.3s, box-shadow 0.3s; position: relative; cursor: pointer; }
.product-card:hover { transform: translateY(-4px); box-shadow: 0 16px 40px rgba(255,45,135,0.15); }
.product-img-wrap { aspect-ratio: 3/4; overflow: hidden; position: relative; background: var(--gray); }
.ph { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; font-size: 3.5rem; transition: transform 0.5s ease; }
.product-card:hover .ph { transform: scale(1.06); }
.p-badge { position: absolute; top: 0.8rem; left: 0.8rem; padding: 0.2rem 0.65rem; border-radius: 2rem; font-size: 0.62rem; font-weight: 900; letter-spacing: 0.1em; text-transform: uppercase; }
.p-badge.new { background: var(--pink); color: white; }
.p-badge.sale { background: var(--yellow); color: var(--black); }
.p-badge.last { background: var(--black); color: white; }
.p-stock-badge { position: absolute; top: 0.8rem; right: 0.8rem; background: rgba(0,0,0,0.65); color: white; padding: 0.2rem 0.6rem; border-radius: 2rem; font-size: 0.6rem; font-weight: 800; text-transform: uppercase; }
.product-actions-hover { position: absolute; bottom: -50px; left: 0; right: 0; background: var(--pink); color: white; padding: 0.75rem; text-align: center; font-size: 0.72rem; font-weight: 900; letter-spacing: 0.1em; text-transform: uppercase; transition: bottom 0.3s cubic-bezier(0.34,1.56,0.64,1); cursor: pointer; border: none; font-family: 'Nunito', sans-serif; width: 100%; }
.product-card:hover .product-actions-hover { bottom: 0; }
.product-info { padding: 1rem; }
.product-cat { font-size: 0.62rem; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; color: var(--pink); margin-bottom: 0.25rem; }
.product-name { font-size: 0.95rem; font-weight: 800; color: var(--black); margin-bottom: 0.35rem; line-height: 1.3; }
.product-sizes { font-size: 0.68rem; color: var(--mid); font-weight: 600; margin-bottom: 0.6rem; }
.product-bottom { display: flex; align-items: center; justify-content: space-between; }
.product-price { font-size: 1.05rem; font-weight: 900; color: var(--black); }
.product-wish { width: 30px; height: 30px; border-radius: 50%; background: var(--gray); border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 0.85rem; transition: background 0.2s, transform 0.2s; }
.product-wish:hover { background: #ffd6e8; transform: scale(1.1); }
