/* ==========================================================================
   Venexia — WooCommerce styles (Sakai look)
   Loaded only on WooCommerce pages. Mobile-first product grid, flat product
   cards, single-product layout, cart, checkout, mini-cart drawer, notices.
   ========================================================================== */

/* Reset some WooCommerce defaults that fight the theme */
.woocommerce .button,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	padding: 0.5rem 0.85rem;
	font-family: inherit;
	font-size: 1rem;
	font-weight: 600;
	line-height: 1.25;
	color: var(--vx-primary-contrast);
	background: var(--vx-primary);
	border: 1px solid var(--vx-primary);
	border-radius: var(--vx-radius);
	cursor: pointer;
	transition: background-color var(--vx-transition) ease, border-color var(--vx-transition) ease, box-shadow var(--vx-transition) ease;
	text-decoration: none;
}
.woocommerce .button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce button.button.alt:hover {
	background: var(--vx-primary-hover);
	border-color: var(--vx-primary-hover);
	color: var(--vx-primary-contrast);
}
.woocommerce button.button.alt,
.woocommerce a.button.alt {
	background: var(--vx-primary);
	border-color: var(--vx-primary);
}
.woocommerce .button.added,
.woocommerce .button[disabled] { opacity: 0.7; }

/* --------------------------------------------------------------------------
   Shop / archive toolbar
   -------------------------------------------------------------------------- */
.woocommerce-products-header__title.page-title { margin-top: 0; }

.woocommerce .woocommerce-result-count,
.woocommerce .woocommerce-ordering {
	margin: 0 0 1rem;
	font-size: 0.875rem;
}
.vx-shop-toolbar {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	margin-bottom: 1rem;
}
.woocommerce .woocommerce-ordering select { width: auto; min-width: 12rem; }

/* --------------------------------------------------------------------------
   Product grid — mobile-first (2 cols on phones, scaling up)
   -------------------------------------------------------------------------- */
.woocommerce ul.products,
.woocommerce-page ul.products {
	display: grid !important;
	grid-template-columns: repeat(2, 1fr);
	gap: 1rem;
	margin: 0 0 1.5rem;
	padding: 0;
	list-style: none;
}
.woocommerce ul.products::before,
.woocommerce ul.products::after { content: none !important; display: none !important; }

@media (min-width: 576px) { .woocommerce ul.products { gap: 1.25rem; } }
@media (min-width: 768px) {
	.woocommerce ul.products,
	.woocommerce-page ul.products { grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 1200px) {
	.woocommerce ul.products,
	.woocommerce-page ul.products { grid-template-columns: repeat(4, 1fr); }
}

/* Override WooCommerce's float/percentage widths */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
	width: auto !important;
	margin: 0 !important;
	float: none !important;
	clear: none !important;
	display: flex;
	flex-direction: column;
	background: var(--vx-card);
	border-radius: var(--vx-radius);
	overflow: hidden;
	box-shadow: var(--vx-shadow-card);
	transition: box-shadow var(--vx-transition) ease, transform var(--vx-transition) ease;
	position: relative;
}
.woocommerce ul.products li.product:hover {
	box-shadow: var(--vx-shadow-popover);
	transform: translateY(-2px);
}

.woocommerce ul.products li.product a.woocommerce-LoopProduct-link {
	display: block;
	color: inherit;
}
.woocommerce ul.products li.product img {
	width: 100%;
	margin: 0;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	background: var(--vx-hover);
	border-radius: 0;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
	padding: 0.85rem 1rem 0;
	font-size: 0.95rem;
	font-weight: 600;
	line-height: 1.35;
	color: var(--vx-text-strong);
}
.woocommerce ul.products li.product .price {
	display: block;
	padding: 0.35rem 1rem 0;
	color: var(--vx-text-strong);
	font-weight: 700;
	font-size: 1rem;
}
.woocommerce ul.products li.product .price del { color: var(--vx-text-muted); font-weight: 400; margin-right: 0.4rem; }
.woocommerce ul.products li.product .price ins { text-decoration: none; }
.woocommerce ul.products li.product .star-rating { margin: 0.4rem 1rem 0; font-size: 0.8rem; }

.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product .added_to_cart {
	margin: 0.75rem 1rem 1rem;
	width: calc(100% - 2rem);
}
.woocommerce ul.products li.product .added_to_cart {
	background: transparent;
	color: var(--vx-primary);
	border-color: var(--vx-border);
}

/* Sale flash badge */
.woocommerce span.onsale,
.woocommerce ul.products li.product .onsale {
	position: absolute;
	top: 0.6rem;
	left: 0.6rem;
	right: auto;
	margin: 0;
	min-height: auto;
	min-width: auto;
	padding: 0.2rem 0.55rem;
	font-size: 0.7rem;
	font-weight: 700;
	line-height: 1.4;
	color: #fff;
	background: var(--vx-danger);
	border-radius: 999px;
	z-index: 2;
}

/* Star rating color */
.woocommerce .star-rating span::before,
.woocommerce p.stars a::before { color: var(--vx-warning); }
.woocommerce .star-rating { color: var(--vx-warning); }

/* --------------------------------------------------------------------------
   Single product
   -------------------------------------------------------------------------- */
.woocommerce div.product { display: block; }

/* Two-column product layout: images | summary, with tabs/related full width. */
@media (min-width: 768px) {
	.single-product div.product {
		display: grid;
		grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
		gap: 2rem;
		align-items: start;
	}
	.single-product div.product > .woocommerce-tabs,
	.single-product div.product > .related,
	.single-product div.product > .upsells,
	.single-product div.product > .woocommerce-product-gallery + .summary ~ * {
		grid-column: 1 / -1;
	}
	.single-product div.product .woocommerce-tabs,
	.single-product div.product .related,
	.single-product div.product .upsells { grid-column: 1 / -1; }
}

.woocommerce div.product div.images,
.woocommerce div.product div.summary {
	width: auto !important;
	float: none !important;
	margin: 0 0 1.5rem !important;
}
.woocommerce div.product div.images img { border-radius: var(--vx-radius); }
.woocommerce div.product .flex-control-thumbs { margin-top: 0.75rem; }
.woocommerce div.product .flex-control-thumbs li { margin: 0 0.5rem 0.5rem 0; width: 4rem; }
.woocommerce div.product .flex-control-thumbs img { border-radius: var(--vx-radius-sm); }

.woocommerce div.product .product_title { margin-top: 0; }
.woocommerce div.product p.price,
.woocommerce div.product span.price {
	color: var(--vx-text-strong);
	font-size: 1.6rem;
	font-weight: 700;
}
.woocommerce div.product p.price del { color: var(--vx-text-muted); font-weight: 400; font-size: 1.1rem; }
.woocommerce div.product p.price ins { text-decoration: none; }
.woocommerce div.product .woocommerce-product-rating { margin-bottom: 1rem; }

.woocommerce div.product form.cart {
	margin: 1.5rem 0;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.75rem;
}
.woocommerce div.product form.cart .quantity { margin: 0; }
.woocommerce .quantity input.qty {
	width: 4.5rem;
	text-align: center;
	padding: 0.5rem;
}
.woocommerce div.product form.cart .variations { width: 100%; }
.woocommerce div.product form.cart .variations td,
.woocommerce div.product form.cart .variations th { padding: 0.35rem 0; }

.woocommerce div.product .woocommerce-tabs {
	margin-top: 2rem;
	clear: both;
}
.woocommerce div.product .woocommerce-tabs ul.tabs {
	display: flex;
	flex-wrap: wrap;
	gap: 0.25rem;
	padding: 0;
	margin: 0 0 1.25rem;
	border-bottom: 1px solid var(--vx-border);
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before { border: 0; }
.woocommerce div.product .woocommerce-tabs ul.tabs li {
	margin: 0;
	padding: 0;
	background: transparent;
	border: 0;
	border-radius: 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after { display: none; }
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	display: block;
	padding: 0.6rem 1rem;
	font-weight: 600;
	color: var(--vx-text-muted);
	border-bottom: 2px solid transparent;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
	color: var(--vx-primary);
	border-bottom-color: var(--vx-primary);
}

/* Related / upsells reuse the grid above */
.woocommerce .related, .woocommerce .upsells { margin-top: 2.5rem; clear: both; }

/* --------------------------------------------------------------------------
   Cart
   -------------------------------------------------------------------------- */
.woocommerce table.shop_table {
	border: 1px solid var(--vx-border);
	border-radius: var(--vx-radius);
	border-collapse: separate;
	border-spacing: 0;
	overflow: hidden;
	background: var(--vx-card);
}
.woocommerce table.shop_table th,
.woocommerce table.shop_table td {
	padding: 0.85rem 1rem;
	border-top: 1px solid var(--vx-border);
}
.woocommerce table.shop_table thead th { border-top: 0; background: var(--vx-hover); font-weight: 700; }
.woocommerce table.shop_table img { width: 3.5rem; border-radius: var(--vx-radius-sm); }

.woocommerce .cart-collaterals .cart_totals,
.woocommerce-page .cart-collaterals .cart_totals { width: 100%; float: none; }
@media (min-width: 992px) {
	.woocommerce .cart-collaterals .cart_totals { width: 38%; float: right; }
}

.woocommerce .coupon { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.woocommerce .coupon input.input-text { width: auto; flex: 1; min-width: 10rem; }

/* --------------------------------------------------------------------------
   Checkout
   -------------------------------------------------------------------------- */
@media (min-width: 992px) {
	.woocommerce .col2-set .col-1,
	.woocommerce .col2-set .col-2,
	.woocommerce-page .col2-set .col-1,
	.woocommerce-page .col2-set .col-2 { width: 48%; }
}
.woocommerce form .form-row { margin-bottom: 1rem; }
.woocommerce form .form-row label { display: block; margin-bottom: 0.35rem; }
.woocommerce-checkout #payment {
	background: var(--vx-hover);
	border-radius: var(--vx-radius);
}
.woocommerce-checkout #payment ul.payment_methods { border-bottom: 1px solid var(--vx-border); }

/* --------------------------------------------------------------------------
   My account
   -------------------------------------------------------------------------- */
@media (min-width: 768px) {
	.woocommerce-account .woocommerce-MyAccount-navigation { width: 28%; float: left; }
	.woocommerce-account .woocommerce-MyAccount-content { width: 68%; float: right; }
}
.woocommerce-MyAccount-navigation ul { list-style: none; padding: 0; margin: 0; }
.woocommerce-MyAccount-navigation li a {
	display: block;
	padding: 0.6rem 0.85rem;
	border-radius: var(--vx-radius-sm);
	color: var(--vx-text);
	font-weight: 500;
}
.woocommerce-MyAccount-navigation li.is-active a,
.woocommerce-MyAccount-navigation li a:hover { background: var(--vx-hover); color: var(--vx-primary); }

/* --------------------------------------------------------------------------
   Notices
   -------------------------------------------------------------------------- */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error,
.woocommerce-noreviews {
	padding: 0.85rem 1rem;
	margin: 0 0 1.25rem;
	border-radius: var(--vx-radius);
	border: 0;
	border-left: 4px solid var(--vx-primary);
	background: var(--vx-primary-50);
	color: var(--vx-text-strong);
	list-style: none;
	box-shadow: var(--vx-shadow-card);
}
html.vx-dark .woocommerce-message,
html.vx-dark .woocommerce-info { background: color-mix(in srgb, var(--vx-primary) 12%, var(--vx-card)); }
.woocommerce-message::before,
.woocommerce-info::before,
.woocommerce-error::before { display: none; }
.woocommerce-info { border-left-color: var(--vx-info); }
.woocommerce-error {
	border-left-color: var(--vx-danger);
	background: #fee2e2;
	color: #7f1d1d;
}
.woocommerce-message .button,
.woocommerce-info .button { padding: 0.3rem 0.6rem; font-size: 0.85rem; }

/* --------------------------------------------------------------------------
   Mini-cart (in the off-canvas / dropdown)
   -------------------------------------------------------------------------- */
.vx-minicart { font-size: 0.9rem; }
.vx-minicart .woocommerce-mini-cart {
	list-style: none;
	margin: 0;
	padding: 0;
	max-height: 50vh;
	overflow-y: auto;
}
.vx-minicart .woocommerce-mini-cart-item {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	padding: 0.6rem 0;
	border-bottom: 1px solid var(--vx-border);
}
.vx-minicart .woocommerce-mini-cart-item img {
	width: 3rem;
	height: 3rem;
	object-fit: cover;
	border-radius: var(--vx-radius-sm);
	order: -1;
}
.vx-minicart .woocommerce-mini-cart-item a:not(.remove) { flex: 1; font-weight: 600; color: var(--vx-text-strong); }
.vx-minicart .remove_from_cart_button {
	display: inline-flex;
	width: 1.5rem; height: 1.5rem;
	align-items: center; justify-content: center;
	border-radius: 50%;
	background: var(--vx-hover);
	color: var(--vx-danger) !important;
	font-size: 1rem;
	text-decoration: none;
}
.vx-minicart .woocommerce-mini-cart__total {
	display: flex;
	justify-content: space-between;
	padding: 0.85rem 0;
	font-weight: 700;
	border-bottom: 1px solid var(--vx-border);
	margin-bottom: 0.85rem;
}
.vx-minicart .woocommerce-mini-cart__buttons { display: flex; flex-direction: column; gap: 0.5rem; margin: 0; }
.vx-minicart .woocommerce-mini-cart__buttons .button { width: 100%; }
.vx-minicart .woocommerce-mini-cart__buttons .checkout { background: var(--vx-primary); }
.vx-minicart-empty { padding: 1rem 0; color: var(--vx-text-muted); }

/* Floating cart subtotal in topbar badge handled by .vx-badge-count */
