/* ===================================================================
   KIFF CANDLES — Product Archive & Shop CSS
   Styles the WooCommerce shop page, category archives, and product cards
   =================================================================== */

/* --- Archive page header --- */
.woocommerce .page-title,
.woocommerce-products-header__title {
  font-family: 'Unbounded', sans-serif;
  color: var(--kiff-navy);
  font-size: clamp(34px, 4.5vw, 54px);
  text-align: center;
  margin: 40px 0 8px;
}

.woocommerce .woocommerce-result-count {
  color: var(--kiff-muted);
  font-size: 14px;
  text-align: center;
  display: block;
  margin: 0 auto 24px;
  float: none;
}

.woocommerce .woocommerce-ordering {
  float: none;
  text-align: center;
  display: block;
  margin-bottom: 30px;
}
.woocommerce .woocommerce-ordering select {
  padding: 10px 18px;
  border: 2px solid var(--kiff-navy);
  border-radius: 100px;
  background: var(--kiff-cream);
  color: var(--kiff-navy);
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  cursor: pointer;
}

/* --- Category chips (above product grid, if using product_categories shortcode) --- */
.kiff-cat-chips, .woocommerce .products.product-category {
  display: flex !important;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  margin: 20px auto 40px !important;
  max-width: 1100px;
  padding: 0 32px;
}
.kiff-cat-chips li, .woocommerce .products.product-category li {
  list-style: none;
  width: auto !important;
  margin: 0 !important;
}
.kiff-cat-chips li a, .woocommerce .products.product-category li a {
  padding: 9px 20px;
  border-radius: 100px;
  background: var(--kiff-cream-deep);
  color: var(--kiff-navy) !important;
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.15s;
  display: inline-block;
}
.kiff-cat-chips li a:hover, .woocommerce .products.product-category li a:hover {
  background: var(--kiff-butter);
}
.kiff-cat-chips li a img, .woocommerce .products.product-category li a img { display: none; }
.kiff-cat-chips li a h2, .woocommerce .products.product-category li h2 {
  display: inline; font-size: 14px; margin: 0; font-family: 'Inter', sans-serif;
}

/* --- Product grid (applies to shop, archives, and related products) --- */
.woocommerce ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin: 0 auto 60px;
  padding: 0 32px;
  max-width: 1200px;
}
.woocommerce ul.products li.product {
  width: 100% !important;
  margin: 0 !important;
  float: none !important;
  background: var(--kiff-cream-deep);
  border-radius: 18px;
  overflow: hidden;
  transition: transform 0.2s, box-shadow 0.2s;
  padding: 0 !important;
  position: relative;
}
.woocommerce ul.products li.product:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 28px rgba(16,80,112,0.08);
}
.woocommerce ul.products li.product a {
  text-decoration: none;
  color: inherit;
  display: block;
}
.woocommerce ul.products li.product .woocommerce-loop-product__link {
  display: flex;
  flex-direction: column;
  height: 100%;
}
.woocommerce ul.products li.product img {
  aspect-ratio: 1 / 1;
  object-fit: contain;
  padding: 18px;
  background: var(--kiff-peach); /* default; per-category tints below */
  margin: 0 !important;
  width: 100%;
}
/* Category-based image tint — requires Woo to add category class on <li> */
.woocommerce ul.products li.product.product_cat-complex img { background: #E2EED4; }
.woocommerce ul.products li.product.product_cat-dude img     { background: var(--kiff-cream-deep); }
.woocommerce ul.products li.product.product_cat-fancy img    { background: #DEC7EE; }
.woocommerce ul.products li.product.product_cat-hippie img   { background: #FCD9C0; }
.woocommerce ul.products li.product.product_cat-novelty img  { background: #FBEDB3; }
.woocommerce ul.products li.product.product_cat-rom img      { background: #F0C8D3; }
.woocommerce ul.products li.product.product_cat-standard img { background: var(--kiff-cream-deep); }
.woocommerce ul.products li.product.product_cat-adult img    { background: var(--kiff-cream-deep); }

.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: 'Inter', sans-serif !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  color: var(--kiff-navy);
  padding: 16px 20px 4px !important;
  margin: 0 !important;
  line-height: 1.3;
}
.woocommerce ul.products li.product .price {
  padding: 0 20px 4px;
  color: var(--kiff-crimson) !important;
  font-weight: 700;
  font-size: 15px;
  margin: 0;
}
.woocommerce ul.products li.product .price del { opacity: 0.5; font-weight: 400; }
.woocommerce ul.products li.product .price ins { text-decoration: none; font-weight: 700; }

.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product .added_to_cart {
  margin: 10px 20px 20px !important;
  padding: 10px 18px !important;
  border-radius: 100px !important;
  background: var(--kiff-navy) !important;
  color: var(--kiff-cream) !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  width: calc(100% - 40px) !important;
  text-align: center !important;
  border: none !important;
}
.woocommerce ul.products li.product .button:hover {
  background: var(--kiff-crimson) !important;
}

/* Sale badges */
.woocommerce span.onsale {
  background: var(--kiff-crimson) !important;
  color: var(--kiff-cream) !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  padding: 4px 10px !important;
  border-radius: 100px !important;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  min-width: 0 !important;
  min-height: 0 !important;
  top: 12px !important;
  right: 12px !important;
  left: auto !important;
  line-height: 1.2 !important;
}

/* Adult category — 18+ badge */
.woocommerce ul.products li.product.product_cat-adult::before {
  content: "18+";
  position: absolute;
  top: 12px; left: 12px; z-index: 2;
  background: var(--kiff-crimson); color: var(--kiff-cream);
  padding: 4px 10px; border-radius: 100px;
  font-size: 11px; font-weight: 700; letter-spacing: 0.08em;
  font-family: 'Inter', sans-serif;
}

/* --- Pagination --- */
.woocommerce nav.woocommerce-pagination { text-align: center; margin: 40px 0 80px; }
.woocommerce nav.woocommerce-pagination ul { border: none !important; display: inline-flex; gap: 8px; }
.woocommerce nav.woocommerce-pagination ul li { border: none !important; }
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  border-radius: 100px !important;
  min-width: 40px; height: 40px;
  line-height: 40px !important;
  padding: 0 14px !important;
  background: var(--kiff-cream-deep) !important;
  color: var(--kiff-navy) !important;
  font-weight: 600;
  font-family: 'Inter', sans-serif;
}
.woocommerce nav.woocommerce-pagination ul li a:hover,
.woocommerce nav.woocommerce-pagination ul li span.current {
  background: var(--kiff-navy) !important;
  color: var(--kiff-cream) !important;
}

/* --- Responsive --- */
@media (max-width: 900px) {
  .woocommerce ul.products { grid-template-columns: repeat(2, 1fr); }
}

/* --- Age gate modal (for Adult product-category page & Adult PDPs) --- */
.kiff-age-gate {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(16, 80, 112, 0.92);
  backdrop-filter: blur(8px);
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
}
.kiff-age-gate.kiff-hidden { display: none; }
.kiff-age-modal {
  background: var(--kiff-cream); border-radius: 24px;
  padding: 48px 44px; max-width: 460px; width: 100%;
  text-align: center; box-shadow: 0 30px 80px rgba(12, 62, 88, 0.4);
}
.kiff-age-flame { width: 72px; height: 72px; border-radius: 50%; background: var(--kiff-crimson); color: var(--kiff-cream); display: flex; align-items: center; justify-content: center; margin: 0 auto 20px; font-size: 36px; }
.kiff-age-modal h2 { font-family: 'Unbounded', sans-serif; color: var(--kiff-navy); font-size: 32px; font-weight: 800; margin: 0 0 14px; }
.kiff-age-modal p { color: var(--kiff-ink); font-size: 16px; line-height: 1.55; margin: 0 0 28px; }
.kiff-age-modal p em { color: var(--kiff-crimson); font-style: italic; font-weight: 600; }
.kiff-age-buttons { display: flex; flex-direction: column; gap: 10px; }
.kiff-age-buttons .kiff-btn { width: 100%; padding: 15px 24px; }
.kiff-age-fine { margin-top: 20px !important; font-size: 12px !important; color: var(--kiff-muted); font-style: italic; }
