/* products.css — Poola & Bloom product / set subpages */
/* Reuses CSS variables from styles.css (:root --bg, --fg, --muted, --brand, etc.) */

/* === Breadcrumb === */
.breadcrumb{padding:12px 0;font-size:13px;color:var(--muted)}
.breadcrumb a{color:var(--muted);text-decoration:none}
.breadcrumb a:hover{color:var(--brand-2)}
.breadcrumb span{margin:0 6px;color:var(--border)}

/* === Product Hero === */
.product-hero__grid{display:grid;grid-template-columns:1fr;gap:24px;align-items:start}
.product-hero__image img{width:100%;max-width:400px;border-radius:12px;display:block;margin:0 auto}
.product-hero__info h1{font-size:clamp(24px,5vw,36px);margin:0 0 8px;line-height:1.2}
.weight-label{font-weight:400;font-size:.6em;color:var(--muted)}
.product-oneliner{font-size:16px;color:var(--muted);margin:0 0 16px;line-height:1.5}

@media(min-width:800px){
  .product-hero__grid{grid-template-columns:380px 1fr;gap:40px}
}

/* === Product Badge === */
.product-badge{
  display:inline-block;padding:4px 12px;border-radius:20px;
  font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;
  background:var(--brand);color:#0b0b0c;margin-bottom:8px;
}
.product-badge--mineral_clean{background:#a8e6cf}
.product-badge--deep_clean{background:#6cc;color:#fff}
.product-badge--everyday{background:#e0e0e0;color:#333}
.product-badge--scrub{background:#c8a070;color:#fff}
.product-badge--comfort{background:#d8b4fe}
.product-badge--gentle{background:#fde68a}

/* === Product Details (weight / scent chips) === */
.product-details{display:flex;gap:16px;margin:16px 0}
.product-detail{
  background:var(--card);border:1px solid var(--border);
  border-radius:10px;padding:10px 16px;
}
.product-detail strong{display:block;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.product-detail span{font-weight:700;font-size:15px}

/* === Product Features list === */
.product-features{list-style:none;padding:0;margin:0 0 16px}
.product-features li{position:relative;padding-left:20px;margin:0 0 8px;font-size:15px;color:var(--muted);line-height:1.5}
.product-features li::before{content:"•";position:absolute;left:0;color:var(--brand-2);font-weight:700}

/* === Cross-link === */
.cross-link{margin-top:12px;font-size:14px}
.cross-link a{color:var(--brand-2);font-weight:600;text-decoration:none}
.cross-link a:hover{text-decoration:underline}

/* === INCI section === */
.inci-text{font-size:14px;color:var(--muted);line-height:1.7;max-width:800px}

/* === Set Hero === */
.set-hero__grid{display:grid;grid-template-columns:1fr;gap:24px;align-items:start}
.set-hero__image img{width:100%;max-width:400px;border-radius:12px;display:block;margin:0 auto}
.set-hero__info h1{font-size:clamp(22px,4.5vw,32px);margin:0 0 12px;line-height:1.2}
.set-extras{
  background:var(--card);border:1px dashed var(--border);
  border-radius:10px;padding:10px 14px;font-size:14px;margin:12px 0;
}

@media(min-width:800px){
  .set-hero__grid{grid-template-columns:380px 1fr;gap:40px}
}

/* === Link cards (listing + cross-reference grids) === */
.product-link-card,
.set-link-card,
.set-product-card{
  display:block;text-decoration:none;color:var(--fg);
  background:var(--card);border:1px solid var(--border);border-radius:14px;padding:10px 10px 12px;
  transition:transform .18s ease,box-shadow .18s ease;
}
.product-link-card:hover,
.set-link-card:hover,
.set-product-card:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(0,0,0,.07)}

.product-link-card h3,
.set-link-card h3,
.set-product-card h3{margin:8px 0 2px;font-size:14px}
.product-link-card p,
.set-link-card p,
.set-product-card p{margin:0;font-size:12px;color:var(--muted)}

/* === "What's inside" product cards === */
.set-product-card{
  background:var(--card);border:1px solid var(--border);border-radius:14px;
  padding:12px;transition:transform .15s ease,box-shadow .15s ease;
}
.set-product-card:hover{transform:translateY(-3px);box-shadow:0 6px 18px rgba(0,0,0,.07)}
.set-product-meta{font-size:12px;color:var(--muted);margin:0 0 4px}
.set-product-desc{font-size:13px;color:var(--fg);line-height:1.4;margin:4px 0 0}

/* === Set link cards (listing + "Available in sets") === */
.set-link-card{
  background:var(--card);border:1px solid var(--border);border-radius:14px;
  padding:12px;transition:transform .15s ease,box-shadow .15s ease;
}
.set-link-card:hover{transform:translateY(-3px);box-shadow:0 6px 18px rgba(0,0,0,.07)}
.set-card-meta{font-size:12px;color:var(--muted);margin:0 0 4px}
.set-card-desc{font-size:13px;color:var(--fg);line-height:1.4;margin:4px 0 0}

/* === Set grid spacing === */
.set-grid{gap:16px !important}

/* === Section lead (listing intro) === */
.section-lead{font-size:16px;color:var(--muted);margin:0 0 8px;max-width:640px;line-height:1.5}
.section-sub{font-size:14px;color:var(--muted);margin:-8px 0 12px;line-height:1.4}

/* === Listing grid tweaks === */
.listing-grid{gap:16px !important}
@media(min-width:600px){.listing-grid{gap:20px !important}}

/* === Normalize product images (contain instead of cover to avoid cropping) === */
.listing-grid .img-frame>img,
.set-grid .img-frame>img,
.product-hero__image img{object-fit:contain;background:#f0f0f0}

/* === Suggested-for tags === */
.sug-tags{display:flex;flex-wrap:wrap;gap:6px;margin:6px 0 4px}
.sug-tag{
  font-size:11px;padding:2px 8px;border-radius:20px;
  background:var(--card);border:1px solid var(--border);
  color:var(--muted);white-space:nowrap;text-decoration:none;
}
a.sug-tag:hover{border-color:var(--brand);color:var(--brand-2)}

/* === 175g size angle === */
.size-angle{
  font-size:14px;color:var(--brand-2);font-weight:600;
  margin:0 0 12px;
}

/* === Proof bar (Amazon + press) === */
.proof-bar{padding:20px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.proof-items{display:flex;gap:24px;flex-wrap:wrap;justify-content:center;text-align:center}
.proof-item{flex:1 1 140px;min-width:0}
.proof-value{display:block;font-weight:800;font-size:18px}
.proof-label{font-size:12px;color:var(--muted)}
.proof-label a{color:var(--brand-2);text-decoration:none}
.proof-label a:hover{text-decoration:underline}
.proof-item--press .proof-value{font-size:15px}
.proof-flags{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:14px}
.proof-flags__label{font-size:12px;color:var(--muted);font-weight:600}
.mp-flag{width:24px;height:18px;vertical-align:middle;border-radius:2px}
.proof-stars{display:flex;justify-content:center}
.proof-stars .stars{display:inline-block;font-size:20px;letter-spacing:2px;line-height:1}
.proof-stars .stars::before{
  content:"\2605\2605\2605\2605\2605";
  background:linear-gradient(90deg,#FFA41C var(--percent,86%),#ddd var(--percent,86%));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}

/* === Customer quotes === */
.quotes-grid{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:600px){.quotes-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.quotes-grid{grid-template-columns:repeat(3,1fr)}}
.quote-card{
  background:var(--card);border:1px solid var(--border);border-radius:14px;
  padding:16px;position:relative;
}
.quote-card::before{
  content:"\201C";position:absolute;top:-8px;left:10px;font-size:64px;line-height:1;
  color:rgba(0,0,0,.06);pointer-events:none;font-family:Georgia,serif;
}
.quote-text{font-size:14px;line-height:1.5;margin:0 0 8px;font-style:italic}
.quote-author{font-size:12px;font-weight:700;color:var(--muted);margin:0}

/* === USP list === */
.usp-list{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:1fr;gap:8px;
}
@media(min-width:600px){.usp-list{grid-template-columns:1fr 1fr}}
@media(min-width:900px){.usp-list{grid-template-columns:1fr 1fr 1fr}}
.usp-list li{
  position:relative;padding-left:20px;font-size:14px;
  color:var(--muted);line-height:1.5;
}
.usp-list li::before{
  content:"\2714";position:absolute;left:0;color:var(--brand-2);font-weight:700;
}

/* === Ingredients detail page === */
.ingredients-grid--detail{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:600px){.ingredients-grid--detail{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.ingredients-grid--detail{grid-template-columns:repeat(3,1fr)}}
.ingredient-card{
  background:var(--card);border:1px solid var(--border);border-radius:14px;
  padding:16px;text-align:center;
}
.ingredient-card .img-frame{max-width:140px;margin:0 auto 10px}
.ingredient-card h3{font-size:16px;margin:0 0 6px}
.ingredient-card p{font-size:13px;color:var(--muted);line-height:1.5;margin:0}

/* === FAQ Accordion === */
.faq-list{max-width:800px}
.faq-item{
  border:1px solid var(--border);border-radius:12px;
  margin-bottom:10px;overflow:hidden;
  transition:box-shadow .15s ease;
}
.faq-item[open]{box-shadow:0 2px 8px rgba(0,0,0,.05)}
.faq-question{
  padding:14px 18px;font-size:15px;font-weight:600;
  cursor:pointer;list-style:none;position:relative;
  padding-right:40px;line-height:1.4;
}
.faq-question::-webkit-details-marker{display:none}
.faq-question::after{
  content:"+";position:absolute;right:18px;top:50%;
  transform:translateY(-50%);font-size:20px;font-weight:400;
  color:var(--muted);transition:transform .2s ease;
}
.faq-item[open] .faq-question::after{content:"\2212"}
.faq-answer{
  padding:0 18px 14px;font-size:14px;line-height:1.6;
  color:var(--muted);
}
.faq-answer p{margin:0}
