/* =====================================================================
   Home — Featured products grid wrapper. Product card markup is
   WooCommerce's own (content-product.php). We style only the outer shell.
   ================================================================== */

.jviens-products {
	padding: clamp(40px, 6vw, 80px) 0;
	background: var(--jv-bg);
}
.jviens-products__inner {
	max-width: var(--jv-container);
	margin: 0 auto;
	padding: 0 var(--jv-gutter);
}

.jviens-products__grid {
	margin-top: 32px;
}

/* Override WC's default float-based grid with CSS grid — scoped to homepage section only. */
.jviens-products__grid ul.products {
	display: grid !important;
	grid-template-columns: repeat(4, 1fr);
	gap: 28px;
	margin: 0;
	padding: 0;
	list-style: none;
}
.jviens-products__grid ul.products::before,
.jviens-products__grid ul.products::after {
	display: none !important; /* kill WC's clearfix pseudo-elements that show as empty cards on grid */
}
.jviens-products__grid ul.products > li.product {
	width: auto !important;
	margin: 0 !important;
	padding: 0 !important;
	float: none !important;
	clear: none !important;
	list-style: none;
	background: var(--jv-bg);
	border: 1px solid var(--jv-border);
	border-radius: var(--jv-radius);
	overflow: hidden;
	transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
	display: flex;
	flex-direction: column;
	position: relative;
}
.jviens-products__grid ul.products > li.product:hover {
	transform: translateY(-3px);
	box-shadow: var(--jv-shadow-md);
	border-color: var(--jv-purple-300);
}

/* Product link wrapping the image + title */
.jviens-products__grid ul.products > li.product > a {
	text-decoration: none;
	color: inherit;
	display: block;
}

/* Featured image */
.jviens-products__grid ul.products > li.product img {
	width: 100%;
	height: auto;
	display: block;
	background: var(--jv-purple-50);
	transition: transform .35s ease;
	margin: 0 !important;
}
.jviens-products__grid ul.products > li.product:hover img { transform: scale(1.04); }

/* Sale flash — round white circle, purple text + % underneath */
.jviens-products__grid ul.products > li.product span.onsale,
.jviens-products__grid ul.products > li.product span.jviens-sale-badge {
	position: absolute;
	top: 12px;
	left: 12px;
	margin: 0;
	width: 70px;
	height: 70px;
	min-width: 70px;
	min-height: 70px;
	padding: 0;
	border-radius: 50%;
	background: #fff;
	color: var(--jv-purple-700);
	border: 1.5px solid var(--jv-purple-300);
	box-shadow: var(--jv-shadow-sm);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 2px;
	font-weight: 700;
	letter-spacing: .04em;
	line-height: 1;
	text-transform: uppercase;
	z-index: 2;
}
.jviens-products__grid ul.products > li.product .jviens-sale-badge__label {
	font-size: 10px;
	letter-spacing: .08em;
	color: var(--jv-purple-500);
}
.jviens-products__grid ul.products > li.product .jviens-sale-badge__pct {
	font-size: 17px;
	font-weight: 800;
	color: var(--jv-purple-900);
}

/* Out-of-stock badge — round white circle, top-right, red text (mirror of DISKON) */
.jviens-products__grid ul.products > li.product .jviens-outofstock-badge {
	position: absolute;
	top: 12px;
	right: 12px;
	width: 70px;
	height: 70px;
	min-width: 70px;
	min-height: 70px;
	padding: 0;
	border-radius: 50%;
	background: #fff;
	color: #c0392b;
	border: 1.5px solid #f5b7b1;
	box-shadow: var(--jv-shadow-sm);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 2px;
	font-weight: 700;
	letter-spacing: .04em;
	line-height: 1;
	text-transform: uppercase;
	z-index: 3;
}
.jviens-products__grid ul.products > li.product .jviens-outofstock-badge__label {
	font-size: 10px;
	letter-spacing: .08em;
	color: #e74c3c;
}
.jviens-products__grid ul.products > li.product .jviens-outofstock-badge__main {
	font-size: 14px;
	font-weight: 800;
	color: #a93226;
}

/* Product title */
.jviens-products__grid ul.products > li.product .woocommerce-loop-product__title {
	padding: 14px 16px 4px;
	font-size: 15px;
	font-weight: 600;
	color: var(--jv-ink);
	line-height: 1.35;
	margin: 0;
	min-height: calc(1.35em * 2 + 4px);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* Star rating */
.jviens-products__grid ul.products > li.product .star-rating {
	margin: 0 16px 6px;
	font-size: 12px;
	color: #EBAF20;
}

/* Price */
.jviens-products__grid ul.products > li.product .price {
	padding: 0 16px 14px;
	margin: 0;
	font-size: 16px;
	font-weight: 700;
	color: var(--jv-purple-700);
	display: flex;
	align-items: baseline;
	gap: 8px;
	flex-wrap: wrap;
}
.jviens-products__grid ul.products > li.product .price del {
	color: var(--jv-ink-muted);
	font-size: 13px;
	font-weight: 500;
	text-decoration: line-through;
	opacity: .7;
}
.jviens-products__grid ul.products > li.product .price ins {
	text-decoration: none;
	color: var(--jv-pink-sale);
}

/* Add-to-cart / view button */
.jviens-products__grid ul.products > li.product .button {
	margin: auto 16px 16px;
	padding: 11px 14px;
	background: var(--jv-purple-700);
	color: #fff !important;
	border: 0;
	border-radius: 10px;
	text-align: center;
	font-weight: 600;
	letter-spacing: .04em;
	text-transform: uppercase;
	font-size: 12px;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	transition: background-color .15s ease;
	cursor: pointer;
}
.jviens-products__grid ul.products > li.product .button:hover {
	background: var(--jv-purple-900);
	color: #fff;
}
.jviens-products__grid ul.products > li.product .added_to_cart {
	margin: 0 16px 12px;
	text-align: center;
	color: var(--jv-purple-700);
	font-size: 12px;
	font-weight: 600;
	text-decoration: underline;
	text-underline-offset: 3px;
}

/* Short description (if themes/plugins emit one) */
.jviens-products__grid ul.products > li.product .woocommerce-product-details__short-description {
	padding: 0 16px 10px;
	color: var(--jv-ink-muted);
	font-size: 13px;
}

/* lg → 3 col */
@media (max-width: 1199.98px) {
	.jviens-products__grid ul.products {
		grid-template-columns: repeat(3, 1fr);
	}
}
/* md → 2 col */
@media (max-width: 899.98px) {
	.jviens-products__grid ul.products {
		grid-template-columns: repeat(2, 1fr);
		gap: 20px;
	}
}
/* sm → 1 col */
@media (max-width: 599.98px) {
	.jviens-products__grid ul.products {
		grid-template-columns: 1fr;
		gap: 16px;
	}
}
