/*
 * WooCommerce compatibility styles — lightweight e-commerce approach.
 *
 * Only overrides core element styles; no template rewrites.
 * References theme.json design tokens.
 *
 * Note: WooCommerce registers its own font size presets via WP_Theme_JSON API,
 * overriding theme.json's small(13px)/medium(20px)/large(36px)/x-large(42px).
 * Use --cclee-* custom variables on Woo pages to bypass overridden presets.
 */

:root {
	--cclee-font-sm: 0.875rem;    /* 14px — Woo overrides small to 13px */
	--cclee-font-md: 1rem;        /* 16px — Woo overrides medium to 20px */
	--cclee-font-lg: 1.125rem;    /* 18px — Woo overrides large to 36px */
	--cclee-font-xl: 1.25rem;     /* 20px — Woo overrides x-large to 42px */
}

/* ===== Buttons — Modern Premium Style ===== */
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce .button,
.woocommerce .wp-block-button__link,
.wc-block-components-product-button .wp-block-button__link,
.woocommerce .wp-element-button {
	background: var(--wp--preset--gradient--accent) !important;
	color: var(--wp--preset--color--base) !important;
	padding: 0.625rem 1.25rem;
	border-radius: var(--wp--custom--border--radius--md);
	border: none;
	font-size: var(--cclee-font-sm);
	font-weight: 600;
	letter-spacing: 0.02em;
	cursor: pointer;
	text-decoration: none;
	box-shadow: 0 2px 8px color-mix(in srgb, var(--wp--preset--color--accent) 25%, transparent),
	            0 1px 2px rgba(0, 0, 0, 0.08);
	transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
	position: relative;
	overflow: hidden;
	min-height: 44px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

/* Disabled state: dimmed but still shows gradient identity */
.woocommerce button.button:disabled,
.woocommerce button.button.disabled,
.woocommerce .button.disabled,
.woocommerce .button.wc-variation-selection-needed {
	opacity: 0.6;
	cursor: not-allowed;
	background: var(--wp--preset--gradient--accent) !important;
	color: var(--wp--preset--color--base) !important;
}

/* Button shimmer effect */
.woocommerce .button::before,
.wc-block-components-product-button .wp-block-button__link::before {
	content: '';
	position: absolute;
	top: 0;
	left: -100%;
	width: 100%;
	height: 100%;
	background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
	transition: left 0.5s ease;
}

.woocommerce .button:hover::before,
.wc-block-components-product-button .wp-block-button__link:hover::before {
	left: 100%;
}

.woocommerce #respond input#submit:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover:not(:disabled),
.woocommerce input.button:hover,
.woocommerce .button:hover:not(.disabled),
.woocommerce .wp-element-button:hover,
.wc-block-components-product-button .wp-block-button__link:hover {
	background: var(--wp--preset--gradient--accent) !important;
	color: var(--wp--preset--color--base) !important;
	transform: translateY(-2px);
	filter: brightness(1.12);
	box-shadow: 0 6px 20px color-mix(in srgb, var(--wp--preset--color--accent) 35%, transparent),
	            0 2px 4px rgba(0, 0, 0, 0.1);
}

.woocommerce #respond input#submit:active,
.woocommerce a.button:active,
.woocommerce button.button:active:not(:disabled),
.woocommerce input.button:active,
.woocommerce .button:active:not(.disabled),
.woocommerce .wp-element-button:active,
.wc-block-components-product-button .wp-block-button__link:active {
	transform: translateY(0) scale(0.98);
	filter: brightness(0.95);
	box-shadow: 0 2px 8px color-mix(in srgb, var(--wp--preset--color--accent) 25%, transparent);
}

/* Secondary/Outline Button Style */
.woocommerce .button.alt,
.woocommerce .button.checkout,
.woocommerce .wp-block-button.is-style-outline .wp-block-button__link {
	background: transparent !important;
	border: 2px solid var(--wp--preset--color--accent);
	color: var(--wp--preset--color--accent) !important;
	box-shadow: none;
}

.woocommerce .button.alt:hover,
.woocommerce .button.checkout:hover,
.woocommerce .wp-block-button.is-style-outline .wp-block-button__link:hover {
	background: var(--wp--preset--gradient--accent) !important;
	border-color: transparent;
	color: var(--wp--preset--color--base) !important;
	transform: translateY(-2px);
	box-shadow: 0 6px 20px color-mix(in srgb, var(--wp--preset--color--accent) 35%, transparent);
}

/* Loading state */
.woocommerce .button.loading,
.wc-block-components-product-button .wp-block-button__link.loading {
	opacity: 0.7;
	pointer-events: none;
}

.woocommerce .button.loading::after,
.wc-block-components-product-button .wp-block-button__link.loading::after {
	content: '';
	display: inline-block;
	width: 14px;
	height: 14px;
	margin-left: 8px;
	border: 2px solid rgba(255, 255, 255, 0.3);
	border-top-color: #fff;
	border-radius: 50%;
	animation: cclee-spin 0.8s linear infinite;
}

@keyframes cclee-spin {
	to { transform: rotate(360deg); }
}

/* Added to cart success state */
.woocommerce .button.added,
.wc-block-components-product-button .wp-block-button__link.added {
	background: linear-gradient(135deg, #10b981 0%, #059669 100%);
	box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3);
}

/* ===== Product Grid ===== */
.woocommerce ul.products {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
	gap: var(--wp--preset--spacing--50);
	margin: 0;
	padding: 0;
	list-style: none;
}

.woocommerce ul.products li.product {
	float: none;
	width: auto;
	margin: 0;
	padding: var(--wp--preset--spacing--40);
	background: var(--wp--preset--color--base);
	border: 1px solid var(--wp--preset--color--neutral-200);
	border-radius: var(--wp--custom--border--radius--md);
	box-shadow: 0 1px 4px rgba(0, 0, 0, 0.04);
	text-align: left;
	transition: box-shadow 0.3s cubic-bezier(0.4, 0, 0.2, 1), transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.woocommerce ul.products li.product:hover {
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
	transform: translateY(-4px);
}

.woocommerce ul.products li.product a:not(.button):not(.wp-element-button) {
	text-decoration: none;
	color: inherit;
}

.woocommerce ul.products li.product h2,
.woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-size: var(--cclee-font-lg);
	color: var(--wp--preset--color--primary);
	margin: var(--wp--preset--spacing--30) 0 var(--wp--preset--spacing--20);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	line-height: 1.4;
}

.woocommerce ul.products li.product .price {
	font-size: var(--cclee-font-md);
	color: var(--wp--preset--color--accent);
	font-weight: 600;
}

/* ===== Single Product ===== */
.woocommerce div.product .product_title {
	font-size: var(--wp--preset--font-size--xx-large);
	color: var(--wp--preset--color--primary);
	margin-bottom: var(--wp--preset--spacing--20);
}

/* Hide WooCommerce internal type hints */
.woocommerce div.product .woocommerce-variation-availability,
.woocommerce div.product .wc-product-type-label {
	display: none;
}

.woocommerce div.product .price {
	font-size: var(--cclee-font-xl);
	color: var(--wp--preset--color--primary);
	font-weight: 700;
	margin-top: var(--wp--preset--spacing--20);
	margin-bottom: var(--wp--preset--spacing--30);
}

.woocommerce div.product .price del {
	color: var(--wp--preset--color--neutral-400);
	font-weight: 400;
}

/* Product meta (SKU / Category) — separator above */
.woocommerce div.product .product_meta {
	margin-top: var(--wp--preset--spacing--50);
	padding-top: var(--wp--preset--spacing--30);
	border-top: 1px solid var(--wp--preset--color--contrast);
	font-size: var(--cclee-font-sm);
	color: var(--wp--preset--color--secondary);
	line-height: 1.8;
}

.woocommerce div.product .product_meta a {
	color: var(--wp--preset--color--primary);
	text-decoration: none;
}

.woocommerce div.product .product_meta a:hover {
	text-decoration: underline;
}

/* ===== Cart ===== */
.woocommerce table.shop_table {
	border-collapse: collapse;
	width: 100%;
	border-radius: 0;
}

.woocommerce table.shop_table th,
.woocommerce table.shop_table td {
	padding: var(--wp--preset--spacing--30);
	border: 1px solid var(--wp--preset--color--contrast);
}

.woocommerce table.shop_table th {
	background: var(--wp--preset--color--contrast);
}

.woocommerce-cart .cart_totals {
	background: var(--wp--preset--color--contrast);
	padding: var(--wp--preset--spacing--40);
	border-radius: 8px;
}

/* ===== Checkout ===== */
.woocommerce-checkout .woocommerce-billing-fields h3,
.woocommerce-checkout .woocommerce-shipping-fields h3,
.woocommerce-checkout #order_review_heading {
	font-size: var(--cclee-font-xl);
	color: var(--wp--preset--color--primary);
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea {
	border: 1px solid var(--wp--preset--color--contrast);
	border-radius: 4px;
	padding: 0.75rem;
	width: 100%;
}

.woocommerce form .form-row label {
	color: var(--wp--preset--color--secondary);
}

/* ===== Notices ===== */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	padding: var(--wp--preset--spacing--30) var(--wp--preset--spacing--40);
	margin-bottom: var(--wp--preset--spacing--40);
	border-radius: 4px;
}

.woocommerce-message {
	background: var(--wp--preset--color--contrast);
	color: var(--wp--preset--color--primary);
	border-left: 4px solid var(--wp--preset--color--accent);
}

.woocommerce-error {
	background: #fff0f0;
	color: #c00;
	border-left: 4px solid #c00;
}

/* ===== Pagination ===== */
.woocommerce nav.woocommerce-pagination {
	margin: var(--wp--preset--spacing--60) 0;
}

.woocommerce nav.woocommerce-pagination ul {
	display: flex;
	gap: 0.5rem;
	list-style: none;
	padding: 0;
	margin: 0;
	border: none;
}

.woocommerce nav.woocommerce-pagination ul li {
	border: none;
}

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
	padding: 0.5rem 1rem;
	border: 1px solid var(--wp--preset--color--contrast);
	border-radius: 4px;
	color: var(--wp--preset--color--primary);
}

.woocommerce nav.woocommerce-pagination ul li a:hover,
.woocommerce nav.woocommerce-pagination ul li span.current {
	background: var(--wp--preset--color--accent);
	color: var(--wp--preset--color--base);
	border-color: var(--wp--preset--color--accent);
}

/* ===== Star Ratings — B2B Compact ===== */

/* Rating wrapper: inline compact */
.woocommerce div.product .woocommerce-product-rating {
	display: flex;
	align-items: center;
	gap: var(--wp--preset--spacing--20);
	margin-bottom: var(--wp--preset--spacing--20);
	line-height: 1;
}

/* Star rating: compact, use theme accent color */
.woocommerce div.product .woocommerce-product-rating .star-rating {
	width: 5.5em;
	height: 1em;
	overflow: hidden;
	position: relative;
	font-size: 0.875rem;
	line-height: 1;
}

.woocommerce div.product .woocommerce-product-rating .star-rating::before {
	content: "★★★★★";
	color: var(--wp--preset--color--neutral-200);
	position: absolute;
	top: 0;
	left: 0;
	letter-spacing: 0.05em;
}

.woocommerce div.product .woocommerce-product-rating .star-rating span {
	overflow: hidden;
	position: absolute;
	top: 0;
	left: 0;
	height: 1em;
	padding-top: 1.5em;
}

.woocommerce div.product .woocommerce-product-rating .star-rating span::before {
	content: "★★★★★";
	color: var(--wp--preset--color--accent);
	top: 0;
	position: absolute;
	left: 0;
	letter-spacing: 0.05em;
}

/* Review count link: small, muted */
.woocommerce div.product .woocommerce-product-rating .woocommerce-review-link,
.woocommerce div.product .woocommerce-product-rating a {
	font-size: var(--cclee-font-sm);
	color: var(--wp--preset--color--secondary);
	text-decoration: none;
}

.woocommerce div.product .woocommerce-product-rating .woocommerce-review-link:hover,
.woocommerce div.product .woocommerce-product-rating a:hover {
	color: var(--wp--preset--color--primary);
	text-decoration: underline;
}

/* Archive / loop star rating: inherit accent */
.woocommerce .star-rating {
	color: var(--wp--preset--color--accent);
}

/* ===== Responsive ===== */
@media (max-width: 768px) {
	.woocommerce ul.products {
		grid-template-columns: repeat(2, 1fr);
		gap: var(--wp--preset--spacing--30);
	}

	.woocommerce table.shop_table thead {
		display: none;
	}

	.woocommerce table.shop_table td {
		display: block;
		text-align: right;
	}

	.woocommerce table.shop_table td::before {
		content: attr(data-title) ": ";
		float: left;
		font-weight: 600;
	}
}

/* ========================================
   Cart & Checkout Page Styles
   ======================================== */

/* Progress Steps */
.woo-progress-steps {
	flex-wrap: wrap;
}

.woo-progress-step {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
}

.woo-progress-step--active .wp-block-group {
	background: var(--wp--preset--color--accent);
	border-color: var(--wp--preset--color--accent);
}

/* Trust Badges */
.woo-trust-badges {
	padding: var(--wp--preset--spacing--20) 0;
	border-top: 1px solid var(--wp--preset--color--neutral-200);
}

.woo-trust-badge {
	transition: opacity var(--wp--custom--transition--fast);
}

.woo-trust-badge:hover {
	opacity: 0.8;
}

/* Cart Page */
.cclee-cart .woocommerce-cart-form {
	margin-bottom: var(--wp--preset--spacing--40);
}

.cclee-cart table.shop_table {
	border-radius: var(--wp--custom--border--radius--lg);
	overflow: hidden;
}

.cclee-cart .coupon {
	display: flex;
	gap: var(--wp--preset--spacing--20);
	align-items: center;
}

.cclee-cart .coupon input.input-text {
	flex: 1;
	max-width: 200px;
}

/* Checkout Page */
.cclee-checkout .woocommerce-billing-fields,
.cclee-checkout .woocommerce-shipping-fields,
.cclee-checkout .woocommerce-additional-fields {
	margin-bottom: var(--wp--preset--spacing--40);
}

.cclee-checkout h3 {
	font-size: var(--cclee-font-lg);
	color: var(--wp--preset--color--primary);
	margin-bottom: var(--wp--preset--spacing--30);
	padding-bottom: var(--wp--preset--spacing--20);
	border-bottom: 1px solid var(--wp--preset--color--neutral-200);
}

/* Order Summary Sidebar */
.cclee-checkout + .wp-block-column .wp-block-group {
	position: sticky;
	top: 100px;
}

/* Payment Methods */
.cclee-checkout .woocommerce-checkout-payment {
	background: var(--wp--preset--color--contrast);
	padding: var(--wp--preset--spacing--40);
	border-radius: var(--wp--custom--border--radius--lg);
	margin-top: var(--wp--preset--spacing--30);
}

.cclee-checkout .woocommerce-checkout-payment ul.payment_methods {
	list-style: none;
	padding: 0;
	margin: 0 0 var(--wp--preset--spacing--30) 0;
}

.cclee-checkout .woocommerce-checkout-payment ul.payment_methods li {
	margin-bottom: var(--wp--preset--spacing--20);
}

.cclee-checkout .woocommerce-checkout-payment label {
	cursor: pointer;
	display: flex;
	align-items: center;
	gap: var(--wp--preset--spacing--15);
}

/* Place Order Button */
.cclee-checkout .woocommerce-checkout-payment .place-order {
	margin-top: var(--wp--preset--spacing--30);
}

.cclee-checkout .woocommerce-checkout-payment .button {
	width: 100%;
	padding: var(--wp--preset--spacing--15) var(--wp--preset--spacing--30);
	font-size: var(--cclee-font-md);
	font-weight: 600;
}

/* Mobile Cart/Checkout */
@media (max-width: 768px) {
	.woo-progress-steps {
		gap: var(--wp--preset--spacing--15);
	}

	.woo-progress-steps .wp-block-separator {
		width: 30px !important;
	}

	.cclee-cart,
	.cclee-checkout {
		margin-bottom: var(--wp--preset--spacing--40);
	}

	.woo-trust-badges {
		flex-direction: column;
		gap: var(--wp--preset--spacing--20);
	}
}

/* ========================================
   Archive Product Styles
   ======================================== */

/* Sort Dropdown */
.woocommerce-ordering {
	position: relative;
}

.woocommerce-ordering select.orderby {
	appearance: none;
	background: var(--wp--preset--color--base);
	border: 1px solid var(--wp--preset--color--neutral-200);
	border-radius: var(--wp--custom--border--radius--md);
	padding: 0.5rem 2.5rem 0.5rem 1rem;
	font-size: var(--cclee-font-sm);
	color: var(--wp--preset--color--secondary);
	cursor: pointer;
	transition: border-color var(--wp--custom--transition--fast);
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23737373' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 0.75rem center;
}

.woocommerce-ordering select.orderby:hover {
	border-color: var(--wp--preset--color--neutral-300);
}

.woocommerce-ordering select.orderby:focus {
	outline: none;
	border-color: var(--wp--preset--color--accent);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--wp--preset--color--accent) 10%, transparent);
}

/* Result Count */
.woocommerce-result-count {
	color: var(--wp--preset--color--neutral-500);
	font-size: var(--cclee-font-sm);
}

/* ========================================
   My Account Styles
   ======================================== */

/* Account Navigation - Left Border Highlight */
.woocommerce-MyAccount-navigation ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.woocommerce-MyAccount-navigation ul li {
	margin: 0;
	padding: 0;
}

.woocommerce-MyAccount-navigation ul li a {
	display: block;
	padding: var(--wp--preset--spacing--30) var(--wp--preset--spacing--40);
	color: var(--wp--preset--color--secondary);
	text-decoration: none;
	border-left: 3px solid transparent;
	transition: all var(--wp--custom--transition--fast);
	font-size: var(--cclee-font-md);
}

.woocommerce-MyAccount-navigation ul li a:hover {
	color: var(--wp--preset--color--primary);
	background: var(--wp--preset--color--neutral-50);
	border-left-color: var(--wp--preset--color--neutral-300);
}

.woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-MyAccount-navigation ul li.current-cat a {
	color: var(--wp--preset--color--primary);
	font-weight: 600;
	background: var(--wp--preset--color--neutral-50);
	border-left-color: var(--wp--preset--color--accent);
}

/* Account Content */
.woocommerce-MyAccount-content {
	padding-left: var(--wp--preset--spacing--50);
}

.woocommerce-MyAccount-content h2,
.woocommerce-MyAccount-content h3 {
	font-size: var(--cclee-font-xl);
	color: var(--wp--preset--color--primary);
	margin-bottom: var(--wp--preset--spacing--40);
}

/* Mobile Account Navigation */
@media (max-width: 768px) {
	.woocommerce-MyAccount-navigation ul {
		display: flex;
		flex-wrap: wrap;
		gap: var(--wp--preset--spacing--10);
		margin-bottom: var(--wp--preset--spacing--40);
		border-bottom: 1px solid var(--wp--preset--color--neutral-200);
		padding-bottom: var(--wp--preset--spacing--20);
	}

	.woocommerce-MyAccount-navigation ul li a {
		padding: var(--wp--preset--spacing--20) var(--wp--preset--spacing--30);
		border-left: none;
		border-bottom: 2px solid transparent;
		border-radius: var(--wp--custom--border--radius--sm);
	}

	.woocommerce-MyAccount-navigation ul li a:hover {
		border-left-color: transparent;
		border-bottom-color: var(--wp--preset--color--neutral-300);
	}

	.woocommerce-MyAccount-navigation ul li.is-active a,
	.woocommerce-MyAccount-navigation ul li.current-cat a {
		border-left-color: transparent;
		border-bottom-color: var(--wp--preset--color--accent);
	}

	.woocommerce-MyAccount-content {
		padding-left: 0;
	}
}

/* ========================================
   Single Product Styles
   ======================================== */

/* Product Gallery — Left sidebar thumbnails (B2B premium style) */
.woocommerce div.product div.images {
	margin-bottom: var(--wp--preset--spacing--50);
}

/* Gallery container: flex row, thumbnails left */
/* Note: .woocommerce-product-gallery and .images are on the SAME element */
.woocommerce div.product div.woocommerce-product-gallery {
	display: flex !important;
	flex-direction: row;
	gap: var(--wp--preset--spacing--30);
	position: relative;
}

/* Zoom trigger: overlay on main image, not a flex child */
.woocommerce div.product .woocommerce-product-gallery__trigger {
	position: absolute;
	top: 12px;
	right: 12px;
	z-index: 10;
	width: auto;
	height: auto;
	pointer-events: auto;
}

/* Sale badge: overlay on main image area */
/* onsale is a sibling of the gallery div (outside it), position relative to .product wrapper */
.woocommerce div.product.type-product {
	position: relative;
}

.woocommerce div.product span.onsale {
	position: absolute;
	top: 12px;
	/* offset past thumbnails (80px) + gap + 12px padding */
	left: calc(80px + var(--wp--preset--spacing--30) + 12px);
	z-index: 10;
	margin: 0;
	border-radius: var(--wp--custom--border--radius--sm);
	background: var(--wp--preset--color--accent);
	color: var(--wp--preset--color--base);
	padding: 4px 12px;
	font-size: 0.75rem;
	font-weight: 700;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

/* Single-image: no thumbnails, reset onsale offset to 12px from left */
.woocommerce div.product .woocommerce-product-gallery:not(:has(.flex-viewport)) ~ span.onsale,
.woocommerce div.product .images:not(:has(.flex-viewport)) span.onsale {
	left: 12px;
}

/* Thumbnail nav: vertical column on the left */
.woocommerce div.product ol.flex-control-nav.flex-control-thumbs {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--20);
	order: -1;
	flex-shrink: 0;
	width: 80px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.woocommerce div.product ol.flex-control-nav.flex-control-thumbs li {
	margin: 0;
	width: 80px;
	height: 80px;
}

.woocommerce div.product ol.flex-control-nav.flex-control-thumbs li img {
	width: 80px;
	height: 80px;
	object-fit: cover;
	border-radius: var(--wp--custom--border--radius--md);
	border: 2px solid transparent;
	cursor: pointer;
	transition: border-color 0.2s ease, opacity 0.2s ease;
	opacity: 0.75;
}

.woocommerce div.product ol.flex-control-nav.flex-control-thumbs li img:hover {
	opacity: 0.9;
	border-color: var(--wp--preset--color--neutral-300);
}

.woocommerce div.product ol.flex-control-nav.flex-control-thumbs li img.flex-active {
	opacity: 1;
	border-color: var(--wp--preset--color--primary);
}

/* Main image viewport: fill remaining space, positioning context for overlays */
.woocommerce div.product .flex-viewport {
	flex: 1;
	min-width: 0;
	position: relative;
}

/* Single-image fallback: when FlexSlider is not initialized (no gallery images),
   __wrapper needs to act as positioning context instead of flex-viewport */
.woocommerce div.product .woocommerce-product-gallery__wrapper:not(:has(.flex-viewport)) {
	flex: 1;
	min-width: 0;
	position: relative;
}

/* Single-image: constrain __image to match img aspect-ratio so overlays align */
.woocommerce div.product .woocommerce-product-gallery__wrapper:not(:has(.flex-viewport)) .woocommerce-product-gallery__image {
	aspect-ratio: 1;
	max-height: 100%;
}

/* Force gallery images square via CSS */
.woocommerce div.product .woocommerce-product-gallery__image img {
	aspect-ratio: 1;
	object-fit: cover;
	width: 100%;
	border-radius: var(--wp--custom--border--radius--lg);
}

.woocommerce div.product .woocommerce-product-gallery img {
	border-radius: var(--wp--custom--border--radius--lg);
}

/* Product Summary */
.woocommerce div.product div.summary {
	padding-left: var(--wp--preset--spacing--60);
}

/* Short description — B2B subtitle */
.woocommerce div.product .woocommerce-short-description {
	margin-top: var(--wp--preset--spacing--20);
	margin-bottom: var(--wp--preset--spacing--20);
	font-size: var(--cclee-font-md);
	color: var(--wp--preset--color--secondary);
	line-height: 1.6;
}

/* ===== Variation Selectors — Premium Style ===== */
.woocommerce div.product .woocommerce-variation-add-to-cart,
.woocommerce div.product .cart {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-end;
	gap: var(--wp--preset--spacing--30);
}

/* Variation label styling */
.woocommerce div.product table.variations td.label label {
	font-size: var(--cclee-font-sm);
	font-weight: 600;
	color: var(--wp--preset--color--primary);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin-bottom: var(--wp--preset--spacing--10);
}

/* Variation select — custom appearance */
.woocommerce div.product table.variations td.value select {
	appearance: none;
	-webkit-appearance: none;
	background: var(--wp--preset--color--base);
	border: 2px solid var(--wp--preset--color--neutral-200);
	border-radius: var(--wp--custom--border--radius--md);
	padding: 0.75rem 2.5rem 0.75rem 1rem;
	font-size: var(--cclee-font-md);
	color: var(--wp--preset--color--primary);
	font-weight: 500;
	cursor: pointer;
	min-height: 48px;
	width: 100%;
	max-width: 320px;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23334155' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 0.75rem center;
}

.woocommerce div.product table.variations td.value select:hover {
	border-color: var(--wp--preset--color--neutral-300);
}

.woocommerce div.product table.variations td.value select:focus {
	outline: none;
	border-color: var(--wp--preset--color--primary);
	box-shadow: 0 0 0 3px rgba(15, 23, 42, 0.08);
}

/* Reset variation link */
.woocommerce div.product .reset_variations {
	font-size: var(--cclee-font-sm);
	color: var(--wp--preset--color--neutral-500);
	text-decoration: underline;
	margin-left: var(--wp--preset--spacing--20);
	transition: color 0.15s ease;
}

.woocommerce div.product .reset_variations:hover {
	color: var(--wp--preset--color--primary);
}

/* ===== Quantity Input — Stepper Buttons ===== */
.woocommerce div.product .quantity {
	display: inline-flex;
	align-items: center;
	border: 2px solid var(--wp--preset--color--neutral-200);
	border-radius: var(--wp--custom--border--radius--md);
	overflow: hidden;
	transition: border-color 0.2s ease;
}

.woocommerce div.product .quantity:hover {
	border-color: var(--wp--preset--color--neutral-300);
}

.woocommerce div.product .quantity:focus-within {
	border-color: var(--wp--preset--color--primary);
	box-shadow: 0 0 0 3px rgba(15, 23, 42, 0.08);
}

.woocommerce div.product .quantity .qty {
	-moz-appearance: textfield;
	appearance: textfield;
	border: none;
	background: transparent;
	text-align: center;
	font-size: var(--cclee-font-md);
	font-weight: 600;
	color: var(--wp--preset--color--primary);
	width: 48px;
	height: 48px;
	padding: 0;
	outline: none;
}

.woocommerce div.product .quantity .qty::-webkit-outer-spin-button,
.woocommerce div.product .quantity .qty::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

/* +/- buttons injected via CSS pseudo on qty input wrapper */
.woocommerce div.product .quantity::before,
.woocommerce div.product .quantity::after {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 48px;
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--wp--preset--color--neutral-500);
	cursor: pointer;
	user-select: none;
	transition: color 0.15s ease, background 0.15s ease;
}

.woocommerce div.product .quantity::before {
	content: '\2212';
}

.woocommerce div.product .quantity::after {
	content: '+';
}

.woocommerce div.product .quantity:hover::before,
.woocommerce div.product .quantity:hover::after {
	color: var(--wp--preset--color--primary);
	background: var(--wp--preset--color--neutral-50);
}

/* Product Meta (SKU, Category, Tags) — B2B prominence */
.woocommerce div.product .product_meta {
	font-size: var(--cclee-font-md);
	color: var(--wp--preset--color--secondary);
	margin-top: var(--wp--preset--spacing--40);
	padding-top: var(--wp--preset--spacing--30);
	border-top: 1px solid var(--wp--preset--color--neutral-200);
	display: flex;
	flex-wrap: wrap;
	gap: var(--wp--preset--spacing--20) var(--wp--preset--spacing--40);
}

.woocommerce div.product .product_meta span {
	display: inline-flex;
	align-items: center;
	gap: var(--wp--preset--spacing--10);
	margin-bottom: 0;
}

.woocommerce div.product .product_meta a {
	color: var(--wp--preset--color--primary);
	text-decoration: none;
	font-weight: 500;
	transition: color 0.15s ease;
}

.woocommerce div.product .product_meta a:hover {
	color: var(--wp--preset--color--accent);
	text-decoration: underline;
	text-underline-offset: 2px;
}

/* Tabs — generous top margin for breathing room */
.woocommerce div.product .woocommerce-tabs {
	margin-top: var(--wp--preset--spacing--70);
}

.woocommerce div.product .woocommerce-tabs ul.tabs {
	padding: 0;
	margin: 0 0 0 -0.25rem;
	list-style: none;
	display: flex;
	gap: 0;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
	margin: 0;
	padding: 0.75rem 1.25rem;
	border: none;
	border-bottom: 3px solid transparent;
	background: transparent;
	font-size: var(--cclee-font-md);
	font-weight: 500;
	color: var(--wp--preset--color--neutral-500);
	transition: color 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	text-decoration: none;
	color: inherit;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li:hover {
	color: var(--wp--preset--color--secondary);
	background: var(--wp--preset--color--neutral-50);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active {
	border-bottom: 3px solid var(--wp--preset--color--primary);
	color: var(--wp--preset--color--primary);
	font-weight: 600;
}

/* Tab panel — subtle background to separate from product area */
.woocommerce div.product .woocommerce-tabs .woocommerce-Tabs-panel,
.woocommerce div.product .woocommerce-tabs panel {
	padding: var(--wp--preset--spacing--50);
	background: var(--wp--preset--color--neutral-50);
	border-radius: var(--wp--custom--border--radius--md);
	margin-top: var(--wp--preset--spacing--30);
}

/* Additional information table */
.woocommerce div.product .woocommerce-tabs table.shop_attributes {
	width: 100%;
	border-collapse: collapse;
}

.woocommerce div.product .woocommerce-tabs table.shop_attributes th {
	text-align: left;
	padding: 0.75rem 1rem;
	font-weight: 600;
	color: var(--wp--preset--color--primary);
	background: var(--wp--preset--color--neutral-100);
	width: 30%;
	font-size: var(--cclee-font-sm);
	letter-spacing: 0.01em;
}

.woocommerce div.product .woocommerce-tabs table.shop_attributes td {
	padding: 0.75rem 1rem;
	color: var(--wp--preset--color--neutral-700);
	font-size: var(--cclee-font-sm);
}

.woocommerce div.product .woocommerce-tabs table.shop_attributes tr {
	border-bottom: 1px solid var(--wp--preset--color--neutral-200);
}

.woocommerce div.product .woocommerce-tabs table.shop_attributes tr:last-child {
	border-bottom: none;
}

.woocommerce div.product .woocommerce-tabs table.shop_attributes th,
.woocommerce div.product .woocommerce-tabs table.shop_attributes td {
	border: none;
}

/* Reviews tab */
.woocommerce div.product .woocommerce-tabs #reviews h2 {
	font-size: var(--cclee-font-lg);
	font-weight: 600;
	color: var(--wp--preset--color--primary);
	margin-bottom: var(--wp--preset--spacing--30);
}

/* Submitted review list */
.woocommerce div.product .woocommerce-tabs #reviews ol.commentlist {
	list-style: none;
	padding: 0;
	margin: 0 0 var(--wp--preset--spacing--40);
}

.woocommerce div.product .woocommerce-tabs #reviews ol.commentlist li {
	margin: 0;
	padding: 0;
	border-bottom: 1px solid var(--wp--preset--color--neutral-200);
}

.woocommerce div.product .woocommerce-tabs #reviews ol.commentlist li:last-child {
	border-bottom: none;
}

.woocommerce div.product .woocommerce-tabs #reviews .comment_container {
	display: flex;
	gap: 1rem;
	padding: var(--wp--preset--spacing--30) 0;
	align-items: flex-start;
}

.woocommerce div.product .woocommerce-tabs #reviews .avatar {
	border-radius: 50%;
	width: 48px;
	height: 48px;
	flex-shrink: 0;
	border: 2px solid var(--wp--preset--color--neutral-100);
}

.woocommerce div.product .woocommerce-tabs #reviews .comment-text {
	flex: 1;
	min-width: 0;
}

/* Star rating in submitted review */
.woocommerce div.product .woocommerce-tabs #reviews .star-rating {
	margin-bottom: 0.5rem;
	position: relative;
	overflow: hidden;
	width: 6em;
	height: 1.2em;
	font-size: 1rem;
	line-height: 1;
	font-family: inherit;
}

.woocommerce div.product .woocommerce-tabs #reviews .star-rating::before {
	content: "\2605\2605\2605\2605\2605";
	color: var(--wp--preset--color--neutral-200);
	position: absolute;
	top: 0;
	left: 0;
	letter-spacing: 0.05em;
}

.woocommerce div.product .woocommerce-tabs #reviews .star-rating span {
	overflow: hidden;
	position: absolute;
	top: 0;
	left: 0;
	height: 1.2em;
	padding-top: 1.5em;
}

.woocommerce div.product .woocommerce-tabs #reviews .star-rating span::before {
	content: "\2605\2605\2605\2605\2605";
	color: var(--wp--preset--color--accent);
	top: 0;
	position: absolute;
	left: 0;
	letter-spacing: 0.05em;
}

/* Review meta: author + date */
.woocommerce div.product .woocommerce-tabs #reviews .comment-text .meta {
	font-size: var(--cclee-font-sm);
	color: var(--wp--preset--color--neutral-500);
	margin-bottom: 0.5rem;
}

.woocommerce div.product .woocommerce-tabs #reviews .comment-text .meta .woocommerce-review__author {
	color: var(--wp--preset--color--primary);
	font-weight: 600;
	font-size: var(--cclee-font-md);
}

.woocommerce div.product .woocommerce-tabs #reviews .comment-text .meta .woocommerce-review__dash {
	margin: 0 0.375rem;
	color: var(--wp--preset--color--neutral-300);
}

.woocommerce div.product .woocommerce-tabs #reviews .comment-text .meta time {
	color: var(--wp--preset--color--neutral-400);
}

/* Review content */
.woocommerce div.product .woocommerce-tabs #reviews .comment-text .description {
	font-size: var(--cclee-font-sm);
	color: var(--wp--preset--color--neutral-700);
	line-height: 1.6;
}

.woocommerce div.product .woocommerce-tabs #reviews .comment-text .description p {
	margin: 0;
}

/* Separator between review list and form */
.woocommerce div.product .woocommerce-tabs #reviews #review_form_wrapper {
	border-top: 1px solid var(--wp--preset--color--neutral-200);
	padding-top: var(--wp--preset--spacing--40);
	margin-top: var(--wp--preset--spacing--20);
}

.woocommerce div.product .woocommerce-tabs #reviews .comment-respond .comment-reply-title {
	font-size: var(--cclee-font-md);
	font-weight: 600;
	color: var(--wp--preset--color--primary);
	margin-bottom: var(--wp--preset--spacing--20);
	display: block;
}

/* Star rating selector */
.woocommerce div.product .woocommerce-tabs .comment-form-rating {
	margin-bottom: var(--wp--preset--spacing--30);
}

.woocommerce div.product .woocommerce-tabs .comment-form-rating label {
	display: block;
	font-weight: 500;
	color: var(--wp--preset--color--neutral-700);
	margin-bottom: 0.5rem;
	font-size: var(--cclee-font-sm);
}

.woocommerce div.product .woocommerce-tabs .comment-form-rating p.stars {
	display: flex;
	gap: 0.25rem;
	position: relative;
}

.woocommerce div.product .woocommerce-tabs .comment-form-rating p.stars span {
	display: flex;
	gap: 0.25rem;
}

.woocommerce div.product .woocommerce-tabs .comment-form-rating p.stars a {
	text-decoration: none;
	overflow: hidden;
	text-indent: -999em;
	position: relative;
	width: 36px;
	height: 36px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: color 0.15s ease;
}

.woocommerce div.product .woocommerce-tabs .comment-form-rating p.stars a::before {
	content: "\2605";
	font-family: inherit;
	text-indent: 0;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	font-size: 1.25rem;
	color: var(--wp--preset--color--neutral-300);
	transition: color 0.15s ease;
}

.woocommerce div.product .woocommerce-tabs .comment-form-rating p.stars a:hover::before,
.woocommerce div.product .woocommerce-tabs .comment-form-rating p.stars a.active::before {
	color: var(--wp--preset--color--accent);
}

/* Highlight all stars up to hovered/active using :has() */
.woocommerce div.product .woocommerce-tabs .comment-form-rating p.stars span:has(a.star-2:hover) a.star-1::before,
.woocommerce div.product .woocommerce-tabs .comment-form-rating p.stars span:has(a.star-3:hover) a.star-1::before,
.woocommerce div.product .woocommerce-tabs .comment-form-rating p.stars span:has(a.star-3:hover) a.star-2::before,
.woocommerce div.product .woocommerce-tabs .comment-form-rating p.stars span:has(a.star-4:hover) a.star-1::before,
.woocommerce div.product .woocommerce-tabs .comment-form-rating p.stars span:has(a.star-4:hover) a.star-2::before,
.woocommerce div.product .woocommerce-tabs .comment-form-rating p.stars span:has(a.star-4:hover) a.star-3::before,
.woocommerce div.product .woocommerce-tabs .comment-form-rating p.stars span:has(a.star-5:hover) a.star-1::before,
.woocommerce div.product .woocommerce-tabs .comment-form-rating p.stars span:has(a.star-5:hover) a.star-2::before,
.woocommerce div.product .woocommerce-tabs .comment-form-rating p.stars span:has(a.star-5:hover) a.star-3::before,
.woocommerce div.product .woocommerce-tabs .comment-form-rating p.stars span:has(a.star-5:hover) a.star-4::before,
.woocommerce div.product .woocommerce-tabs .comment-form-rating p.stars span:has(a.star-2.active) a.star-1::before,
.woocommerce div.product .woocommerce-tabs .comment-form-rating p.stars span:has(a.star-3.active) a.star-1::before,
.woocommerce div.product .woocommerce-tabs .comment-form-rating p.stars span:has(a.star-3.active) a.star-2::before,
.woocommerce div.product .woocommerce-tabs .comment-form-rating p.stars span:has(a.star-4.active) a.star-1::before,
.woocommerce div.product .woocommerce-tabs .comment-form-rating p.stars span:has(a.star-4.active) a.star-2::before,
.woocommerce div.product .woocommerce-tabs .comment-form-rating p.stars span:has(a.star-4.active) a.star-3::before,
.woocommerce div.product .woocommerce-tabs .comment-form-rating p.stars span:has(a.star-5.active) a.star-1::before,
.woocommerce div.product .woocommerce-tabs .comment-form-rating p.stars span:has(a.star-5.active) a.star-2::before,
.woocommerce div.product .woocommerce-tabs .comment-form-rating p.stars span:has(a.star-5.active) a.star-3::before,
.woocommerce div.product .woocommerce-tabs .comment-form-rating p.stars span:has(a.star-5.active) a.star-4::before {
	color: var(--wp--preset--color--accent);
}

/* Review form fields */
.woocommerce div.product .woocommerce-tabs #review_form .comment-form-comment textarea,
.woocommerce div.product .woocommerce-tabs #review_form .comment-form-author input,
.woocommerce div.product .woocommerce-tabs #review_form .comment-form-email input {
	width: 100%;
	padding: 0.75rem 1rem;
	border: 1px solid var(--wp--preset--color--neutral-200);
	border-radius: var(--wp--custom--border--radius--sm);
	background: var(--wp--preset--color--base);
	font-size: var(--cclee-font-sm);
	color: var(--wp--preset--color--primary);
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.woocommerce div.product .woocommerce-tabs #review_form .comment-form-comment textarea:focus,
.woocommerce div.product .woocommerce-tabs #review_form .comment-form-author input:focus,
.woocommerce div.product .woocommerce-tabs #review_form .comment-form-email input:focus {
	outline: none;
	border-color: var(--wp--preset--color--primary);
	box-shadow: 0 0 0 2px rgba(15, 23, 42, 0.08);
}

.woocommerce div.product .woocommerce-tabs #review_form .comment-form-comment textarea {
	min-height: 120px;
	resize: vertical;
}

.woocommerce div.product .woocommerce-tabs #review_form label {
	display: block;
	font-weight: 500;
	color: var(--wp--preset--color--neutral-700);
	margin-bottom: 0.375rem;
	font-size: var(--cclee-font-sm);
}

.woocommerce div.product .woocommerce-tabs #review_form .comment-form-author,
.woocommerce div.product .woocommerce-tabs #review_form .comment-form-email {
	margin-bottom: var(--wp--preset--spacing--20);
}

/* Review submit button */
.woocommerce div.product .woocommerce-tabs #review_form .form-submit .submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.75rem 2rem;
	background: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--base);
	border: none;
	border-radius: var(--wp--custom--border--radius--sm);
	font-size: var(--cclee-font-sm);
	font-weight: 600;
	cursor: pointer;
	transition: background 0.2s ease, transform 0.15s ease;
	text-decoration: none;
}

.woocommerce div.product .woocommerce-tabs #review_form .form-submit .submit:hover {
	background: var(--wp--preset--color--neutral-800);
	transform: translateY(-1px);
}

/* "No reviews" text */
.woocommerce div.product .woocommerce-tabs .woocommerce-noreviews {
	color: var(--wp--preset--color--neutral-500);
	font-size: var(--cclee-font-sm);
	padding: var(--wp--preset--spacing--20) 0;
}

/* Related Products — B2B premium card treatment */
.woocommerce .related.products {
	margin-top: var(--wp--preset--spacing--70);
	padding: var(--wp--preset--spacing--60) 0;
	background: var(--wp--preset--color--neutral-50);
	border-radius: var(--wp--custom--border--radius--lg);
}

.woocommerce .related.products ul.products {
	grid-template-columns: repeat(4, 1fr);
	gap: var(--wp--preset--spacing--50);
	align-items: stretch;
}

/* WooCommerce ::before/::after pseudo-elements become grid items — hide them */
.woocommerce .related.products ul.products::before,
.woocommerce .related.products ul.products::after {
	display: none;
}

.woocommerce .related.products ul.products li.product {
	background: var(--wp--preset--color--base);
	border: 1px solid var(--wp--preset--color--neutral-100);
	border-radius: var(--wp--custom--border--radius--md);
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
	transition: box-shadow 0.3s cubic-bezier(0.4, 0, 0.2, 1), transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
	display: flex;
	flex-direction: column;
}

/* Link area: flex grow + positioning context for sale badge */
.woocommerce .related.products ul.products li.product a.woocommerce-LoopProduct-link {
	flex: 1 0 auto;
	position: relative;
}

/* Equalize product images: 1:1 square + object-fit */
.woocommerce .related.products ul.products li.product img {
	width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: cover;
}

/* Sale badge: top-right inside image area */
.woocommerce .related.products ul.products li.product .onsale {
	position: absolute;
	top: 8px;
	right: 8px;
	z-index: 2;
	font-size: 0.6875rem;
	padding: 2px 8px;
	border-radius: var(--wp--custom--border--radius--sm);
	line-height: 1.4;
}

.woocommerce .related.products ul.products li.product:hover {
	box-shadow: 0 12px 32px rgba(0, 0, 0, 0.1);
	transform: translateY(-4px);
}

/* Related products — B2B: hide buttons, card click is sufficient */
.woocommerce .related.products ul.products li.product .button,
.woocommerce .related.products ul.products li.product .wp-element-button,
.woocommerce .related.products ul.products li.product a.button {
	display: none;
}

/* Hide price in related products — B2B: contact for pricing */
.woocommerce .related.products ul.products li.product .price {
	display: none;
}

/* Product title in related — left-aligned, tighter spacing */
.woocommerce .related.products ul.products li.product h2,
.woocommerce .related.products ul.products li.product .woocommerce-loop-product__title {
	text-align: left;
	margin: var(--wp--preset--spacing--20) 0 var(--wp--preset--spacing--10);
}

@media (max-width: 768px) {
	/* Gallery: thumbnails horizontal below main image on mobile */
	.woocommerce div.product div.woocommerce-product-gallery {
		flex-direction: column;
		gap: var(--wp--preset--spacing--20);
	}

	.woocommerce div.product ol.flex-control-nav.flex-control-thumbs {
		flex-direction: row;
		order: 1;
		width: 100%;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		scroll-snap-type: x mandatory;
		scroll-padding-left: 0;
		gap: var(--wp--preset--spacing--15);
		padding-bottom: var(--wp--preset--spacing--10);
	}

	.woocommerce div.product ol.flex-control-nav.flex-control-thumbs li {
		flex-shrink: 0;
		scroll-snap-align: start;
	}

	.woocommerce div.product ol.flex-control-nav.flex-control-thumbs li img {
		width: 64px;
		height: 64px;
	}

	/* Variation select: larger touch target */
	.woocommerce div.product table.variations td.value select {
		min-height: 48px;
		padding: 0.875rem 2.5rem 0.875rem 1rem;
	}

	/* Quantity input: larger touch target */
	.woocommerce div.product .quantity .qty {
		height: 48px;
		width: 48px;
	}

	.woocommerce div.product .quantity::before,
	.woocommerce div.product .quantity::after {
		height: 48px;
		width: 44px;
	}

	/* Summary: reset padding */
	.woocommerce div.product div.summary {
		padding-left: 0;
		margin-top: var(--wp--preset--spacing--40);
	}

	/* Tabs: convert to accordion on mobile */
	.woocommerce div.product .woocommerce-tabs {
		margin-top: var(--wp--preset--spacing--50);
	}

	.woocommerce div.product .woocommerce-tabs ul.tabs {
		flex-direction: column;
		gap: 0;
	}

	.woocommerce div.product .woocommerce-tabs ul.tabs li {
		padding: var(--wp--preset--spacing--30) 0;
		border-bottom: 1px solid var(--wp--preset--color--neutral-200) !important;
		border-left: 3px solid transparent;
	}

	.woocommerce div.product .woocommerce-tabs ul.tabs li:hover {
		background: transparent;
	}

	.woocommerce div.product .woocommerce-tabs ul.tabs li.active {
		border-bottom: 1px solid var(--wp--preset--color--neutral-200) !important;
		border-left: 3px solid var(--wp--preset--color--primary);
		border-bottom-color: transparent;
		font-weight: 600;
	}

	/* Product meta: stack vertically on mobile */
	.woocommerce div.product .product_meta {
		flex-direction: column;
		gap: var(--wp--preset--spacing--10);
	}

	/* Additional info table: label above value on mobile */
	.woocommerce div.product .woocommerce-tabs table.shop_attributes th,
	.woocommerce div.product .woocommerce-tabs table.shop_attributes td {
		display: block;
		width: 100%;
		padding: 0.375rem 1rem;
	}

	.woocommerce div.product .woocommerce-tabs table.shop_attributes th {
		padding-bottom: 0;
	}
}

/* ========================================
   Toolbar Container
   ======================================== */

.cclee-toolbar {
	border-bottom: 1px solid var(--wp--preset--color--neutral-300);
	box-shadow: 0 1px 4px rgba(0, 0, 0, 0.05);
}

.cclee-toolbar > .alignwide {
	gap: var(--wp--preset--spacing--40);
	align-items: center;
}

/* ========================================
   View Toggle (Grid/List)
   ======================================== */

.cclee-view-toggle {
	display: flex;
	gap: var(--wp--preset--spacing--10);
}

.cclee-view-toggle__btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	border: 1px solid var(--wp--preset--color--neutral-200);
	border-radius: var(--wp--custom--border--radius--sm);
	background: var(--wp--preset--color--base);
	color: var(--wp--preset--color--neutral-400);
	cursor: pointer;
	transition: all 0.25s ease;
}

.cclee-view-toggle__btn:hover {
	border-color: var(--wp--preset--color--neutral-300);
	color: var(--wp--preset--color--primary);
}

.cclee-view-toggle__btn.is-active {
	background: var(--wp--preset--color--primary);
	border-color: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--base);
	box-shadow: 0 2px 6px rgba(15, 23, 42, 0.12);
}

.cclee-view-toggle__btn svg {
	width: 18px;
	height: 18px;
}

/* Products Wrapper Views */
.cclee-products-wrapper {
	max-width: 1320px;
	margin-left: auto;
	margin-right: auto;
}
/* List view — premium B2B catalog style */

.cclee-products-wrapper.is-view-list .wp-block-post-template {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--70);
}

.cclee-products-wrapper.is-view-list .wp-block-post-template.is-flex-container.columns-4 > li {
	width: 100%;
}

.cclee-products-wrapper.is-view-list .cclee-overflow-hidden {
	display: flex;
	flex-direction: row;
	align-items: center;
	text-align: left;
	gap: var(--wp--preset--spacing--40);
	padding: var(--wp--preset--spacing--50) !important;
}

/* Image area: 280x280 square, cover crop */
.cclee-products-wrapper.is-view-list .cclee-product-card__image {
	flex-shrink: 0;
	width: 280px;
	min-height: 280px;
	aspect-ratio: 1;
	overflow: hidden;
}

.cclee-products-wrapper.is-view-list .cclee-product-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* Content area: generous padding, flex column for zone split */
.cclee-products-wrapper.is-view-list .cclee-product-card > .wp-block-group:not(.cclee-product-card__image) {
	flex: 1;
	min-width: 0;
	padding: var(--wp--preset--spacing--60) !important;
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--20);
}

/* Product card title: 2-line clamp for consistent card height */
.cclee-products-wrapper .wp-block-post-template .wp-block-post-title {
	display: -webkit-box;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	line-height: 1.4;
}

.cclee-products-wrapper.is-view-list .wp-block-post-template .wp-block-post-title {
	margin-top: 0;
	font-size: var(--cclee-font-lg);
	-webkit-line-clamp: unset;
	line-clamp: unset;
	overflow: visible;
}

/* Bottom zone divider: border-top on SKU, pushed to bottom via margin-top: auto */
.cclee-products-wrapper.is-view-list .cclee-product-card .wc-block-components-product-sku,
.cclee-products-wrapper.is-view-list .cclee-product-card .wp-block-woocommerce-product-sku {
	margin-top: auto;
	padding-top: var(--wp--preset--spacing--40);
	border-top: 1px solid var(--wp--preset--color--neutral-100);
}

/* Excerpt: limit to 2 lines, comfortable line height */
.cclee-products-wrapper.is-view-list .cclee-product-card .wp-block-post-excerpt__excerpt {
	display: -webkit-box;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	line-height: 1.6;
}

/* Actions row: price left, button right */
.cclee-products-wrapper.is-view-list .cclee-product-card__actions {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.cclee-products-wrapper.is-view-list .cclee-product-card__actions .wp-block-woocommerce-product-button {
	text-align: right !important;
}

/* Ghost button in list view — less visual weight */
.cclee-products-wrapper.is-view-list .cclee-product-card .wp-block-woocommerce-product-button .wp-block-button__link,
.cclee-products-wrapper.is-view-list .cclee-product-card .wp-block-woocommerce-product-button .wp-element-button {
	background: transparent !important;
	border: 1.5px solid var(--wp--preset--color--primary) !important;
	color: var(--wp--preset--color--primary) !important;
	box-shadow: none !important;
	min-height: 38px;
	font-weight: 500;
	transition: all 0.25s ease;
}

.cclee-products-wrapper.is-view-list .cclee-product-card .wp-block-woocommerce-product-button .wp-block-button__link:hover,
.cclee-products-wrapper.is-view-list .cclee-product-card .wp-block-woocommerce-product-button .wp-element-button:hover {
	background: var(--wp--preset--color--primary) !important;
	color: var(--wp--preset--color--base) !important;
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(15, 23, 42, 0.12) !important;
}

@media (max-width: 768px) {
	.cclee-view-toggle {
		display: none; /* Hide toggle on mobile, always show grid */
	}

	.cclee-compare-table {
		display: block;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
	}
}

/* ========================================
   Filter Toggle Button
   ======================================== */

.cclee-filter-toggle {
	display: inline-flex;
	cursor: pointer;
}

.cclee-filter-toggle__input {
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
	pointer-events: none;
}

.cclee-filter-toggle__btn {
	display: inline-flex;
	align-items: center;
	gap: var(--wp--preset--spacing--20);
	padding: 10px 22px;
	border: 1px solid var(--wp--preset--color--neutral-200);
	border-radius: 100px;
	background: var(--wp--preset--color--base);
	color: var(--wp--preset--color--neutral-600);
	font-size: var(--cclee-font-sm);
	font-weight: 500;
	transition: all 0.25s ease;
}

.cclee-filter-toggle__btn:hover {
	border-color: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--primary);
	box-shadow: 0 2px 8px rgba(15, 23, 42, 0.06);
}

.cclee-filter-toggle__btn svg {
	width: 16px;
	height: 16px;
}

.cclee-filter-toggle__btn .cclee-icon-chevron-down {
	transition: transform 0.25s ease;
}

/* Expanded state */
.cclee-filter-toggle__input:checked ~ .cclee-filter-toggle__btn {
	background: var(--wp--preset--color--primary);
	border-color: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--base);
	box-shadow: 0 2px 8px rgba(15, 23, 42, 0.12);
}

.cclee-filter-toggle__input:checked ~ .cclee-filter-toggle__btn .cclee-icon-chevron-down {
	transform: rotate(180deg);
}

/* ========================================
   Filter Panel (expandable)
   ======================================== */

.cclee-filter-panel {
	max-height: 0;
	overflow: hidden;
	opacity: 0;
	margin-top: 0;
	gap: var(--wp--preset--spacing--30);
	transition:
		max-height 0.4s cubic-bezier(0.4, 0, 0.2, 1),
		opacity 0.3s ease,
		margin-top 0.3s ease;
}

/* Use :has() for checkbox -> panel relationship */
.wp-block-group:has(.cclee-filter-toggle__input:checked) .cclee-filter-panel {
	max-height: 600px;
	opacity: 1;
	margin-top: var(--wp--preset--spacing--50);
	overflow: visible;
}

/* Individual filter items */
.cclee-filter-panel__item {
	min-width: 180px;
	flex: 1;
	background: var(--wp--preset--color--neutral-50);
	border: 1px solid var(--wp--preset--color--neutral-100);
	border-radius: var(--wp--custom--border--radius--md);
	padding: var(--wp--preset--spacing--40) !important;
}

.cclee-filter-panel__item > p {
	margin-top: 0;
	margin-bottom: var(--wp--preset--spacing--20);
}

/* Category list as horizontal pill tags */
.cclee-filter-panel .wp-block-woocommerce-product-categories {
	margin: 0;
}

.cclee-filter-panel .wc-block-product-categories-list--depth-0 {
	display: flex;
	flex-wrap: wrap;
	gap: var(--wp--preset--spacing--20);
	list-style: none;
	padding: 0;
	margin: 0;
}

.cclee-filter-panel .wc-block-product-categories-list--depth-0 > li {
	margin: 0;
	display: flex;
	align-items: center;
	gap: var(--wp--preset--spacing--10);
}

.cclee-filter-panel .wc-block-product-categories-list-item > a {
	display: inline-flex;
	align-items: center;
	font-size: var(--cclee-font-sm);
	color: var(--wp--preset--color--neutral-700);
	text-decoration: none;
	padding: var(--wp--preset--spacing--10) var(--wp--preset--spacing--30);
	border: 1px solid var(--wp--preset--color--neutral-200);
	border-radius: var(--wp--custom--border--radius--full);
	transition: all var(--wp--custom--transition--fast);
	line-height: 1.4;
}

.cclee-filter-panel .wc-block-product-categories-list-item > a:hover {
	color: var(--wp--preset--color--primary);
	border-color: var(--wp--preset--color--primary);
	background: rgba(15, 23, 42, 0.04);
}

/* Count badge next to tag */
.cclee-filter-panel .wc-block-product-categories-list-item-count {
	font-size: var(--cclee-font-sm);
	color: var(--wp--preset--color--neutral-400);
}

/* Hide sub-categories to keep tags flat */
.cclee-filter-panel .wc-block-product-categories-list--depth-1 {
	display: none;
}

/* ========================================
   Product Search (pill-shaped, unified)
   ======================================== */

.cclee-toolbar .wp-block-woocommerce-product-search .wc-block-product-search__label {
	position: absolute;
	width: 1px;
	height: 1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
}

.cclee-toolbar .wp-block-woocommerce-product-search .wc-block-product-search__fields {
	display: flex;
	gap: 0;
	border: 1px solid var(--wp--preset--color--neutral-200);
	border-radius: 100px;
	overflow: hidden;
	background: var(--wp--preset--color--neutral-50);
	transition: all 0.25s ease;
}

.cclee-toolbar .wp-block-woocommerce-product-search .wc-block-product-search__fields:focus-within {
	border-color: var(--wp--preset--color--primary);
	box-shadow: 0 0 0 3px rgba(15, 23, 42, 0.06);
	background: var(--wp--preset--color--base);
}

.cclee-toolbar .wp-block-woocommerce-product-search .wc-block-product-search__field {
	padding: 10px 20px;
	border: none;
	font-size: var(--cclee-font-sm);
	background: transparent;
	min-width: 240px;
	color: var(--wp--preset--color--neutral-700);
	flex-grow: 1;
}

.cclee-toolbar .wp-block-woocommerce-product-search .wc-block-product-search__field::placeholder {
	color: var(--wp--preset--color--neutral-400);
}

.cclee-toolbar .wp-block-woocommerce-product-search .wc-block-product-search__field:focus {
	outline: none;
	box-shadow: none;
}

.cclee-toolbar .wp-block-woocommerce-product-search .wc-block-product-search__button {
	padding: 10px 16px;
	border: none;
	background: transparent;
	color: var(--wp--preset--color--neutral-500);
	cursor: pointer;
	display: flex;
	align-items: center;
	margin: 0;
	transition: all 0.25s ease;
}

.cclee-toolbar .wp-block-woocommerce-product-search .wc-block-product-search__button:hover {
	background: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--base);
	border-radius: 0 100px 100px 0;
}

/* Result count - subtle secondary text */
.cclee-toolbar .woocommerce-result-count {
	color: var(--wp--preset--color--neutral-400);
	font-size: var(--cclee-font-sm);
}

/* ========================================
   Sort Dropdown
   ======================================== */

.cclee-toolbar select.orderby {
	padding: 9px 28px 9px 12px;
	border: 1px solid var(--wp--preset--color--neutral-200);
	border-radius: var(--wp--custom--border--radius--sm);
	background: var(--wp--preset--color--base);
	color: var(--wp--preset--color--neutral-600);
	font-size: var(--cclee-font-sm);
	appearance: none;
	-webkit-appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%2378716c' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 4.5L6 7.5L9 4.5'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 8px center;
	cursor: pointer;
	transition: all 0.25s ease;
}

.cclee-toolbar select.orderby:focus {
	outline: none;
	border-color: var(--wp--preset--color--primary);
	box-shadow: 0 0 0 3px rgba(15, 23, 42, 0.06);
}

/* ========================================
   Filter Bar Mobile
   ======================================== */

@media (max-width: 768px) {
	.cclee-filter-panel {
		flex-direction: column;
	}

	.cclee-filter-panel__item {
		min-width: 100%;
	}

	.wp-block-woocommerce-product-search .wc-block-product-search__field {
		min-width: 140px;
	}
}

/* ========================================
   Breadcrumb — enhanced visibility
   ======================================== */

.woocommerce-breadcrumb,
.wp-block-woocommerce-breadcrumbs {
	font-size: var(--cclee-font-sm);
	color: var(--wp--preset--color--secondary);
	margin-bottom: var(--wp--preset--spacing--40);
}

.woocommerce-breadcrumb a,
.wp-block-woocommerce-breadcrumbs a {
	color: var(--wp--preset--color--neutral-500);
	text-decoration: none;
	transition: color 0.15s ease;
}

.woocommerce-breadcrumb a:hover,
.wp-block-woocommerce-breadcrumbs a:hover {
	color: var(--wp--preset--color--primary);
	text-decoration: underline;
	text-underline-offset: 2px;
}

/* ========================================
   Product Card Enhancement
   ======================================== */

/* Image wrapper — positioned context for badge + hover */
.cclee-product-card__image {
	position: relative;
	overflow: hidden;
}

/* Category overlay on product image */
.cclee-product-card__image .wp-block-post-terms {
	position: absolute;
	bottom: 12px;
	left: 12px;
	z-index: 2;
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin: 0;
}

.cclee-product-card__image .wp-block-post-terms a {
	display: inline-block;
	padding: 3px 10px;
	background: rgba(15, 23, 42, 0.75);
	color: var(--wp--preset--color--base);
	font-size: 0.6875rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	text-decoration: none;
	border-radius: var(--wp--custom--border--radius--sm);
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	transition: background 0.2s ease;
}

.cclee-product-card__image .wp-block-post-terms a:hover {
	background: rgba(15, 23, 42, 0.95);
}

/* Category tag overlay on product image */
.cclee-product-card__image .wp-block-post-terms {
	position: absolute;
	bottom: 12px;
	left: 12px;
	z-index: 3;
}

.cclee-product-card__image .wp-block-post-terms a {
	display: inline-block;
	background: rgba(15, 23, 42, 0.7);
	color: var(--wp--preset--color--base);
	font-size: 0.6875rem;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	text-decoration: none;
	padding: 3px 10px;
	border-radius: var(--wp--custom--border--radius--sm);
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	transition: background 0.2s ease;
}

.cclee-product-card__image .wp-block-post-terms a:hover {
	background: rgba(15, 23, 42, 0.9);
}

.cclee-product-card__image > a {
	display: block;
	line-height: 0;
}

.cclee-product-card__image img {
	transition: transform 0.4s ease;
}

/* Sale Badge */
.cclee-sale-badge {
	position: absolute;
	top: 12px;
	left: 12px;
	z-index: 2;
	background: var(--wp--preset--color--accent);
	color: var(--wp--preset--color--base);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	padding: 4px 12px;
	border-radius: var(--wp--custom--border--radius--sm);
	box-shadow: 0 2px 8px rgba(245, 158, 11, 0.3);
}

/* Smooth scale on featured image hover */
.cclee-product-card:hover .cclee-product-card__image > a img {
	transform: scale(1.03);
}

/* Card hover lift */
.cclee-product-card {
	transition: box-shadow 0.3s ease, transform 0.3s ease;
}

.cclee-product-card:hover {
	box-shadow: 0 8px 30px rgba(0, 0, 0, 0.08);
	transform: translateY(-2px);
}

/* ========================================
   Product Card — Equal Height & Button Align
   ======================================== */

/* Grid rows stretch to equal height */
.is-view-grid .wp-block-post-template.is-flex-container {
	align-items: stretch;
}

/* Card: flex column so content can push button to bottom */
.is-view-grid .cclee-product-card {
	display: flex;
	flex-direction: column;
	height: 100%;
}

/* Image: natural height, don't stretch */
.is-view-grid .cclee-product-card__image {
	flex-shrink: 0;
}

/* Content area: fill remaining space, own flex column */
.is-view-grid .cclee-product-card > .wp-block-group:not(.cclee-product-card__image) {
	flex: 1;
	display: flex;
	flex-direction: column;
}

/* Actions wrapper: push to bottom of card content */
.is-view-grid .cclee-product-card__actions {
	margin-top: auto;
}

/* ========================================
   Product Card — Excerpt
   ======================================== */

.cclee-product-card .wp-block-post-excerpt {
	margin: 0;
}

.cclee-product-card .wp-block-post-excerpt__excerpt {
	margin: 0;
	line-height: 1.5;
}

.cclee-product-card .wp-block-post-excerpt__more-link {
	display: none;
}

/* ========================================
   Product Card — SKU
   ======================================== */

.cclee-product-card .wp-block-woocommerce-product-sku,
.cclee-product-card .wc-block-components-product-sku {
	font-size: var(--cclee-font-sm);
	color: var(--wp--preset--color--neutral-400);
}

/* ========================================
   Category Description (hero)
   ======================================== */

.wp-block-woocommerce-category-description {
	max-width: 600px;
	margin-left: auto;
	margin-right: auto;
}

/* ========================================
   Mobile
   ======================================== */

@media (max-width: 768px) {
	.cclee-breadcrumb-bar {
		display: none;
	}

	.cclee-product-card__image img {
		height: auto;
	}

	.cclee-sale-badge {
		font-size: var(--cclee-font-sm);
		padding: 4px 10px;
	}
}
