﻿/**
 * B&M WooCommerce Styles
 *
 * Comprehensive styling for Shop, Single Product, Cart, Checkout,
 * and My Account pages — unified with the B&M design system.
 *
 * @package BM_Child
 * @since   1.4.0
 */

/* ==========================================================================
   SHOP / ARCHIVE PAGE
   ========================================================================== */

/* Product grid container — wider to fill the space */
.woocommerce .ast-woocommerce-container,
.woocommerce-page .ast-woocommerce-container {
	max-width: 87.5rem;
	width: 100%;
	margin: 0 auto;
	padding: var(--bm-space-2xl) var(--bm-space-2xl);
}

/* Ensure product grid and content are always visible */
.woocommerce ul.products,
.woocommerce div.product,
.woocommerce .ast-woocommerce-container {
	opacity: 1 !important;
	visibility: visible !important;
}

/* Result count and ordering */
.woocommerce .woocommerce-result-count {
	font-family: var(--bm-font-accent);
	color: var(--bm-grey);
	font-size: var(--bm-text-sm);
}

.woocommerce .woocommerce-ordering select {
	font-family: var(--bm-font-accent) !important;
	font-size: var(--bm-text-sm) !important;
	cursor: pointer;
}

/* Product Cards */
.woocommerce ul.products li.product {
	background: var(--bm-white);
	border: 1px solid var(--bm-border-light);
	border-radius: var(--bm-radius-lg);
	overflow: hidden;
	transition: box-shadow var(--bm-transition-slow), transform var(--bm-transition);
	padding: 0 !important;
	text-align: left;
	/* Ensure products always have intrinsic size for lazy-load calculations */
	min-height: 1px;
}

/* Thumbnail wrapper must be block-level with width for sizes=auto to work */
.woocommerce ul.products li.product .astra-shop-thumbnail-wrap {
	display: block;
	width: 100%;
}

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

/* Product image — explicit sizing prevents lazy-load deadlock on mobile.
   Without aspect-ratio, lazy images with sizes=auto can't compute layout width,
   so they never enter the viewport threshold and never load (blank page). */
.woocommerce ul.products li.product .woocommerce-LoopProduct-link img,
.woocommerce ul.products li.product a img {
	margin: 0 !important;
	border-radius: 0;
	width: 100%;
	height: auto;
	aspect-ratio: 1 / 1;
	object-fit: cover;
}

/* Override WP 6.9 contain-intrinsic-size: 3000px 1500px for shop images —
   the massive default causes layout thrashing with sizes=auto */
.woocommerce ul.products li.product img:is([sizes^="auto" i], [sizes^="auto," i]) {
	contain-intrinsic-size: 300px 300px;
}

.woocommerce ul.products li.product .woocommerce-LoopProduct-link {
	overflow: hidden;
	display: block;
}

/* Product title */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product .woocommerce-loop-category__title {
	font-family: var(--bm-font-heading) !important;
	font-size: var(--bm-text-lg) !important;
	font-weight: 600 !important;
	color: var(--bm-black) !important;
	padding: var(--bm-space-md) var(--bm-space-md) var(--bm-space-xs) !important;
	margin: 0 !important;
}

/* Product price */
.woocommerce ul.products li.product .price {
	color: var(--bm-primary) !important;
	font-family: var(--bm-font-accent) !important;
	font-weight: 700 !important;
	font-size: var(--bm-text-base) !important;
	padding: 0 var(--bm-space-md) !important;
	margin-bottom: var(--bm-space-sm) !important;
}

/* Short description in loop */
.woocommerce ul.products li.product .ast-woo-shop-product-description p {
	font-size: var(--bm-text-sm);
	color: var(--bm-grey);
	padding: 0 var(--bm-space-md);
	line-height: 1.5;
	margin: 0 0 var(--bm-space-sm);
}

/* Add to cart button in loop */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product .added_to_cart {
	margin: var(--bm-space-sm) var(--bm-space-md) var(--bm-space-md) !important;
	background: var(--bm-primary) !important;
	color: var(--bm-white) !important;
	border: none !important;
	border-radius: var(--bm-radius-md) !important;
	font-family: var(--bm-font-accent) !important;
	font-weight: 600 !important;
	font-size: var(--bm-text-sm) !important;
	padding: 0.6rem 1.2rem !important;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	transition: background var(--bm-transition), box-shadow var(--bm-transition) !important;
	display: inline-block !important;
}

.woocommerce ul.products li.product .button:hover {
	background: var(--bm-primary-dark) !important;
	color: var(--bm-white) !important;
	box-shadow: var(--bm-shadow-md) !important;
}

/* Sale badge */
.woocommerce span.onsale {
	background: var(--bm-accent) !important;
	color: var(--bm-black) !important;
	font-family: var(--bm-font-accent) !important;
	font-weight: 700 !important;
	border-radius: var(--bm-radius-full) !important;
	font-size: 0.75rem !important;
	letter-spacing: 0.05em;
	text-transform: uppercase;
}

/* Star ratings */
.woocommerce .star-rating span::before {
	color: var(--bm-accent) !important;
}

/* ==========================================================================
   SINGLE PRODUCT PAGE
   ========================================================================== */

.woocommerce div.product {
	max-width: 75rem;
	margin: 0 auto;
	padding: var(--bm-space-2xl) var(--bm-space-xl);
}

.single-product .bm-page-banner {
	padding-top: var(--bm-space-2xl);
	padding-bottom: var(--bm-space-xl);
}

.single-product.woocommerce .ast-woocommerce-container,
.single-product.woocommerce-page .ast-woocommerce-container {
	padding-top: var(--bm-space-xl);
	padding-bottom: var(--bm-space-xl);
}

.single-product.woocommerce div.product,
.single-product.woocommerce-page div.product {
	max-width: 68rem;
	padding-top: 0;
	padding-bottom: 0;
}

.single-product div.product .summary > .woocommerce-breadcrumb,
.single-product div.product .single-product-category,
.single-product div.product .product_meta {
	display: none !important;
}

/* Product gallery */
.woocommerce div.product div.images {
	border-radius: var(--bm-radius-lg);
	overflow: hidden;
	box-shadow: var(--bm-shadow-md);
	background: var(--bm-cream);
}

.woocommerce div.product div.images img {
	border-radius: var(--bm-radius-lg);
}

/* Product title */
.woocommerce div.product .product_title {
	font-family: var(--bm-font-heading) !important;
	font-size: var(--bm-text-3xl) !important;
	font-weight: 700 !important;
	color: var(--bm-black) !important;
	margin-bottom: var(--bm-space-sm) !important;
}

/* Price */
.woocommerce div.product p.price,
.woocommerce div.product span.price {
	font-family: var(--bm-font-accent) !important;
	font-size: var(--bm-text-xl) !important;
	font-weight: 700 !important;
	color: var(--bm-primary) !important;
}

/* Description / macros */
.woocommerce div.product .woocommerce-product-details__short-description {
	font-size: var(--bm-text-base);
	color: var(--bm-grey);
	line-height: 1.65;
	margin-bottom: var(--bm-space-lg);
}

.woocommerce div.product .woocommerce-product-details__short-description strong {
	color: var(--bm-dark);
}

.woocommerce div.product .bm-product-macros {
	border: 1px solid rgba(106, 142, 35, 0.18);
	border-radius: var(--bm-radius-md);
	background: rgba(106, 142, 35, 0.06);
	margin: 0 0 var(--bm-space-lg);
	padding: var(--bm-space-md);
}

.woocommerce div.product .bm-product-macros__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--bm-space-md);
	margin-bottom: var(--bm-space-sm);
}

.woocommerce div.product .bm-product-macros__head span {
	font-family: var(--bm-font-accent);
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--bm-secondary);
}

.woocommerce div.product .bm-product-macros__head h2 {
	font-family: var(--bm-font-heading) !important;
	font-size: var(--bm-text-lg) !important;
	line-height: 1.2;
	color: var(--bm-black) !important;
	margin: 0 !important;
}

.woocommerce div.product .bm-product-macros__grid {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 0.5rem;
	margin: 0;
}

.woocommerce div.product .bm-product-macros__item {
	min-width: 0;
	border-radius: var(--bm-radius-sm);
	background: var(--bm-white);
	padding: 0.65rem 0.7rem;
	text-align: center;
	box-shadow: var(--bm-shadow-sm);
}

.woocommerce div.product .bm-product-macros__item dt {
	display: block;
	color: var(--bm-grey);
	font-family: var(--bm-font-accent);
	font-size: 0.72rem;
	font-weight: 700;
	line-height: 1.2;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin: 0 0 0.25rem;
}

.woocommerce div.product .bm-product-macros__item dd {
	color: var(--bm-black);
	font-family: var(--bm-font-accent);
	font-size: var(--bm-text-base);
	font-weight: 800;
	line-height: 1.1;
	margin: 0;
}

/* Quantity input */
.woocommerce .quantity .qty {
	border: 1px solid var(--bm-toasted-tan) !important;
	border-radius: var(--bm-radius-md) !important;
	font-family: var(--bm-font-accent) !important;
	font-weight: 600 !important;
	width: 4.375rem !important;
	text-align: center !important;
}

/* Single add to cart button */
.woocommerce div.product form.cart .button,
.woocommerce div.product .single_add_to_cart_button {
	background: var(--bm-primary) !important;
	color: var(--bm-white) !important;
	border: none !important;
	border-radius: var(--bm-radius-md) !important;
	font-family: var(--bm-font-accent) !important;
	font-weight: 600 !important;
	font-size: 1rem !important;
	padding: 0.85rem 2.5rem !important;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	transition: all var(--bm-transition) !important;
}

.woocommerce div.product form.cart .button:hover {
	background: var(--bm-primary-dark) !important;
	box-shadow: var(--bm-shadow-lg) !important;
	transform: translateY(-2px);
}

/* Tabs */
.woocommerce div.product .woocommerce-tabs ul.tabs {
	padding: 0 !important;
	margin: var(--bm-space-xl) 0 0 !important;
	border-bottom: 2px solid var(--bm-border-light) !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs::before {
	border-bottom-color: var(--bm-border-light) !important;
}

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

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	font-family: var(--bm-font-accent) !important;
	font-weight: 600 !important;
	font-size: var(--bm-text-sm) !important;
	text-transform: uppercase !important;
	letter-spacing: 0.08em !important;
	color: var(--bm-grey) !important;
	padding: var(--bm-space-md) var(--bm-space-lg) !important;
	transition: color var(--bm-transition) !important;
	position: relative;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a::after {
	content: '';
	position: absolute;
	bottom: -2px;
	left: 0;
	right: 0;
	height: 2px;
	background: transparent;
	transition: background var(--bm-transition);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
	color: var(--bm-primary) !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a::after {
	background: var(--bm-primary);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
	color: var(--bm-primary) !important;
}

.woocommerce div.product .woocommerce-tabs .panel {
	padding: var(--bm-space-lg) 0;
	font-family: var(--bm-font-body);
	line-height: 1.7;
	color: var(--bm-grey);
}

.woocommerce div.product .woocommerce-tabs .panel h2 {
	font-family: var(--bm-font-heading) !important;
	font-size: var(--bm-text-xl) !important;
	color: var(--bm-black) !important;
}

/* Meta (SKU, categories) */
.woocommerce div.product .product_meta {
	display: none !important;
}

.woocommerce div.product .product_meta a {
	color: var(--bm-primary) !important;
}

/* Related products */
.woocommerce div.product .related h2,
.woocommerce div.product .upsells h2 {
	font-family: var(--bm-font-heading) !important;
	font-size: var(--bm-text-2xl) !important;
	color: var(--bm-black) !important;
	text-align: center;
	margin-bottom: var(--bm-space-xl);
}

/* ==========================================================================
   CART PAGE
   ========================================================================== */

.woocommerce-cart .woocommerce {
	max-width: 75rem;
	margin: 0 auto;
	padding: var(--bm-space-2xl) var(--bm-space-xl);
}

/* Cart table */
.woocommerce table.shop_table {
	border: 1px solid var(--bm-border-light) !important;
	border-radius: var(--bm-radius-lg) !important;
	overflow: hidden;
	border-collapse: separate !important;
}

.woocommerce table.shop_table thead {
	background: var(--bm-black) !important;
}

.woocommerce table.shop_table thead th {
	font-family: var(--bm-font-accent) !important;
	font-weight: 600 !important;
	font-size: var(--bm-text-sm) !important;
	text-transform: uppercase !important;
	letter-spacing: 0.06em !important;
	color: var(--bm-white) !important;
	padding: var(--bm-space-md) var(--bm-space-lg) !important;
	border: none !important;
}

.woocommerce table.shop_table td {
	padding: var(--bm-space-md) var(--bm-space-lg) !important;
	border-top: 1px solid var(--bm-border-light) !important;
	vertical-align: middle !important;
	font-family: var(--bm-font-body) !important;
	color: var(--bm-dark) !important;
}

.woocommerce table.shop_table .product-name a {
	font-family: var(--bm-font-heading) !important;
	font-weight: 600 !important;
	color: var(--bm-black) !important;
	font-size: var(--bm-text-lg) !important;
}

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

/* Cart item add-on display */
.woocommerce table.shop_table .product-name dl.variation {
	font-size: var(--bm-text-sm);
	color: var(--bm-grey);
	margin: var(--bm-space-xs) 0 0;
}

.woocommerce table.shop_table .product-name dl.variation dt {
	font-weight: 600;
	color: var(--bm-dark);
}

/* Cart thumbnail */
.woocommerce table.shop_table img {
	border-radius: var(--bm-radius-md) !important;
	width: 4.5rem !important;
}

/* Cart totals box — match Astra's specificity */
.woocommerce-cart .cart-collaterals .cart_totals,
.woocommerce .cart_totals,
.woocommerce-page .cart_totals {
	background: var(--bm-black) !important;
	background-color: var(--bm-black) !important;
	border-radius: var(--bm-radius-lg) !important;
	padding: var(--bm-space-xl) !important;
	border: none !important;
	border-color: transparent !important;
	box-shadow: var(--bm-shadow-lg);
}

/* h2 heading — Astra uses .cart-collaterals .cart_totals > h2 with negative margins */
.woocommerce-cart .cart-collaterals .cart_totals > h2,
.woocommerce .cart_totals h2,
.woocommerce-page .cart_totals h2 {
	font-family: var(--bm-font-heading) !important;
	font-size: var(--bm-text-xl) !important;
	color: rgba(254, 254, 250, 0.9) !important;
	background: transparent !important;
	background-color: transparent !important;
	margin: 0 0 var(--bm-space-md) 0 !important;
	padding: 0 0 var(--bm-space-md) 0 !important;
	border-bottom: 1px solid rgba(254, 254, 250, 0.1) !important;
	border-top: none !important;
	border-left: none !important;
	border-right: none !important;
}

.woocommerce .cart_totals table {
	border: none !important;
	margin-bottom: var(--bm-space-md) !important;
}

.woocommerce .cart_totals table td,
.woocommerce .cart_totals table th {
	border-top: 1px solid rgba(254, 254, 250, 0.1) !important;
	padding: var(--bm-space-md) 0 !important;
	font-family: var(--bm-font-body) !important;
	color: rgba(254, 254, 250, 0.7) !important;
}

.woocommerce .cart_totals table th {
	font-family: var(--bm-font-accent) !important;
	font-weight: 600 !important;
	color: rgba(254, 254, 250, 0.5) !important;
}

.woocommerce .cart_totals .order-total td {
	font-size: var(--bm-text-xl) !important;
	font-weight: 700 !important;
	color: var(--bm-white) !important;
}

.woocommerce .cart_totals .order-total td .woocommerce-Price-amount {
	color: var(--bm-primary) !important;
}

.woocommerce .cart_totals .includes_tax,
.woocommerce .cart_totals .tax_label,
.woocommerce .cart_totals small {
	display: block;
	margin-top: var(--bm-space-xs);
	color: rgba(254, 254, 250, 0.58) !important;
	font-size: var(--bm-text-sm) !important;
	line-height: 1.45;
}

.woocommerce .cart_totals .wc-proceed-to-checkout {
	clear: both;
	display: block;
	margin-top: var(--bm-space-lg) !important;
	padding: 0 !important;
}

/* Proceed to checkout button */
.woocommerce .cart_totals .wc-proceed-to-checkout a.checkout-button,
.woocommerce a.checkout-button {
	background: var(--bm-primary) !important;
	color: var(--bm-white) !important;
	border-radius: var(--bm-radius-md) !important;
	font-family: var(--bm-font-accent) !important;
	font-weight: 600 !important;
	font-size: 1rem !important;
	padding: 1rem !important;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	transition: all var(--bm-transition) !important;
	display: block !important;
	position: static !important;
	margin: 0 !important;
}

.woocommerce .cart_totals .wc-proceed-to-checkout a.checkout-button:hover {
	background: var(--bm-primary-dark) !important;
	box-shadow: var(--bm-shadow-lg) !important;
}

/* Coupon field */
.woocommerce .coupon .input-text {
	border-radius: var(--bm-radius-md) 0 0 var(--bm-radius-md) !important;
}

.woocommerce .coupon .button {
	background: var(--bm-dark) !important;
	color: var(--bm-white) !important;
	border-radius: 0 var(--bm-radius-md) var(--bm-radius-md) 0 !important;
	font-family: var(--bm-font-accent) !important;
	font-weight: 600 !important;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

/* Update cart button */
.woocommerce button[name="update_cart"] {
	background: var(--bm-dark) !important;
	color: var(--bm-white) !important;
	border: none !important;
	border-radius: var(--bm-radius-md) !important;
	font-family: var(--bm-font-accent) !important;
	font-weight: 600 !important;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	transition: all var(--bm-transition) !important;
}

.woocommerce button[name="update_cart"]:hover {
	background: var(--bm-black) !important;
}

/* Empty cart state */
.woocommerce .cart-empty.woocommerce-info {
	text-align: center;
	padding: var(--bm-space-3xl) var(--bm-space-xl) !important;
	background: var(--bm-cream) !important;
	border: 1px solid var(--bm-light) !important;
	border-left: 1px solid var(--bm-light) !important;
	border-radius: var(--bm-radius-lg) !important;
	font-family: var(--bm-font-heading) !important;
	font-size: var(--bm-text-xl) !important;
	color: var(--bm-dark) !important;
	box-shadow: none !important;
}

.woocommerce .cart-empty.woocommerce-info::before {
	display: block !important;
	font-size: 3rem !important;
	margin-bottom: var(--bm-space-md) !important;
	color: var(--bm-silver) !important;
}

.woocommerce .return-to-shop a {
	background: var(--bm-primary) !important;
	color: var(--bm-white) !important;
	border-radius: var(--bm-radius-md) !important;
	font-family: var(--bm-font-accent) !important;
	font-weight: 600 !important;
	padding: 0.85rem 2rem !important;
	font-size: 1rem !important;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	transition: all var(--bm-transition) !important;
	display: inline-block !important;
	margin-top: var(--bm-space-md) !important;
}

.woocommerce .return-to-shop a:hover {
	background: var(--bm-primary-dark) !important;
	box-shadow: var(--bm-shadow-lg) !important;
}

/* ==========================================================================
   CHECKOUT PAGE
   ========================================================================== */

.woocommerce-checkout .woocommerce {
	max-width: 75rem;
	margin: 0 auto;
	padding: var(--bm-space-2xl) var(--bm-space-xl);
}

.woocommerce form.checkout_coupon,
.woocommerce form.login,
.woocommerce form.register {
	border: 1px solid var(--bm-border-light) !important;
	border-radius: var(--bm-radius-lg) !important;
	padding: var(--bm-space-xl) !important;
	background: var(--bm-white) !important;
}

/* Checkout section headings (NOT order_review_heading — that has its own box) */
.woocommerce-checkout h3:not(#order_review_heading),
.woocommerce-checkout .woocommerce-billing-fields h3,
.woocommerce-checkout .woocommerce-shipping-fields h3,
.woocommerce-checkout .woocommerce-additional-fields h3 {
	font-family: var(--bm-font-heading) !important;
	font-size: var(--bm-text-xl) !important;
	font-weight: 700 !important;
	color: var(--bm-black) !important;
	padding-bottom: var(--bm-space-md) !important;
	border-bottom: 2px solid var(--bm-border-light) !important;
	margin-bottom: var(--bm-space-lg) !important;
}

/* Form labels */
.woocommerce form .form-row label {
	font-family: var(--bm-font-accent) !important;
	font-weight: 600 !important;
	font-size: var(--bm-text-sm) !important;
	color: var(--bm-dark) !important;
}

.woocommerce form .form-row .required {
	color: var(--bm-primary) !important;
}

/* Order review heading — top of the box */
.woocommerce-checkout #order_review_heading {
	font-family: var(--bm-font-heading) !important;
	font-size: var(--bm-text-xl) !important;
	font-weight: 700 !important;
	color: var(--bm-black) !important;
	border-width: 2px 2px 0 2px !important;
	border-style: solid !important;
	border-color: var(--bm-toasted-tan) !important;
	border-radius: var(--bm-radius-lg) var(--bm-radius-lg) 0 0 !important;
	background: var(--bm-cream) !important;
	padding: 1em 1.5em !important;
	margin: 0 !important;
}

/* Order review body — bottom of the box */
.woocommerce-checkout form #order_review {
	border-width: 0 2px 2px 2px !important;
	border-style: solid !important;
	border-color: var(--bm-toasted-tan) !important;
	border-radius: 0 0 var(--bm-radius-lg) var(--bm-radius-lg) !important;
	background: var(--bm-white) !important;
	padding-left: 1.5em !important;
	padding-right: 1.5em !important;
}

/* Order review table */
.woocommerce-checkout-review-order-table {
	border: none !important;
	border-radius: 0 !important;
	margin: 0 !important;
}

.woocommerce-checkout form #order_review td,
.woocommerce-checkout form #order_review th {
	border-color: var(--bm-light) !important;
}

/* Place order button */
.woocommerce #place_order {
	background: var(--bm-primary) !important;
	color: var(--bm-white) !important;
	border: none !important;
	border-radius: var(--bm-radius-md) !important;
	font-family: var(--bm-font-accent) !important;
	font-weight: 700 !important;
	font-size: 1.1rem !important;
	padding: 1rem 2rem !important;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	width: 100%;
	transition: all var(--bm-transition) !important;
}

.woocommerce #place_order:hover {
	background: var(--bm-primary-dark) !important;
	box-shadow: var(--bm-shadow-lg) !important;
}

/* Payment methods */
.woocommerce-checkout #payment {
	background: var(--bm-cream) !important;
	border-radius: var(--bm-radius-md) !important;
	border: 1px solid var(--bm-light) !important;
	margin-top: var(--bm-space-md) !important;
}

.woocommerce-checkout #payment ul.payment_methods {
	border-bottom: 1px solid var(--bm-light) !important;
	padding: var(--bm-space-md) var(--bm-space-lg) !important;
}

.woocommerce-checkout #payment ul.payment_methods li {
	font-family: var(--bm-font-body) !important;
}

.woocommerce-checkout #payment .payment_box {
	background: rgba(255, 255, 255, 0.6) !important;
	border-radius: var(--bm-radius-md) !important;
	color: var(--bm-grey) !important;
	box-sizing: border-box !important;
	margin: var(--bm-space-md) 0 0 !important;
	max-width: 100% !important;
	overflow: visible !important;
	width: 100% !important;
}

.woocommerce-checkout #payment fieldset.wc-stripe-upe-form {
	border: 0 !important;
	margin: 0 !important;
	min-width: 0 !important;
	padding: 0 !important;
}

.woocommerce-checkout #payment .wc-stripe-upe-element,
.woocommerce-checkout #payment .wc-stripe-elements-field,
.woocommerce-checkout #payment .stripe-card-group,
.woocommerce-checkout #payment .StripeElement,
.woocommerce-checkout #payment .__PrivateStripeElement,
.woocommerce-checkout #payment .__PrivateStripeElement iframe {
	box-sizing: border-box !important;
	display: block !important;
	max-width: 100% !important;
	min-width: 0 !important;
	overflow: visible !important;
	width: 100% !important;
}

.woocommerce-checkout #payment .woocommerce-SavedPaymentMethods-saveNew {
	align-items: flex-start !important;
	background: var(--bm-white) !important;
	border: 1px solid var(--bm-light) !important;
	border-radius: var(--bm-radius-md) !important;
	color: var(--bm-dark) !important;
	display: flex !important;
	gap: 0.6rem !important;
	line-height: 1.45 !important;
	margin: var(--bm-space-md) 0 0 !important;
	padding: 0.75rem 0.85rem !important;
	visibility: visible !important;
}

.woocommerce-checkout #payment .woocommerce-SavedPaymentMethods-saveNew input[type="checkbox"] {
	appearance: auto !important;
	display: inline-block !important;
	flex: 0 0 auto !important;
	height: 1rem !important;
	margin: 0.18rem 0 0 !important;
	opacity: 1 !important;
	position: static !important;
	visibility: visible !important;
	width: 1rem !important;
}

.woocommerce-checkout #payment .woocommerce-SavedPaymentMethods-saveNew label {
	color: var(--bm-dark) !important;
	display: block !important;
	font-family: var(--bm-font-body) !important;
	font-size: var(--bm-text-sm) !important;
	font-weight: 500 !important;
	line-height: 1.45 !important;
	margin: 0 !important;
	opacity: 1 !important;
	visibility: visible !important;
	white-space: normal !important;
}

.bm-checkout-tip {
	border-bottom: 1px solid var(--bm-light);
	border-top: 1px solid var(--bm-light);
	margin: var(--bm-space-md) 0;
	padding: var(--bm-space-md) 0;
}

.bm-checkout-tip__head {
	align-items: flex-start;
	display: flex;
	gap: var(--bm-space-md);
	justify-content: space-between;
	margin-bottom: var(--bm-space-sm);
}

.bm-checkout-tip__title,
.bm-checkout-tip__note {
	margin: 0;
}

.bm-checkout-tip__title {
	color: var(--bm-black);
	font-family: var(--bm-font-heading);
	font-size: var(--bm-text-lg);
	font-weight: 700;
	line-height: 1.25;
}

.bm-checkout-tip__note {
	color: var(--bm-grey);
	font-family: var(--bm-font-body);
	font-size: var(--bm-text-sm);
	line-height: 1.45;
	text-align: right;
}

.bm-checkout-tip__options {
	display: grid;
	gap: 0.5rem;
	grid-template-columns: repeat(5, minmax(0, 1fr));
}

.bm-checkout-tip__option {
	cursor: pointer;
	display: block;
	min-width: 0;
	position: relative;
}

.bm-checkout-tip__option input {
	inset: 0;
	opacity: 0;
	position: absolute;
}

.bm-checkout-tip__option-text {
	align-items: center;
	background: var(--bm-white);
	border: 1px solid var(--bm-border-light);
	border-radius: var(--bm-radius-md);
	color: var(--bm-dark);
	display: flex;
	flex-direction: column;
	font-family: var(--bm-font-accent);
	gap: 0.15rem;
	justify-content: center;
	min-height: 3.5rem;
	padding: 0.55rem 0.35rem;
	text-align: center;
	transition: border-color var(--bm-transition), box-shadow var(--bm-transition), color var(--bm-transition);
	width: 100%;
}

.bm-checkout-tip__option-text strong {
	font-size: var(--bm-text-sm);
	line-height: 1.2;
}

.bm-checkout-tip__option-text small {
	color: var(--bm-grey);
	font-size: 0.72rem;
	font-weight: 700;
	line-height: 1.2;
}

.bm-checkout-tip__option input:checked + .bm-checkout-tip__option-text {
	border-color: var(--bm-primary);
	box-shadow: 0 0 0 2px rgba(216, 106, 61, 0.16);
	color: var(--bm-primary-dark);
}

.bm-checkout-tip__option input:focus-visible + .bm-checkout-tip__option-text {
	outline: 2px solid var(--bm-primary);
	outline-offset: 2px;
}

.bm-checkout-tip__custom {
	align-items: center;
	display: flex;
	gap: var(--bm-space-sm);
	justify-content: flex-end;
	margin-top: var(--bm-space-sm);
}

.bm-checkout-tip__custom label {
	color: var(--bm-dark);
	font-family: var(--bm-font-accent);
	font-size: var(--bm-text-sm);
	font-weight: 700;
	margin: 0;
}

.bm-checkout-tip__amount {
	align-items: center;
	background: var(--bm-white);
	border: 1px solid var(--bm-border-light);
	border-radius: var(--bm-radius-md);
	display: inline-flex;
	gap: 0.25rem;
	min-height: 2.5rem;
	padding: 0 0.75rem;
}

.bm-checkout-tip__amount span {
	color: var(--bm-grey);
	font-family: var(--bm-font-accent);
	font-weight: 700;
}

.bm-checkout-tip__amount input {
	background: transparent !important;
	border: 0 !important;
	box-shadow: none !important;
	color: var(--bm-black);
	font-family: var(--bm-font-accent);
	font-weight: 700;
	min-height: 2.25rem;
	padding: 0 !important;
	width: 5.5rem;
}

.bm-checkout-tip__amount input:focus {
	outline: none;
}

/* ==========================================================================
   MY ACCOUNT PAGE
   ========================================================================== */

/* Account page — force side-by-side layout via flexbox */
.woocommerce-account .entry-content,
.woocommerce-account .ast-woocommerce-container,
.woocommerce-account #primary .ast-woocommerce-container {
	max-width: 75rem !important;
	margin: 0 auto !important;
	padding: var(--bm-space-2xl) var(--bm-space-xl) !important;
}

/* Clear Astra floats — they break everything */
.woocommerce-account .woocommerce-MyAccount-navigation {
	float: none !important;
	width: 16.25rem !important;
	flex-shrink: 0 !important;
}

.woocommerce-account .woocommerce-MyAccount-content {
	float: none !important;
	width: auto !important;
	flex: 1 !important;
	min-width: 0 !important;
}

/* The parent of nav+content — make it flex */
.woocommerce-account .woocommerce-MyAccount-navigation + .woocommerce-MyAccount-content {
	/* This ensures content is after nav — use a shared parent flex */
}

/* Target whatever element directly contains both nav and content */
.woocommerce-account .woocommerce {
	display: flex !important;
	flex-wrap: wrap !important;
	gap: var(--bm-space-xl) !important;
	align-items: flex-start !important;
}

/* Notices should take full width */
.woocommerce-account .woocommerce > .woocommerce-notices-wrapper,
.woocommerce-account .woocommerce > .woocommerce-message,
.woocommerce-account .woocommerce > .woocommerce-error,
.woocommerce-account .woocommerce > .woocommerce-info,
.woocommerce-account .woocommerce > form.woocommerce-form-login,
.woocommerce-account .woocommerce > form.woocommerce-form-register {
	width: 100% !important;
	flex-basis: 100% !important;
}

/* Not-logged-in: single column (login form only) */
.woocommerce-account:not(.logged-in) .woocommerce {
	display: block !important;
}

/* ---- Navigation sidebar ---- */
.woocommerce-account .woocommerce-MyAccount-navigation {
	background: var(--bm-black);
	border-radius: var(--bm-radius-lg);
	overflow: hidden;
	padding: var(--bm-space-md) 0;
	position: sticky;
	top: calc(var(--bm-space-xl) + 5rem);
}

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

.woocommerce-account .woocommerce-MyAccount-navigation ul li {
	margin: 0 !important;
	padding: 0 !important;
	border: none !important;
}

/* Kill ALL border/underline styles Astra might inject */
.woocommerce-account .woocommerce-MyAccount-navigation ul li,
.woocommerce-account .woocommerce-MyAccount-navigation ul li a,
.woocommerce-account .woocommerce-MyAccount-navigation ul li a::before,
.woocommerce-account .woocommerce-MyAccount-navigation ul li a::after {
	border: none !important;
	border-bottom: none !important;
	border-top: none !important;
	box-shadow: none !important;
	text-decoration: none !important;
	outline: none !important;
	background-image: none !important;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
	display: flex;
	align-items: center;
	gap: var(--bm-space-sm);
	padding: 0.85rem var(--bm-space-xl) !important;
	font-family: var(--bm-font-accent) !important;
	font-weight: 500 !important;
	font-size: var(--bm-text-base) !important;
	color: rgba(254, 254, 250, 0.6) !important;
	transition: all var(--bm-transition) !important;
	border-left: 3px solid transparent !important;
	background: transparent !important;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
	background: rgba(254, 254, 250, 0.04) !important;
	color: var(--bm-white) !important;
	border-left-color: rgba(254, 254, 250, 0.15) !important;
}

/* Active state */
.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: rgba(216, 106, 61, 0.08) !important;
	color: var(--bm-white) !important;
	border-left-color: var(--bm-primary) !important;
	font-weight: 600 !important;
}

/* Logout link — subtle differentiation */
.woocommerce-account .woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link--customer-logout {
	margin-top: var(--bm-space-sm);
	border-top: 1px solid rgba(254, 254, 250, 0.06) !important;
	padding-top: var(--bm-space-sm);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link--customer-logout a {
	color: rgba(254, 254, 250, 0.35) !important;
	font-size: var(--bm-text-sm) !important;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link--customer-logout a:hover {
	color: var(--bm-error) !important;
}

/* ---- Content area ---- */
.woocommerce-account .woocommerce-MyAccount-content {
	background: var(--bm-white);
	border-radius: var(--bm-radius-lg);
	border: 1px solid var(--bm-border-light);
	padding: var(--bm-space-2xl);
	min-height: 25rem;
	box-sizing: border-box;
}

.woocommerce-account.woocommerce-view-order .woocommerce-MyAccount-content,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-order-details,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-customer-details,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-order-downloads {
	clear: both;
	display: block !important;
	float: none !important;
	max-width: 100%;
	opacity: 1 !important;
	visibility: visible !important;
	width: 100% !important;
}

.woocommerce-account.woocommerce-view-order .woocommerce-MyAccount-content {
	flex: 1 1 28rem !important;
	min-width: 0 !important;
}

.woocommerce-account .woocommerce-MyAccount-content .woocommerce-order-details,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-customer-details,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-order-downloads {
	margin-top: var(--bm-space-xl);
}

.woocommerce-account .woocommerce-MyAccount-content .woocommerce-order-details:first-child,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-customer-details:first-child,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-order-downloads:first-child {
	margin-top: 0;
}

.woocommerce-account .woocommerce-MyAccount-content .woocommerce-table--order-details,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-order-details table.shop_table {
	display: table !important;
	table-layout: auto;
	width: 100% !important;
}

.woocommerce-account .woocommerce-MyAccount-content .woocommerce-customer-details address {
	background: var(--bm-cream);
	border: 1px solid var(--bm-border-light);
	border-radius: var(--bm-radius-lg);
	color: var(--bm-grey);
	line-height: 1.7;
	padding: var(--bm-space-lg);
}

.woocommerce-order-received .woocommerce-order,
.woocommerce-order-received .woocommerce-order-details,
.woocommerce-order-received .woocommerce-customer-details,
.woocommerce-order-received .woocommerce-order-downloads {
	clear: both;
	display: block !important;
	float: none !important;
	max-width: 100%;
	opacity: 1 !important;
	visibility: visible !important;
	width: 100% !important;
}

/* Dashboard greeting */
.woocommerce-account .woocommerce-MyAccount-content > p:first-child {
	font-size: var(--bm-text-lg);
	color: var(--bm-dark);
	line-height: 1.7;
	padding-bottom: var(--bm-space-lg);
	border-bottom: 1px solid var(--bm-border-light);
	margin-bottom: var(--bm-space-lg);
}

.woocommerce-account .woocommerce-MyAccount-content p {
	color: var(--bm-grey);
	line-height: 1.7;
}

.woocommerce-account .woocommerce-MyAccount-content a {
	color: var(--bm-primary) !important;
	font-weight: 500;
	text-decoration: none !important;
}

.woocommerce-account .woocommerce-MyAccount-content a:hover {
	color: var(--bm-primary-dark) !important;
	text-decoration: underline !important;
}

/* Account content headings */
.woocommerce-account .woocommerce-MyAccount-content h2,
.woocommerce-account .woocommerce-MyAccount-content h3 {
	font-family: var(--bm-font-heading) !important;
	color: var(--bm-black) !important;
	margin-bottom: var(--bm-space-md) !important;
}

/* Orders table */
.woocommerce-account .woocommerce-orders-table {
	border-radius: var(--bm-radius-lg) !important;
	overflow: hidden;
}

/* Account buttons */
.woocommerce-account .woocommerce-MyAccount-content .button,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Button {
	background: var(--bm-primary) !important;
	color: var(--bm-white) !important;
	border: none !important;
	border-radius: var(--bm-radius-md) !important;
	font-family: var(--bm-font-accent) !important;
	font-weight: 600 !important;
	padding: 0.65rem 1.5rem !important;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	font-size: var(--bm-text-sm) !important;
	transition: all var(--bm-transition) !important;
}

.woocommerce-account .woocommerce-MyAccount-content .button:hover {
	background: var(--bm-primary-dark) !important;
	box-shadow: var(--bm-shadow-md) !important;
}

/* ---- Addresses grid ---- */
.woocommerce-account .woocommerce-Addresses {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--bm-space-lg);
}

.woocommerce-account .woocommerce-Addresses .woocommerce-Address {
	background: var(--bm-cream);
	border-radius: var(--bm-radius-lg);
	padding: var(--bm-space-xl);
	border: 1px solid var(--bm-border-light);
}

.woocommerce-account .woocommerce-Addresses .woocommerce-Address header h3 {
	font-family: var(--bm-font-heading) !important;
	font-size: var(--bm-text-lg) !important;
	margin-bottom: var(--bm-space-md) !important;
}

.woocommerce-account .woocommerce-Addresses address {
	font-style: normal;
	color: var(--bm-grey);
	line-height: 1.7;
}

/* ---- Login / Register forms ---- */
.woocommerce-account .woocommerce-form-login,
.woocommerce-account .woocommerce-form-register {
	border: 1px solid var(--bm-border-light) !important;
	border-radius: var(--bm-radius-lg) !important;
	padding: var(--bm-space-2xl) !important;
	background: var(--bm-white) !important;
	max-width: 31.25rem;
	margin: 0 auto !important;
	box-shadow: var(--bm-shadow-sm);
}

/* Override grid for login page (not logged in = no nav) */
.woocommerce-account:not(.logged-in) .woocommerce {
	display: block;
}

.woocommerce-account .woocommerce-form-login h2,
.woocommerce-account .woocommerce-form-register h2 {
	font-family: var(--bm-font-heading) !important;
	text-align: center;
	margin-bottom: var(--bm-space-xl) !important;
}

.woocommerce-account .woocommerce-form-login .button,
.woocommerce-account .woocommerce-form-register .button {
	width: 100%;
	text-align: center;
	padding: 0.85rem !important;
	font-size: 1rem !important;
}

/* ==========================================================================
   PAGINATION
   ========================================================================== */

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
	font-family: var(--bm-font-accent) !important;
	font-weight: 600 !important;
	color: var(--bm-grey) !important;
	border-color: var(--bm-border-light) !important;
	border-radius: var(--bm-radius-md) !important;
	transition: all var(--bm-transition) !important;
}

.woocommerce nav.woocommerce-pagination ul li a:hover {
	background: var(--bm-primary) !important;
	color: var(--bm-white) !important;
	border-color: var(--bm-primary) !important;
}

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

/* ==========================================================================
   DIETARY PREFERENCES (Checkout + My Account)
   ========================================================================== */

.bm-dietary {
	margin-top: var(--bm-space-xl);
}

.bm-dietary h3,
.bm-dietary legend {
	font-family: var(--bm-font-heading) !important;
	font-size: var(--bm-text-xl) !important;
	font-weight: 700 !important;
	color: var(--bm-black) !important;
	padding-bottom: var(--bm-space-md) !important;
	border-bottom: 2px solid var(--bm-border-light) !important;
	margin-bottom: var(--bm-space-lg) !important;
	width: 100%;
}

.bm-dietary--account {
	border: none;
	padding: 0;
	margin-top: var(--bm-space-2xl);
}

.bm-dietary__note {
	font-family: var(--bm-font-accent);
	font-size: var(--bm-text-sm);
	color: var(--bm-grey);
	margin-bottom: var(--bm-space-lg);
}

/* Group containers with accent left border */
.bm-dietary__group {
	padding: var(--bm-space-lg);
	margin-bottom: var(--bm-space-lg);
	border-radius: var(--bm-radius-md);
	background: var(--bm-cream);
	border-left: 4px solid transparent;
}

.bm-dietary__group--allergy {
	border-left-color: var(--bm-error);
}

.bm-dietary__group--sensitivity {
	border-left-color: var(--bm-warning);
}

.bm-dietary__group h4 {
	font-family: var(--bm-font-heading) !important;
	font-size: var(--bm-text-lg) !important;
	font-weight: 600 !important;
	color: var(--bm-dark) !important;
	margin: 0 0 var(--bm-space-xs) !important;
}

.bm-dietary__desc {
	font-size: var(--bm-text-sm);
	color: var(--bm-grey);
	margin: 0 0 var(--bm-space-md);
}

/* Checkbox grid */
.bm-dietary__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--bm-space-sm);
}

.bm-dietary__checkbox {
	display: flex;
	align-items: center;
	gap: var(--bm-space-sm);
	padding: var(--bm-space-sm) var(--bm-space-md);
	background: var(--bm-white);
	border: 1px solid var(--bm-border-light);
	border-radius: var(--bm-radius-md);
	cursor: pointer;
	transition: border-color var(--bm-transition), box-shadow var(--bm-transition);
}

.bm-dietary__checkbox:hover {
	border-color: var(--bm-toasted-tan);
}

.bm-dietary__checkbox input[type="checkbox"] {
	accent-color: var(--bm-primary);
	width: 1.125rem;
	height: 1.125rem;
	flex-shrink: 0;
	cursor: pointer;
}

.bm-dietary__checkbox-label {
	font-family: var(--bm-font-accent);
	font-size: var(--bm-text-sm);
	font-weight: 500;
	color: var(--bm-dark);
}

/* "Other" free-text input */
.bm-dietary__other {
	margin-top: var(--bm-space-sm);
	display: flex;
	align-items: center;
	gap: var(--bm-space-sm);
}

.bm-dietary__other label {
	font-family: var(--bm-font-accent);
	font-size: var(--bm-text-sm);
	font-weight: 600;
	color: var(--bm-dark);
	white-space: nowrap;
}

.bm-dietary__other input[type="text"] {
	flex: 1;
	border: 1px solid var(--bm-border-light);
	border-radius: var(--bm-radius-md);
	padding: var(--bm-space-sm) var(--bm-space-md);
	font-family: var(--bm-font-body);
	font-size: var(--bm-text-sm);
	transition: border-color var(--bm-transition);
}

.bm-dietary__other input[type="text"]:focus {
	outline: none;
	border-color: var(--bm-primary);
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */

@media (max-width: 64em) {
	/* Account sidebar narrower on small laptops */
	.woocommerce-account .woocommerce-MyAccount-navigation {
		width: 13rem !important;
	}
}

@media (min-width: 90em) {
	.woocommerce .ast-woocommerce-container,
	.woocommerce-page .ast-woocommerce-container {
		max-width: 95rem;
	}

	.woocommerce-cart .woocommerce,
	.woocommerce-checkout .woocommerce {
		max-width: 85rem;
	}

	.woocommerce-account .entry-content,
	.woocommerce-account .ast-woocommerce-container,
	.woocommerce-account #primary .ast-woocommerce-container {
		max-width: 85rem !important;
	}
}

@media (min-width: 160em) {
	.woocommerce .ast-woocommerce-container,
	.woocommerce-page .ast-woocommerce-container {
		max-width: 110rem;
	}

	.woocommerce-cart .woocommerce,
	.woocommerce-checkout .woocommerce {
		max-width: 95rem;
	}

	.woocommerce-account .entry-content,
	.woocommerce-account .ast-woocommerce-container,
	.woocommerce-account #primary .ast-woocommerce-container {
		max-width: 95rem !important;
	}
}

/* Astra switches to mobile layout at 921px — match that breakpoint (57.5em) */
@media (max-width: 57.5em) {
	/* Ensure content area is always visible and properly sized on mobile */
	.site-content .ast-container {
		display: block !important;
		width: 100% !important;
	}

	#primary,
	#primary .site-main,
	.ast-woocommerce-container {
		display: block !important;
		width: 100% !important;
		min-height: 50vh;
	}

	.woocommerce .ast-woocommerce-container,
	.woocommerce-cart .woocommerce,
	.woocommerce-checkout .woocommerce,
	.woocommerce-account .woocommerce {
		padding: var(--bm-space-xl) var(--bm-space-md);
	}

	/* Checkout columns must not retain WooCommerce desktop floats on phones. */
	.woocommerce-checkout form.checkout,
	.woocommerce-checkout form.checkout .col2-set,
	.woocommerce-checkout form.checkout #customer_details,
	.woocommerce-checkout form.checkout #order_review_heading,
	.woocommerce-checkout form.checkout #order_review {
		box-sizing: border-box !important;
		clear: both !important;
		display: block !important;
		float: none !important;
		max-width: 100% !important;
		width: 100% !important;
	}

	.woocommerce-checkout form.checkout .col2-set .col-1,
	.woocommerce-checkout form.checkout .col2-set .col-2,
	.woocommerce-checkout form.checkout .form-row-first,
	.woocommerce-checkout form.checkout .form-row-last {
		box-sizing: border-box !important;
		clear: both !important;
		float: none !important;
		max-width: 100% !important;
		width: 100% !important;
	}

	.woocommerce-checkout form.checkout #order_review_heading {
		margin-top: var(--bm-space-xl) !important;
	}

	.woocommerce-checkout form.checkout #order_review {
		padding-left: var(--bm-space-md) !important;
		padding-right: var(--bm-space-md) !important;
	}

	.woocommerce-checkout #payment,
	.woocommerce-checkout #payment ul.payment_methods,
	.woocommerce-checkout #payment ul.payment_methods li,
	.woocommerce-checkout #payment .payment_box,
	.woocommerce-checkout #payment fieldset.wc-stripe-upe-form,
	.woocommerce-checkout #payment .wc-stripe-upe-element,
	.woocommerce-checkout #payment .wc-stripe-elements-field,
	.woocommerce-checkout #payment .stripe-card-group,
	.woocommerce-checkout #payment .StripeElement,
	.woocommerce-checkout #payment .__PrivateStripeElement,
	.woocommerce-checkout #payment .__PrivateStripeElement iframe {
		box-sizing: border-box !important;
		display: block !important;
		max-width: 100% !important;
		min-width: 0 !important;
		overflow: visible !important;
		width: 100% !important;
	}

	.woocommerce-checkout #payment ul.payment_methods {
		padding: var(--bm-space-md) !important;
	}

	.woocommerce-checkout #payment .payment_box {
		padding-left: var(--bm-space-sm) !important;
		padding-right: var(--bm-space-sm) !important;
	}

	.bm-checkout-tip__head,
	.bm-checkout-tip__custom {
		align-items: stretch;
		flex-direction: column;
	}

	.bm-checkout-tip__note {
		text-align: left;
	}

	.bm-checkout-tip__options {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.bm-checkout-tip__amount {
		width: 100%;
	}

	.bm-checkout-tip__amount input {
		flex: 1;
		width: auto;
	}

	@media (max-width: 30em) {
		.woocommerce-checkout form.checkout #order_review {
			padding-left: var(--bm-space-sm) !important;
			padding-right: var(--bm-space-sm) !important;
		}

		.woocommerce-checkout #payment ul.payment_methods {
			padding-left: var(--bm-space-sm) !important;
			padding-right: var(--bm-space-sm) !important;
		}

		.woocommerce-checkout #payment .payment_box {
			padding-left: 0 !important;
			padding-right: 0 !important;
		}
	}

	/* Stack account layout on mobile */
	.woocommerce-account .woocommerce {
		flex-direction: column !important;
	}

	.woocommerce-account .woocommerce-MyAccount-navigation {
		width: 100% !important;
		position: static;
	}

	.woocommerce-account .woocommerce-MyAccount-content {
		padding: var(--bm-space-lg);
		width: 100% !important;
	}

	/* Stack addresses */
	.woocommerce-account .woocommerce-Addresses {
		grid-template-columns: 1fr;
	}

	/* Cart table responsive */
	.woocommerce table.shop_table td {
		padding: var(--bm-space-sm) var(--bm-space-md) !important;
	}

	/* Single product — explicit width prevents initial render blank on mobile */
	.woocommerce div.product {
		max-width: 100%;
		width: 100%;
		padding: var(--bm-space-xl) var(--bm-space-md);
	}

	.single-product.woocommerce .ast-woocommerce-container,
	.single-product.woocommerce-page .ast-woocommerce-container,
	.single-product.woocommerce div.product,
	.single-product.woocommerce-page div.product {
		padding-left: var(--bm-space-md);
		padding-right: var(--bm-space-md);
	}

	.woocommerce div.product .bm-product-macros__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	/* Product grid container */
	.woocommerce .ast-woocommerce-container,
	.woocommerce-page .ast-woocommerce-container {
		max-width: 100%;
	}

	/* Product cards — single column on mobile with explicit dimensions
	   so sizes=auto lazy images can compute their layout width */
	.woocommerce ul.products {
		display: grid !important;
		grid-template-columns: 1fr !important;
		width: 100% !important;
		gap: var(--bm-space-lg);
	}

	.woocommerce ul.products li.product {
		width: 100% !important;
		max-width: 100% !important;
		margin: 0 !important;
		float: none !important;
	}

	/* Dietary checkbox grid — 2 columns on mobile */
	.bm-dietary__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

.bm-fulfillment-field .woocommerce-input-wrapper {
	display: flex;
	flex-wrap: wrap;
	gap: var(--bm-space-md);
}

.bm-fulfillment-field label.radio {
	display: inline-flex;
	align-items: center;
	gap: var(--bm-space-xs);
	border: 1px solid var(--bm-border-light);
	border-radius: var(--bm-radius-md);
	padding: 0.75rem 1rem;
	background: var(--bm-white);
	font-weight: 700;
}

.bm-fulfillment-doordash-fields {
	border: 1px solid rgba(216, 106, 61, 0.28);
	border-radius: var(--bm-radius-md);
	background: rgba(216, 106, 61, 0.06);
	padding: var(--bm-space-md);
	margin-bottom: var(--bm-space-lg);
}
