/* ==========================================================================
   Knack Theme: WooCommerce Styles
   ========================================================================== */

/* --- Hide Breadcrumbs & Page Titles Site-Wide --- */
.woocommerce-breadcrumb,
.woocommerce-products-header__title.page-title,
.page-title {
	display: none !important;
}

/* --- WooCommerce Main Content --- */
.knack-wc-main {
	max-width: var(--knack-container-width);
	margin: 0 auto;
	padding: var(--knack-space-xl) var(--knack-space-lg);
}

/* --- Product Grid --- */
.woocommerce ul.products {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
	gap: var(--knack-space-xl);
	padding: 0;
}
/* WooCommerce adds clearfix ::before/::after pseudo-elements to ul.products.
   In a CSS grid container these become phantom grid items — the ::before
   steals the first cell and pushes every product over by one (empty top-left,
   products offset; glaring at 2 columns on mobile). Suppress them. */
.woocommerce ul.products::before,
.woocommerce ul.products::after {
	content: none;
	display: none;
}

/* --- Product Card: Clean Minimal --- */
.woocommerce ul.products li.product {
	position: relative;
	background: var(--knack-bg);
	border: none;
	border-radius: var(--knack-radius-2xl);
	overflow: hidden;
	margin: 0;
	padding: 0;
	float: none;
	width: auto;
	transition: transform 0.3s ease, box-shadow 0.3s ease, background 0.3s ease;
}

.woocommerce ul.products li.product:hover {
	transform: translateY(-4px);
	box-shadow: var(--knack-shadow-lg);
	background: var(--knack-surface);
}

/* --- Product Image with Feathering --- */
.woocommerce ul.products li.product a img {
	display: block;
	width: 100%;
	height: auto;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	margin: 0;
	border-radius: 0;
	transition: transform 0.5s ease;
	-webkit-mask-image: linear-gradient(to bottom, #000 45%, rgba(0,0,0,0.55) 70%, rgba(0,0,0,0.2) 85%, transparent 100%);
	mask-image: linear-gradient(to bottom, #000 45%, rgba(0,0,0,0.55) 70%, rgba(0,0,0,0.2) 85%, transparent 100%);
}

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

/* --- Product Title --- */
.woocommerce ul.products li.product .woocommerce-loop-product__title {
	position: relative;
	z-index: 1;
	padding: 0 var(--knack-space-md);
	margin-top: -36px;
	font-size: 0.9375rem;
	font-weight: 600;
	color: var(--knack-text);
	line-height: 1.35;
	letter-spacing: -0.01em;
}

.woocommerce ul.products li.product a:hover .woocommerce-loop-product__title {
	color: var(--knack-accent);
}

/* --- Product Price --- */
.woocommerce ul.products li.product .price {
	display: flex;
	align-items: center;
	gap: 6px;
	padding: var(--knack-space-xs) var(--knack-space-md) 0;
	font-size: 0.9375rem;
	font-weight: 700;
	color: var(--knack-text);
}

.woocommerce ul.products li.product .price del {
	font-size: 0.8125rem;
	font-weight: 400;
	color: var(--knack-text-muted);
	opacity: 0.7;
}

.woocommerce ul.products li.product .price ins {
	text-decoration: none;
	color: var(--knack-text);
	font-weight: 700;
}

/* --- Add to Cart Button --- */
.woocommerce ul.products li.product .button {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin: var(--knack-space-sm) var(--knack-space-md) var(--knack-space-md);
	padding: 8px 18px;
	background: transparent;
	color: var(--knack-text-secondary);
	border: 1px solid var(--knack-border);
	border-radius: var(--knack-radius-pill);
	font-size: 0.8125rem;
	font-weight: 500;
	cursor: pointer;
	transition: all 0.2s ease;
}

.woocommerce ul.products li.product .button:hover {
	background: var(--knack-btn-bg, var(--knack-accent));
	color: var(--knack-accent-text);
	border-color: var(--knack-btn-bg, var(--knack-accent));
}

/* "Read more" button for variable products */
.woocommerce ul.products li.product .button.product_type_variable,
.woocommerce ul.products li.product a.button[href*="product"] {
	background: transparent;
	color: var(--knack-text-secondary);
	border: 1px solid var(--knack-border);
}

.woocommerce ul.products li.product .button.product_type_variable:hover,
.woocommerce ul.products li.product a.button[href*="product"]:hover {
	background: var(--knack-bg-secondary);
	color: var(--knack-text);
	border-color: var(--knack-border);
}

/* "View cart" link after adding to cart */
.woocommerce ul.products li.product .added_to_cart {
	display: inline-flex;
	align-items: center;
	margin-left: var(--knack-space-sm);
	padding: 8px 0;
	font-size: 0.8125rem;
	font-weight: 500;
	color: var(--knack-accent);
	text-decoration: none;
}

.woocommerce ul.products li.product .added_to_cart:hover {
	color: var(--knack-accent-hover);
	text-decoration: underline;
}

/* --- Sale Badge --- */
.woocommerce ul.products li.product .onsale,
.woocommerce span.onsale {
	position: absolute !important;
	top: var(--knack-space-sm) !important;
	right: var(--knack-space-sm) !important;
	left: auto !important;
	bottom: auto !important;
	z-index: 2;
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	width: auto !important;
	height: auto !important;
	padding: 4px 10px !important;
	background: var(--knack-btn-bg, var(--knack-accent)) !important;
	color: var(--knack-accent-text) !important;
	font-size: 0.6875rem !important;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	border-radius: var(--knack-radius-pill) !important;
	min-height: 0 !important;
	min-width: 0 !important;
	line-height: 1.4;
	margin: 0 !important;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

/* --- Star Ratings --- */
.woocommerce ul.products li.product .star-rating {
	margin: var(--knack-space-xs) var(--knack-space-md) 0;
	font-size: 0.75rem;
	color: var(--knack-accent);
}

/* --- Product card bottom area spacing --- */
.woocommerce ul.products li.product .price + .button,
.woocommerce ul.products li.product .star-rating + .button {
	margin-top: var(--knack-space-sm);
}

/* --- WooCommerce Buttons (global) --- */
.woocommerce .button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce a.button {
	background: var(--knack-btn-bg, var(--knack-accent));
	color: var(--knack-accent-text);
	border: none;
	border-radius: var(--knack-radius-xl);
	font-weight: 600;
	font-family: var(--knack-font-body);
	transition: all var(--knack-transition);
}

.woocommerce .button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce a.button:hover {
	background: var(--knack-btn-bg-hover, var(--knack-accent-hover));
	color: var(--knack-accent-text);
	filter: brightness(1.1);
}

.woocommerce .button.alt,
.woocommerce button.button.alt {
	background: var(--knack-btn-bg, var(--knack-accent));
	color: var(--knack-accent-text);
}

.woocommerce .button.alt:hover,
.woocommerce button.button.alt:hover {
	background: var(--knack-btn-bg-hover, var(--knack-accent-hover));
	filter: brightness(1.1);
}

/* --- Shop Controls (result count + ordering) --- */
.woocommerce .woocommerce-result-count {
	color: var(--knack-text-muted);
	font-size: 0.8125rem;
	margin-bottom: var(--knack-space-lg);
}

.woocommerce .woocommerce-ordering {
	margin-bottom: var(--knack-space-lg);
}

.woocommerce .woocommerce-ordering select {
	padding: 8px 32px 8px 12px;
	font-size: 0.8125rem;
	font-family: var(--knack-font-body);
	color: var(--knack-text);
	background: var(--knack-bg);
	border: 1px solid var(--knack-border);
	border-radius: var(--knack-radius-xl);
	cursor: pointer;
	transition: border-color var(--knack-transition);
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 10px center;
}

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

/* --- WooCommerce Pagination --- */
.woocommerce nav.woocommerce-pagination {
	margin-top: var(--knack-space-2xl);
}

.woocommerce nav.woocommerce-pagination ul {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--knack-space-xs);
	border: none;
}

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

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
	display: flex;
	align-items: center;
	justify-content: center;
	min-width: 36px;
	height: 36px;
	padding: 0 var(--knack-space-sm);
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--knack-text-secondary);
	background: transparent;
	border: 1px solid var(--knack-border-soft);
	border-radius: var(--knack-radius-xl);
	text-decoration: none;
	transition: all var(--knack-transition);
}

.woocommerce nav.woocommerce-pagination ul li a:hover {
	color: var(--knack-text);
	background: var(--knack-bg-secondary);
	border-color: var(--knack-border);
}

.woocommerce nav.woocommerce-pagination ul li span.current {
	background: var(--knack-btn-bg, var(--knack-accent));
	color: var(--knack-accent-text);
	border-color: var(--knack-btn-bg, var(--knack-accent));
	font-weight: 600;
}

/* --- WooCommerce Notices --- */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	background: var(--knack-surface);
	border: 1px solid var(--knack-border-soft);
	border-radius: var(--knack-radius-2xl);
	padding: var(--knack-space-md) var(--knack-space-lg);
	color: var(--knack-text);
	font-size: 0.875rem;
	border-top: 3px solid;
	margin-bottom: var(--knack-space-lg);
}

.woocommerce-message {
	border-top-color: var(--knack-success);
}

.woocommerce-info {
	border-top-color: var(--knack-accent);
}

.woocommerce-error {
	border-top-color: var(--knack-danger);
}

.woocommerce-message::before,
.woocommerce-info::before {
	color: var(--knack-accent);
}

.woocommerce-error::before {
	color: var(--knack-danger);
}

.woocommerce-message a.button,
.woocommerce-info a.button {
	padding: 6px 16px;
	font-size: 0.8125rem;
	border-radius: var(--knack-radius-xl);
}

/* ==========================================================================
   Single Product Page: Clean Minimal Redesign
   ========================================================================== */

/* --- Breadcrumbs --- */
.woocommerce .woocommerce-breadcrumb {
	font-size: 0.8125rem;
	color: var(--knack-text-muted);
	margin-bottom: var(--knack-space-lg);
	padding: 0;
	font-weight: 400;
}

.woocommerce .woocommerce-breadcrumb a {
	color: var(--knack-text-secondary);
	text-decoration: none;
	transition: color var(--knack-transition);
}

.woocommerce .woocommerce-breadcrumb a:hover {
	color: var(--knack-accent);
}

/* --- Single Product Layout --- */
.woocommerce div.product {
	max-width: var(--knack-container-width);
	margin: 0 auto;
}

.woocommerce div.product div.summary {
	margin-bottom: var(--knack-space-xl);
}

/* --- Product Gallery --- */
.woocommerce div.product div.images {
	margin-bottom: var(--knack-space-xl);
}

.woocommerce div.product div.images img {
	border-radius: var(--knack-radius-xl);
	transition: transform 0.3s ease;
}

.woocommerce div.product div.images .woocommerce-product-gallery__image a {
	display: block;
	border-radius: var(--knack-radius-xl);
	overflow: hidden;
}

/* Gallery thumbnails */
.woocommerce div.product div.images .flex-control-thumbs {
	display: flex;
	gap: var(--knack-space-sm);
	margin-top: var(--knack-space-sm);
	padding: 0;
	list-style: none;
}

.woocommerce div.product div.images .flex-control-thumbs li {
	flex: 0 0 auto;
	width: 72px;
	opacity: 0.6;
	transition: opacity var(--knack-transition);
	cursor: pointer;
}

.woocommerce div.product div.images .flex-control-thumbs li:hover,
.woocommerce div.product div.images .flex-control-thumbs li .flex-active {
	opacity: 1;
}

.woocommerce div.product div.images .flex-control-thumbs li img {
	border-radius: var(--knack-radius);
	width: 100%;
	height: auto;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	border: 2px solid transparent;
	transition: border-color var(--knack-transition);
}

.woocommerce div.product div.images .flex-control-thumbs li img.flex-active,
.woocommerce div.product div.images .flex-control-thumbs li:hover img {
	border-color: var(--knack-accent);
}

/* --- Product Title --- */
.woocommerce div.product .product_title {
	font-size: 1.75rem;
	font-weight: 700;
	color: var(--knack-text);
	line-height: 1.3;
	letter-spacing: -0.02em;
	margin-bottom: var(--knack-space-sm);
}

/* --- Product Price (single) --- */
.woocommerce div.product p.price,
.woocommerce div.product span.price {
	font-size: 1.375rem;
	font-weight: 700;
	color: var(--knack-text);
	margin-bottom: var(--knack-space-md);
	display: flex;
	align-items: baseline;
	gap: var(--knack-space-sm);
}

.woocommerce div.product p.price del,
.woocommerce div.product span.price del {
	font-size: 1rem;
	font-weight: 400;
	color: var(--knack-text-muted);
	opacity: 0.7;
}

.woocommerce div.product p.price ins,
.woocommerce div.product span.price ins {
	text-decoration: none;
	color: var(--knack-text);
	font-weight: 700;
}

/* --- Star Rating (single) --- */
.woocommerce div.product .woocommerce-product-rating {
	display: flex;
	align-items: center;
	gap: var(--knack-space-sm);
	margin-bottom: var(--knack-space-md);
}

.woocommerce div.product .woocommerce-product-rating .star-rating {
	font-size: 0.875rem;
	color: var(--knack-accent);
}

.woocommerce div.product .woocommerce-product-rating .woocommerce-review-link {
	font-size: 0.8125rem;
	color: var(--knack-text-muted);
	text-decoration: none;
	transition: color var(--knack-transition);
}

.woocommerce div.product .woocommerce-product-rating .woocommerce-review-link:hover {
	color: var(--knack-accent);
}

/* --- Short Description --- */
.woocommerce div.product .woocommerce-product-details__short-description {
	font-size: 0.9375rem;
	line-height: 1.7;
	color: var(--knack-text-secondary);
	margin-bottom: var(--knack-space-lg);
}

.woocommerce div.product .woocommerce-product-details__short-description p:last-child {
	margin-bottom: 0;
}

/* --- Quantity Selector --- */
.woocommerce div.product form.cart {
	display: flex;
	align-items: center;
	gap: var(--knack-space-md);
	margin-bottom: var(--knack-space-xl);
	padding-top: var(--knack-space-lg);
	border-top: 1px solid var(--knack-border-soft);
}

.woocommerce .quantity {
	display: inline-flex;
	align-items: center;
	border: 1px solid var(--knack-border);
	border-radius: var(--knack-radius-xl);
	overflow: hidden;
	background: var(--knack-bg);
}

.woocommerce .quantity .qty {
	width: 56px;
	height: 44px;
	padding: 0;
	text-align: center;
	font-size: 0.9375rem;
	font-weight: 600;
	font-family: var(--knack-font-body);
	color: var(--knack-text);
	background: transparent;
	border: none;
	border-radius: 0;
	-moz-appearance: textfield;
	outline: none;
}

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

/* Add to cart button (single product) */
.woocommerce div.product form.cart .button,
.woocommerce div.product form.cart .single_add_to_cart_button {
	flex: 1;
	max-width: 320px;
	height: 44px;
	padding: 0 var(--knack-space-xl);
	font-size: 0.9375rem;
	font-weight: 600;
	border-radius: var(--knack-radius-xl);
	background: var(--knack-btn-bg, var(--knack-accent));
	color: var(--knack-accent-text);
	border: none;
	cursor: pointer;
	transition: all var(--knack-transition);
	text-transform: none;
	letter-spacing: 0;
}

.woocommerce div.product form.cart .button:hover,
.woocommerce div.product form.cart .single_add_to_cart_button:hover {
	background: var(--knack-btn-bg-hover, var(--knack-accent-hover));
	filter: brightness(1.05);
	transform: translateY(-1px);
	box-shadow: var(--knack-shadow-md);
}

/* --- Variations (Variable Products) --- */
.woocommerce div.product form.cart .variations {
	width: 100%;
	margin-bottom: var(--knack-space-md);
	border-collapse: separate;
	border-spacing: 0;
}

.woocommerce div.product form.cart .variations td,
.woocommerce div.product form.cart .variations th {
	border: none;
	padding: var(--knack-space-sm) 0;
	vertical-align: middle;
}

.woocommerce div.product form.cart .variations td.label label {
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--knack-text);
	margin: 0;
}

.woocommerce div.product form.cart .variations td.value select {
	width: 100%;
	max-width: 280px;
	padding: 10px 36px 10px 14px;
	font-size: 0.875rem;
	font-family: var(--knack-font-body);
	color: var(--knack-text);
	background: var(--knack-bg);
	border: 1px solid var(--knack-border);
	border-radius: var(--knack-radius-xl);
	cursor: pointer;
	transition: border-color var(--knack-transition);
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 12px center;
}

.woocommerce div.product form.cart .variations td.value select:focus {
	outline: none;
	border-color: var(--knack-accent);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--knack-accent) 15%, transparent);
}

.woocommerce div.product form.cart .variations .reset_variations {
	font-size: 0.8125rem;
	color: var(--knack-text-muted);
	text-decoration: none;
	margin-left: var(--knack-space-sm);
	transition: color var(--knack-transition);
}

.woocommerce div.product form.cart .variations .reset_variations:hover {
	color: var(--knack-danger);
}

/* Variable product - wrap cart form */
.woocommerce div.product form.cart.variations_form {
	flex-wrap: wrap;
}

.woocommerce div.product form.cart .woocommerce-variation-add-to-cart {
	display: flex;
	align-items: center;
	gap: var(--knack-space-md);
	width: 100%;
}

/* --- Product Meta (SKU, Categories, Tags) --- */
.woocommerce div.product .product_meta {
	padding-top: var(--knack-space-lg);
	border-top: 1px solid var(--knack-border-soft);
	margin-top: var(--knack-space-lg);
	font-size: 0.8125rem;
	color: var(--knack-text-muted);
	line-height: 2;
}

.woocommerce div.product .product_meta > span {
	display: block;
}

.woocommerce div.product .product_meta a {
	color: var(--knack-text-secondary);
	text-decoration: none;
	transition: color var(--knack-transition);
}

.woocommerce div.product .product_meta a:hover {
	color: var(--knack-accent);
}

/* ==========================================================================
   Product Tabs: Clean Minimal with #E8E9EB inactive
   ========================================================================== */

.woocommerce div.product .woocommerce-tabs {
	margin-top: var(--knack-space-2xl);
	margin-bottom: var(--knack-space-2xl);
}

/* Tab navigation */
.woocommerce div.product .woocommerce-tabs ul.tabs {
	display: flex;
	list-style: none;
	margin: 0;
	padding: 0;
	border-bottom: 2px solid var(--knack-border-soft);
	gap: var(--knack-space-xs);
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

/* Remove WooCommerce default tab styles */
.woocommerce div.product .woocommerce-tabs ul.tabs::before,
.woocommerce div.product .woocommerce-tabs ul.tabs::after {
	display: none !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
	position: relative;
	margin: 0;
	padding: 0;
	border: none;
	background: none;
	border-radius: 0;
	flex-shrink: 0;
}

/* Remove WooCommerce default tab decorations */
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after {
	display: none !important;
}

/* Inactive tab */
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	display: block;
	padding: 12px 24px;
	font-size: 0.875rem;
	font-weight: 500;
	font-family: var(--knack-font-body);
	color: var(--knack-text-secondary);
	text-decoration: none;
	background: #E8E9EB;
	border-radius: var(--knack-radius-lg) var(--knack-radius-lg) 0 0;
	transition: all var(--knack-transition);
	border: none;
	white-space: nowrap;
}

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

/* Active tab */
.woocommerce div.product .woocommerce-tabs ul.tabs li.active {
	border-bottom: none;
	background: none;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
	color: var(--knack-text);
	font-weight: 600;
	background: var(--knack-bg);
	border: 2px solid var(--knack-border-soft);
	border-bottom: 2px solid var(--knack-bg);
	margin-bottom: -2px;
}

/* Tab panels */
.woocommerce div.product .woocommerce-tabs .woocommerce-Tabs-panel,
.woocommerce div.product .woocommerce-tabs .panel {
	padding: var(--knack-space-xl) var(--knack-space-lg);
	background: var(--knack-bg);
	border: 2px solid var(--knack-border-soft);
	border-top: none;
	border-radius: 0 0 var(--knack-radius-lg) var(--knack-radius-lg);
	font-size: 0.9375rem;
	line-height: 1.7;
	color: var(--knack-text-secondary);
}

.woocommerce div.product .woocommerce-tabs .panel > *:last-child {
	margin-bottom: 0;
}

.woocommerce div.product .woocommerce-tabs .panel h2 {
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--knack-text);
	margin-bottom: var(--knack-space-md);
}

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

.woocommerce div.product .woocommerce-tabs .shop_attributes th {
	text-align: left;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--knack-text);
	padding: 12px 16px;
	background: var(--knack-bg-secondary);
	border-bottom: 1px solid var(--knack-border-soft);
	width: 30%;
}

.woocommerce div.product .woocommerce-tabs .shop_attributes td {
	font-size: 0.875rem;
	color: var(--knack-text-secondary);
	padding: 12px 16px;
	border-bottom: 1px solid var(--knack-border-soft);
}

.woocommerce div.product .woocommerce-tabs .shop_attributes td p {
	margin: 0;
}

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

/* --- Reviews Tab --- */
.woocommerce div.product .woocommerce-tabs #reviews {
	padding: 0;
}

.woocommerce div.product .woocommerce-tabs #reviews #comments {
	margin-bottom: var(--knack-space-xl);
}

.woocommerce div.product .woocommerce-tabs #reviews .commentlist {
	list-style: none;
	margin: 0;
	padding: 0;
}

.woocommerce div.product .woocommerce-tabs #reviews .commentlist li {
	padding: var(--knack-space-lg) 0;
	border-bottom: 1px solid var(--knack-border-soft);
}

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

.woocommerce div.product .woocommerce-tabs #reviews .commentlist .comment_container {
	display: flex;
	gap: var(--knack-space-md);
}

.woocommerce div.product .woocommerce-tabs #reviews .commentlist .avatar {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	object-fit: cover;
	flex-shrink: 0;
}

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

.woocommerce div.product .woocommerce-tabs #reviews .commentlist .comment-text .star-rating {
	font-size: 0.75rem;
	color: var(--knack-accent);
	margin-bottom: var(--knack-space-xs);
}

.woocommerce div.product .woocommerce-tabs #reviews .commentlist .comment-text .meta {
	font-size: 0.8125rem;
	color: var(--knack-text-muted);
	margin-bottom: var(--knack-space-sm);
}

.woocommerce div.product .woocommerce-tabs #reviews .commentlist .comment-text .meta strong {
	color: var(--knack-text);
	font-weight: 600;
}

.woocommerce div.product .woocommerce-tabs #reviews .commentlist .comment-text .description p {
	font-size: 0.9375rem;
	color: var(--knack-text-secondary);
	line-height: 1.6;
	margin: 0;
}

/* Review form */
.woocommerce div.product .woocommerce-tabs #review_form_wrapper {
	margin-top: var(--knack-space-lg);
	padding-top: var(--knack-space-lg);
	border-top: 1px solid var(--knack-border-soft);
}

.woocommerce div.product .woocommerce-tabs #review_form #respond .comment-form label {
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--knack-text);
	margin-bottom: var(--knack-space-xs);
}

.woocommerce div.product .woocommerce-tabs #review_form #respond .comment-form input,
.woocommerce div.product .woocommerce-tabs #review_form #respond .comment-form textarea {
	font-family: var(--knack-font-body);
}

.woocommerce div.product .woocommerce-tabs #review_form #respond .comment-form .form-submit input {
	background: var(--knack-btn-bg, var(--knack-accent));
	color: var(--knack-accent-text);
	border: none;
	border-radius: var(--knack-radius-xl);
	padding: 10px 24px;
	font-weight: 600;
	font-family: var(--knack-font-body);
	cursor: pointer;
	transition: all var(--knack-transition);
}

.woocommerce div.product .woocommerce-tabs #review_form #respond .comment-form .form-submit input:hover {
	background: var(--knack-btn-bg-hover, var(--knack-accent-hover));
	filter: brightness(1.05);
}

/* Star rating input in review form */
.woocommerce div.product .woocommerce-tabs #review_form .comment-form-rating .stars {
	margin-bottom: var(--knack-space-sm);
}

.woocommerce div.product .woocommerce-tabs #review_form .comment-form-rating .stars a {
	color: var(--knack-accent);
}

/* --- Related Products / Upsells --- */
.woocommerce div.product .related,
.woocommerce div.product .upsells {
	margin-top: var(--knack-space-2xl);
	padding-top: var(--knack-space-xl);
	border-top: 1px solid var(--knack-border-soft);
}

.woocommerce div.product .related > h2,
.woocommerce div.product .upsells > h2 {
	font-size: 1.25rem;
	font-weight: 600;
	color: var(--knack-text);
	margin-bottom: var(--knack-space-lg);
	letter-spacing: -0.01em;
}

/* --- Sale Badge on Single Product --- */
.woocommerce div.product .onsale {
	position: absolute !important;
	top: var(--knack-space-md) !important;
	right: var(--knack-space-md) !important;
	left: auto !important;
	bottom: auto !important;
	z-index: 2;
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	width: auto !important;
	height: auto !important;
	padding: 6px 14px !important;
	background: var(--knack-btn-bg, var(--knack-accent)) !important;
	color: var(--knack-accent-text) !important;
	font-size: 0.75rem !important;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	border-radius: var(--knack-radius-pill) !important;
	min-height: 0 !important;
	min-width: 0 !important;
	line-height: 1.4;
	margin: 0 !important;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

/* --- Stock Status --- */
.woocommerce div.product .stock {
	font-size: 0.8125rem;
	font-weight: 500;
	margin-bottom: var(--knack-space-md);
}

.woocommerce div.product .stock.in-stock {
	color: var(--knack-success);
}

.woocommerce div.product .stock.out-of-stock {
	color: var(--knack-danger);
}

/* ==========================================================================
   Single Product: Dark Mode Overrides
   ========================================================================== */

/* Tab navigation in dark mode */
body.aoty-dark-mode .woocommerce div.product .woocommerce-tabs ul.tabs {
	border-bottom-color: var(--knack-border);
}

body.aoty-dark-mode .woocommerce div.product .woocommerce-tabs ul.tabs li a {
	background: var(--knack-surface);
	color: var(--knack-text-muted);
}

body.aoty-dark-mode .woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
	background: var(--knack-surface-raised);
	color: var(--knack-text-secondary);
}

body.aoty-dark-mode .woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
	background: var(--knack-bg);
	color: var(--knack-text);
	border-color: var(--knack-border);
	border-bottom-color: var(--knack-bg);
}

/* Tab panels in dark mode */
body.aoty-dark-mode .woocommerce div.product .woocommerce-tabs .woocommerce-Tabs-panel,
body.aoty-dark-mode .woocommerce div.product .woocommerce-tabs .panel {
	background: var(--knack-bg);
	border-color: var(--knack-border);
}

/* Attributes table dark mode */
body.aoty-dark-mode .woocommerce div.product .woocommerce-tabs .shop_attributes th {
	background: var(--knack-bg-secondary);
	color: var(--knack-text);
	border-color: var(--knack-border);
}

body.aoty-dark-mode .woocommerce div.product .woocommerce-tabs .shop_attributes td {
	border-color: var(--knack-border);
}

/* Quantity in dark mode */
body.aoty-dark-mode .woocommerce .quantity {
	border-color: var(--knack-border);
	background: var(--knack-bg-secondary);
}

body.aoty-dark-mode .woocommerce .quantity .qty {
	color: var(--knack-text);
}

/* Variations select in dark mode */
body.aoty-dark-mode .woocommerce div.product form.cart .variations td.value select {
	background-color: var(--knack-bg-secondary);
	border-color: var(--knack-border);
	color: var(--knack-text);
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238b949e' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
}

/* Product meta dark mode */
body.aoty-dark-mode .woocommerce div.product .product_meta {
	border-top-color: var(--knack-border);
}

/* Cart form divider dark mode */
body.aoty-dark-mode .woocommerce div.product form.cart {
	border-top-color: var(--knack-border);
}

/* Related / upsells divider dark mode */
body.aoty-dark-mode .woocommerce div.product .related,
body.aoty-dark-mode .woocommerce div.product .upsells {
	border-top-color: var(--knack-border);
}

/* Review list dark mode */
body.aoty-dark-mode .woocommerce div.product .woocommerce-tabs #reviews .commentlist li {
	border-bottom-color: var(--knack-border);
}

body.aoty-dark-mode .woocommerce div.product .woocommerce-tabs #review_form_wrapper {
	border-top-color: var(--knack-border);
}

/* Gallery thumbnail border in dark mode */
body.aoty-dark-mode .woocommerce div.product div.images .flex-control-thumbs li img {
	border-color: transparent;
}

body.aoty-dark-mode .woocommerce div.product div.images .flex-control-thumbs li img.flex-active,
body.aoty-dark-mode .woocommerce div.product div.images .flex-control-thumbs li:hover img {
	border-color: var(--knack-accent);
}

/* ==========================================================================
   Single Product: Responsive
   ========================================================================== */

@media (max-width: 768px) {
	.woocommerce div.product .product_title {
		font-size: 1.375rem;
	}

	.woocommerce div.product p.price,
	.woocommerce div.product span.price {
		font-size: 1.125rem;
	}

	.woocommerce div.product form.cart {
		flex-wrap: wrap;
	}

	.woocommerce div.product form.cart .button,
	.woocommerce div.product form.cart .single_add_to_cart_button {
		max-width: none;
		width: 100%;
	}

	.woocommerce div.product form.cart .woocommerce-variation-add-to-cart {
		flex-wrap: wrap;
	}

	.woocommerce div.product .woocommerce-tabs ul.tabs li a {
		padding: 10px 16px;
		font-size: 0.8125rem;
	}

	.woocommerce div.product .woocommerce-tabs .woocommerce-Tabs-panel,
	.woocommerce div.product .woocommerce-tabs .panel {
		padding: var(--knack-space-lg) var(--knack-space-md);
	}

	.woocommerce div.product .woocommerce-tabs .shop_attributes th {
		width: 40%;
	}
}

@media (max-width: 480px) {
	.woocommerce div.product .product_title {
		font-size: 1.25rem;
	}

	.woocommerce div.product .woocommerce-tabs ul.tabs {
		gap: 2px;
	}

	.woocommerce div.product .woocommerce-tabs ul.tabs li a {
		padding: 8px 12px;
		font-size: 0.75rem;
	}

	.woocommerce div.product .woocommerce-tabs .shop_attributes th,
	.woocommerce div.product .woocommerce-tabs .shop_attributes td {
		display: block;
		width: 100%;
		padding: 8px 12px;
	}

	.woocommerce div.product .woocommerce-tabs .shop_attributes th {
		padding-bottom: 4px;
		border-bottom: none;
	}
}

/* --- Dark Mode: WooCommerce --- */
body.aoty-dark-mode .woocommerce ul.products li.product {
	background: var(--knack-bg);
}

body.aoty-dark-mode .woocommerce ul.products li.product:hover {
	background: var(--knack-bg-secondary);
}

body.aoty-dark-mode .woocommerce ul.products li.product .woocommerce-loop-product__title {
	color: var(--knack-text);
}

body.aoty-dark-mode .woocommerce ul.products li.product .button {
	border-color: var(--knack-border);
	color: var(--knack-text-secondary);
}

body.aoty-dark-mode .woocommerce ul.products li.product .button:hover {
	background: var(--knack-btn-bg, var(--knack-accent));
	color: var(--knack-accent-text);
	border-color: var(--knack-btn-bg, var(--knack-accent));
}

/* --- Responsive: WooCommerce --- */
@media (max-width: 1024px) {
	.woocommerce ul.products {
		grid-template-columns: repeat(3, 1fr);
		gap: var(--knack-space-lg);
	}
}

@media (max-width: 768px) {
	/* Force 2-col grid on every WC products list. Selectors broadened to catch
	   `.up-sells.upsells.products` (no `div.product` ancestor on some installs)
	   and any wrapper that just has `.products` + a `.upsell` substring class.
	   `!important` on display/grid-template ensures we beat any plugin override. */
	.woocommerce ul.products,
	ul.products,
	.related ul.products,
	.upsells ul.products,
	.up-sells ul.products,
	[class*="upsell"] ul.products,
	[class*="cross-sell"] ul.products,
	[class*="related"] ul.products {
		display: grid !important;
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
		gap: var(--knack-space-md) !important;
		list-style: none !important;
		padding: 0 !important;
	}

	/* Kill the leading-orphan-cell symptom. WC / Dokan / some upsell helpers
	   inject `<li class="clear">` or empty `<li>` elements that take a grid
	   cell and shift real products to the right. Hide anything that isn't a
	   real product (the WC class is always `product`). */
	.woocommerce ul.products > li:not(.product),
	ul.products > li.clear,
	ul.products > li:empty {
		display: none !important;
	}

	/* Cards fill their grid cell. Override WC's `width: 48%` / `22%` / float,
	   any explicit grid placement, and WC's `.first` class which sometimes
	   carries narrower width from legacy column rules. Also wins against
	   inline `style="width:..."` set by some upsell / vendor plugins via the
	   `[style]` attribute selector that adds specificity. */
	.woocommerce ul.products li.product,
	ul.products li.product,
	ul.products > li.product,
	ul.products > li.product.first,
	ul.products > li.product.last,
	ul.products > li.product[style],
	.related ul.products li.product,
	.upsells ul.products li.product,
	.up-sells ul.products li.product {
		width: auto !important;
		max-width: none !important;
		min-width: 0 !important;
		margin: 0 !important;
		padding: 0 !important;
		float: none !important;
		clear: none !important;
		grid-column: auto !important;
		grid-row: auto !important;
		box-sizing: border-box !important;
	}

	/* Direct children of a product card must use the cell width — kills any
	   inner wrapper with explicit narrow width (e.g. Dokan vendor wrappers
	   that constrain the first product). */
	ul.products > li.product > a,
	ul.products > li.product > a > img,
	ul.products > li.product > a > .woocommerce-LoopProduct-link {
		display: block !important;
		width: 100% !important;
		max-width: 100% !important;
	}

	/* Title shouldn't shrink-wrap to its longest unbreakable word. Force it
	   to fill the cell width so the WC heading wraps normally. */
	.woocommerce ul.products li.product .woocommerce-loop-product__title,
	ul.products li.product .woocommerce-loop-product__title,
	ul.products li.product > a > h2 {
		display: block !important;
		width: auto !important;
		max-width: 100% !important;
		min-width: 0 !important;
		font-size: 0.875rem;
		margin-top: -28px;
		padding: 0 var(--knack-space-md) !important;
		word-break: normal;
		overflow-wrap: anywhere;
		hyphens: none;
		white-space: normal !important;
	}

	.woocommerce ul.products li.product .price {
		font-size: 0.875rem;
		padding: 0 var(--knack-space-md);
	}

	/* "Add to cart" / "Read more" buttons render as inline pills, not the
	   cramped vertically-stacked-text circle WC produces when the parent has
	   constrained width. */
	.woocommerce ul.products li.product .button,
	.woocommerce ul.products li.product .added_to_cart,
	ul.products li.product .button,
	ul.products li.product .added_to_cart {
		display: inline-flex !important;
		align-items: center;
		justify-content: center;
		width: auto !important;
		max-width: 100%;
		min-width: 0 !important;
		margin: var(--knack-space-sm) var(--knack-space-md) var(--knack-space-md) !important;
		padding: 8px 14px !important;
		font-size: 0.75rem;
		white-space: nowrap !important;
		border-radius: var(--knack-radius-pill);
	}

	/* Product image must scale to cell — kills the "huge collage image at full
	   page width" pattern from products whose featured image is intrinsically
	   large (album covers, single covers). */
	.woocommerce ul.products li.product a img,
	ul.products li.product a img,
	ul.products li.product img {
		display: block;
		width: 100% !important;
		height: auto !important;
		max-width: 100% !important;
		aspect-ratio: 1 / 1;
		object-fit: cover;
	}
}

@media (max-width: 480px) {
	.woocommerce ul.products {
		grid-template-columns: repeat(2, 1fr);
		gap: var(--knack-space-sm);
	}

	.woocommerce ul.products li.product a img {
		aspect-ratio: 4 / 5;
	}
}

/* ==========================================================================
   WooCommerce Block Checkout & Cart
   Targets `wc-block-*` classes used by the block-based cart/checkout pages.
   These blocks ship with utilitarian defaults — this section refines them
   to match the rest of the Knack UI (card surfaces, theme accent, Inter font,
   consistent spacing).
   ========================================================================== */

/* Outer block layout — give the form room to breathe and pin the sidebar. */
.wp-block-woocommerce-checkout {
	max-width: var(--knack-container-width);
	margin: var(--knack-space-xl) auto;
	padding: 0 var(--knack-space-lg);
	gap: var(--knack-space-2xl);
}

.wp-block-woocommerce-checkout .wc-block-checkout__main {
	display: flex;
	flex-direction: column;
	gap: var(--knack-space-md);
}

.wp-block-woocommerce-checkout .wc-block-checkout__sidebar {
	position: sticky;
	top: calc(var(--knack-header-height) + var(--knack-space-md));
	align-self: flex-start;
}

/* Each checkout step → card. Contact info, billing, shipping, payment. */
.wc-block-components-checkout-step {
	background: var(--knack-surface);
	border: 1px solid var(--knack-border-soft);
	border-radius: var(--knack-radius-xl);
	padding: var(--knack-space-lg) var(--knack-space-lg);
	margin: 0;
	box-shadow: var(--knack-shadow-card);
	transition: box-shadow var(--knack-transition), border-color var(--knack-transition);
}

.wc-block-components-checkout-step:hover {
	box-shadow: var(--knack-shadow-card-hover);
	border-color: var(--knack-border);
}

.wc-block-components-checkout-step--with-step-number {
	padding-left: var(--knack-space-lg);
}

/* The step number badge — recolor to theme accent. */
.wc-block-components-checkout-step__container::before {
	display: none;
}

.wc-block-components-checkout-step__heading {
	margin: 0 0 var(--knack-space-md);
	display: flex;
	align-items: baseline;
	gap: var(--knack-space-sm);
}

.wc-block-components-checkout-step__title {
	font-family: var(--knack-font-heading);
	font-size: var(--knack-font-size-lg);
	font-weight: 600;
	color: var(--knack-text);
	letter-spacing: -0.01em;
	margin: 0;
	line-height: 1.3;
}

.wc-block-components-checkout-step__description,
.wc-block-components-checkout-step__heading-content {
	font-size: var(--knack-font-size-sm);
	color: var(--knack-text-secondary);
	font-weight: 400;
}

/* Form inputs — softer fill, theme-purple focus with subtle glow. */
.wc-block-components-text-input,
.wc-block-components-address-form .wc-block-components-text-input,
.wc-block-components-combobox {
	margin: 0;
}

.wc-block-components-text-input input.input-text,
.wc-block-components-text-input input[type="text"],
.wc-block-components-text-input input[type="email"],
.wc-block-components-text-input input[type="tel"],
.wc-block-components-text-input input[type="number"],
.wc-block-components-combobox .components-form-token-field__input-container,
.wc-block-components-select .wc-block-components-select__select {
	background: var(--knack-bg);
	border: 1px solid var(--knack-border);
	border-radius: var(--knack-radius-lg);
	min-height: 56px;
	padding: 18px 16px 6px;
	font-family: var(--knack-font-body);
	font-size: var(--knack-font-size-base);
	color: var(--knack-text);
	transition: border-color var(--knack-transition), box-shadow var(--knack-transition), background var(--knack-transition);
}

.wc-block-components-text-input input.input-text:hover,
.wc-block-components-text-input input[type="email"]:hover,
.wc-block-components-text-input input[type="text"]:hover,
.wc-block-components-text-input input[type="tel"]:hover {
	border-color: var(--knack-text-muted);
}

.wc-block-components-text-input input.input-text:focus,
.wc-block-components-text-input input[type="email"]:focus,
.wc-block-components-text-input input[type="text"]:focus,
.wc-block-components-text-input input[type="tel"]:focus,
.wc-block-components-text-input input[type="number"]:focus,
.wc-block-components-combobox .components-form-token-field__input-container:focus-within,
.wc-block-components-select .wc-block-components-select__select:focus,
.wc-block-components-select:focus-within .wc-block-components-select__select {
	border-color: var(--knack-accent);
	box-shadow: 0 0 0 3px var(--knack-accent-muted);
	outline: none;
	background: var(--knack-bg);
}

/* Floating label — riding on the input border. */
.wc-block-components-text-input label,
.wc-block-components-combobox label {
	font-family: var(--knack-font-body);
	font-size: var(--knack-font-size-base);
	color: var(--knack-text-secondary);
	font-weight: 400;
	left: 16px;
	transition: transform var(--knack-transition), color var(--knack-transition), font-size var(--knack-transition);
}

.wc-block-components-text-input.is-active label,
.wc-block-components-text-input input:focus + label,
.wc-block-components-text-input input:not(:placeholder-shown) + label,
.wc-block-components-combobox.is-active label {
	transform: translateY(-12px) scale(0.85);
	color: var(--knack-text-secondary);
	font-weight: 500;
}

.wc-block-components-text-input.is-active input:focus + label,
.wc-block-components-text-input input:focus + label {
	color: var(--knack-accent);
}

/* Select dropdown caret — line up with the text. */
.wc-block-components-select .wc-block-components-select__select {
	padding-right: 40px;
}

/* "+ Add apartment, suite, unit, etc." link → soft, theme-accent. */
.wc-block-components-address-card__edit,
.wc-block-components-checkout-step a.wc-block-components-button.wc-block-components-button--link,
.wc-block-checkout__add-note .wc-block-components-checkbox__label,
button.wc-block-components-address-form__address_2-toggle {
	color: var(--knack-accent);
	font-weight: 500;
	font-size: var(--knack-font-size-sm);
	text-decoration: none;
}

button.wc-block-components-address-form__address_2-toggle:hover {
	color: var(--knack-accent-hover);
	text-decoration: underline;
}

/* Field validation states — keep them clear without shouting. */
.wc-block-components-text-input.has-error input.input-text,
.wc-block-components-text-input.has-error input[type="text"],
.wc-block-components-text-input.has-error input[type="email"] {
	border-color: var(--knack-danger);
	box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.12);
}

.wc-block-components-validation-error {
	color: var(--knack-danger);
	font-size: var(--knack-font-size-xs);
	margin-top: 6px;
}

/* Checkbox / radio — recolor to theme accent. */
.wc-block-components-checkbox__input:checked + .wc-block-components-checkbox__mark,
input[type="checkbox"]:checked + label::before {
	background: var(--knack-accent);
	border-color: var(--knack-accent);
}

.wc-block-components-radio-control__option input[type="radio"]:checked + .wc-block-components-radio-control__label::before {
	border-color: var(--knack-accent);
}

.wc-block-components-radio-control__option input[type="radio"]:checked + .wc-block-components-radio-control__label::after {
	background: var(--knack-accent);
}

/* Sidebar — Order Summary card. */
.wp-block-woocommerce-checkout-order-summary-block,
.wc-block-components-sidebar {
	background: var(--knack-surface);
	border: 1px solid var(--knack-border-soft);
	border-radius: var(--knack-radius-xl);
	padding: var(--knack-space-lg);
	box-shadow: var(--knack-shadow-card);
}

.wc-block-components-order-summary__title,
.wc-block-components-totals-wrapper > h2,
.wp-block-woocommerce-checkout-order-summary-block .wc-block-components-checkout-step__title {
	font-size: var(--knack-font-size-lg);
	font-weight: 600;
	margin: 0 0 var(--knack-space-md);
	letter-spacing: -0.01em;
}

/* Line item rows — image + name + price. */
.wc-block-components-order-summary-item {
	padding: var(--knack-space-md) 0;
	border-bottom: 1px solid var(--knack-border-soft);
	gap: var(--knack-space-md);
}

.wc-block-components-order-summary-item:last-of-type {
	border-bottom: none;
}

.wc-block-components-order-summary-item__image > img,
.wc-block-components-order-summary-item__image > .wc-block-components-product-image {
	border-radius: var(--knack-radius-lg);
	border: 1px solid var(--knack-border-soft);
	background: var(--knack-bg-secondary);
}

.wc-block-components-order-summary-item__quantity .wc-block-components-order-summary-item__count {
	background: var(--knack-text);
	color: var(--knack-bg);
	font-weight: 600;
	font-size: var(--knack-font-size-xs);
}

.wc-block-components-order-summary-item__title {
	font-weight: 600;
	font-size: var(--knack-font-size-base);
	color: var(--knack-text);
}

.wc-block-components-order-summary-item__individual-prices,
.wc-block-components-order-summary-item__total-price {
	font-size: var(--knack-font-size-sm);
	color: var(--knack-text-secondary);
}

.wc-block-components-order-summary-item__total-price .wc-block-components-formatted-money-amount {
	color: var(--knack-text);
	font-weight: 600;
}

/* Coupon expander panel — clean accordion. */
.wc-block-components-totals-coupon .wc-block-components-panel__button,
.wp-block-woocommerce-checkout-order-summary-coupon-form-block .wc-block-components-panel__button {
	font-weight: 500;
	color: var(--knack-text);
	padding: var(--knack-space-md) 0;
	border-top: 1px solid var(--knack-border-soft);
	border-bottom: 1px solid var(--knack-border-soft);
	font-size: var(--knack-font-size-sm);
}

.wc-block-components-totals-coupon .wc-block-components-panel__button:hover {
	color: var(--knack-accent);
}

.wc-block-components-totals-coupon__form {
	padding: var(--knack-space-md) 0 var(--knack-space-sm);
	gap: var(--knack-space-sm);
}

/* Totals — subtotal, shipping, total. */
.wc-block-components-totals-item {
	padding: var(--knack-space-sm) 0;
	color: var(--knack-text-secondary);
	font-size: var(--knack-font-size-base);
}

.wc-block-components-totals-item__label {
	color: var(--knack-text-secondary);
	font-weight: 500;
}

.wc-block-components-totals-item__value {
	color: var(--knack-text);
	font-weight: 500;
}

/* Final total — bigger, bolder, theme-accent. */
.wc-block-components-totals-footer-item {
	border-top: 1px solid var(--knack-border);
	padding: var(--knack-space-md) 0 0;
	margin-top: var(--knack-space-sm);
}

.wc-block-components-totals-footer-item .wc-block-components-totals-item__label {
	font-size: var(--knack-font-size-lg);
	font-weight: 600;
	color: var(--knack-text);
}

.wc-block-components-totals-footer-item .wc-block-components-totals-item__value {
	font-size: var(--knack-font-size-2xl);
	font-weight: 700;
	color: var(--knack-accent);
	letter-spacing: -0.01em;
}

.wc-block-components-totals-footer-item__description {
	color: var(--knack-text-muted);
	font-size: var(--knack-font-size-xs);
}

/* Place Order / Proceed to Checkout button — primary CTA. */
.wc-block-components-checkout-place-order-button,
.wc-block-cart__submit-button,
.wc-block-components-button.contained {
	background: var(--knack-accent) !important;
	color: var(--knack-accent-text) !important;
	border: none;
	border-radius: var(--knack-radius-lg);
	padding: var(--knack-space-md) var(--knack-space-lg);
	font-family: var(--knack-font-body);
	font-weight: 600;
	font-size: var(--knack-font-size-base);
	min-height: 52px;
	width: 100%;
	box-shadow: 0 4px 12px var(--knack-accent-muted);
	transition: background var(--knack-transition), transform var(--knack-transition), box-shadow var(--knack-transition);
	letter-spacing: 0;
	text-transform: none;
}

.wc-block-components-checkout-place-order-button:hover,
.wc-block-cart__submit-button:hover,
.wc-block-components-button.contained:hover {
	background: var(--knack-accent-hover) !important;
	transform: translateY(-1px);
	box-shadow: 0 6px 16px var(--knack-accent-muted);
}

.wc-block-components-checkout-place-order-button:active,
.wc-block-cart__submit-button:active,
.wc-block-components-button.contained:active {
	transform: translateY(0);
	box-shadow: 0 2px 6px var(--knack-accent-muted);
}

.wc-block-components-checkout-place-order-button:disabled,
.wc-block-cart__submit-button:disabled {
	opacity: 0.55;
	cursor: not-allowed;
	transform: none;
	box-shadow: none;
}

/* Secondary "Return to Cart" link below the place-order button. */
.wc-block-components-checkout-return-to-cart-button {
	color: var(--knack-text-secondary);
	font-weight: 500;
	margin-top: var(--knack-space-md);
}

.wc-block-components-checkout-return-to-cart-button:hover {
	color: var(--knack-accent);
}

/* Payment method picker — radio cards. */
.wc-block-components-payment-methods .wc-block-components-radio-control__option {
	background: var(--knack-bg);
	border: 1px solid var(--knack-border-soft);
	border-radius: var(--knack-radius-lg);
	padding: var(--knack-space-md);
	margin-bottom: var(--knack-space-sm);
	transition: border-color var(--knack-transition), background var(--knack-transition);
}

.wc-block-components-payment-methods .wc-block-components-radio-control__option:hover {
	border-color: var(--knack-text-muted);
}

.wc-block-components-payment-methods .wc-block-components-radio-control__option--checked,
.wc-block-components-payment-methods .wc-block-components-radio-control__option:has(input:checked) {
	border-color: var(--knack-accent);
	background: var(--knack-accent-light);
}

.wc-block-components-payment-method-content {
	padding: var(--knack-space-md) 0 0 var(--knack-space-md);
	color: var(--knack-text-secondary);
	font-size: var(--knack-font-size-sm);
}

/* Notice / error banners. */
.wc-block-components-notices__notice,
.wc-block-store-notice {
	border-radius: var(--knack-radius-lg);
	border-width: 1px;
	font-size: var(--knack-font-size-sm);
	padding: var(--knack-space-md);
}

/* Loading skeletons — slightly less harsh. */
.wc-block-components-skeleton__lines > div {
	background: linear-gradient(90deg, var(--knack-bg-secondary) 0%, var(--knack-bg-tertiary) 50%, var(--knack-bg-secondary) 100%);
}

/* --- Cart Block --- */

.wp-block-woocommerce-cart {
	max-width: var(--knack-container-width);
	margin: var(--knack-space-xl) auto;
	padding: 0 var(--knack-space-lg);
	gap: var(--knack-space-2xl);
}

.wc-block-cart__main,
.wc-block-cart-items {
	display: flex;
	flex-direction: column;
	gap: 0;
}

.wc-block-cart-items {
	background: var(--knack-surface);
	border: 1px solid var(--knack-border-soft);
	border-radius: var(--knack-radius-xl);
	box-shadow: var(--knack-shadow-card);
	overflow: hidden;
}

.wc-block-cart-items__header {
	background: var(--knack-bg-secondary);
	border-bottom: 1px solid var(--knack-border-soft);
	padding: var(--knack-space-md) var(--knack-space-lg);
	font-weight: 600;
	font-size: var(--knack-font-size-sm);
	color: var(--knack-text-secondary);
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.wc-block-cart-items .wc-block-cart-items__row {
	padding: var(--knack-space-lg);
	border-bottom: 1px solid var(--knack-border-soft);
}

.wc-block-cart-items .wc-block-cart-items__row:last-child {
	border-bottom: none;
}

.wc-block-cart-item__image > img {
	border-radius: var(--knack-radius-lg);
}

.wc-block-cart-item__product-name {
	font-weight: 600;
	color: var(--knack-text);
	text-decoration: none;
}

.wc-block-cart-item__product-name:hover {
	color: var(--knack-accent);
}

.wc-block-components-quantity-selector input[type="number"] {
	background: var(--knack-bg);
	border-color: var(--knack-border);
	border-radius: var(--knack-radius);
	min-height: 36px;
}

.wc-block-components-quantity-selector__button {
	color: var(--knack-text-secondary);
}

.wc-block-components-quantity-selector__button:hover {
	color: var(--knack-accent);
}

/* Empty-cart fallback — center it nicely. */
.wp-block-woocommerce-empty-cart-block {
	text-align: center;
	padding: var(--knack-space-2xl) var(--knack-space-lg);
}

/* --- Responsive --- */

@media (max-width: 900px) {
	.wp-block-woocommerce-checkout,
	.wp-block-woocommerce-cart {
		grid-template-columns: 1fr;
		gap: var(--knack-space-lg);
	}

	.wp-block-woocommerce-checkout .wc-block-checkout__sidebar {
		position: static;
		top: auto;
	}
}

@media (max-width: 640px) {
	.wp-block-woocommerce-checkout,
	.wp-block-woocommerce-cart {
		padding: 0 var(--knack-space-md);
		margin: var(--knack-space-md) auto;
	}

	.wc-block-components-checkout-step,
	.wp-block-woocommerce-checkout-order-summary-block {
		padding: var(--knack-space-md);
		border-radius: var(--knack-radius-lg);
	}
}

/* ==========================================================================
   Order Received / Thank-You page (theme override at themes/Knack/woocommerce/checkout/thankyou.php)
   ========================================================================== */

.knack-order-received {
	max-width: 760px;
	margin: var(--knack-space-2xl) auto;
	padding: 0 var(--knack-space-md);
}

.knack-order-received__card {
	background: var(--knack-surface);
	border: 1px solid var(--knack-border-soft);
	border-radius: var(--knack-radius-2xl);
	padding: var(--knack-space-2xl) var(--knack-space-xl);
	text-align: center;
	box-shadow: var(--knack-shadow-card);
	position: relative;
	overflow: hidden;
}

.knack-order-received__card--success {
	background: linear-gradient(180deg, var(--knack-accent-light) 0%, var(--knack-surface) 140px);
}

.knack-order-received__icon {
	width: 72px;
	height: 72px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto var(--knack-space-md);
	background: var(--knack-surface);
	box-shadow: 0 4px 16px var(--knack-accent-muted);
}

.knack-order-received__icon--success {
	background: var(--knack-accent);
	color: var(--knack-accent-text);
}

.knack-order-received__icon--failed {
	background: #fee;
	color: #c12;
}

.knack-order-received__badge {
	display: inline-block;
	padding: 4px 12px;
	border-radius: var(--knack-radius-pill);
	font-size: var(--knack-font-size-xs);
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	background: var(--knack-bg-secondary);
	color: var(--knack-text-secondary);
	margin: 0 0 var(--knack-space-sm);
}

.knack-order-received__badge--processing,
.knack-order-received__badge--on-hold,
.knack-order-received__badge--pending {
	background: #fef3cd;
	color: #7a5d00;
}

.knack-order-received__badge--completed {
	background: #d1f4e0;
	color: #0a5d2f;
}

.knack-order-received__badge--cancelled,
.knack-order-received__badge--refunded {
	background: #fde2e2;
	color: #8a1f1f;
}

.knack-order-received__title {
	font-family: var(--knack-font-heading);
	font-size: var(--knack-font-size-3xl);
	font-weight: 700;
	letter-spacing: -0.02em;
	color: var(--knack-text);
	margin: 0 0 var(--knack-space-md);
	line-height: 1.15;
}

.knack-order-received__desc {
	font-size: var(--knack-font-size-base);
	line-height: 1.6;
	color: var(--knack-text-secondary);
	max-width: 520px;
	margin: 0 auto var(--knack-space-xl);
}

/* Overview list — order #, date, payment, total */
.knack-order-received__overview {
	background: var(--knack-bg-secondary);
	border: 1px solid var(--knack-border-soft);
	border-radius: var(--knack-radius-xl);
	padding: var(--knack-space-md) var(--knack-space-lg);
	margin: 0 0 var(--knack-space-xl);
	text-align: left;
}

.knack-order-received__overview-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 10px 0;
	border-bottom: 1px solid var(--knack-border-soft);
	font-size: var(--knack-font-size-base);
}

.knack-order-received__overview-row:last-child {
	border-bottom: none;
}

.knack-order-received__overview-row dt {
	color: var(--knack-text-secondary);
	font-weight: 500;
	margin: 0;
}

.knack-order-received__overview-row dd {
	color: var(--knack-text);
	margin: 0;
	font-weight: 500;
	text-align: right;
}

.knack-order-received__overview-row--total {
	border-top: 1px solid var(--knack-border);
	margin-top: 4px;
	padding-top: 14px;
}

.knack-order-received__overview-row--total dt {
	font-weight: 600;
	font-size: var(--knack-font-size-lg);
}

.knack-order-received__overview-row--total dd strong {
	font-size: var(--knack-font-size-xl);
	color: var(--knack-accent);
	font-weight: 700;
}

/* Action buttons */
.knack-order-received__actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--knack-space-sm);
	justify-content: center;
	margin: 0;
}

.knack-order-received__actions--top {
	margin-top: var(--knack-space-md);
}

.knack-order-received__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 12px 24px;
	font-weight: 600;
	font-size: var(--knack-font-size-base);
	border-radius: var(--knack-radius-lg);
	text-decoration: none;
	border: 1px solid transparent;
	cursor: pointer;
	transition: transform .15s ease, background .15s ease, box-shadow .15s ease;
	min-height: 44px;
	font-family: var(--knack-font-body);
}

.knack-order-received__btn--primary {
	background: var(--knack-accent);
	color: var(--knack-accent-text);
	box-shadow: 0 4px 12px var(--knack-accent-muted);
}

.knack-order-received__btn--primary:hover {
	background: var(--knack-accent-hover);
	color: var(--knack-accent-text);
	transform: translateY(-1px);
	box-shadow: 0 6px 16px var(--knack-accent-muted);
}

.knack-order-received__btn--ghost {
	background: transparent;
	color: var(--knack-text-secondary);
	border-color: var(--knack-border);
}

.knack-order-received__btn--ghost:hover {
	color: var(--knack-accent);
	border-color: var(--knack-accent);
	background: var(--knack-accent-light);
}

/* Failed card */
.knack-order-received__card--failed {
	background: linear-gradient(180deg, #fff5f5 0%, var(--knack-surface) 140px);
}

/* Sections below the hero — downloads, order details, customer details. */
.knack-order-received__sections {
	margin-top: var(--knack-space-xl);
	display: flex;
	flex-direction: column;
	gap: var(--knack-space-xl);
}

.knack-order-received__sections > h2,
.knack-order-received__sections > .woocommerce-order-details > h2,
.knack-order-received__sections > .woocommerce-customer-details > h2,
.knack-order-received__sections .woocommerce-order-downloads h2 {
	font-family: var(--knack-font-heading);
	font-size: var(--knack-font-size-xl);
	font-weight: 700;
	color: var(--knack-text);
	margin: 0 0 var(--knack-space-md);
	letter-spacing: -0.01em;
}

/* Wrap each section in a card */
.knack-order-received__sections .woocommerce-order-downloads,
.knack-order-received__sections .woocommerce-order-details,
.knack-order-received__sections .woocommerce-customer-details {
	background: var(--knack-surface);
	border: 1px solid var(--knack-border-soft);
	border-radius: var(--knack-radius-xl);
	padding: var(--knack-space-lg);
	box-shadow: var(--knack-shadow-card);
}

/* Order details + downloads tables */
.knack-order-received__sections table.woocommerce-table {
	width: 100%;
	border-collapse: collapse;
	border: none;
	margin: 0;
	background: transparent;
}

.knack-order-received__sections table.woocommerce-table thead th {
	background: var(--knack-bg-secondary);
	border-bottom: 1px solid var(--knack-border);
	color: var(--knack-text-secondary);
	font-size: var(--knack-font-size-sm);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	padding: 10px 14px;
	text-align: left;
}

.knack-order-received__sections table.woocommerce-table thead th:last-child {
	text-align: right;
}

.knack-order-received__sections table.woocommerce-table tbody td {
	padding: 14px;
	border-bottom: 1px solid var(--knack-border-soft);
	vertical-align: middle;
	font-size: var(--knack-font-size-base);
	color: var(--knack-text);
}

.knack-order-received__sections table.woocommerce-table tbody tr:last-child td {
	border-bottom: none;
}

.knack-order-received__sections table.woocommerce-table tbody td.product-name a {
	color: var(--knack-text);
	font-weight: 500;
	text-decoration: none;
}

.knack-order-received__sections table.woocommerce-table tbody td.product-name a:hover {
	color: var(--knack-accent);
}

.knack-order-received__sections table.woocommerce-table tbody td.product-total,
.knack-order-received__sections table.woocommerce-table tbody td:last-child {
	text-align: right;
	font-variant-numeric: tabular-nums;
}

.knack-order-received__sections table.woocommerce-table tfoot th {
	padding: 12px 14px;
	font-weight: 600;
	color: var(--knack-text-secondary);
	border-top: 1px solid var(--knack-border-soft);
	text-align: left;
}

.knack-order-received__sections table.woocommerce-table tfoot td {
	padding: 12px 14px;
	font-weight: 600;
	color: var(--knack-text);
	text-align: right;
	border-top: 1px solid var(--knack-border-soft);
	font-variant-numeric: tabular-nums;
}

.knack-order-received__sections table.woocommerce-table tfoot tr:last-child th,
.knack-order-received__sections table.woocommerce-table tfoot tr:last-child td {
	font-size: var(--knack-font-size-lg);
	color: var(--knack-text);
	border-top: 2px solid var(--knack-border);
}

.knack-order-received__sections table.woocommerce-table tfoot tr:last-child td {
	color: var(--knack-accent);
	font-weight: 700;
	font-size: var(--knack-font-size-xl);
}

/* Vendor link inline in product rows */
.knack-order-received__sections .product-name .ks-vendor-line {
	font-size: var(--knack-font-size-sm);
	color: var(--knack-text-secondary);
	margin-top: 4px;
}

/* Customer details */
.knack-order-received__sections .woocommerce-customer-details address {
	font-style: normal;
	line-height: 1.7;
	color: var(--knack-text);
	font-size: var(--knack-font-size-base);
	padding: 0;
	background: transparent;
	border: none;
}

.knack-order-received__sections .woocommerce-customer-details .woocommerce-customer-details--phone,
.knack-order-received__sections .woocommerce-customer-details .woocommerce-customer-details--email {
	color: var(--knack-text-secondary);
	font-size: var(--knack-font-size-sm);
	margin: 8px 0 0;
}

.knack-order-received__sections .woocommerce-column--billing-address,
.knack-order-received__sections .woocommerce-column--shipping-address {
	padding: 0;
}

/* Print: clean receipt — strip site chrome, expand cards. */
@media print {
	body * { visibility: hidden; }
	.knack-order-received, .knack-order-received * { visibility: visible; }
	.knack-order-received {
		position: absolute; top: 0; left: 0; right: 0;
		max-width: 100%;
		padding: 0;
		margin: 0;
	}
	.knack-order-received__card,
	.knack-order-received__sections .woocommerce-order-downloads,
	.knack-order-received__sections .woocommerce-order-details,
	.knack-order-received__sections .woocommerce-customer-details {
		box-shadow: none !important;
		border: 1px solid #ddd !important;
		background: #fff !important;
	}
	.knack-order-received__btn,
	.knack-order-received__actions { display: none !important; }
	.knack-order-received__icon { box-shadow: none !important; }
	.knack-order-received__card--success { background: #fff !important; }
}

/* Responsive */
@media (max-width: 640px) {
	.knack-order-received {
		margin: var(--knack-space-md) auto;
		padding: 0 var(--knack-space-sm);
	}
	.knack-order-received__card {
		padding: var(--knack-space-xl) var(--knack-space-md);
	}
	.knack-order-received__title {
		font-size: var(--knack-font-size-2xl);
	}
	.knack-order-received__btn {
		flex: 1 1 100%;
	}
	.knack-order-received__overview-row {
		font-size: var(--knack-font-size-sm);
	}
}
