/* ══════════════════════════════════════════════════════════════
   milmul-collection.css — collection / product listing page
   ══════════════════════════════════════════════════════════════ */

/* ── collection hero ── */
.collection-hero {
  background:
    radial-gradient(ellipse at 78% 28%, #FFE3EE 0%, transparent 55%),
    radial-gradient(ellipse at 12% 85%, #FFD7E5 0%, transparent 50%),
    repeating-linear-gradient(135deg, #FFEEF3 0 22px, #FFE4EC 22px 44px);
}

/* organic brush divider sitting on hero's bottom edge */
.brush-divider { display: block; width: 100%; height: 26px; }

/* ── filter + sort bar ── */
.filter-bar {
  position: sticky;
  top: 73px; /* below the sticky nav */
  z-index: 15;
  background: rgba(255,251,252,0.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(45,32,40,0.08);
}
@media (max-width: 1023px) { .filter-bar { top: 65px; } }

/* horizontal-scroll pill rail — hide scrollbar */
.pill-rail { scrollbar-width: none; -ms-overflow-style: none; }
.pill-rail::-webkit-scrollbar { display: none; }

.filter-pill {
  position: relative;
  white-space: nowrap;
  background: var(--card);
  color: var(--ink);
  border: 1px solid transparent;
  border-radius: 24px;
  transition: background-color .2s, color .2s, border-color .2s;
}
.filter-pill:hover:not(.is-active) { border-color: var(--accent); color: var(--accent); }
/* active pill — raspberry fill + soft watercolor-blob glow */
.filter-pill.is-active {
  background: var(--accent);
  color: #FFFBFC;
  box-shadow: 0 5px 16px rgba(232,69,139,0.38);
}

/* ── product grid ── */
.prod-grid { display: grid; gap: 24px; }
.prod-grid.cols-4 { grid-template-columns: repeat(4, 1fr); }
.prod-grid.cols-3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 1100px) { .prod-grid.cols-4, .prod-grid.cols-3 { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 760px)  { .prod-grid.cols-4, .prod-grid.cols-3 { grid-template-columns: repeat(2, 1fr); gap: 16px; } }

/* grid toggle */
.grid-toggle-btn { color: var(--ink-soft); transition: color .2s, background-color .2s; }
.grid-toggle-btn.is-active { color: var(--accent); background: var(--accent-light); }

/* ── product card ── */
.prod-card { transition: transform .3s cubic-bezier(.2,.8,.2,1); }
.prod-card:hover { transform: translateY(-4px) rotate(-0.4deg); }
.prod-card:hover .prod-img-primary { opacity: 0; }
.prod-card:hover .prod-img-alt { opacity: 1; transform: scale(1.03); }
.prod-card:hover .prod-quickview { opacity: 1; transform: translate(-50%, 0); }
.prod-card:hover .prod-fav { color: var(--accent); }
/* organic brush-stroke frame appears on hover */
.prod-card .brush-frame { opacity: 0; transition: opacity .35s ease; }
.prod-card:hover .brush-frame { opacity: 1; }
/* soft glow shadow */
.prod-card::after {
  content: ''; position: absolute; left: 8%; right: 8%; bottom: -16px; height: 26px;
  background: radial-gradient(ellipse at center, rgba(232,69,139,0.18), transparent 70%);
  z-index: -1; filter: blur(8px); opacity: 0; transition: opacity .3s, bottom .3s;
}
.prod-card:hover::after { opacity: 1; bottom: -20px; }

.prod-img-primary, .prod-img-alt { transition: opacity .4s ease, transform .4s ease; }
.prod-fav { transition: color .2s, transform .2s; }
.prod-fav:active { transform: scale(0.85); }
.prod-fav.is-saved { color: var(--accent); }
.prod-quickview {
  opacity: 0; transform: translate(-50%, 8px);
  transition: opacity .3s ease, transform .3s ease;
}
.prod-quickview:hover { background: var(--ink); color: #FFFBFC; }

/* card add-to-cart button */
.card-cart-btn {
  border: 1.5px solid var(--accent);
  color: var(--accent);
  background: transparent;
  border-radius: 10px;
  transition: background-color .2s, color .2s;
}
.card-cart-btn:hover { background: var(--accent); color: #FFFBFC; }

/* hand-drawn badge — slight stamped rotation */
.badge-new  { transform: rotate(-3deg); }
.badge-sale { transform: rotate(2deg); }

/* heart bounce on save */
@keyframes heartPop { 0% { transform: scale(1); } 45% { transform: scale(1.32); } 100% { transform: scale(1); } }
.prod-fav.bouncing { animation: heartPop .4s ease; }

/* ── skeleton loading card ── */
@keyframes shimmer { from { background-position: -340px 0; } to { background-position: 340px 0; } }
.skeleton {
  background: linear-gradient(90deg, #FFF1F5 25%, #FFE4EC 50%, #FFF1F5 75%);
  background-size: 680px 100%;
  animation: shimmer 1.3s linear infinite;
}

/* ── load more ── */
.load-more-btn { border: 1.5px solid var(--accent); color: var(--accent); background: transparent; transition: background-color .2s, color .2s; }
.load-more-btn:hover { background: var(--accent); color: #FFFBFC; }

/* ── collection story ── */
.story-art { clip-path: polygon(2% 4%, 16% 0%, 34% 5%, 52% 1%, 70% 5%, 86% 1%, 99% 8%, 97% 28%, 100% 50%, 97% 72%, 100% 92%, 88% 99%, 68% 96%, 48% 100%, 28% 96%, 10% 99%, 1% 88%, 4% 66%, 0% 48%, 3% 28%); }

/* ── recently viewed rail ── */
.recent-rail { scrollbar-width: none; -ms-overflow-style: none; }
.recent-rail::-webkit-scrollbar { display: none; }
.recent-card { transition: transform .25s ease; }
.recent-card:hover { transform: translateY(-3px); }

/* ── mobile filter drawer ── */
.filter-drawer { transform: translateX(100%); transition: transform .28s cubic-bezier(.2,.8,.2,1); }
.filter-drawer.is-open { transform: translateX(0); }

/* ── toast ── */
@keyframes toastIn { from { transform: translateY(16px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
.collection-toast { animation: toastIn .25s ease; }

/* ── reduced motion ── */
@media (prefers-reduced-motion: reduce) {
  .prod-card, .prod-img-primary, .prod-img-alt, .recent-card,
  .skeleton, .filter-drawer, .collection-toast, .prod-fav.bouncing {
    animation: none !important;
    transition: none !important;
  }
}
