/*
 * WooCommerce Dark Mode — Moto Deal Fribourg
 *
 * Styles for shop archive, single product, cart, checkout & account pages.
 * Loaded conditionally only on WooCommerce pages.
 *
 * @package MotoDealFribourg
 * @since   1.0.0
 */

/* ==========================================================================
   Kadence WooCommerce Overrides — Layout reset
   ========================================================================== */

.woocommerce-page .entry-content-wrap,
.woocommerce-page .content-wrap,
.post-type-archive-product .entry-content-wrap,
.post-type-archive-product .content-wrap,
.tax-product_cat .entry-content-wrap,
.tax-product_cat .content-wrap {
	padding: 0 !important;
	max-width: none !important;
}

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

/* Grid layout */
ul.products {
	display: grid !important;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-lg);
	list-style: none;
	padding: 0;
	margin: 0 0 var(--space-2xl);
}

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

@media (max-width: 480px) {
	ul.products {
		grid-template-columns: 1fr;
	}
}

/* Product card */
ul.products li.product {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	overflow: hidden;
	transition: border-color var(--transition-base), transform var(--transition-base);
	margin: 0 !important;
	padding: 0 !important;
	width: 100% !important;
	float: none !important;
}

ul.products li.product:hover {
	border-color: var(--color-accent-border);
	transform: translateY(-2px);
}

/* Product image */
ul.products li.product .woocommerce-loop-product__link img,
ul.products li.product .kadence-product-image-wrap img,
ul.products li.product a img {
	width: 100%;
	height: 240px;
	object-fit: cover;
	display: block;
	border-radius: 0;
	margin: 0 !important;
}

/* Product details area */
ul.products li.product .product-details,
ul.products li.product .entry-content-wrap {
	padding: var(--space-md);
}

/* Product title */
ul.products li.product .woocommerce-loop-product__title,
ul.products li.product h2 {
	font-family: var(--font-heading);
	font-size: 1rem;
	font-weight: 700;
	color: var(--color-text);
	margin: 0 0 var(--space-sm);
	line-height: 1.3;
}

ul.products li.product a {
	color: var(--color-text);
	text-decoration: none;
}

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

/* Product price */
ul.products li.product .price {
	font-family: var(--font-heading);
	font-weight: 800;
	font-size: 1.125rem;
	color: var(--color-text);
	margin-bottom: var(--space-sm);
}

ul.products li.product .price del {
	color: var(--color-muted);
	font-weight: 400;
	font-size: 0.875rem;
	text-decoration: line-through;
	opacity: 1;
}

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

/* Sale badge */
ul.products li.product .onsale,
.woocommerce span.onsale {
	background-color: var(--color-accent);
	color: #fff;
	font-family: var(--font-heading);
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	border-radius: var(--radius-sm);
	padding: 4px 10px;
	line-height: 1.4;
	min-height: auto;
	min-width: auto;
	top: 8px;
	right: 8px;
	left: auto;
}

/* Add to cart button in grid */
ul.products li.product .button,
ul.products li.product .add_to_cart_button {
	width: 100%;
	margin-top: var(--space-sm);
	font-size: 0.8125rem;
	padding: 0.625rem 1rem;
}

/* Star rating */
ul.products li.product .star-rating,
.woocommerce .star-rating {
	color: #F59E0B;
}

/* ==========================================================================
   Shop Archive — Result count, Ordering, Breadcrumb
   ========================================================================== */

.woocommerce-result-count {
	color: var(--color-muted);
	font-size: 0.875rem;
}

.woocommerce-ordering select {
	background-color: var(--color-surface-2);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	color: var(--color-text);
	padding: 0.5rem 0.75rem;
	font-family: var(--font-body);
	font-size: 0.875rem;
}

.woocommerce-breadcrumb {
	color: var(--color-muted);
	font-size: 0.875rem;
	margin-bottom: var(--space-lg);
}

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

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

/* Pagination */
.woocommerce nav.woocommerce-pagination {
	margin: var(--space-xl) 0;
}

.woocommerce nav.woocommerce-pagination ul {
	border: none;
	display: flex;
	gap: 4px;
	justify-content: center;
}

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

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	color: var(--color-text);
	padding: 0.5rem 0.875rem;
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: 0.875rem;
	text-decoration: none;
	min-width: auto;
}

.woocommerce nav.woocommerce-pagination ul li a:hover {
	background-color: var(--color-surface-2);
	border-color: var(--color-accent-border);
	color: var(--color-accent);
}

.woocommerce nav.woocommerce-pagination ul li span.current {
	background-color: var(--color-accent);
	border-color: var(--color-accent);
	color: #fff;
}

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

.single-product .entry-content-wrap,
.single-product .content-wrap {
	padding: 0 !important;
	max-width: none !important;
}

/* Product gallery */
.woocommerce div.product div.images {
	margin-bottom: var(--space-lg);
}

.woocommerce div.product div.images img {
	border-radius: var(--radius-md);
	border: 1px solid var(--color-border);
}

.woocommerce div.product div.images .flex-control-thumbs li img {
	border-radius: var(--radius-sm);
	border: 1px solid var(--color-border);
	opacity: 0.6;
	transition: opacity var(--transition-fast), border-color var(--transition-fast);
}

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

/* Product summary */
.woocommerce div.product .product_title {
	font-family: var(--font-heading);
	font-size: 2rem;
	font-weight: 800;
	color: var(--color-text);
	margin-bottom: var(--space-sm);
}

/* Brand display (via product tags) */
.mdf-product-brand {
	font-family: var(--font-heading);
	font-size: 0.8125rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--color-accent);
	margin-bottom: var(--space-sm);
}

/* Price on single product */
.woocommerce div.product p.price,
.woocommerce div.product span.price {
	font-family: var(--font-heading);
	font-weight: 800;
	font-size: 1.75rem;
	color: var(--color-text);
	margin-bottom: var(--space-lg);
}

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

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

/* Short description */
.woocommerce div.product .woocommerce-product-details__short-description {
	color: var(--color-text);
	font-size: 0.9375rem;
	line-height: 1.6;
	margin-bottom: var(--space-lg);
	padding-bottom: var(--space-lg);
	border-bottom: 1px solid var(--color-border);
}

/* Add to cart form */
.woocommerce div.product form.cart {
	margin-bottom: var(--space-lg);
	display: flex;
	align-items: center;
	gap: var(--space-md);
}

.woocommerce div.product form.cart .quantity input.qty {
	background-color: var(--color-surface-2);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	color: var(--color-text);
	font-family: var(--font-heading);
	font-weight: 700;
	width: 70px;
	text-align: center;
	padding: 0.625rem 0.5rem;
}

.woocommerce div.product form.cart button.single_add_to_cart_button {
	flex: 1;
}

/* Product meta (SKU, categories, tags) */
.woocommerce div.product .product_meta {
	border-top: 1px solid var(--color-border);
	padding-top: var(--space-md);
	font-size: 0.875rem;
	color: var(--color-muted);
}

.woocommerce div.product .product_meta > span {
	display: block;
	margin-bottom: var(--space-xs);
}

.woocommerce div.product .product_meta a {
	color: var(--color-text);
}

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

/* ==========================================================================
   Product Tabs
   ========================================================================== */

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

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

.woocommerce div.product .woocommerce-tabs ul.tabs::before {
	display: none;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
	background: none;
	border: none;
	border-bottom: 2px solid transparent;
	padding: 0;
	margin: 0;
	border-radius: 0;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after {
	display: none;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	font-family: var(--font-heading);
	font-size: 0.875rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--color-muted);
	padding: var(--space-sm) var(--space-md);
	display: block;
	text-decoration: none;
	transition: 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 {
	border-bottom-color: var(--color-accent);
}

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

.woocommerce div.product .woocommerce-tabs .panel {
	background: none;
	border: none;
	padding: 0;
	color: var(--color-text);
	font-size: 0.9375rem;
	line-height: 1.6;
}

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

/* ==========================================================================
   Related Products / Upsells
   ========================================================================== */

.woocommerce .related.products,
.woocommerce .upsells.products {
	margin-top: var(--space-2xl);
	padding-top: var(--space-xl);
	border-top: 1px solid var(--color-border);
}

.woocommerce .related.products > h2,
.woocommerce .upsells.products > h2 {
	font-family: var(--font-heading);
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--color-text);
	margin-bottom: var(--space-lg);
}

/* ==========================================================================
   Cart Page
   ========================================================================== */

/* Cart table */
.woocommerce table.shop_table {
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	overflow: hidden;
	border-collapse: separate;
	border-spacing: 0;
}

.woocommerce table.shop_table th {
	background-color: var(--color-surface);
	color: var(--color-text);
	font-family: var(--font-heading);
	font-size: 0.8125rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	padding: var(--space-md);
	border-bottom: 1px solid var(--color-border);
}

.woocommerce table.shop_table td {
	background-color: var(--color-bg);
	color: var(--color-text);
	padding: var(--space-md);
	border-bottom: 1px solid var(--color-border);
	vertical-align: middle;
}

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

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

.woocommerce table.shop_table td.product-remove a.remove {
	color: var(--color-muted) !important;
	font-size: 1.25rem;
	transition: color var(--transition-fast);
}

.woocommerce table.shop_table td.product-remove a.remove:hover {
	color: var(--color-accent) !important;
	background: none;
}

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

/* Cart quantity */
.woocommerce table.shop_table td.product-quantity input.qty {
	background-color: var(--color-surface-2);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	color: var(--color-text);
	width: 60px;
	text-align: center;
	padding: 0.5rem;
	font-family: var(--font-heading);
	font-weight: 700;
}

/* Cart totals */
.woocommerce .cart_totals {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-lg);
}

.woocommerce .cart_totals h2 {
	font-size: 1.25rem;
	margin-bottom: var(--space-md);
}

.woocommerce .cart_totals table.shop_table {
	border: none;
}

.woocommerce .cart_totals table.shop_table th,
.woocommerce .cart_totals table.shop_table td {
	background: none;
	padding: var(--space-sm) 0;
}

.woocommerce .cart_totals .order-total th,
.woocommerce .cart_totals .order-total td {
	font-family: var(--font-heading);
	font-weight: 800;
	font-size: 1.25rem;
	border-top: 1px solid var(--color-border);
	padding-top: var(--space-md);
}

/* Coupon field */
.woocommerce .coupon {
	display: flex;
	gap: var(--space-sm);
	align-items: center;
}

.woocommerce .coupon input#coupon_code {
	max-width: 200px;
}

/* Proceed to checkout button */
.woocommerce .cart_totals .wc-proceed-to-checkout a.checkout-button {
	width: 100%;
	margin-top: var(--space-md);
	font-size: 1rem;
	padding: 0.875rem 1.5rem;
}

/* ==========================================================================
   Checkout Page
   ========================================================================== */

/* Form sections */
.woocommerce-checkout .col2-set {
	margin-bottom: var(--space-xl);
}

.woocommerce-checkout .col2-set .col-1,
.woocommerce-checkout .col2-set .col-2 {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-lg);
	margin-bottom: var(--space-lg);
}

.woocommerce-checkout h3 {
	font-size: 1.25rem;
	margin-bottom: var(--space-lg);
	padding-bottom: var(--space-sm);
	border-bottom: 1px solid var(--color-border);
}

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

.woocommerce form .form-row label {
	color: var(--color-text);
	font-family: var(--font-body);
	font-weight: 500;
	font-size: 0.875rem;
	margin-bottom: var(--space-xs);
}

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

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
	background-color: var(--color-surface-2);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	color: var(--color-text);
	padding: 0.75rem 1rem;
	font-size: 1rem;
	font-family: var(--font-body);
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
	border-color: var(--color-accent);
	box-shadow: 0 0 0 1px var(--color-accent-border);
	outline: none;
}

/* Select2 dropdowns (WC uses select2 for country/state) */
.select2-container--default .select2-selection--single {
	background-color: var(--color-surface-2);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	height: auto;
	padding: 0.625rem 1rem;
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
	color: var(--color-text);
	font-family: var(--font-body);
	font-size: 1rem;
	line-height: 1.4;
	padding: 0;
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
	top: 50%;
	transform: translateY(-50%);
	right: 8px;
}

.select2-container--default .select2-results__option {
	color: var(--color-text);
	padding: 0.5rem 0.75rem;
}

.select2-dropdown {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
}

.select2-container--default .select2-results__option--highlighted[aria-selected],
.select2-container--default .select2-results__option--highlighted[data-selected] {
	background-color: var(--color-accent);
	color: #fff;
}

.select2-container--default .select2-search--dropdown .select2-search__field {
	background-color: var(--color-surface-2);
	border: 1px solid var(--color-border);
	color: var(--color-text);
	padding: 0.5rem;
}

/* Order review table */
.woocommerce-checkout #order_review {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-lg);
}

.woocommerce-checkout #order_review_heading {
	font-size: 1.25rem;
	margin-bottom: var(--space-md);
}

/* Payment methods */
.woocommerce-checkout #payment {
	background-color: var(--color-surface) !important;
	border-radius: var(--radius-md);
}

.woocommerce-checkout #payment ul.payment_methods {
	list-style: none;
	padding: 0;
	border-bottom: 1px solid var(--color-border);
}

.woocommerce-checkout #payment ul.payment_methods li {
	padding: var(--space-md);
	border-bottom: 1px solid var(--color-border);
}

.woocommerce-checkout #payment ul.payment_methods li:last-child {
	border-bottom: none;
}

.woocommerce-checkout #payment ul.payment_methods li label {
	color: var(--color-text);
	font-weight: 600;
	cursor: pointer;
}

.woocommerce-checkout #payment div.payment_box {
	background-color: var(--color-surface-2);
	color: var(--color-text);
	border-radius: var(--radius-sm);
	padding: var(--space-md);
	margin-top: var(--space-sm);
}

.woocommerce-checkout #payment div.payment_box::before {
	border-bottom-color: var(--color-surface-2);
}

.woocommerce-checkout #payment .place-order {
	padding: var(--space-lg);
}

.woocommerce-checkout #payment #place_order {
	width: 100%;
	font-size: 1rem;
	padding: 1rem 1.5rem;
}

/* ==========================================================================
   My Account Page
   ========================================================================== */

.woocommerce-account .woocommerce-MyAccount-navigation {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	overflow: hidden;
}

.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: block;
	padding: var(--space-md);
	color: var(--color-text);
	font-family: var(--font-heading);
	font-size: 0.875rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	text-decoration: none;
	transition: background-color var(--transition-fast), color var(--transition-fast);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
	background-color: var(--color-surface-2);
	color: var(--color-accent);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a {
	background-color: var(--color-accent-bg);
	color: var(--color-accent);
	border-left: 3px solid var(--color-accent);
}

/* Login/Register forms */
.woocommerce-account .woocommerce-form-login,
.woocommerce-account .woocommerce-form-register {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-xl);
}

/* ==========================================================================
   Notices & Messages
   ========================================================================== */

.woocommerce-message,
.woocommerce-info {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-left: 4px solid var(--color-accent);
	border-radius: var(--radius-sm);
	color: var(--color-text);
	padding: var(--space-md) var(--space-lg);
	margin-bottom: var(--space-lg);
}

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

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

.woocommerce-error {
	background-color: var(--color-surface);
	border: 1px solid rgba(239, 68, 68, 0.3);
	border-left: 4px solid #EF4444;
	border-radius: var(--radius-sm);
	color: var(--color-text);
	padding: var(--space-md) var(--space-lg);
	margin-bottom: var(--space-lg);
	list-style: none;
}

.woocommerce-error::before {
	color: #EF4444;
}

/* ==========================================================================
   Widgets — Sidebar / Footer
   ========================================================================== */

/* Price filter */
.woocommerce .widget_price_filter .ui-slider {
	background-color: var(--color-surface-2);
	border-radius: 4px;
}

.woocommerce .widget_price_filter .ui-slider .ui-slider-range {
	background-color: var(--color-accent);
}

.woocommerce .widget_price_filter .ui-slider .ui-slider-handle {
	background-color: var(--color-accent);
	border: 2px solid #fff;
	border-radius: 50%;
	top: -4px;
}

/* Product categories widget */
.woocommerce .widget_product_categories ul {
	list-style: none;
	padding: 0;
}

.woocommerce .widget_product_categories ul li a {
	color: var(--color-text);
	text-decoration: none;
	padding: var(--space-xs) 0;
	display: block;
}

.woocommerce .widget_product_categories ul li a:hover {
	color: var(--color-accent);
}

.woocommerce .widget_product_categories ul li .count {
	color: var(--color-muted);
	font-size: 0.875rem;
}

/* ==========================================================================
   Mini Cart / Cart Widget
   ========================================================================== */

.widget_shopping_cart .cart_list li {
	padding: var(--space-sm) 0;
	border-bottom: 1px solid var(--color-border);
}

.widget_shopping_cart .cart_list li a {
	color: var(--color-text);
	text-decoration: none;
	font-weight: 500;
}

.widget_shopping_cart .cart_list li a:hover {
	color: var(--color-accent);
}

.widget_shopping_cart .cart_list li img {
	border-radius: var(--radius-sm);
	border: 1px solid var(--color-border);
}

.widget_shopping_cart .total {
	font-family: var(--font-heading);
	font-weight: 700;
	color: var(--color-text);
	border-top: 1px solid var(--color-border);
	padding-top: var(--space-sm);
}

.widget_shopping_cart .buttons a {
	margin-bottom: var(--space-xs);
}

/* ==========================================================================
   Responsive — Mobile adjustments
   ========================================================================== */

@media (max-width: 768px) {
	/* Single product title */
	.woocommerce div.product .product_title {
		font-size: 1.5rem;
	}

	/* Single product price */
	.woocommerce div.product p.price,
	.woocommerce div.product span.price {
		font-size: 1.375rem;
	}

	/* Cart table — horizontal scroll */
	.woocommerce table.shop_table {
		display: block;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
	}

	/* Checkout columns — stack */
	.woocommerce-checkout .col2-set .col-1,
	.woocommerce-checkout .col2-set .col-2 {
		padding: var(--space-md);
	}

	/* Tabs — scroll horizontal */
	.woocommerce div.product .woocommerce-tabs ul.tabs {
		overflow-x: auto;
		flex-wrap: nowrap;
		-webkit-overflow-scrolling: touch;
	}

	.woocommerce div.product .woocommerce-tabs ul.tabs li a {
		white-space: nowrap;
		padding: var(--space-sm) var(--space-md);
	}

	/* Cart form stacking */
	.woocommerce div.product form.cart {
		flex-wrap: wrap;
	}

	.woocommerce div.product form.cart .quantity {
		width: 100%;
	}

	.woocommerce div.product form.cart button.single_add_to_cart_button {
		width: 100%;
	}
}

@media (max-width: 480px) {
	/* Cart totals */
	.woocommerce .cart_totals {
		padding: var(--space-md);
	}

	/* Checkout review */
	.woocommerce-checkout #order_review {
		padding: var(--space-md);
	}
}

/* ==========================================================================
   Product Category Cards (if used)
   ========================================================================== */

ul.products li.product-category {
	text-align: center;
}

ul.products li.product-category a {
	display: block;
}

ul.products li.product-category a img {
	height: 180px;
	object-fit: cover;
}

ul.products li.product-category h2.woocommerce-loop-category__title {
	font-size: 1rem;
	padding: var(--space-md);
	margin: 0;
}

ul.products li.product-category h2.woocommerce-loop-category__title .count {
	color: var(--color-muted);
	font-size: 0.8125rem;
	font-weight: 400;
}
