/* =====================================================================
   Jviens — WooCommerce page styling (shop, category, single-product,
   cart, checkout, account). We don't override WC templates; we only
   style outer wrappers and polish WC's native class names.
   ================================================================== */

.jviens-wc {
	padding-top: 56px;
	padding-bottom: 56px;
	display: grid;
	grid-template-columns: 260px minmax(0, 1fr);
	gap: 40px;
	align-items: start;
}
.jviens-wc__main { min-width: 0; order: 2; }
.jviens-wc__sidebar { order: 1; }

/* Sidebar (WC default widget area) */
.jviens-wc__sidebar {
	position: sticky;
	top: 24px;
	font-size: 14px;
	color: var(--jv-ink);
}
.jviens-wc__sidebar #sidebar { padding: 0; }
.jviens-wc__sidebar ul {
	list-style: none;
	padding: 0;
	margin: 0 0 20px;
}
.jviens-wc__sidebar > #sidebar > ul > li {
	background: var(--jv-bg);
	border: 1px solid var(--jv-border);
	border-radius: var(--jv-radius);
	padding: 18px 20px;
	margin: 0 0 16px;
}
.jviens-wc__sidebar h2 {
	font-family: var(--jv-serif);
	font-size: 16px;
	font-weight: 600;
	color: var(--jv-ink);
	margin: 0 0 12px;
	padding: 0 0 10px;
	border-bottom: 1px solid var(--jv-border);
	letter-spacing: -0.01em;
}
.jviens-wc__sidebar li {
	margin: 0;
	padding: 0;
}
.jviens-wc__sidebar ul ul li {
	padding: 6px 0;
	border-bottom: 1px solid transparent;
}
.jviens-wc__sidebar ul ul li + li { border-top: 1px solid var(--jv-border); }
.jviens-wc__sidebar a {
	color: var(--jv-ink);
	text-decoration: none;
	display: inline-block;
	transition: color .15s ease;
}
.jviens-wc__sidebar a:hover { color: var(--jv-purple-500); }
.jviens-wc__sidebar .current_page_parent > a,
.jviens-wc__sidebar .current-cat > a,
.jviens-wc__sidebar .current_page_item > a {
	color: var(--jv-purple-700);
	font-weight: 600;
}

/* Sidebar search form */
.jviens-wc__sidebar .search-form {
	display: flex;
	gap: 8px;
}
.jviens-wc__sidebar .search-form label {
	flex: 1;
	margin: 0;
	display: block;
}
.jviens-wc__sidebar .search-field {
	width: 100%;
	padding: 10px 14px;
	border: 1px solid var(--jv-border);
	border-radius: 999px;
	font-family: inherit;
	font-size: 14px;
	background: var(--jv-bg);
	color: var(--jv-ink);
	box-sizing: border-box;
}
.jviens-wc__sidebar .search-field:focus {
	outline: none;
	border-color: var(--jv-purple-500);
}
.jviens-wc__sidebar .search-submit {
	padding: 10px 16px;
	background: var(--jv-purple-500);
	color: #fff;
	border: 0;
	border-radius: 999px;
	font-family: inherit;
	font-size: 13px;
	font-weight: 500;
	cursor: pointer;
	transition: background .2s ease;
}
.jviens-wc__sidebar .search-submit:hover { background: var(--jv-purple-700); }

/* Breadcrumb */
.woocommerce-breadcrumb {
	font-size: 13px;
	color: var(--jv-ink-muted);
	margin: 0 0 18px;
}
.woocommerce-breadcrumb a {
	color: var(--jv-ink-muted);
	text-decoration: none;
}
.woocommerce-breadcrumb a:hover { color: var(--jv-purple-500); }

/* Page / archive title */
.jviens-wc .page-title,
.jviens-wc .woocommerce-products-header__title {
	font-family: var(--jv-serif);
	font-size: clamp(22px, 4vw, 40px);
	font-weight: 600;
	color: var(--jv-ink);
	margin: 0 0 12px;
	letter-spacing: -0.01em;
}

/* Term description */
.term-description {
	color: var(--jv-ink-muted);
	max-width: 720px;
	margin: 0 0 28px;
	line-height: 1.6;
}

/* Result count + sorting toolbar */
.woocommerce-result-count {
	color: var(--jv-ink-muted);
	font-size: 14px;
	margin: 0 0 20px;
}
.woocommerce-ordering {
	margin: 0 0 20px;
}
.woocommerce-ordering select {
	border: 1px solid var(--jv-border);
	border-radius: 999px;
	padding: 8px 36px 8px 16px;
	background: var(--jv-bg);
	color: var(--jv-ink);
	font-family: inherit;
	font-size: 14px;
	cursor: pointer;
}

/* Product grid — 3 col desktop (sidebar eats the 4th). */
.jviens-wc ul.products {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px 20px;
	list-style: none;
	margin: 0 0 32px;
	padding: 0;
}
.jviens-wc ul.products::before,
.jviens-wc ul.products::after { content: none; }

.jviens-wc ul.products > li.product {
	width: auto !important;
	margin: 0 !important;
	padding: 0 !important;
	float: none !important;
	clear: none !important;
	list-style: none;
	text-align: left;
	background: var(--jv-bg);
	border: 1px solid var(--jv-border);
	border-radius: var(--jv-radius);
	overflow: hidden;
	transition: box-shadow .15s ease, border-color .15s ease;
	display: flex;
	flex-direction: column;
	position: relative;
}
.jviens-wc ul.products > li.product:hover {
	box-shadow: var(--jv-shadow-md);
	border-color: var(--jv-purple-300);
}

/* Link wrapper — image + title */
.jviens-wc ul.products > li.product > a {
	text-decoration: none;
	color: inherit;
	display: block;
}

/* Featured image — full bleed to card edges */
.jviens-wc ul.products > li.product img {
	width: 100%;
	height: auto;
	display: block;
	background: var(--jv-purple-50);
	margin: 0 !important;
	border-radius: 0;
}

/* Title */
.jviens-wc ul.products > li.product .woocommerce-loop-product__title {
	font-family: var(--jv-sans);
	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-wc ul.products > li.product .star-rating {
	margin: 0 16px 6px;
	font-size: 12px;
	color: #EBAF20;
}

/* Price */
.jviens-wc 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-wc ul.products > li.product .price del {
	color: var(--jv-ink-muted);
	font-size: 13px;
	font-weight: 500;
	text-decoration: line-through;
	opacity: .7;
}
.jviens-wc ul.products > li.product .price ins {
	background: transparent;
	text-decoration: none;
	color: var(--jv-pink-sale);
}

/* Sale badge — round circle, top-left, white bg, purple text + % underneath.
   Selectors cover BOTH the loop card (ul.products > li.product) AND the
   single-product page (div#product-X.product), since the badge HTML is
   identical but the wrapping ancestors differ between those two contexts. */
.jviens-wc ul.products > li.product span.onsale,
.jviens-wc ul.products > li.product span.jviens-sale-badge,
.jviens-wc div.product > span.onsale,
.jviens-wc div.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-wc ul.products > li.product .jviens-sale-badge__label,
.jviens-wc div.product > .jviens-sale-badge .jviens-sale-badge__label {
	font-size: 10px;
	letter-spacing: .08em;
	color: var(--jv-purple-500);
}
.jviens-wc ul.products > li.product .jviens-sale-badge__pct,
.jviens-wc div.product > .jviens-sale-badge .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 */
.jviens-wc 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-wc ul.products > li.product .jviens-outofstock-badge__label {
	font-size: 10px;
	letter-spacing: .08em;
	color: #e74c3c;
}
.jviens-wc ul.products > li.product .jviens-outofstock-badge__main {
	font-size: 14px;
	font-weight: 800;
	color: #a93226;
}

/* Single-product page stock pill — replace WC's brown text with a clean
   white pill: red for out-of-stock, green for in-stock. */
.jviens-wc .summary p.stock,
.jviens-wc .product p.stock {
	display: block;
	width: fit-content;
	clear: both;
	margin: 0 0 var(--jv-gutter, 16px);
	padding: 6px 14px;
	border-radius: 999px;
	background: #fff;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: .04em;
	text-transform: uppercase;
	line-height: 1.4;
	border: 1.5px solid var(--jv-border);
	color: var(--jv-ink);
	float: none;
}
.jviens-wc .summary p.stock.in-stock,
.jviens-wc .product p.stock.in-stock {
	background: #eaf7ee;
	border-color: #b8e0c4;
	color: #1e7e34;
}
.jviens-wc .summary p.stock.out-of-stock,
.jviens-wc .product p.stock.out-of-stock {
	background: #fdecec;
	border-color: #f5b7b1;
	color: #c0392b;
}

/* Strukly QR card — theme overrides the plugin's neutral defaults so the
   card picks up jviens brand tokens without forking the plugin. */
.strukly-product-qr {
	--strukly-qr-border: var(--jv-border);
	--strukly-qr-radius: var(--jv-radius);
	--strukly-qr-shadow: var(--jv-shadow-sm);
	--strukly-qr-text:   var(--jv-ink);
}

/* Add-to-cart / view button */
.jviens-wc 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-wc ul.products > li.product .button:hover {
	background: var(--jv-purple-900);
	color: #fff;
}
.jviens-wc 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;
}

/* Pagination — override WooCommerce defaults (which set a bordered ul + floated li). */
nav.woocommerce-pagination {
	margin: 24px 0 0;
	text-align: center;
}
nav.woocommerce-pagination ul,
nav.woocommerce-pagination ul.page-numbers {
	display: inline-flex !important;
	flex-wrap: wrap;
	justify-content: center;
	gap: 6px;
	list-style: none;
	padding: 0;
	margin: 0;
	border: 0 !important;
	white-space: normal;
}
nav.woocommerce-pagination ul li {
	list-style: none;
	margin: 0 !important;
	padding: 0 !important;
	border: 0 !important;
	float: none !important;
	display: flex !important;
	overflow: visible;
}
nav.woocommerce-pagination ul li::marker { content: none; }
nav.woocommerce-pagination ul li a,
nav.woocommerce-pagination ul li span {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 12px !important;
	margin: 0 !important;
	line-height: 1;
	border: 1px solid var(--jv-border);
	border-radius: 999px;
	color: var(--jv-ink);
	text-decoration: none;
	font-size: 14px;
	font-weight: 500;
	background: var(--jv-bg);
	box-sizing: border-box;
}
nav.woocommerce-pagination ul li a:hover {
	border-color: var(--jv-purple-500);
	color: var(--jv-purple-500);
	background: var(--jv-purple-50);
}
nav.woocommerce-pagination ul li span.current {
	background: var(--jv-purple-500);
	border-color: var(--jv-purple-500);
	color: #fff;
}
nav.woocommerce-pagination ul li span.dots {
	border-color: transparent;
	background: transparent;
	color: var(--jv-ink-muted);
}

/* Single product gallery — hint that the image opens a lightbox on click. */
.woocommerce-product-gallery__image,
.woocommerce-product-gallery__image a,
.woocommerce-product-gallery__image img {
	cursor: zoom-in;
}

/* WC messages */
.jviens-wc .woocommerce-message,
.jviens-wc .woocommerce-info,
.jviens-wc .woocommerce-error {
	border-radius: var(--jv-radius);
	border-top-color: var(--jv-purple-500);
	background: var(--jv-purple-50);
	color: var(--jv-ink);
}
.jviens-wc .woocommerce-message .button,
.jviens-wc .woocommerce-info .button {
	background: var(--jv-purple-500);
	color: #fff;
	border-radius: 999px;
	padding: 8px 16px;
}

/* Responsive — stack sidebar + step grid */
/* lg → sidebar stacks, 3 col grid */
@media (max-width: 1199.98px) {
	.jviens-wc {
		grid-template-columns: 1fr;
		gap: 32px;
	}
	.jviens-wc__sidebar {
		position: static;
		order: 2;
	}
	.jviens-wc__main { order: 1; }
	.jviens-wc ul.products {
		grid-template-columns: repeat(3, 1fr);
		gap: 22px 16px;
	}
}
/* md → 2 col */
@media (max-width: 899.98px) {
	.jviens-wc ul.products {
		grid-template-columns: repeat(2, 1fr);
	}
}
/* sm → 1 col */
@media (max-width: 599.98px) {
	.jviens-wc ul.products {
		grid-template-columns: 1fr;
		gap: 16px;
	}
	.jviens-wc ul.products > li.product .woocommerce-loop-product__title {
		font-size: 14px;
	}
}

/* Single product page — match heights of qty input + Add to cart button */
.woocommerce div.product form.cart {
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	gap: 8px;
	margin-top: 12px;
}
/* Wrapper is layout-transparent — children flow directly into the form's flex
   layout, which means: stock=1 (hidden input) → nothing visible, no space;
   stock>1 (visible input) → input lines up next to the button with the form's
   gap. No conditional CSS or PHP needed. */
.woocommerce div.product form.cart .quantity {
	display: contents;
}
.woocommerce div.product form.cart input.qty {
	height: 48px;
	box-sizing: border-box;
	padding: 0 10px;
	line-height: 1.2;
	font-size: 16px;
	width: 72px;
}
.woocommerce div.product form.cart .single_add_to_cart_button {
	height: 48px;
	box-sizing: border-box;
	padding: 0 22px;
	line-height: 1.2;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
