/* ==========================================================================
   OZeAuto — WooCommerce Stylesheet
   Custom styles replacing default WooCommerce CSS.
   Version: 1.0.0
   ========================================================================== */


/* ==========================================================================
   1. Product Grid — Archive / Shop
   ========================================================================== */

.woocommerce ul.products,
ul.products {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-5);
	list-style: none;
	padding: 0;
	margin: 0;
}

/* Product card — li.product-card */
.woocommerce ul.products li.product,
ul.products li.product,
li.product-card {
	position: relative;
	background-color: var(--color-white);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-sm);
	overflow: hidden;
	transition: box-shadow var(--transition-base),
	            transform var(--transition-base);
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
}

.woocommerce ul.products li.product:hover,
li.product-card:hover {
	box-shadow: var(--shadow-lg);
	transform: translateY(-2px);
}

/* Product card link — wrapping anchor */
.product-card-link {
	display: block;
	text-decoration: none;
	color: inherit;
	flex-grow: 1;
	display: flex;
	flex-direction: column;
}

.product-card-link:hover {
	color: inherit;
}

/* Product card badges — absolute positioned container */
.product-card-badges {
	position: absolute;
	top: var(--space-3);
	left: var(--space-3);
	z-index: 2;
	display: flex;
	flex-direction: column;
	gap: var(--space-1);
}

/* Badge pill styles */
.woocommerce ul.products li.product .onsale,
.woocommerce span.onsale,
.product-badge {
	display: inline-block;
	padding: var(--space-1) var(--space-3);
	font-size: var(--font-size-xs);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	border-radius: var(--radius-full);
	line-height: 1.4;
	white-space: nowrap;
}

.woocommerce ul.products li.product .onsale,
.woocommerce span.onsale,
.product-badge--sale {
	background-color: var(--color-error);
	color: var(--color-white);
}

.product-badge--new {
	background-color: var(--color-primary);
	color: var(--color-white);
}

.product-badge--bestseller,
.product-badge--best-seller {
	background-color: var(--color-accent);
	color: var(--color-text);
}

/* Product card image — square container */
.product-card-image {
	position: relative;
	overflow: hidden;
	aspect-ratio: 1 / 1;
	background-color: var(--color-bg-alt);
}

.product-card-image img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	padding: var(--space-3);
	display: block;
	transition: transform var(--transition-slow);
}

li.product-card:hover .product-card-image img {
	transform: scale(1.04);
}

/* Legacy image wrapper fallback */
.woocommerce ul.products li.product a img,
ul.products li.product .product-image-wrapper img {
	width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	display: block;
	transition: transform var(--transition-slow);
}

.woocommerce ul.products li.product:hover a img {
	transform: scale(1.04);
}

.product-image-wrapper {
	position: relative;
	overflow: hidden;
	aspect-ratio: 1 / 1;
}

/* Product card info — content area */
.product-card-info {
	padding: var(--space-4);
	display: flex;
	flex-direction: column;
	flex-grow: 1;
	gap: var(--space-1);
}

/* Legacy .product-info fallback */
.woocommerce ul.products li.product .product-info,
.product-info {
	padding: var(--space-4);
	display: flex;
	flex-direction: column;
	flex-grow: 1;
}

/* Product card brand — muted uppercase label */
.product-card-brand {
	font-size: var(--font-size-xs);
	color: var(--color-text-muted);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	order: -1;
}

.product-brand {
	font-size: var(--font-size-xs);
	color: var(--color-text-muted);
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.3px;
	margin-bottom: var(--space-2);
}

/* Product title */
.product-card-info .woocommerce-loop-product__title,
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce-loop-product__title {
	font-size: var(--font-size-sm);
	font-weight: 600;
	color: var(--color-text);
	line-height: var(--line-height-tight);
	margin-bottom: var(--space-1);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* Product card price */
.product-card-price {
	margin-top: auto;
	font-size: var(--font-size-lg);
	font-weight: 700;
	color: var(--color-text);
	display: flex;
	align-items: baseline;
	gap: var(--space-2);
	flex-wrap: wrap;
}

.product-card-price ins {
	text-decoration: none;
	color: var(--color-error);
	font-weight: 700;
}

.product-card-price del {
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	font-weight: 400;
}

/* General price styling */
.woocommerce ul.products li.product .price,
.woocommerce .price {
	font-size: var(--font-size-lg);
	font-weight: 700;
	color: var(--color-text);
	margin-bottom: var(--space-3);
	display: flex;
	align-items: baseline;
	gap: var(--space-2);
	flex-wrap: wrap;
}

.woocommerce .price ins {
	text-decoration: none;
	color: var(--color-primary-dark);
	font-weight: 700;
}

.woocommerce .price del {
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	font-weight: 400;
}

.woocommerce .price .amount {
	/* inherits from parent */
}

/* Product card actions — add to cart area */
.product-card-actions {
	padding: 0 var(--space-4) var(--space-4);
	margin-top: auto;
}

.product-card-actions .btn-add-to-cart,
.product-card-actions .button,
.product-card-actions .add_to_cart_button {
	display: block;
	width: 100%;
	padding: var(--space-3) var(--space-4);
	background-color: var(--color-primary);
	color: var(--color-white);
	font-size: var(--font-size-sm);
	font-weight: 600;
	text-align: center;
	border: none;
	border-radius: var(--radius-md);
	cursor: pointer;
	transition: background-color var(--transition-fast),
	            box-shadow var(--transition-fast);
}

.product-card-actions .btn-add-to-cart:hover,
.product-card-actions .button:hover,
.product-card-actions .add_to_cart_button:hover {
	background-color: var(--color-primary-dark);
	color: var(--color-white);
	box-shadow: 0 4px 12px rgba(34, 197, 94, 0.3);
}

.product-card-actions .added_to_cart {
	display: block;
	text-align: center;
	font-size: var(--font-size-xs);
	color: var(--color-primary);
	font-weight: 600;
	margin-top: var(--space-2);
}

/* Star rating (display — used in reviews, product summary, etc.) */
.woocommerce .star-rating {
	position: relative;
	overflow: hidden;
	margin-bottom: var(--space-2);
	font-size: 0;
	height: 18px;
	width: 90px;
	line-height: 1;
}

.woocommerce .star-rating::before {
	content: '\2605\2605\2605\2605\2605';
	font-size: var(--font-size-sm);
	color: var(--color-border);
	position: absolute;
	top: 0;
	left: 0;
	letter-spacing: 2px;
}

.woocommerce .star-rating span {
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	overflow: hidden;
	font-size: 0;
}

.woocommerce .star-rating span::before {
	content: '\2605\2605\2605\2605\2605';
	font-size: var(--font-size-sm);
	color: var(--color-accent);
	position: absolute;
	top: 0;
	left: 0;
	letter-spacing: 2px;
}

/* Legacy add to cart button (grid) */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product .add_to_cart_button,
.woocommerce ul.products li.product .ajax_add_to_cart {
	display: block;
	width: 100%;
	padding: var(--space-3) var(--space-4);
	background-color: var(--color-primary);
	color: var(--color-white);
	font-size: var(--font-size-sm);
	font-weight: 600;
	text-align: center;
	border: none;
	border-radius: var(--radius-md);
	cursor: pointer;
	transition: background-color var(--transition-fast);
	margin-top: auto;
}

.woocommerce ul.products li.product .button:hover,
.woocommerce ul.products li.product .add_to_cart_button:hover {
	background-color: var(--color-primary-dark);
	color: var(--color-white);
}

/* "Added to cart" state */
.woocommerce ul.products li.product .added_to_cart {
	display: block;
	text-align: center;
	font-size: var(--font-size-xs);
	color: var(--color-primary);
	font-weight: 600;
	margin-top: var(--space-2);
}


/* ==========================================================================
   2. Single Product — Old-site-inspired layout
   ========================================================================== */

.single-product .product {
	padding: 0 0 var(--space-6);
}

/* --- Full-width product title header (dark strip) --- */
.product-title-header {
	background-color: var(--color-bg-alt);
	border-bottom: 3px solid var(--color-primary);
	padding: var(--space-4) 0;
	margin-bottom: var(--space-5);
}

.product-title-header__name {
	font-size: var(--font-size-xl);
	font-weight: 800;
	text-transform: uppercase;
	color: var(--color-dark);
	margin: 0;
	letter-spacing: 0.02em;
}

/* --- Two-column layout --- */
.single-product-top {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-5);
	margin-bottom: var(--space-6);
}

.single-product-tabs {
	margin-top: var(--space-4);
}

/* --- Gallery --- */
.woocommerce div.product div.images,
.single-product-gallery,
.product-gallery {
	position: relative;
	overflow: hidden;
}

.single-product-gallery .woocommerce-product-gallery {
	width: 100% !important;
	float: none !important;
}

.single-product-gallery .woocommerce-product-gallery__wrapper {
	margin: 0;
	padding: 0;
}

.single-product-gallery .woocommerce-product-gallery__image {
	overflow: hidden;
}

.woocommerce div.product div.images .woocommerce-product-gallery__image img,
.product-gallery__main img {
	width: 100%;
	height: auto;
	max-height: 600px;
	border-radius: var(--radius-md);
	object-fit: contain;
	background-color: var(--color-white);
	border: 1px solid var(--color-border);
	padding: var(--space-4);
}

.woocommerce div.product div.images .flex-viewport {
	max-height: 650px;
}

/* Thumbnails */
.single-product-gallery .flex-control-thumbs {
	display: flex !important;
	gap: var(--space-2);
	margin-top: var(--space-3);
	overflow-x: auto;
	list-style: none;
	padding: 0;
}

.single-product-gallery .flex-control-thumbs li {
	width: 72px !important;
	flex-shrink: 0;
}

.single-product-gallery .flex-control-thumbs li img {
	width: 72px;
	height: 72px;
	object-fit: cover;
	border-radius: var(--radius-sm);
	border: 2px solid var(--color-border);
	cursor: pointer;
	transition: border-color var(--transition-fast);
	opacity: 0.6;
}

.single-product-gallery .flex-control-thumbs li img:hover,
.single-product-gallery .flex-control-thumbs li img.flex-active {
	border-color: var(--color-error);
	opacity: 1;
}

/* --- Summary card (right column) --- */
.single-product-summary {
	background-color: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-5);
}

/* Hide the default WC title rendered by hooks (we show it in the header) */
.single-product-summary .product_title {
	display: none;
}

/* --- Description panel --- */
.sp-description-panel {
	margin-bottom: var(--space-4);
	padding-bottom: var(--space-4);
	border-bottom: 1px solid var(--color-border);
}

.sp-panel-heading {
	font-size: var(--font-size-base);
	font-weight: 600;
	color: var(--color-text);
	margin-bottom: var(--space-2);
	padding-bottom: var(--space-2);
	border-bottom: 3px solid var(--color-error);
	display: inline-block;
}

.sp-short-description {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	line-height: 1.7;
}

.sp-read-more {
	font-weight: 700;
	color: var(--color-error);
	margin-left: var(--space-1);
}

.sp-read-more:hover {
	text-decoration: underline;
}

/* --- Meta table (SKU, Categories, Brand, Weight) --- */
.sp-meta-table {
	margin-bottom: var(--space-4);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	overflow: hidden;
}

.sp-meta-row {
	display: flex;
	flex-wrap: wrap;
	border-bottom: 1px solid var(--color-border);
}

.sp-meta-row:last-child {
	border-bottom: none;
}

.sp-meta-cell {
	flex: 1;
	min-width: 50%;
	padding: var(--space-3) var(--space-4);
	font-size: var(--font-size-sm);
	display: flex;
	align-items: baseline;
	gap: var(--space-2);
	border-right: 1px solid var(--color-border);
}

.sp-meta-cell:last-child {
	border-right: none;
}

.sp-meta-label {
	color: var(--color-text-light);
	font-weight: 400;
	white-space: nowrap;
	flex-shrink: 0;
}

.sp-meta-value {
	color: var(--color-text);
	font-weight: 500;
}

.sp-meta-value a {
	color: var(--color-primary);
}

.sp-meta-value a:hover {
	text-decoration: underline;
}

/* --- Purchase area (Price / Quantity / Options row) --- */
.sp-purchase-area {
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	overflow: hidden;
	margin-bottom: var(--space-4);
}

.sp-purchase-header {
	display: flex;
	background-color: var(--color-bg-alt);
	border-bottom: 1px solid var(--color-border);
}

.sp-purchase-header .sp-purchase-label {
	flex: 1;
	padding: var(--space-2) var(--space-4);
	font-size: var(--font-size-sm);
	font-weight: 600;
	color: var(--color-text-light);
	text-transform: uppercase;
	letter-spacing: 0.3px;
	border-right: 1px solid var(--color-border);
}

.sp-purchase-header .sp-purchase-label:last-child {
	border-right: none;
}

.sp-purchase-row {
	display: flex;
	align-items: stretch;
}

.sp-purchase-price {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	padding: var(--space-3) var(--space-4);
	border-right: 1px solid var(--color-border);
}

.sp-purchase-price .price {
	font-size: var(--font-size-lg) !important;
	font-weight: 700;
	margin: 0 !important;
}

.sp-purchase-form {
	flex: 1;
	min-width: 0;
}

/* Override WC form.cart layout inside the purchase area */
.sp-purchase-form .woocommerce div.product form.cart,
.sp-purchase-form form.cart {
	display: flex;
	align-items: center;
	gap: var(--space-3);
	margin: 0;
	padding: var(--space-3) var(--space-4);
	flex-wrap: wrap;
}

/* Variations inside the purchase row */
.sp-purchase-form .variations {
	margin: 0 !important;
}

.sp-purchase-form .variations tr {
	display: flex;
	align-items: center;
	gap: var(--space-2);
}

.sp-purchase-form .variations th {
	padding: 0 !important;
}

.sp-purchase-form .variations th label {
	font-size: var(--font-size-xs) !important;
	white-space: nowrap;
}

.sp-purchase-form .variations td {
	padding: 0 !important;
}

.sp-purchase-form .variations td select {
	padding: var(--space-2) var(--space-3) !important;
	font-size: var(--font-size-sm) !important;
	min-width: 140px;
}

/* Quantity input */
.woocommerce .quantity {
	display: inline-flex;
	align-items: center;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	overflow: hidden;
}

.woocommerce .quantity .qty {
	width: 48px;
	height: 38px;
	text-align: center;
	border: none;
	font-size: var(--font-size-sm);
	font-weight: 600;
	-moz-appearance: textfield;
	appearance: textfield;
}

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

.quantity-btn {
	width: 32px;
	height: 38px;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: var(--color-bg-alt);
	color: var(--color-text);
	font-size: var(--font-size-base);
	cursor: pointer;
	border: none;
	transition: background-color var(--transition-fast);
}

.quantity-btn:hover {
	background-color: var(--color-border);
}

/* Add-to-cart button inside purchase area */
.sp-purchase-form .single_add_to_cart_button,
.woocommerce div.product form.cart .single_add_to_cart_button,
.single-product .btn-add-to-cart {
	padding: var(--space-2) var(--space-5);
	background-color: var(--color-bg-alt);
	color: var(--color-text);
	font-size: var(--font-size-sm);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	cursor: pointer;
	transition: background-color var(--transition-fast),
	            border-color var(--transition-fast),
	            color var(--transition-fast);
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
}

.sp-purchase-form .single_add_to_cart_button:hover,
.woocommerce div.product form.cart .single_add_to_cart_button:hover {
	background-color: var(--color-primary);
	border-color: var(--color-primary);
	color: var(--color-white);
}

/* --- Action row (rating) --- */
.sp-action-row {
	display: flex;
	align-items: center;
	gap: var(--space-4);
	margin-bottom: var(--space-4);
	padding-bottom: var(--space-4);
	border-bottom: 1px solid var(--color-border);
}

.sp-rating {
	display: flex;
	align-items: center;
	gap: var(--space-2);
}

/* Trust signals box */
.product-trust-signals {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-3);
	margin-top: var(--space-4);
	padding: var(--space-4);
	background-color: var(--color-bg-alt);
	border-radius: var(--radius-md);
	border: 1px solid var(--color-border);
}

.trust-signal-item {
	display: flex;
	align-items: center;
	gap: var(--space-2);
	font-size: var(--font-size-sm);
	color: var(--color-text);
}

.trust-signal-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	flex-shrink: 0;
	background-color: var(--color-primary);
	border-radius: var(--radius-full);
	color: var(--color-white);
}

.trust-signal-icon svg {
	width: 18px;
	height: 18px;
}

.trust-signal-text {
	font-weight: 600;
	line-height: 1.3;
}

.trust-signal-text small {
	display: block;
	font-weight: 400;
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
}

/* Hide the duplicate WC-generated meta (we render it in sp-meta-table) */
.woocommerce div.product .product_meta {
	display: none;
}

/* Tabs — Description, Additional Info, Reviews */
.woocommerce div.product .woocommerce-tabs {
	margin-top: var(--space-8);
}

.woocommerce div.product .woocommerce-tabs ul.tabs {
	display: flex;
	gap: 0;
	border-bottom: 2px solid var(--color-border);
	padding: 0;
	margin: 0 0 var(--space-5) 0;
	list-style: none;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
	margin: 0;
	padding: 0;
	border: none;
	background: none;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	display: block;
	padding: var(--space-3) var(--space-5);
	font-size: var(--font-size-sm);
	font-weight: 600;
	color: var(--color-text-light);
	border-bottom: 2px solid transparent;
	margin-bottom: -2px;
	transition: color var(--transition-fast),
	            border-color var(--transition-fast);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
	color: var(--color-text);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
	color: var(--color-primary);
	border-bottom-color: var(--color-primary);
}

.woocommerce div.product .woocommerce-tabs .panel {
	padding: var(--space-4) 0;
}

.woocommerce div.product .woocommerce-tabs .panel h2 {
	font-size: var(--font-size-lg);
	margin-bottom: var(--space-4);
}

/* ==========================================================================
   2b. Reviews — Star rating selector + form layout
   ========================================================================== */

/* Review section container */
#reviews {
	padding: var(--space-4) 0;
}

#reviews #comments {
	margin-bottom: var(--space-6);
}

#reviews .woocommerce-Reviews-title {
	font-size: var(--font-size-lg);
	font-weight: 700;
	margin-bottom: var(--space-4);
}

/* Existing review list */
#reviews .commentlist {
	list-style: none;
	padding: 0;
	margin: 0 0 var(--space-5) 0;
}

#reviews .commentlist .review {
	padding: var(--space-4);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	margin-bottom: var(--space-3);
	background-color: var(--color-white);
}

#reviews .commentlist .review .comment_container {
	display: flex;
	gap: var(--space-4);
}

#reviews .commentlist .review img.avatar {
	width: 48px;
	height: 48px;
	border-radius: var(--radius-full);
	flex-shrink: 0;
}

#reviews .commentlist .review .comment-text {
	flex: 1;
}

#reviews .commentlist .review .comment-text .star-rating {
	margin-bottom: var(--space-2);
}

#reviews .commentlist .review .meta {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	margin-bottom: var(--space-2);
}

#reviews .commentlist .review .meta strong {
	color: var(--color-text);
	font-weight: 600;
}

#reviews .commentlist .review .meta .woocommerce-review__awaiting-approval {
	color: var(--color-accent);
	font-style: italic;
}

#reviews .commentlist .review .description p {
	font-size: var(--font-size-sm);
	line-height: 1.6;
	margin: 0;
	color: var(--color-text);
}

/* Review form card */
#review_form_wrapper {
	background-color: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-5);
}

#review_form_wrapper #reply-title {
	font-size: var(--font-size-base);
	font-weight: 700;
	color: var(--color-text);
	margin-bottom: var(--space-4);
}

#review_form_wrapper .comment-notes {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	margin-bottom: var(--space-4);
}

/* ---- Star rating selector ---- */
.comment-form-rating label {
	display: block;
	font-size: var(--font-size-sm);
	font-weight: 600;
	color: var(--color-text);
	margin-bottom: var(--space-2);
}

p.stars {
	display: inline-flex;
	margin: 0 0 var(--space-4) 0;
	line-height: 1;
}

p.stars span {
	display: inline-flex;
	gap: 2px;
}

p.stars a {
	display: inline-block;
	width: 28px;
	height: 28px;
	text-indent: -9999px;
	overflow: hidden;
	position: relative;
	text-decoration: none;
}

p.stars a::before {
	content: '\2605';
	display: flex;
	align-items: center;
	justify-content: center;
	position: absolute;
	inset: 0;
	text-indent: 0;
	font-size: 24px;
	color: var(--color-border);
	transition: color 0.15s ease;
}

/* Hover state — fill stars up to hovered one */
p.stars:hover a::before {
	color: var(--color-accent);
}

p.stars a:hover ~ a::before {
	color: var(--color-border);
}

/* Selected state — fill stars up to selected one */
p.stars.selected a.active ~ a::before {
	color: var(--color-border);
}

p.stars.selected a::before {
	color: var(--color-accent);
}

/* ---- Review form fields ---- */
.comment-form label {
	display: block;
	font-size: var(--font-size-sm);
	font-weight: 500;
	color: var(--color-text);
	margin-bottom: var(--space-1);
}

.comment-form label .required {
	color: var(--color-error);
}

.comment-form .comment-form-comment {
	margin-bottom: var(--space-4);
}

.comment-form textarea {
	width: 100%;
	min-height: 140px;
	padding: var(--space-3);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	font-size: var(--font-size-sm);
	font-family: inherit;
	color: var(--color-text);
	background-color: var(--color-white);
	resize: vertical;
	transition: border-color var(--transition-fast),
	            box-shadow var(--transition-fast);
}

.comment-form textarea:focus {
	border-color: var(--color-primary);
	box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.15);
	outline: none;
}

/* Name + Email fields — side by side on tablet+ */
.comment-form .comment-form-author,
.comment-form .comment-form-email {
	margin-bottom: var(--space-4);
}

.comment-form .comment-form-author input,
.comment-form .comment-form-email input {
	width: 100%;
	padding: var(--space-3);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	font-size: var(--font-size-sm);
	font-family: inherit;
	color: var(--color-text);
	background-color: var(--color-white);
	transition: border-color var(--transition-fast),
	            box-shadow var(--transition-fast);
}

.comment-form .comment-form-author input:focus,
.comment-form .comment-form-email input:focus {
	border-color: var(--color-primary);
	box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.15);
	outline: none;
}

/* Cookies consent */
.comment-form .comment-form-cookies-consent {
	display: flex;
	align-items: center;
	gap: var(--space-2);
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	margin-bottom: var(--space-4);
}

.comment-form .comment-form-cookies-consent input[type="checkbox"] {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
	accent-color: var(--color-primary);
}

/* Submit button */
.comment-form .form-submit .submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: var(--space-3) var(--space-6);
	background-color: var(--color-primary);
	color: var(--color-white);
	font-size: var(--font-size-sm);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	border: none;
	border-radius: var(--radius-md);
	cursor: pointer;
	transition: background-color var(--transition-fast),
	            box-shadow var(--transition-fast);
}

.comment-form .form-submit .submit:hover {
	background-color: var(--color-primary-dark);
	box-shadow: 0 4px 12px rgba(34, 197, 94, 0.3);
}

/* Side-by-side name/email on tablet+ */
@media (min-width: 768px) {
	.comment-form {
		display: grid;
		grid-template-columns: 1fr 1fr;
		column-gap: var(--space-4);
	}

	.comment-form > * {
		grid-column: 1 / -1;
	}

	.comment-form .comment-form-author {
		grid-column: 1;
	}

	.comment-form .comment-form-email {
		grid-column: 2;
	}
}


/* Related & Upsell products */
.woocommerce .related.products,
.woocommerce .upsells.products {
	margin-top: var(--space-10);
	padding-top: var(--space-6);
	border-top: 1px solid var(--color-border);
}

.woocommerce .related.products h2,
.woocommerce .upsells.products h2 {
	font-size: var(--font-size-xl);
	margin-bottom: var(--space-5);
}


/* ==========================================================================
   3. Cart Page
   ========================================================================== */

.woocommerce-cart .woocommerce {
	padding: var(--space-6) 0;
}

.woocommerce table.shop_table {
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	overflow: hidden;
}

.woocommerce table.shop_table th {
	background-color: var(--color-bg-alt);
	padding: var(--space-3) var(--space-4);
	font-size: var(--font-size-sm);
	font-weight: 600;
	color: var(--color-text-light);
	text-transform: uppercase;
	letter-spacing: 0.3px;
	border-bottom: 1px solid var(--color-border);
	text-align: left;
}

.woocommerce table.shop_table td {
	padding: var(--space-4);
	border-bottom: 1px solid var(--color-border);
	vertical-align: middle;
	font-size: var(--font-size-sm);
}

.woocommerce table.shop_table tr:last-child td {
	border-bottom: none;
}

/* Cart product thumbnail */
.woocommerce table.shop_table .product-thumbnail img {
	width: 72px;
	height: 72px;
	object-fit: cover;
	border-radius: var(--radius-sm);
}

/* Cart product name */
.woocommerce table.shop_table .product-name a {
	font-weight: 600;
	color: var(--color-text);
}

.woocommerce table.shop_table .product-name a:hover {
	color: var(--color-primary);
}

/* Remove item button */
.woocommerce table.shop_table .product-remove a.remove {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border-radius: var(--radius-full);
	background-color: var(--color-bg-alt);
	color: var(--color-text-light);
	font-size: var(--font-size-lg);
	line-height: 1;
	transition: background-color var(--transition-fast),
	            color var(--transition-fast);
}

.woocommerce table.shop_table .product-remove a.remove:hover {
	background-color: var(--color-error);
	color: var(--color-white);
}

/* Cart actions (update / coupon) */
.woocommerce .cart-actions,
.woocommerce table.shop_table td.actions {
	padding: var(--space-4);
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
	align-items: center;
	justify-content: space-between;
}

.woocommerce .coupon {
	display: flex;
	gap: var(--space-2);
}

.woocommerce .coupon input[type="text"] {
	padding: var(--space-2) var(--space-3);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	font-size: var(--font-size-sm);
	min-width: 160px;
}

.woocommerce .coupon input[type="text"]:focus {
	border-color: var(--color-primary);
	outline: none;
	box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.15);
}

.woocommerce .coupon .button,
.woocommerce button[name="update_cart"] {
	padding: var(--space-2) var(--space-4);
	background-color: var(--color-bg-alt);
	color: var(--color-text);
	font-size: var(--font-size-sm);
	font-weight: 600;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	cursor: pointer;
	transition: background-color var(--transition-fast);
}

.woocommerce .coupon .button:hover,
.woocommerce button[name="update_cart"]:hover {
	background-color: var(--color-border);
}

/* Cart totals */
.woocommerce .cart_totals,
.cart-collaterals .cart_totals {
	background-color: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-5);
	margin-top: var(--space-5);
}

.woocommerce .cart_totals h2 {
	font-size: var(--font-size-lg);
	margin-bottom: var(--space-4);
}

.woocommerce .cart_totals table {
	border: none;
}

.woocommerce .cart_totals table th,
.woocommerce .cart_totals table td {
	padding: var(--space-3) 0;
	border-bottom: 1px solid var(--color-border);
	font-size: var(--font-size-sm);
}

.woocommerce .cart_totals table th {
	background: none;
	text-transform: none;
	font-weight: 600;
	color: var(--color-text);
}

.woocommerce .cart_totals .order-total th,
.woocommerce .cart_totals .order-total td {
	font-size: var(--font-size-lg);
	font-weight: 700;
	border-bottom: none;
}

/* Proceed to checkout */
.woocommerce .wc-proceed-to-checkout a.checkout-button,
.woocommerce a.checkout-button {
	display: block;
	width: 100%;
	padding: var(--space-4);
	background-color: var(--color-primary);
	color: var(--color-white);
	font-size: var(--font-size-base);
	font-weight: 700;
	text-align: center;
	border-radius: var(--radius-md);
	margin-top: var(--space-4);
	transition: background-color var(--transition-fast),
	            box-shadow var(--transition-fast);
}

.woocommerce .wc-proceed-to-checkout a.checkout-button:hover {
	background-color: var(--color-primary-dark);
	box-shadow: 0 4px 12px rgba(34, 197, 94, 0.3);
	color: var(--color-white);
}


/* ==========================================================================
   4. Checkout Page
   ========================================================================== */

.woocommerce-checkout .woocommerce {
	padding: var(--space-6) 0;
}

.woocommerce form.woocommerce-checkout {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-6);
}

/* Billing / Shipping fields */
.woocommerce-checkout .col2-set {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-5);
}

.woocommerce-checkout .col2-set h3 {
	font-size: var(--font-size-lg);
	margin-bottom: var(--space-4);
	padding-bottom: var(--space-3);
	border-bottom: 1px solid var(--color-border);
}

/* Form fields */
.woocommerce form .form-row {
	margin-bottom: var(--space-4);
}

.woocommerce form .form-row label {
	display: block;
	margin-bottom: var(--space-1);
	font-weight: 500;
	font-size: var(--font-size-sm);
	color: var(--color-text);
}

.woocommerce form .form-row label .required {
	color: var(--color-error);
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.woocommerce .select2-container--default .select2-selection--single {
	width: 100%;
	padding: 0.625rem 0.875rem;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	font-size: var(--font-size-base);
	color: var(--color-text);
	background-color: var(--color-white);
	transition: border-color var(--transition-fast),
	            box-shadow var(--transition-fast);
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
	border-color: var(--color-primary);
	box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.15);
	outline: none;
}

/* Order review / Payment */
.woocommerce-checkout #order_review_heading {
	font-size: var(--font-size-lg);
	margin-bottom: var(--space-4);
}

.woocommerce-checkout #order_review {
	background-color: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-5);
}

.woocommerce-checkout #order_review table {
	margin-bottom: var(--space-5);
}

.woocommerce-checkout #order_review table th,
.woocommerce-checkout #order_review table td {
	padding: var(--space-3) 0;
	border-bottom: 1px solid var(--color-border);
	font-size: var(--font-size-sm);
}

/* Payment methods */
.woocommerce #payment {
	border-radius: var(--radius-md);
	overflow: hidden;
}

.woocommerce #payment ul.payment_methods {
	list-style: none;
	padding: 0;
	margin: 0 0 var(--space-4) 0;
}

.woocommerce #payment ul.payment_methods li {
	padding: var(--space-4);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	margin-bottom: var(--space-2);
	cursor: pointer;
	transition: border-color var(--transition-fast);
}

.woocommerce #payment ul.payment_methods li:hover {
	border-color: var(--color-primary);
}

.woocommerce #payment ul.payment_methods li label {
	font-weight: 600;
	cursor: pointer;
	display: flex;
	align-items: center;
	gap: var(--space-2);
}

.woocommerce #payment ul.payment_methods li img {
	max-height: 24px;
	width: auto;
}

.woocommerce #payment div.payment_box {
	padding: var(--space-3) var(--space-4);
	background-color: var(--color-bg-alt);
	border-radius: var(--radius-sm);
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
	margin-top: var(--space-3);
}

/* Place order button */
.woocommerce #payment #place_order,
.woocommerce #place_order {
	display: block;
	width: 100%;
	padding: var(--space-4) var(--space-5);
	background-color: var(--color-primary);
	color: var(--color-white);
	font-size: var(--font-size-md);
	font-weight: 700;
	border: none;
	border-radius: var(--radius-md);
	cursor: pointer;
	transition: background-color var(--transition-fast),
	            box-shadow var(--transition-fast);
}

.woocommerce #payment #place_order:hover {
	background-color: var(--color-primary-dark);
	box-shadow: 0 4px 12px rgba(34, 197, 94, 0.3);
}


/* ==========================================================================
   5. My Account
   ========================================================================== */

.woocommerce-account .woocommerce {
	padding: var(--space-6) 0;
}

.woocommerce-account .woocommerce-MyAccount-navigation {
	background-color: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	overflow: hidden;
	margin-bottom: var(--space-5);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li {
	border-bottom: 1px solid var(--color-border);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li:last-child {
	border-bottom: none;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
	display: flex;
	align-items: center;
	gap: var(--space-3);
	padding: var(--space-3) var(--space-4);
	font-size: var(--font-size-sm);
	font-weight: 500;
	color: var(--color-text);
	transition: background-color var(--transition-fast),
	            color var(--transition-fast);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
	background-color: var(--color-bg-alt);
	color: var(--color-primary);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link--dashboard.is-active a {
	background-color: var(--color-primary);
	color: var(--color-white);
}

.woocommerce-account .woocommerce-MyAccount-content {
	background-color: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-5);
}

/* Order history table */
.woocommerce-account .woocommerce-orders-table {
	font-size: var(--font-size-sm);
}

.woocommerce-account .woocommerce-orders-table th {
	background-color: var(--color-bg-alt);
	padding: var(--space-3) var(--space-4);
	font-weight: 600;
	text-align: left;
}

.woocommerce-account .woocommerce-orders-table td {
	padding: var(--space-3) var(--space-4);
	border-bottom: 1px solid var(--color-border);
}

.woocommerce-account .woocommerce-orders-table .button {
	padding: var(--space-1) var(--space-3);
	background-color: var(--color-primary);
	color: var(--color-white);
	font-size: var(--font-size-xs);
	font-weight: 600;
	border-radius: var(--radius-sm);
	border: none;
	cursor: pointer;
	transition: background-color var(--transition-fast);
}

.woocommerce-account .woocommerce-orders-table .button:hover {
	background-color: var(--color-primary-dark);
}

/* Account forms */
.woocommerce-account .woocommerce-EditAccountForm fieldset {
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-4);
	margin-bottom: var(--space-4);
}

.woocommerce-account .woocommerce-EditAccountForm fieldset legend {
	font-weight: 600;
	font-size: var(--font-size-sm);
	padding: 0 var(--space-2);
}


/* ==========================================================================
   6. Notices & Messages
   ========================================================================== */

.woocommerce-message,
.woocommerce-info,
.woocommerce-error,
.woocommerce-notice {
	padding: var(--space-4) var(--space-5);
	margin-bottom: var(--space-4);
	border-radius: var(--radius-md);
	font-size: var(--font-size-sm);
	font-weight: 500;
	display: flex;
	align-items: center;
	gap: var(--space-3);
}

.woocommerce-message {
	background-color: #f0fdf4;
	border-left: 4px solid var(--color-success);
	color: #166534;
}

.woocommerce-error {
	background-color: #fef2f2;
	border-left: 4px solid var(--color-error);
	color: #991b1b;
	list-style: none;
	padding-left: var(--space-5);
}

.woocommerce-error li {
	margin-bottom: var(--space-2);
}

.woocommerce-error li:last-child {
	margin-bottom: 0;
}

.woocommerce-info {
	background-color: #eff6ff;
	border-left: 4px solid var(--color-info);
	color: #1e40af;
}

.woocommerce-message a,
.woocommerce-info a,
.woocommerce-error a {
	font-weight: 600;
	text-decoration: underline;
}

.woocommerce-message .button,
.woocommerce-info .button {
	margin-left: auto;
	padding: var(--space-1) var(--space-3);
	font-size: var(--font-size-xs);
	font-weight: 600;
	background-color: transparent;
	border: 1px solid currentColor;
	border-radius: var(--radius-sm);
	cursor: pointer;
	white-space: nowrap;
}


/* ==========================================================================
   7. Pagination
   ========================================================================== */

.woocommerce nav.woocommerce-pagination,
.woocommerce-pagination {
	text-align: center;
	margin-top: var(--space-8);
	padding-top: var(--space-5);
	border-top: 1px solid var(--color-border);
}

.woocommerce nav.woocommerce-pagination ul {
	display: inline-flex;
	align-items: center;
	gap: var(--space-1);
	list-style: none;
	padding: 0;
	margin: 0;
}

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 var(--space-2);
	font-size: var(--font-size-sm);
	font-weight: 500;
	color: var(--color-text);
	background-color: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	transition: background-color var(--transition-fast),
	            border-color var(--transition-fast),
	            color var(--transition-fast);
}

.woocommerce nav.woocommerce-pagination ul li a:hover {
	border-color: var(--color-primary);
	color: var(--color-primary);
}

.woocommerce nav.woocommerce-pagination ul li span.current {
	background-color: var(--color-primary);
	border-color: var(--color-primary);
	color: var(--color-white);
}


/* ==========================================================================
   8. Sidebar & Filters
   ========================================================================== */

.shop-sidebar .widget,
.woocommerce-sidebar .widget {
	background-color: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-4);
	margin-bottom: var(--space-4);
}

.shop-sidebar .widget-title,
.woocommerce-sidebar .widget-title {
	font-size: var(--font-size-sm);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.3px;
	color: var(--color-text);
	margin-bottom: var(--space-3);
	padding-bottom: var(--space-3);
	border-bottom: 1px solid var(--color-border);
}

.shop-sidebar .widget ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.shop-sidebar .widget ul li {
	margin-bottom: var(--space-2);
}

.shop-sidebar .widget ul li a {
	font-size: var(--font-size-sm);
	color: var(--color-text);
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: var(--space-1) 0;
	transition: color var(--transition-fast);
}

.shop-sidebar .widget ul li a:hover {
	color: var(--color-primary);
}

.shop-sidebar .widget ul li .count {
	font-size: var(--font-size-xs);
	color: var(--color-text-muted);
	background-color: var(--color-bg-alt);
	padding: 1px 6px;
	border-radius: var(--radius-full);
}

/* Price filter slider */
.woocommerce .widget_price_filter .price_slider_wrapper {
	padding-top: var(--space-3);
}

.woocommerce .widget_price_filter .ui-slider {
	position: relative;
	height: 6px;
	background-color: var(--color-border);
	border-radius: 3px;
	margin-bottom: var(--space-4);
}

.woocommerce .widget_price_filter .ui-slider .ui-slider-range {
	position: absolute;
	height: 100%;
	background-color: var(--color-primary);
	border-radius: 3px;
}

.woocommerce .widget_price_filter .ui-slider .ui-slider-handle {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 18px;
	height: 18px;
	background-color: var(--color-white);
	border: 2px solid var(--color-primary);
	border-radius: var(--radius-full);
	cursor: grab;
	outline: none;
}

.woocommerce .widget_price_filter .ui-slider .ui-slider-handle:active {
	cursor: grabbing;
}

.woocommerce .widget_price_filter .price_slider_amount {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--space-3);
}

.woocommerce .widget_price_filter .price_slider_amount .price_label {
	font-size: var(--font-size-sm);
	font-weight: 600;
	color: var(--color-text);
}

.woocommerce .widget_price_filter .price_slider_amount .button {
	padding: var(--space-1) var(--space-3);
	background-color: var(--color-primary);
	color: var(--color-white);
	font-size: var(--font-size-xs);
	font-weight: 600;
	border: none;
	border-radius: var(--radius-sm);
	cursor: pointer;
	transition: background-color var(--transition-fast);
}

.woocommerce .widget_price_filter .price_slider_amount .button:hover {
	background-color: var(--color-primary-dark);
}

/* Hierarchical category list — sidebar */
.shop-sidebar .product-categories {
	list-style: none;
	padding: 0;
	margin: 0;
}

.shop-sidebar .product-categories > li {
	margin-bottom: var(--space-1);
}

.shop-sidebar .product-categories > li > a {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: var(--space-2) var(--space-3);
	font-size: var(--font-size-sm);
	font-weight: 500;
	color: var(--color-text);
	border-radius: var(--radius-md);
	transition: background-color var(--transition-fast),
	            color var(--transition-fast);
}

.shop-sidebar .product-categories > li > a:hover,
.shop-sidebar .product-categories > li.current-cat-parent > a {
	background-color: rgba(34, 197, 94, 0.08);
	color: var(--color-primary);
}

.shop-sidebar .product-categories .count {
	font-size: var(--font-size-xs);
	color: var(--color-text-muted);
	font-weight: 400;
}

.shop-sidebar .product-categories .children {
	list-style: none;
	padding: 0;
	margin: var(--space-1) 0 var(--space-2) var(--space-4);
	border-left: 2px solid var(--color-bg-alt);
}

.shop-sidebar .product-categories .children li a {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: var(--space-1) var(--space-3);
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
	border-radius: var(--radius-sm);
	transition: color var(--transition-fast),
	            background-color var(--transition-fast);
}

.shop-sidebar .product-categories .children li a:hover,
.shop-sidebar .product-categories .children li.current-cat a {
	color: var(--color-primary);
	background-color: rgba(34, 197, 94, 0.05);
}

/* Results count + ordering */
.woocommerce .woocommerce-result-count {
	font-size: var(--font-size-sm);
	color: var(--color-text-light);
}

.woocommerce .woocommerce-ordering select {
	padding: var(--space-2) var(--space-3);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	font-size: var(--font-size-sm);
	color: var(--color-text);
	background-color: var(--color-white);
	cursor: pointer;
}

.shop-controls {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--space-3);
	margin-bottom: var(--space-5);
}


/* ==========================================================================
   9. Responsive — Tablet (>= 768px)
   ========================================================================== */

@media (min-width: 768px) {

	/* Product grid: 3 columns */
	.woocommerce ul.products,
	ul.products {
		grid-template-columns: repeat(3, 1fr);
	}

	/* Single product: two columns */
	.single-product-top {
		grid-template-columns: 45% 1fr;
	}

	.product-title-header__name {
		font-size: var(--font-size-2xl);
	}

	/* Checkout: two columns */
	.woocommerce-checkout .col2-set {
		grid-template-columns: 1fr 1fr;
	}

	.woocommerce form.woocommerce-checkout {
		grid-template-columns: 1.2fr 1fr;
	}

	/* My Account: sidebar + content */
	.woocommerce-account .woocommerce {
		display: grid;
		grid-template-columns: 240px 1fr;
		gap: var(--space-5);
	}

	.woocommerce-account .woocommerce-MyAccount-navigation {
		margin-bottom: 0;
	}
}


/* ==========================================================================
   10. Responsive — Desktop (>= 1024px)
   ========================================================================== */

@media (min-width: 1024px) {

	/* Product grid: 4 columns */
	.woocommerce ul.products,
	ul.products {
		grid-template-columns: repeat(4, 1fr);
	}

	/* Related / upsell: 4 columns */
	.woocommerce .related.products ul.products,
	.woocommerce .upsells.products ul.products {
		grid-template-columns: repeat(4, 1fr);
	}
}
