/* =========================================================
   Fun Coffee — Products page
   ========================================================= */

.page-head{
  background:linear-gradient(135deg,var(--c-coffee-900) 0%,var(--c-coffee-700) 100%);
  color:#fff;
  padding:56px 0 40px;
  text-align:center;
}
.page-head .section-tag{color:#f0d4a8}
.page-head h1{
  font-family:var(--font-serif);
  font-size:42px;font-weight:500;
  letter-spacing:.02em;
  line-height:1.2;
  margin-bottom:8px;
}
.page-head p{color:#cfb89a;font-size:14px}

/* ---------- Filter Bar ---------- */
.filter-bar{
  background:#fff;
  border-bottom:1px solid var(--c-line);
  position:sticky;
  top:53px;  /* below header */
  z-index:50;
}
.filter-inner{
  max-width:1280px;
  margin:0 auto;
  padding:14px 24px;
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:14px 18px;
}
.filter-group{
  display:flex;
  align-items:center;
  gap:6px;
}
.filter-label{
  font-size:11px;
  letter-spacing:.1em;
  color:var(--c-muted);
  text-transform:uppercase;
}
.filter-pills{display:flex;gap:6px;flex-wrap:wrap}
.f-pill{
  background:#fff;
  border:1px solid var(--c-line);
  color:var(--c-coffee-700);
  padding:6px 14px;
  font-size:12px;
  font-weight:500;
  border-radius:999px;
  cursor:pointer;
  transition:all .15s;
}
.f-pill:hover{border-color:var(--c-coffee-700)}
.f-pill.active{
  background:var(--c-coffee-900);
  color:#fff;
  border-color:var(--c-coffee-900);
}
.filter-spacer{flex:1}
.filter-sort{
  display:flex;align-items:center;gap:6px;
  font-size:12px;color:var(--c-muted);
}
.filter-sort select{
  padding:6px 10px;
  font-size:12px;
  font-family:inherit;
  border:1px solid var(--c-line);
  border-radius:4px;
  background:#fff;
  color:var(--c-text);
}
.search-input{
  padding:8px 12px;
  font-size:13px;
  font-family:inherit;
  border:1px solid var(--c-line);
  border-radius:4px;
  background:#fff;
  width:220px;
}
.search-input:focus{outline:none;border-color:var(--c-coffee-700)}

.result-bar{
  max-width:1280px;
  margin:0 auto;
  padding:20px 24px 0;
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:13px;
  color:var(--c-muted);
}
.result-bar strong{color:var(--c-coffee-900);font-weight:700}

/* ---------- Product Grid ---------- */
.product-list{
  max-width:1280px;
  margin:0 auto;
  padding:20px 24px 80px;
}
.product-list .product-grid{
  grid-template-columns:repeat(4,1fr);
}

/* extra info on cards in list view */
.product-card .stock-line{
  margin-top:6px;
  font-size:11px;
  color:var(--c-muted);
  display:flex;
  align-items:center;
  gap:6px;
}
.stock-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--c-green);
  flex-shrink:0;
}
.stock-dot.low{background:var(--c-amber, #d4a017)}
.stock-dot.out{background:#bbb}

.no-results{
  text-align:center;
  padding:80px 20px;
  color:var(--c-muted);
}
.no-results h3{
  font-family:var(--font-serif);
  font-size:24px;
  color:var(--c-coffee-900);
  margin-bottom:8px;
}

/* ---------- Empty state for missing images ---------- */
.product-img.no-image{
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--c-coffee-50);
  color:var(--c-muted);
  font-family:var(--font-serif);
  font-size:24px;
}

/* ---------- Pagination ---------- */
.pagination{
  margin-top:48px;
  display:flex;
  justify-content:center;
  gap:6px;
  flex-wrap:wrap;
}
.pagination button{
  min-width:38px;
  height:38px;
  padding:0 12px;
  border:1px solid var(--c-line);
  background:#fff;
  border-radius:4px;
  font-size:13px;
  font-weight:600;
  color:var(--c-coffee-700);
  cursor:pointer;
  transition:all .15s;
}
.pagination button:hover{border-color:var(--c-coffee-700)}
.pagination button.active{
  background:var(--c-coffee-900);
  color:#fff;
  border-color:var(--c-coffee-900);
}
.pagination button:disabled{opacity:.4;cursor:not-allowed}

/* ---------- Sources strip ---------- */
.data-source{
  background:var(--c-coffee-50);
  border-top:1px solid var(--c-line);
  border-bottom:1px solid var(--c-line);
  padding:12px 0;
  font-size:12px;
  color:var(--c-muted);
  text-align:center;
}
.data-source code{
  background:#fff;
  padding:2px 8px;
  border-radius:3px;
  font-family:monospace;
  color:var(--c-coffee-900);
  border:1px solid var(--c-line);
}

/* ---------- Responsive ---------- */
@media(max-width:1024px){
  .product-list .product-grid{grid-template-columns:repeat(3,1fr)}
  .page-head h1{font-size:32px}
}
@media(max-width:768px){
  .product-list .product-grid{grid-template-columns:repeat(2,1fr);gap:24px 12px}
  .page-head{padding:40px 0 28px}
  .page-head h1{font-size:24px}
  .filter-bar{top:0;position:static}
  .filter-inner{padding:12px 16px;gap:10px}
  .search-input{width:100%}
  .filter-spacer{display:none}
  .product-list{padding:16px 16px 60px}
}
