﻿/* ============================================
   PRODUCTS PAGE STYLES
   ============================================ */

.products-hero {
  background: linear-gradient(135deg, var(--green-dark) 0%, var(--green) 60%, var(--green-light) 100%);
}
.products-hero::before {
  background: url('../images/products_hero.png') center/cover no-repeat;
}

/* Filter Bar */
.filter-bar {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  flex-wrap: wrap;
  margin-bottom: 3rem;
  padding: 1.5rem;
  background: var(--off-white);
  border-radius: var(--radius-lg);
  border: 1px solid rgba(200,16,46,0.08);
}
.filter-btn {
  padding: 0.6rem 1.5rem;
  border-radius: 50px;
  border: 2px solid rgba(200,16,46,0.2);
  background: var(--white);
  color: var(--gray);
  font-size: 0.88rem;
  font-weight: 600;
  cursor: pointer;
  transition: var(--transition);
  font-family: 'Inter', sans-serif;
}
.filter-btn:hover {
  border-color: var(--red);
  color: var(--red);
  background: rgba(200,16,46,0.04);
}
.filter-btn.active {
  background: linear-gradient(135deg, var(--red), var(--red-dark));
  color: var(--white);
  border-color: transparent;
  box-shadow: 0 4px 16px rgba(200,16,46,0.3);
}

/* Products Catalog */
.products-catalog {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.75rem;
}
.product-card { border-radius: var(--radius-lg); overflow: hidden; }
.product-img {
  position: relative;
  height: 240px;
  overflow: hidden;
}
.product-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}
.product-card:hover .product-img img { transform: scale(1.08); }
.product-overlay {
  position: absolute;
  inset: 0;
  background: rgba(26,74,26,0.75);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: var(--transition);
}
.product-card:hover .product-overlay { opacity: 1; }
.product-badge {
  position: absolute;
  top: 0.75rem; left: 0.75rem;
  font-size: 0.72rem;
  font-weight: 700;
  padding: 0.25rem 0.65rem;
  border-radius: 50px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: white;
}
.product-badge.bestseller { background: linear-gradient(135deg, var(--red), var(--red-dark)); }
.product-badge.organic { background: linear-gradient(135deg, var(--green), var(--green-dark)); }
.product-badge.new { background: linear-gradient(135deg, var(--gold-dark), var(--gold)); color: var(--dark); }

.product-body { padding: 1.25rem; }
.product-cat {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--red);
  margin-bottom: 0.4rem;
}
.product-body h3 {
  font-family: 'Playfair Display', serif;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--dark);
  margin-bottom: 0.4rem;
}
.product-body p { color: var(--gray); font-size: 0.85rem; line-height: 1.5; margin-bottom: 0.85rem; }
.product-sizes { display: flex; gap: 0.4rem; flex-wrap: wrap; margin-bottom: 1rem; }
.product-sizes span {
  background: rgba(200,16,46,0.06);
  color: var(--red);
  font-size: 0.72rem;
  font-weight: 600;
  padding: 0.2rem 0.55rem;
  border-radius: 50px;
  border: 1px solid rgba(200,16,46,0.15);
}
.product-footer { display: flex; align-items: center; justify-content: space-between; gap: 0.5rem; }
.product-purity {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--green);
  background: rgba(45,106,45,0.08);
  padding: 0.2rem 0.6rem;
  border-radius: 50px;
}
.btn-sm { padding: 0.5rem 1rem !important; font-size: 0.82rem !important; }

/* Product Modal */
.product-modal {
  background: var(--white);
  border-radius: var(--radius-lg);
  max-width: 800px;
  width: 90%;
  max-height: 90vh;
  overflow-y: auto;
  grid-template-columns: 1fr 1fr;
  box-shadow: 0 30px 80px rgba(0,0,0,0.3);
  /* display is controlled by JS — do NOT use !important here */
}
.modal-img { overflow: hidden; border-radius: var(--radius-lg) 0 0 var(--radius-lg); }
.modal-img img { width: 100%; height: 100%; object-fit: cover; min-height: 400px; }
.modal-info { padding: 2.5rem; }
.modal-info h2 {
  font-family: 'Playfair Display', serif;
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--dark);
  margin: 0.5rem 0 0;
}
.modal-info p { color: var(--gray); line-height: 1.7; margin-bottom: 1.5rem; }
.modal-features { display: flex; flex-direction: column; gap: 0.5rem; margin-bottom: 1.25rem; }
.modal-feature {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.9rem;
  color: var(--dark-2);
}
.modal-feature span { color: var(--green); font-weight: 700; }
.modal-sizes {
  font-size: 0.88rem;
  color: var(--gray);
  padding: 0.75rem 1rem;
  background: var(--off-white);
  border-radius: var(--radius);
  border-left: 3px solid var(--gold);
}
.modal-sizes strong { color: var(--dark); }

/* Responsive */
@media (max-width: 1200px) {
  .products-catalog { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 900px) {
  .products-catalog { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .products-catalog { grid-template-columns: 1fr; }
  .product-modal { grid-template-columns: 1fr; }
  .modal-img { border-radius: var(--radius-lg) var(--radius-lg) 0 0; }
  .modal-img img { min-height: 220px; }
}
