/* Beautyforest — WooCommerce shop + product card.
   The card mirrors the structure of nextjs.vapeforest.co.uk's ProductCardEnhanced,
   restyled in Beautyforest tokens (rendered by woocommerce/content-product.php). */

/* ---------- Shop grid ---------- */
.woocommerce ul.products,
.woocommerce-page ul.products{
  display:grid !important;
  grid-template-columns:repeat(2,1fr);
  gap:1rem;
  margin:0;padding:0;list-style:none;
}
@media (min-width:600px){.woocommerce ul.products{grid-template-columns:repeat(3,1fr)}}
@media (min-width:900px){.woocommerce ul.products{grid-template-columns:repeat(4,1fr)}}
.woocommerce ul.products li.product{width:auto !important;margin:0 !important;float:none !important;padding:0 !important}
.woocommerce ul.products li.product::before,
.woocommerce ul.products li.product::after{display:none !important}

/* ---------- Product card ---------- */
.bf-card{
  background:#fff;border:1px solid var(--bf-hairline);border-radius:var(--bf-radius);overflow:hidden;
  display:flex;flex-direction:column;height:100%;box-shadow:0 2px 4px rgba(0,0,0,.1);
  transition:box-shadow .2s ease;
}
.bf-card:hover{box-shadow:0 8px 20px rgba(20,20,20,.12)}

.bf-card__media{position:relative;display:block;background:#fff;padding-bottom:95%;overflow:hidden;border-bottom:1px solid var(--bf-hairline)}
.bf-card__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;padding:12px;transition:transform .3s ease}
.bf-card:hover .bf-card__media img{transform:scale(1.05)}

.bf-card__badge{position:absolute;left:8px;top:8px;z-index:2;display:inline-flex;align-items:center;gap:4px;
  background:#fff;border:1px solid var(--bf-hairline);border-radius:var(--bf-radius);
  font-size:9px;font-weight:700;color:var(--bf-green-ink);padding:3px 8px;box-shadow:0 1px 2px rgba(0,0,0,.06);line-height:1}
.bf-card__badge svg{width:11px;height:11px}

.bf-card__body{padding:6px;display:flex;flex-direction:column;flex:1}

.bf-row{display:flex;align-items:stretch;gap:1px;margin-bottom:1px}
.bf-box,.bf-seg{
  min-height:22px;border-radius:var(--bf-radius);display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:600;line-height:1.1;padding:3px 4px;box-sizing:border-box;
  border:1px solid rgba(0,0,0,.05);box-shadow:0 1px 2px rgba(0,0,0,.05);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.bf-box{flex:0 0 32%}
.bf-segs{flex:1;display:flex;gap:1px;align-items:stretch;min-height:22px}
.bf-seg{flex:1}
.bf-price{background:var(--bf-green);color:var(--bf-green-ink);font-size:14px}
.bf-price del{opacity:.55;font-weight:500;margin-right:4px}
.bf-price ins{text-decoration:none}
.bf-sale{background:var(--bf-forest);color:#fff}
.bf-neutral{background:var(--bf-mint);color:var(--bf-green-ink)}
.bf-chip{background:#F1F4EF;color:var(--bf-graphite)}
.bf-deal{background:var(--bf-mint);color:var(--bf-green-ink)}

.bf-card__title{margin:8px 2px 0;padding:0}
.bf-card__title a{
  font-family:var(--wp--preset--font-family--heading);font-weight:600;font-size:15px;line-height:1.25;
  color:var(--bf-graphite);text-decoration:none;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.bf-card__title a:hover{text-decoration:underline;text-decoration-color:var(--bf-green);text-decoration-thickness:2px}
.bf-card__meta{font-size:11px;color:var(--bf-stone-deep);margin:3px 2px 0}
.bf-card__stars{font-size:11px;color:var(--bf-stone-deep);margin:4px 2px 6px}
.bf-card__stars .bf-star{color:#E8A100;letter-spacing:1px}

/* keep WooCommerce default add-to-cart/price out of the custom card */
.bf-card .button,.bf-card .added_to_cart,.bf-card .price{display:none}
