/*
 * MFD — WooCommerce Styles
 *
 * All shop, product-card, single-product, cart, checkout, and account styles.
 * Design tokens and base utilities come from design-system.css (loaded before this).
 * See docs/DESIGN-SPEC.md §1, §3.3–§3.6, §3.16–§3.18, §4.
 *
 * Responsive breakpoints:
 *   max-width: 960px  tablet/mobile
 *   max-width: 640px  phone
 */

/* ============================================================
 * 1. WooCommerce global resets / overrides
 * ============================================================ */

/* Remove WooCommerce's built-in button styles that clash with MFD */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button {
	background: var(--mfd-tan);
	color: var(--mfd-white);
	font-family: var(--mfd-font-body);
	font-weight: 700;
	font-size: 11px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	padding: 14px 28px;
	border-radius: 0;
	border: 1.5px solid transparent;
	line-height: 1;
	transition: background 0.25s ease;
}

.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover {
	background: var(--mfd-tan-dark);
	color: var(--mfd-white);
}

.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt {
	background: var(--mfd-ink);
	color: var(--mfd-white);
}

.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover {
	background: #333;
	color: var(--mfd-white);
}

/* Wipe WooCommerce star-rating (not used in MFD design) */
.woocommerce .star-rating {
	display: none;
}

/* WooCommerce notices — style consistently */
.woocommerce-message,
.woocommerce-error,
.woocommerce-info {
	font-family: var(--mfd-font-body);
	font-size: 13px;
	padding: 14px 20px;
	border-left: 3px solid var(--mfd-tan);
	background: var(--mfd-cream);
	margin-bottom: 20px;
	list-style: none;
}

.woocommerce-error {
	border-left-color: #c0392b;
}

/* WooCommerce breadcrumb — styled via hook defaults in inc/woocommerce.php */
.mfd-breadcrumb {
	padding: 16px 0;
}

.mfd-breadcrumb__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	list-style: none;
	margin: 0;
	padding: 0;
	font-family: var(--mfd-font-body);
	font-size: 11px;
	font-weight: 400;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

.mfd-breadcrumb__item a {
	color: var(--mfd-muted);
	text-decoration: none;
	transition: color var(--mfd-transition);
}

.mfd-breadcrumb__item a:hover {
	color: var(--mfd-tan);
}

.mfd-breadcrumb__item:last-child {
	font-weight: 700;
	color: var(--mfd-ink);
}

.mfd-breadcrumb__sep {
	color: var(--mfd-line);
	font-size: 10px;
}

/* ============================================================
 * 2. WooCommerce main wrapper
 * ============================================================ */

.mfd-wc-main {
	display: block;
}

/* ============================================================
 * 3. ARCHIVE — shop / category listing
 * ============================================================ */

.mfd-archive-header {
	padding-block: clamp(32px, 5vw, 56px);
	background: var(--mfd-cream);
}

.mfd-archive-header .mfd-eyebrow {
	margin-bottom: 10px;
}

.mfd-archive-header__desc {
	margin-top: 14px;
	max-width: 600px;
	font-size: 15px;
	line-height: 1.7;
	color: var(--mfd-muted);
}

.mfd-archive-loop {
	padding-block: clamp(32px, 5vw, 64px);
}

.mfd-archive-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 12px;
	margin-bottom: 28px;
	padding-bottom: 16px;
	border-bottom: var(--mfd-border);
}

/* WooCommerce result count */
.woocommerce-result-count {
	font-family: var(--mfd-font-body);
	font-size: 12px;
	color: var(--mfd-muted);
	margin: 0;
}

/* WooCommerce ordering select */
.woocommerce-ordering select {
	font-family: var(--mfd-font-body);
	font-size: 12px;
	padding: 8px 12px;
	border: var(--mfd-border);
	background: var(--mfd-white);
	color: var(--mfd-ink);
	cursor: pointer;
}

/* WooCommerce pagination */
.woocommerce-pagination {
	margin-top: 40px;
	text-align: center;
}

.woocommerce-pagination ul {
	display: inline-flex;
	flex-wrap: wrap;
	gap: 4px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.woocommerce-pagination ul li a,
.woocommerce-pagination ul li span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	font-family: var(--mfd-font-body);
	font-size: 12px;
	font-weight: 600;
	border: var(--mfd-border);
	color: var(--mfd-ink);
	text-decoration: none;
	transition: background var(--mfd-transition), color var(--mfd-transition);
}

.woocommerce-pagination ul li a:hover {
	background: var(--mfd-tan);
	color: var(--mfd-white);
	border-color: var(--mfd-tan);
}

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

/* ============================================================
 * 4. PRODUCT CARD (content-product.php)
 * DESIGN-SPEC §4.4 — aspect-ratio 1/1 image, gold frame, Lora italic name
 * ============================================================ */

/* Grid: mfd-grid-4 is defined in design-system.css */
.mfd-products {
	list-style: none;
	margin: 0;
	padding: 0;
}

.mfd-product-card {
	display: flex;
	flex-direction: column;
	/* Hover lift effect */
	transition: transform 0.3s ease;
}

.mfd-product-card:hover {
	transform: translateY(-4px);
}

/* Image area: square, tan frame, product-tile background */
.mfd-product-card__image-wrap {
	position: relative;
	aspect-ratio: 1 / 1;
	overflow: hidden;
	background: var(--mfd-product-tile);
	/* .mfd-frame provides 1px solid tan border */
}

.mfd-product-card__image-wrap img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.6s ease;
}

.mfd-product-card:hover .mfd-product-card__image-wrap img {
	transform: scale(1.03);
}

/* Body */
.mfd-product-card__body {
	padding: 14px 4px 4px;
	text-align: center;
	display: flex;
	flex-direction: column;
	gap: 6px;
}

/* Product name — Lora italic 16px */
.mfd-product-card__name {
	font-size: 16px;
	line-height: 1.3;
	/* .mfd-serif.mfd-italic provides Lora italic 800 */
}

.mfd-product-card__name a {
	text-decoration: none;
	color: var(--mfd-ink);
	transition: color var(--mfd-transition);
}

.mfd-product-card__name a:hover {
	color: var(--mfd-tan);
}

/* Description — Montserrat 13px */
.mfd-product-card__desc {
	font-size: 13px;
	line-height: 1.5;
	color: var(--mfd-muted);
	margin: 0;
}

/* Price — italic muted 14px */
.mfd-product-card__price .price,
.mfd-product-card__price .woocommerce-Price-amount {
	font-size: 14px;
	font-style: italic;
	color: var(--mfd-muted);
}

.mfd-product-card__price ins {
	text-decoration: none;
}

/* Add to cart actions area */
.mfd-product-card__actions {
	margin-top: 8px;
}

/* WooCommerce adds .button .add_to_cart_button to the loop button.
   DESIGN-SPEC §3.3 / §1.4: fully-rounded pill, tan fill, white text, inline-flex.
   High-specificity rule overrides the global .woocommerce button.button {border-radius:0} above. */
.mfd-product-card__actions .add_to_cart_button,
.mfd-product-card__actions .button,
.woocommerce .mfd-product-card__actions .add_to_cart_button,
.woocommerce .mfd-product-card__actions .button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 999px !important;
	background-color: var(--mfd-tan) !important;
	color: var(--mfd-white) !important;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	padding: 10px 22px;
	width: 100%;
	border: none;
	text-decoration: none;
	transition: background var(--mfd-transition);
}

.mfd-product-card__actions .add_to_cart_button:hover,
.mfd-product-card__actions .button:hover,
.woocommerce .mfd-product-card__actions .add_to_cart_button:hover,
.woocommerce .mfd-product-card__actions .button:hover {
	background-color: var(--mfd-tan-dark) !important;
	color: var(--mfd-white) !important;
}

/* "Added to cart" state */
.mfd-product-card__actions .added_to_cart {
	font-size: 11px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--mfd-tan);
	text-decoration: none;
}

/* Sale badge */
.woocommerce span.onsale,
.onsale {
	position: absolute;
	top: 10px;
	left: 10px;
	background: var(--mfd-tan);
	color: var(--mfd-white);
	font-family: var(--mfd-font-body);
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	padding: 4px 8px;
	z-index: 2;
	border-radius: 0;
}

/* ============================================================
 * 5. SINGLE PRODUCT  (woocommerce/single-product.php + partials)
 * DESIGN-SPEC §3.6
 * ============================================================ */

/* Breadcrumb is rendered inside mfd-wc-main before single-product layout */
.mfd-single-product {
	padding-block: clamp(32px, 5vw, 56px);
}

/* 2-column layout: gallery (left) + info (right) */
.mfd-single-product__layout {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 44px;
	align-items: start;
}

/* ── Gallery ── */
.mfd-single-product__gallery {
	position: sticky;
	top: 120px;
}

.woocommerce-product-gallery__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* WooCommerce product gallery */
.woocommerce-product-gallery {
	position: relative;
}

.woocommerce-product-gallery .flex-viewport {
	background: var(--mfd-gallery-base);
}

.woocommerce-product-gallery ol.flex-control-nav.flex-control-thumbs {
	display: flex;
	gap: 10px;
	margin-top: 12px;
	padding: 0;
	list-style: none;
}

.woocommerce-product-gallery ol.flex-control-nav.flex-control-thumbs li {
	flex: 0 0 calc(20% - 8px);
}

.woocommerce-product-gallery ol.flex-control-nav.flex-control-thumbs li img {
	width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	cursor: pointer;
	opacity: 0.65;
	transition: opacity var(--mfd-transition);
	border: 2px solid transparent;
}

.woocommerce-product-gallery ol.flex-control-nav.flex-control-thumbs li img.flex-active,
.woocommerce-product-gallery ol.flex-control-nav.flex-control-thumbs li img:hover {
	opacity: 1;
	border-color: var(--mfd-tan);
}

/* ── Info / summary ── */
.mfd-single-product__info {
	display: flex;
	flex-direction: column;
	gap: 0;
}

/* Product title */
.mfd-single-product__title,
.woocommerce div.product h1.product_title {
	font-family: var(--mfd-font-body);
	font-weight: 800;
	font-size: clamp(24px, 3.5vw, 34px);
	line-height: 1.15;
	margin: 0 0 20px;
}

/* ── Product Tabs ── */
.mfd-product-tabs {
	margin-bottom: 24px;
}

.mfd-product-tabs__strip {
	display: flex;
	gap: 0;
	border-bottom: 1px solid var(--mfd-line);
	margin-bottom: 20px;
}

.mfd-product-tabs__trigger {
	background: none;
	border: none;
	padding: 12px 16px;
	font-family: var(--mfd-font-body);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--mfd-muted);
	cursor: pointer;
	border-bottom: 2px solid transparent;
	margin-bottom: -1px;
	transition: color var(--mfd-transition), border-color var(--mfd-transition);
	white-space: nowrap;
}

.mfd-product-tabs__trigger:hover {
	color: var(--mfd-ink);
}

.mfd-product-tabs__trigger.is-active,
.mfd-product-tabs__trigger[aria-selected="true"] {
	color: var(--mfd-ink);
	border-bottom-color: var(--mfd-ink);
}

.mfd-product-tabs__trigger:focus-visible {
	outline: 2px solid var(--mfd-tan);
	outline-offset: -2px;
}

.mfd-product-tabs__panel {
	font-size: 14px;
	line-height: 1.7;
	color: var(--mfd-ink);
}

.mfd-product-tabs__panel p {
	margin: 0 0 12px;
}

.mfd-product-tabs__panel p:last-child {
	margin-bottom: 0;
}

/* Tan italic accent line inside tab content */
.mfd-product-tabs__panel em,
.mfd-product-tabs__panel i {
	color: var(--mfd-tan);
	font-style: italic;
}

/* ── Personalisation box (DESIGN-SPEC §3.6 §4) ── */
.mfd-personalise {
	border: 1px solid var(--mfd-tan);
	padding: 22px;
	margin: 24px 0;
}

.mfd-personalise__title {
	font-family: var(--mfd-font-body);
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	text-align: center;
	margin-bottom: 20px;
}

.mfd-personalise__title strong {
	font-weight: 800;
}

.mfd-personalise__group {
	margin-bottom: 18px;
}

.mfd-personalise__group:last-child {
	margin-bottom: 0;
}

.mfd-personalise__label {
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	margin-bottom: 10px;
	display: block;
}

/* Diamant / Métal pill selector buttons */
.mfd-personalise__options {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.mfd-personalise__option {
	font-family: var(--mfd-font-body);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.06em;
	padding: 8px 16px;
	border: 1px solid var(--mfd-line);
	background: var(--mfd-white);
	color: var(--mfd-ink);
	cursor: pointer;
	transition: border-color var(--mfd-transition), background var(--mfd-transition);
}

.mfd-personalise__option:hover {
	border-color: var(--mfd-tan);
}

.mfd-personalise__option.is-selected,
.mfd-personalise__option[aria-pressed="true"] {
	border: 1.5px solid var(--mfd-ink);
	background: var(--mfd-white);
}

.mfd-personalise__option:focus-visible {
	outline: 2px solid var(--mfd-tan);
	outline-offset: 2px;
}

/* Colour swatches */
.mfd-personalise__swatches {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.mfd-personalise__swatch {
	width: 28px;
	height: 28px;
	border-radius: 50%;
	border: 2px solid transparent;
	cursor: pointer;
	position: relative;
	transition: border-color var(--mfd-transition), box-shadow var(--mfd-transition);
	flex-shrink: 0;
}

.mfd-personalise__swatch:hover {
	border-color: rgba(0, 0, 0, 0.3);
}

.mfd-personalise__swatch.is-selected,
.mfd-personalise__swatch[aria-pressed="true"] {
	border-color: var(--mfd-ink);
	box-shadow: 0 0 0 3px var(--mfd-cream);
}

.mfd-personalise__swatch:focus-visible {
	outline: 2px solid var(--mfd-tan);
	outline-offset: 3px;
}

/* Colour swatch definitions (DESIGN-SPEC §1.1) */
.mfd-swatch--jaune  { background-color: #E8C547; }
.mfd-swatch--rouge  { background-color: #D9534F; }
.mfd-swatch--noir   { background-color: #1A1A1A; }
.mfd-swatch--creme  { background-color: #FAF1DC; border: 1px solid var(--mfd-line); }
.mfd-swatch--vert   { background-color: #5B8C5A; }
.mfd-swatch--bleu   { background-color: #3A5BA0; }
.mfd-swatch--corail { background-color: #C97B5C; }
.mfd-swatch--prune  { background-color: #8E5572; }
.mfd-swatch--gris   { background-color: #A0A0A0; }
.mfd-swatch--rose   { background-color: #F5C9D3; border: 1px solid var(--mfd-line); }
.mfd-swatch--brun   { background-color: #6B4226; }
.mfd-swatch--sarcelle { background-color: #2C5F5F; }

/* Colour label — selected name in tan italic */
.mfd-personalise__colour-label {
	font-size: 12px;
	font-style: italic;
	color: var(--mfd-tan);
}

/* ── Dynamic price ── */
.mfd-single-product__price,
.woocommerce div.product p.price,
.woocommerce div.product span.price {
	font-family: var(--mfd-font-body);
	font-size: 30px;
	font-weight: 800;
	line-height: 1;
	text-align: right;
	margin: 0 0 20px;
	color: var(--mfd-ink);
}

/* JS hook for dynamic price update — see contract below */
[data-mfd-price] {
	display: inline-block;
}

/* ── Quantity stepper + add-to-cart ── */
.mfd-single-product__atc {
	display: flex;
	align-items: stretch;
	gap: 12px;
	margin-bottom: 16px;
}

.mfd-single-product__atc .mfd-qty {
	flex: 0 0 auto;
}

.mfd-single-product__atc .single_add_to_cart_button,
.mfd-single-product__atc button[name="add-to-cart"] {
	flex: 1;
}

/* Reassurance line */
.mfd-single-product__reassurance {
	font-family: var(--mfd-font-body);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	text-align: center;
	color: var(--mfd-muted);
	margin: 0;
}

/* WooCommerce variations form */
.variations_form .variations {
	width: 100%;
	border: none;
}

.variations_form .variations td,
.variations_form .variations th {
	padding: 6px 0;
	border: none;
	vertical-align: middle;
}

.variations_form .variations label {
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

.variations_form select {
	font-family: var(--mfd-font-body);
	font-size: 13px;
	padding: 10px 12px;
	border: var(--mfd-border);
	background: var(--mfd-white);
	width: 100%;
}

.woocommerce-variation-price .price {
	font-size: 24px;
	font-weight: 800;
}

.woocommerce-variation-description p {
	font-size: 13px;
	color: var(--mfd-muted);
	margin-bottom: 0;
}

/* ── Quantity stepper (global/quantity-input.php) ── */
.mfd-qty {
	display: inline-flex;
	align-items: center;
	border: 1px solid var(--mfd-line);
}

.mfd-qty__btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 44px;
	background: none;
	border: none;
	cursor: pointer;
	color: var(--mfd-ink);
	transition: color var(--mfd-transition), background var(--mfd-transition);
	flex-shrink: 0;
}

.mfd-qty__btn:hover {
	background: var(--mfd-cream);
}

.mfd-qty__btn:disabled,
.is-at-min .mfd-qty__btn--minus,
.is-at-max .mfd-qty__btn--plus {
	opacity: 0.4;
	cursor: not-allowed;
}

.mfd-qty__input {
	width: 44px;
	height: 44px;
	text-align: center;
	font-family: var(--mfd-font-body);
	font-weight: 700;
	font-size: 14px;
	border: none;
	border-left: 1px solid var(--mfd-line);
	border-right: 1px solid var(--mfd-line);
	background: var(--mfd-white);
	color: var(--mfd-ink);
	-moz-appearance: textfield;
}

.mfd-qty__input::-webkit-inner-spin-button,
.mfd-qty__input::-webkit-outer-spin-button {
	-webkit-appearance: none;
}

.mfd-qty__input:focus {
	outline: none;
	border-color: var(--mfd-tan);
}

/* ── Related products (single-product/related.php) ── */
.mfd-related-products {
	margin-top: 0;
}

.mfd-related-products__title {
	margin-bottom: 32px;
}

/* ============================================================
 * 6. CART (cart/cart.php)
 * DESIGN-SPEC §3.16 — 2-col: items (1.5fr) / summary (1fr)
 * ============================================================ */

.mfd-cart-section {
	padding-block: clamp(40px, 6vw, 72px);
}

.mfd-cart-header {
	display: flex;
	align-items: baseline;
	gap: 16px;
	margin-bottom: 32px;
}

.mfd-cart-header__count {
	font-size: 14px;
	margin: 0;
}

/* 2-column layout */
.mfd-cart-layout {
	display: grid;
	grid-template-columns: 1.5fr 1fr;
	gap: clamp(24px, 4vw, 48px);
	align-items: start;
}

/* ── Line items table ── */
.mfd-cart-table {
	width: 100%;
	border-collapse: collapse;
}

.mfd-cart-table__head tr {
	background: var(--mfd-cream-soft);
}

.mfd-cart-table__head th {
	font-family: var(--mfd-font-body);
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--mfd-muted);
	padding: 12px 10px;
	border-bottom: var(--mfd-border);
	text-align: left;
}

/* Hide the header on mobile per DESIGN-SPEC §1.5 */
@media (max-width: 640px) {
	.mfd-cart-table__head {
		display: none;
	}
}

.mfd-cart-row td {
	padding: 16px 10px;
	border-bottom: var(--mfd-border);
	vertical-align: middle;
}

/* Mobile data-title cells */
@media (max-width: 640px) {
	.mfd-cart-row td[data-title]::before {
		content: attr(data-title) ": ";
		font-size: 10px;
		font-weight: 700;
		letter-spacing: 0.08em;
		text-transform: uppercase;
		color: var(--mfd-muted);
		display: block;
		margin-bottom: 4px;
	}
}

.mfd-cart-row__thumb-link img,
.product-thumbnail img {
	width: 70px;
	height: 70px;
	object-fit: cover;
	display: block;
	border: var(--mfd-frame);
}

.mfd-cart-row__name-link {
	font-size: 15px;
	text-decoration: none;
	color: var(--mfd-ink);
	transition: color var(--mfd-transition);
}

.mfd-cart-row__name-link:hover {
	color: var(--mfd-tan);
}

/* Variation meta */
.woocommerce-cart-form .variation {
	font-size: 12px;
	color: var(--mfd-muted);
	margin-top: 4px;
}

.woocommerce-cart-form .variation dt,
.woocommerce-cart-form .variation dd {
	display: inline;
	margin: 0;
}

.woocommerce-cart-form .variation dd::after {
	content: " ";
}

.mfd-cart-row__price {
	font-style: italic;
	font-size: 14px;
}

.mfd-cart-row__remove {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	color: var(--mfd-muted);
	text-decoration: none;
	transition: color var(--mfd-transition);
}

.mfd-cart-row__remove:hover {
	color: var(--mfd-ink);
}

/* Actions row */
.mfd-cart-actions-row td {
	padding-top: 20px;
	border-bottom: none;
}

.mfd-cart-coupon {
	display: flex;
	gap: 8px;
	margin-bottom: 12px;
}

.mfd-cart-coupon__field {
	flex: 1;
}

.mfd-cart-continue {
	display: inline-block;
	margin-right: 12px;
}

.mfd-cart-update {
	float: right;
}

/* ── Cart summary box ── */
.mfd-cart-summary {
	padding: clamp(20px, 3vw, 28px);
	background: var(--mfd-cream);
	position: sticky;
	top: 120px;
}

.mfd-cart-summary__title {
	/* DESIGN-SPEC §3.16 / §1.2: Montserrat italic 800 */
	font-family: var(--mfd-font-body);
	font-weight: 800;
	font-style: italic;
	font-size: clamp(20px, 3vw, 26px);
	text-transform: none;
	margin-bottom: 20px;
}

/* WooCommerce cart totals */
.cart-collaterals {
	width: 100%;
}

.cart_totals {
	width: 100%;
}

.cart_totals h2 {
	display: none; /* hidden; MFD summary title replaces it */
}

.cart_totals table {
	width: 100%;
	border-collapse: collapse;
}

.cart_totals table th,
.cart_totals table td {
	padding: 10px 0;
	font-size: 14px;
	border-bottom: var(--mfd-border);
	vertical-align: middle;
}

.cart_totals table th {
	font-weight: 600;
	color: var(--mfd-ink);
}

.cart_totals .order-total th,
.cart_totals .order-total td {
	font-style: italic;
	font-size: 20px;
	font-weight: 800;
	border-bottom: none;
	padding-top: 16px;
}

/* Shipping methods */
.woocommerce-shipping-methods {
	list-style: none;
	margin: 0;
	padding: 0;
}

.woocommerce-shipping-methods li {
	padding: 6px 0;
}

.woocommerce-shipping-methods label {
	font-size: 13px;
	cursor: pointer;
}

.mfd-cart-summary__cta {
	margin-top: 20px;
}

.mfd-cart-summary__checkout-btn {
	width: 100%;
	justify-content: center;
}

.mfd-cart-summary__reassurance {
	font-size: 10px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--mfd-muted);
	text-align: center;
	margin-top: 10px;
	margin-bottom: 0;
}

/* ── Empty cart ── */
.mfd-cart-empty {
	padding: 48px 36px;
	text-align: center;
	max-width: 480px;
	margin-inline: auto;
}

.mfd-cart-empty__headline {
	font-size: 22px;
	margin-bottom: 12px;
}

.mfd-cart-empty__sub {
	color: var(--mfd-muted);
	margin-bottom: 24px;
}

/* ============================================================
 * 7. CHECKOUT (checkout/form-checkout.php)
 * DESIGN-SPEC §3.17 — 2-col: fields (1.4fr) / summary (1fr)
 * ============================================================ */

.mfd-checkout-section {
	padding-block: clamp(40px, 6vw, 72px);
}

/* 2-column layout */
.mfd-checkout-layout {
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: clamp(24px, 4vw, 48px);
	align-items: start;
}

/* ── Step blocks ── */
.mfd-checkout-step {
	margin-bottom: 32px;
}

.mfd-checkout-step__title {
	/* DESIGN-SPEC §3.17 / §1.2: Montserrat italic 800 for checkout section headings */
	font-family: var(--mfd-font-body);
	font-weight: 800;
	font-style: italic;
	font-size: clamp(18px, 2.5vw, 22px);
	margin-bottom: 20px;
	display: flex;
	align-items: baseline;
	gap: 8px;
	text-transform: none;
}

.mfd-checkout-step__num {
	color: var(--mfd-tan);
}

.mfd-checkout-step__body {
	padding-left: 20px;
	border-left: 2px solid var(--mfd-line);
}

/* WooCommerce checkout fields */
.woocommerce-billing-fields,
.woocommerce-shipping-fields {
	width: 100%;
}

.woocommerce-billing-fields h3,
.woocommerce-shipping-fields h3,
.woocommerce-additional-fields h3 {
	display: none; /* MFD step titles replace these */
}

.woocommerce-billing-fields__field-wrapper,
.woocommerce-shipping-fields__field-wrapper {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 14px 16px;
}

.woocommerce-billing-fields .form-row,
.woocommerce-shipping-fields .form-row,
.woocommerce-additional-fields .form-row {
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.woocommerce-billing-fields .form-row-wide,
.woocommerce-shipping-fields .form-row-wide {
	grid-column: 1 / -1;
}

/* Labels */
.woocommerce-billing-fields label,
.woocommerce-shipping-fields label,
.woocommerce form .form-row label {
	font-family: var(--mfd-font-body);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--mfd-ink);
}

/* Inputs */
.woocommerce-billing-fields input,
.woocommerce-billing-fields select,
.woocommerce-billing-fields textarea,
.woocommerce-shipping-fields input,
.woocommerce-shipping-fields select,
.woocommerce-additional-fields textarea,
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row select {
	width: 100%;
	padding: 12px 14px;
	font-family: var(--mfd-font-body);
	font-size: 14px;
	font-style: italic;
	color: var(--mfd-ink);
	background: var(--mfd-white);
	border: 1px solid var(--mfd-line);
	border-radius: 0;
	transition: border-color var(--mfd-transition);
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row select:focus {
	outline: none;
	border-color: var(--mfd-tan);
}

/* Required asterisk */
.required {
	color: var(--mfd-tan);
}

/* Validation error */
.woocommerce-invalid input {
	border-color: #c0392b;
}

.woocommerce-invalid-required-field label::after {
	content: " *";
	color: #c0392b;
}

/* Shipping methods — selectable rows (DESIGN-SPEC §3.17) */
#shipping_method {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

#shipping_method li {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 12px 16px;
	border: 1px solid var(--mfd-line);
	cursor: pointer;
	transition: border-color var(--mfd-transition), background var(--mfd-transition);
}

#shipping_method li:has(input:checked) {
	border: 2px solid var(--mfd-tan);
	background: var(--mfd-cream-soft);
}

#shipping_method li input[type="radio"] {
	accent-color: var(--mfd-tan);
	width: 16px;
	height: 16px;
	flex-shrink: 0;
}

#shipping_method li label {
	font-size: 13px;
	cursor: pointer;
	flex: 1;
	text-transform: none;
	letter-spacing: 0;
	font-weight: 400;
}

/* Payment methods */
#payment {
	background: var(--mfd-cream);
	padding: 20px;
	margin-bottom: 0;
}

#payment ul.payment_methods {
	list-style: none;
	margin: 0 0 16px;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

#payment ul.payment_methods li {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 12px 16px;
	border: 1px solid var(--mfd-line);
	transition: border-color var(--mfd-transition), background var(--mfd-transition);
}

#payment ul.payment_methods li.wc_payment_method.payment_method_selected {
	border: 2px solid var(--mfd-tan);
	background: var(--mfd-cream-soft);
}

#payment ul.payment_methods li label {
	font-size: 13px;
	cursor: pointer;
	flex: 1;
	text-transform: none;
	letter-spacing: 0;
	font-weight: 400;
}

#payment ul.payment_methods li input[type="radio"] {
	accent-color: var(--mfd-tan);
	width: 16px;
	height: 16px;
	flex-shrink: 0;
}

#payment .payment_box {
	padding: 12px;
	background: var(--mfd-white);
	font-size: 13px;
	color: var(--mfd-muted);
}

/* Place order button */
#place_order,
#place_order_summary {
	width: 100%;
	justify-content: center;
	margin-top: 20px;
}

/* ── Order summary (right column) ── */
.mfd-checkout-summary {
	padding: clamp(20px, 3vw, 28px);
	background: var(--mfd-cream);
	position: sticky;
	top: 120px;
}

.mfd-checkout-summary__title {
	font-size: clamp(20px, 3vw, 24px);
	margin-bottom: 20px;
}

.mfd-checkout-summary__item {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	padding: 12px 0;
	border-bottom: var(--mfd-border);
}

.mfd-checkout-summary__thumb img {
	width: 64px;
	height: 64px;
	object-fit: cover;
	border: var(--mfd-frame);
	display: block;
}

.mfd-checkout-summary__item-info {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.mfd-checkout-summary__item-name {
	font-size: 14px;
}

.mfd-checkout-summary__item-qty {
	font-size: 12px;
}

.woocommerce-cart-item-data {
	font-size: 12px;
	color: var(--mfd-muted);
}

.mfd-checkout-summary__item-price {
	font-size: 14px;
	font-style: italic;
	white-space: nowrap;
}

.mfd-checkout-summary__totals {
	padding: 16px 0 0;
}

.mfd-checkout-summary__line {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	font-size: 14px;
	margin-bottom: 8px;
}

.mfd-checkout-summary__line--discount {
	color: var(--mfd-tan);
}

.mfd-checkout-summary__divider {
	border: none;
	border-top: var(--mfd-border);
	margin: 12px 0;
}

.mfd-checkout-summary__total {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	font-size: 22px;
	font-weight: 800;
}

.mfd-checkout-summary__total-amount {
	color: var(--mfd-ink);
}

.mfd-checkout-summary__confirm {
	width: 100%;
	justify-content: center;
	margin-top: 20px;
}

/* ============================================================
 * 8. MY ACCOUNT  (myaccount/)
 * DESIGN-SPEC §3.18 — 2-col: nav sidebar (240px) / content (1fr)
 * ============================================================ */

.mfd-account-section {
	padding-block: clamp(40px, 6vw, 72px);
}

.mfd-account-header {
	margin-bottom: 36px;
}

.mfd-account-header__meta {
	font-size: 14px;
	margin: 8px 0 0;
}

/* 2-column layout */
.mfd-account-layout {
	display: grid;
	grid-template-columns: 240px 1fr;
	gap: clamp(24px, 4vw, 48px);
	align-items: start;
}

/* ── Nav sidebar ── */
.mfd-account-nav {
	background: var(--mfd-cream);
	padding: 8px 0;
}

.mfd-account-nav__list ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.mfd-account-nav__item {
	border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

.mfd-account-nav__link {
	display: block;
	padding: 14px 20px;
	font-family: var(--mfd-font-serif);
	font-size: 14px;
	font-weight: 400;
	text-decoration: none;
	color: var(--mfd-ink);
	border-left: 3px solid transparent;
	transition: color var(--mfd-transition), border-color var(--mfd-transition), background var(--mfd-transition);
}

.mfd-account-nav__link:hover {
	color: var(--mfd-tan);
	background: rgba(0, 0, 0, 0.02);
}

/* Active nav item — tan text + tan left border */
.mfd-account-nav__item.is-active .mfd-account-nav__link,
.mfd-account-nav__item .mfd-account-nav__link[aria-current="page"],
.woocommerce-MyAccount-navigation li.is-active > a,
.woocommerce-MyAccount-navigation li a[aria-current="page"] {
	color: var(--mfd-tan);
	border-left-color: var(--mfd-tan);
	font-weight: 600;
	background: rgba(213, 169, 95, 0.04);
}

/* ── Content panel ── */
.mfd-account-content {
	min-height: 300px;
}

.mfd-account-content h2,
.woocommerce-MyAccount-content h2 {
	font-family: var(--mfd-font-body);
	font-style: italic;
	font-weight: 800;
	font-size: clamp(20px, 3vw, 26px);
	margin-bottom: 20px;
}

/* ── Dashboard stat cards ── */
.mfd-account-stats {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
	margin-bottom: 32px;
}

/* ── Orders table ── */
.woocommerce-orders-table,
.shop_table.order_details {
	width: 100%;
	border-collapse: collapse;
}

.woocommerce-orders-table thead,
.shop_table.order_details thead {
	background: var(--mfd-cream-soft);
}

.woocommerce-orders-table thead th,
.shop_table.order_details thead th {
	font-family: var(--mfd-font-body);
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--mfd-muted);
	padding: 12px 10px;
	text-align: left;
	border-bottom: var(--mfd-border);
}

.woocommerce-orders-table tbody td {
	padding: 14px 10px;
	font-size: 13px;
	border-bottom: var(--mfd-border);
	vertical-align: middle;
}

/* Order status badges */
.woocommerce-orders-table .order-status,
.wc-item-meta .wc-item-meta-label {
	display: inline-block;
	padding: 3px 10px;
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.woocommerce-orders-table mark.order-status.status-completed,
.order-status.woocommerce-order-status-completed {
	background: rgba(91, 140, 90, 0.12);
	color: var(--mfd-status-delivered);
}

.woocommerce-orders-table mark.order-status.status-processing,
.order-status.woocommerce-order-status-processing {
	background: rgba(213, 169, 95, 0.12);
	color: var(--mfd-status-shipped);
}

/* ── Saved configurations cards ── */
.mfd-saved-configs {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
	margin-top: 16px;
}

/* ============================================================
 * 8b. MY ACCOUNT — LOGIN PAGE headings (woocommerce-column__title)
 * DESIGN-SPEC §1.2 / §3.18: Montserrat italic 800, no Anton
 * ============================================================ */

.woocommerce-column__title,
.woocommerce-form-login .woocommerce-column__title,
.woocommerce-form-register .woocommerce-column__title,
.woocommerce-MyAccount-login h2,
.woocommerce-page .woocommerce h2,
.woocommerce-account .woocommerce h2 {
	font-family: var(--mfd-font-body) !important;
	font-weight: 800 !important;
	font-style: italic !important;
	font-size: clamp(20px, 3vw, 26px) !important;
	text-transform: none !important;
	letter-spacing: -0.01em !important;
}

/* ============================================================
 * 9. CHECKOUT ORDER RECEIVED / THANK YOU PAGE
 * ============================================================ */

.woocommerce-order-received .woocommerce {
	max-width: 720px;
	margin-inline: auto;
	text-align: center;
	padding-block: clamp(48px, 8vw, 96px);
}

.woocommerce-thankyou-order-details {
	list-style: none;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 16px;
	margin: 24px 0;
	padding: 0;
}

.woocommerce-thankyou-order-details li {
	border: 1px solid var(--mfd-tan);
	padding: 16px;
}

.woocommerce-thankyou-order-details strong {
	display: block;
	font-size: 18px;
	font-weight: 800;
	margin-bottom: 4px;
}

/* ============================================================
 * 10. WOOCOMMERCE NOTICES
 * ============================================================ */

.woocommerce-cart .woocommerce-info,
.woocommerce-checkout .woocommerce-info,
.woocommerce .woocommerce-message,
.woocommerce .woocommerce-error,
.woocommerce .woocommerce-info {
	padding: 12px 18px 12px 46px;
	border-radius: 0;
	border-top: none;
	border-right: none;
	border-bottom: none;
	border-left: 3px solid var(--mfd-tan);
	background: var(--mfd-cream);
	font-size: 13px;
	list-style: none;
	margin: 0 0 16px;
}

.woocommerce .woocommerce-error {
	border-left-color: #c0392b;
}

/* ============================================================
 * 11. RESPONSIVE
 * ============================================================ */

@media (max-width: 960px) {

	/* Single product: stack gallery above info */
	.mfd-single-product__layout {
		grid-template-columns: 1fr;
		gap: 28px;
	}

	.mfd-single-product__gallery {
		position: static;
	}

	/* Cart: tighten layout */
	.mfd-cart-layout {
		grid-template-columns: 1fr;
	}

	.mfd-cart-summary {
		position: static;
	}

	/* Checkout: stack columns */
	.mfd-checkout-layout {
		grid-template-columns: 1fr;
	}

	.mfd-checkout-summary {
		position: static;
	}

	/* Stacked layout: the summary's "Confirmer & payer" proxy button is the
	   single place-order CTA; the in-step native #place_order is hidden but
	   still triggered by it (see main.js initCheckoutProxy). */
	#place_order {
		display: none;
	}

	/* Account: stack nav above content */
	.mfd-account-layout {
		grid-template-columns: 1fr;
	}

	.mfd-account-nav {
		padding: 4px 0;
	}

	.mfd-account-nav__list ul {
		display: flex;
		flex-wrap: wrap;
	}

	.mfd-account-nav__item {
		flex: 0 0 50%;
	}

	/* Stat cards */
	.mfd-account-stats {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (max-width: 640px) {

	/* Product card grid → 2 cols (design-system.css handles .mfd-grid-4 → 2 cols) */

	/* Single product: prevent horizontal overflow on mobile (visual-qa.md defect #10) */
	.mfd-single-product {
		overflow-x: hidden;
	}

	.mfd-single-product__gallery,
	.woocommerce-product-gallery {
		max-width: 100%;
		overflow: hidden;
		width: 100%;
	}

	.woocommerce-product-gallery .woocommerce-product-gallery__image img,
	.woocommerce-product-gallery .flex-viewport {
		max-width: 100%;
		width: 100% !important;
	}

	.mfd-single-product__info {
		max-width: 100%;
	}

	.mfd-single-product__layout {
		max-width: 100%;
		overflow-x: hidden;
	}

	/* Cart table: reflow to responsive stacked rows */
	.mfd-cart-table {
		display: block;
	}

	.mfd-cart-table thead {
		display: none;
	}

	.mfd-cart-table tbody,
	.mfd-cart-table tr,
	.mfd-cart-table td {
		display: block;
	}

	.mfd-cart-row {
		border-bottom: var(--mfd-border);
		padding-bottom: 16px;
		margin-bottom: 16px;
		display: grid;
		grid-template-columns: 70px 1fr 30px;
		gap: 0 12px;
		align-items: start;
	}

	.mfd-cart-row td {
		border: none;
		padding: 4px 0;
	}

	.mfd-cart-row .product-thumbnail {
		grid-row: 1 / 3;
	}

	.mfd-cart-row .product-name {
		grid-column: 2;
		grid-row: 1;
	}

	.mfd-cart-row .product-quantity,
	.mfd-cart-row .product-subtotal {
		grid-column: 2;
	}

	.mfd-cart-row .product-remove {
		grid-row: 1;
		grid-column: 3;
		justify-self: end;
	}

	.mfd-cart-actions-row td {
		grid-column: 1 / -1;
	}

	/* Checkout billing grid → 1 col */
	.woocommerce-billing-fields__field-wrapper,
	.woocommerce-shipping-fields__field-wrapper {
		grid-template-columns: 1fr;
	}

	/* Account nav: full-width items */
	.mfd-account-nav__item {
		flex: 0 0 100%;
	}

	/* Stat cards: 1 col */
	.mfd-account-stats {
		grid-template-columns: 1fr;
	}

	.mfd-saved-configs {
		grid-template-columns: 1fr;
	}

	/* Product tabs: scrollable strip */
	.mfd-product-tabs__strip {
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
	}

	.mfd-product-tabs__strip::-webkit-scrollbar {
		display: none;
	}

	.mfd-product-tabs__trigger {
		flex-shrink: 0;
		padding: 10px 12px;
	}

}

/* ============================================================
 * 12. SELF-SUFFICIENT REPLACEMENTS FOR WooCommerce bundled CSS
 *
 * WooCommerce's bundled woocommerce.css, woocommerce-layout.css,
 * woocommerce-smallscreen.css, and wc-blocks.css are dequeued in
 * inc/woocommerce.php. This section provides everything those files
 * would have handled, scoped tightly so no rule reaches the theme's
 * global header/footer chrome.
 * ============================================================ */

/* ── 12a. IMAGE RESETS (scoped to WooCommerce content only) ──
 * Replaces .woocommerce img { height: auto } which was the root cause
 * of the header/footer image size regression. We scope strictly to
 * WooCommerce output containers so the rule never touches .mfd-header
 * or .mfd-footer.
 * ---------------------------------------------------------------- */
.woocommerce-page .woocommerce img,
.woocommerce-cart .woocommerce img,
.woocommerce-checkout .woocommerce img,
.woocommerce-account .woocommerce img,
.single-product .woocommerce-product-gallery img,
.woocommerce div.product .woocommerce-product-gallery img {
	max-width: 100%;
	height: auto;
}

/* Product card loop images: governed by the card's own rules (aspect-ratio + object-fit).
 * Reset any auto height so object-fit works properly. */
.mfd-products .woocommerce-loop-product__link img,
.mfd-products .attachment-woocommerce_thumbnail {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* ── 12b. PRODUCT LOOP / GRID ─────────────────────────────────
 * ul.products is WooCommerce's default loop wrapper.
 * Our PHP filter (mfd_loop_start) injects .mfd-products and .mfd-grid-4,
 * so the grid layout comes from design-system.css. These rules handle
 * generic ul.products contexts (e.g. related-products, upsells) that
 * bypass the filter.
 * ---------------------------------------------------------------- */
ul.products {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: clamp(16px, 2.5vw, 28px);
}

ul.products li.product {
	margin: 0;
	padding: 0;
}

/* Fallback for any WC-generated product title / price in the loop */
ul.products li.product .woocommerce-loop-product__title {
	font-family: var(--mfd-font-serif);
	font-size: 16px;
	font-style: italic;
	font-weight: 700;
	padding: 0;
	margin: 0 0 6px;
	color: var(--mfd-ink);
}

ul.products li.product .price {
	font-size: 14px;
	font-style: italic;
	color: var(--mfd-muted);
	display: block;
	margin-bottom: 8px;
}

ul.products li.product .price del {
	opacity: 0.6;
	margin-right: 4px;
}

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

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

/* ── 12c. NOTICES ─────────────────────────────────────────────
 * .demo_store / .woocommerce-store-notice: sticky top notice bar
 * ---------------------------------------------------------------- */
.demo_store,
.woocommerce-store-notice {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 9999;
	background: var(--mfd-tan);
	color: var(--mfd-white);
	font-family: var(--mfd-font-body);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.06em;
	padding: 10px 20px;
	text-align: center;
	margin: 0;
}

.demo_store a,
.woocommerce-store-notice a {
	color: var(--mfd-white);
	text-decoration: underline;
}

/* Notice list base — WooCommerce renders these as <ul> */
.woocommerce .woocommerce-message,
.woocommerce .woocommerce-error,
.woocommerce .woocommerce-info {
	/* Supplemented from section 10; ensure list resets */
	margin: 0 0 16px;
	padding-left: 46px;
	list-style: none;
	position: relative;
}

.woocommerce .woocommerce-message::before,
.woocommerce .woocommerce-info::before {
	font-family: var(--mfd-font-body);
	font-size: 14px;
	font-weight: 800;
	position: absolute;
	left: 16px;
	top: 12px;
	color: var(--mfd-tan);
	content: "\2139"; /* info glyph */
}

.woocommerce .woocommerce-message::before {
	content: "\2714"; /* checkmark */
}

.woocommerce .woocommerce-error::before {
	content: "\26A0"; /* warning */
	color: #c0392b;
}

.woocommerce .woocommerce-message a.button,
.woocommerce .woocommerce-message a.restore-item {
	float: right;
	margin-left: 12px;
	padding: 6px 16px;
	font-size: 11px;
}

/* ── 12d. BUTTONS (supplementary) ────────────────────────────
 * .button.alt, .added_to_cart standalone (outside product card)
 * ---------------------------------------------------------------- */
.woocommerce .button.alt,
.woocommerce input.button.alt,
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button {
	display: inline-block;
	background: var(--mfd-tan);
	color: var(--mfd-white);
	font-family: var(--mfd-font-body);
	font-weight: 700;
	font-size: 11px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	padding: 14px 28px;
	border: 1.5px solid transparent;
	border-radius: 0;
	line-height: 1;
	text-decoration: none;
	cursor: pointer;
	transition: background 0.25s ease;
}

.woocommerce .button.alt:hover,
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:hover {
	background: var(--mfd-tan-dark, #B98E47);
	color: var(--mfd-white);
}

/* "View cart" link that appears after AJAX add-to-cart */
a.added_to_cart {
	display: inline-block;
	font-family: var(--mfd-font-body);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--mfd-tan);
	text-decoration: none;
	margin-top: 6px;
	transition: color var(--mfd-transition);
}

a.added_to_cart:hover {
	color: var(--mfd-ink);
}

/* Disabled button state */
.woocommerce a.button.disabled,
.woocommerce button.button.disabled,
.woocommerce a.button:disabled,
.woocommerce button.button:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

/* ── 12e. FORMS & INPUT WRAPPER ──────────────────────────────
 * .form-row / .woocommerce-form-row / .woocommerce-input-wrapper
 * These are used on login, register, lost-password, checkout, account-edit.
 * ---------------------------------------------------------------- */
.woocommerce form .form-row,
.woocommerce-form-row {
	display: flex;
	flex-direction: column;
	gap: 5px;
	margin-bottom: 14px;
	padding: 0;
}

.woocommerce form .form-row label {
	font-family: var(--mfd-font-body);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--mfd-ink);
	line-height: 1.4;
}

.woocommerce form .form-row label.hidden {
	visibility: hidden;
	display: block;
	height: 0;
	overflow: hidden;
}

.woocommerce form .form-row label.inline {
	display: inline;
	text-transform: none;
	letter-spacing: 0;
	font-weight: 400;
}

/* Input wrapper — wraps the input + optional description tooltip */
.woocommerce-input-wrapper {
	display: block;
	position: relative;
}

.woocommerce-input-wrapper input[type="text"],
.woocommerce-input-wrapper input[type="email"],
.woocommerce-input-wrapper input[type="tel"],
.woocommerce-input-wrapper input[type="password"],
.woocommerce-input-wrapper input[type="number"],
.woocommerce-input-wrapper select,
.woocommerce-input-wrapper textarea {
	width: 100%;
	padding: 12px 14px;
	font-family: var(--mfd-font-body);
	font-size: 14px;
	font-style: italic;
	color: var(--mfd-ink);
	background: var(--mfd-white);
	border: 1px solid var(--mfd-line);
	border-radius: 0;
	transition: border-color var(--mfd-transition);
}

.woocommerce-input-wrapper input:focus,
.woocommerce-input-wrapper select:focus,
.woocommerce-input-wrapper textarea:focus {
	outline: none;
	border-color: var(--mfd-tan);
}

/* Password strength meter */
.woocommerce-password-strength {
	font-size: 12px;
	padding: 6px 10px;
	margin-top: 4px;
	font-family: var(--mfd-font-body);
}

.woocommerce-password-strength.strong { background: rgba(91,140,90,.15); color: #3a7a39; }
.woocommerce-password-strength.good   { background: rgba(213,169,95,.15); color: #8a6500; }
.woocommerce-password-strength.short,
.woocommerce-password-strength.bad    { background: rgba(192,57,43,.1);   color: #c0392b; }

/* Password hint text */
.woocommerce-password-hint {
	font-size: 12px;
	color: var(--mfd-muted);
	margin-top: 4px;
	display: block;
}

/* ── 12f. SHOP TOOLBAR (result-count / ordering) ─────────────
 * Already styled in §3 above; these ensure the WC-generated
 * wrappers themselves have proper display behaviour.
 * ---------------------------------------------------------------- */
.woocommerce-result-count,
.woocommerce-ordering {
	display: block;
}

/* ── 12g. STAR RATINGS ────────────────────────────────────────
 * Hidden per MFD design (§3, removed from loop hook in woocommerce.php).
 * WooCommerce star ratings use ::before pseudoelement with a custom font.
 * Hide the widget entirely but keep the review form stars accessible.
 * ---------------------------------------------------------------- */
.woocommerce .star-rating {
	display: none;
}

/* Restore stars inside comment/review forms so customers can rate */
.woocommerce #review_form .stars a,
.woocommerce #review_form .star-rating {
	display: inline-block;
}

/* ── 12h. PRICE DISPLAY ──────────────────────────────────────
 * Generic .price outside of explicitly styled contexts.
 * ---------------------------------------------------------------- */
.woocommerce .price {
	color: var(--mfd-ink);
	font-family: var(--mfd-font-body);
}

.woocommerce .price del {
	opacity: 0.55;
	margin-right: 6px;
	font-weight: 400;
}

.woocommerce .price ins {
	text-decoration: none;
	font-weight: 700;
}

/* ── 12i. QUANTITY INPUT (WC default .qty) ───────────────────
 * WC renders a plain <input type="number" class="qty"> in some
 * contexts. Style consistently with the MFD quantity stepper.
 * ---------------------------------------------------------------- */
.woocommerce .quantity input.qty {
	width: 60px;
	height: 44px;
	text-align: center;
	font-family: var(--mfd-font-body);
	font-weight: 700;
	font-size: 14px;
	border: 1px solid var(--mfd-line);
	background: var(--mfd-white);
	color: var(--mfd-ink);
	padding: 0;
	border-radius: 0;
	-moz-appearance: textfield;
}

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

.woocommerce .quantity input.qty:focus {
	outline: none;
	border-color: var(--mfd-tan);
}

/* ── 12j. PRODUCT TABS (WC default tab layout) ───────────────
 * WooCommerce renders tabs as .woocommerce-tabs > .wc-tabs.
 * The MFD single-product template overrides these with .mfd-product-tabs
 * (handled in §5). These rules ensure the default WC tabs fall back
 * gracefully if the theme template is not active.
 * ---------------------------------------------------------------- */
.woocommerce-tabs .wc-tabs {
	display: flex;
	gap: 0;
	list-style: none;
	margin: 0;
	padding: 0;
	border-bottom: 1px solid var(--mfd-line);
}

.woocommerce-tabs .wc-tabs li {
	margin: 0;
}

.woocommerce-tabs .wc-tabs li a {
	display: block;
	padding: 12px 16px;
	font-family: var(--mfd-font-body);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--mfd-muted);
	text-decoration: none;
	border-bottom: 2px solid transparent;
	margin-bottom: -1px;
	transition: color var(--mfd-transition), border-color var(--mfd-transition);
}

.woocommerce-tabs .wc-tabs li a:hover {
	color: var(--mfd-ink);
}

.woocommerce-tabs .wc-tabs li.active a {
	color: var(--mfd-ink);
	border-bottom-color: var(--mfd-ink);
}

.woocommerce-tabs .woocommerce-Tabs-panel {
	padding: 24px 0;
	font-size: 14px;
	line-height: 1.7;
	color: var(--mfd-ink);
}

/* ── 12k. CART TABLE (.shop_table) ──────────────────────────
 * WooCommerce cart.php outputs <table class="shop_table woocommerce-cart-form__contents">.
 * The theme's cart template uses .mfd-cart-table but the fallback WC template
 * uses .shop_table — style both consistently.
 * ---------------------------------------------------------------- */
table.shop_table {
	width: 100%;
	border-collapse: collapse;
	font-family: var(--mfd-font-body);
	font-size: 14px;
}

table.shop_table thead th {
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--mfd-muted);
	padding: 12px 10px;
	border-bottom: var(--mfd-border);
	background: var(--mfd-cream-soft);
	text-align: left;
}

table.shop_table tbody td {
	padding: 14px 10px;
	border-bottom: var(--mfd-border);
	vertical-align: middle;
}

table.shop_table tfoot td,
table.shop_table tfoot th {
	padding: 10px 10px;
	font-size: 14px;
	border-bottom: var(--mfd-border);
	vertical-align: middle;
}

table.shop_table tfoot .order-total th,
table.shop_table tfoot .order-total td {
	font-size: 18px;
	font-weight: 800;
	font-style: italic;
	border-bottom: none;
	padding-top: 16px;
}

/* Product image in cart row */
table.shop_table td.product-thumbnail img {
	width: 70px;
	height: 70px;
	object-fit: cover;
	display: block;
	border: var(--mfd-frame);
}

/* Product name link */
table.shop_table .product-name a {
	color: var(--mfd-ink);
	text-decoration: none;
	font-size: 15px;
	transition: color var(--mfd-transition);
}

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

/* Variation meta inside cart */
table.shop_table .variation {
	font-size: 12px;
	color: var(--mfd-muted);
	margin-top: 4px;
}

table.shop_table .variation dt,
table.shop_table .variation dd {
	display: inline;
	margin: 0;
}

/* Remove link */
table.shop_table a.remove {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	font-size: 16px;
	font-weight: 700;
	color: var(--mfd-muted);
	text-decoration: none;
	line-height: 1;
	transition: color var(--mfd-transition);
}

table.shop_table a.remove:hover {
	color: #c0392b;
}

/* ── 12l. CART TOTALS (.cart_totals) ─────────────────────────
 * Already partially handled in §6. Ensure the WC-generated
 * .woocommerce-cart-totals wrapper displays correctly.
 * ---------------------------------------------------------------- */
.woocommerce-cart-totals {
	width: 100%;
}

/* ── 12m. CHECKOUT ORDER REVIEW TABLE ───────────────────────
 * .woocommerce-checkout-review-order-table
 * ---------------------------------------------------------------- */
table.woocommerce-checkout-review-order-table {
	width: 100%;
	border-collapse: collapse;
	font-family: var(--mfd-font-body);
	font-size: 14px;
}

table.woocommerce-checkout-review-order-table thead th {
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--mfd-muted);
	padding: 10px 0;
	border-bottom: var(--mfd-border);
	text-align: left;
	background: transparent;
}

table.woocommerce-checkout-review-order-table tbody td {
	padding: 10px 0;
	border-bottom: var(--mfd-border);
	vertical-align: middle;
}

table.woocommerce-checkout-review-order-table tfoot td,
table.woocommerce-checkout-review-order-table tfoot th {
	padding: 10px 0;
	font-size: 14px;
	border-bottom: var(--mfd-border);
}

table.woocommerce-checkout-review-order-table tfoot .order-total th,
table.woocommerce-checkout-review-order-table tfoot .order-total td {
	font-size: 18px;
	font-weight: 800;
	font-style: italic;
	border-bottom: none;
	padding-top: 14px;
}

/* Product name × quantity formatting in checkout review */
table.woocommerce-checkout-review-order-table .product-name .product-quantity {
	font-size: 12px;
	color: var(--mfd-muted);
	margin-left: 4px;
}

/* ── 12n. MY-ACCOUNT NAVIGATION (WC default markup) ─────────
 * WooCommerce outputs .woocommerce-MyAccount-navigation > ul.
 * The theme wraps this in .mfd-account-nav, but style the WC
 * defaults defensively so a bare template still looks correct.
 * ---------------------------------------------------------------- */
.woocommerce-MyAccount-navigation {
	background: var(--mfd-cream);
	padding: 8px 0;
}

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

.woocommerce-MyAccount-navigation ul li {
	border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

.woocommerce-MyAccount-navigation ul li a {
	display: block;
	padding: 14px 20px;
	font-family: var(--mfd-font-serif);
	font-size: 14px;
	text-decoration: none;
	color: var(--mfd-ink);
	border-left: 3px solid transparent;
	transition: color var(--mfd-transition), border-color var(--mfd-transition), background var(--mfd-transition);
}

.woocommerce-MyAccount-navigation ul li a:hover {
	color: var(--mfd-tan);
	background: rgba(0, 0, 0, 0.02);
}

.woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link--is-active a {
	color: var(--mfd-tan);
	border-left-color: var(--mfd-tan);
	font-weight: 600;
}

/* ── 12o. MY-ACCOUNT CONTENT AREA ───────────────────────────
 * .woocommerce-MyAccount-content
 * ---------------------------------------------------------------- */
.woocommerce-MyAccount-content {
	min-width: 0; /* prevent grid blowout */
}

.woocommerce-MyAccount-content p {
	font-size: 14px;
	line-height: 1.7;
	color: var(--mfd-ink);
	margin-bottom: 16px;
}

/* My-account address blocks */
.woocommerce-addresses {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: clamp(16px, 3vw, 32px);
}

.woocommerce-addresses .woocommerce-Address {
	border: 1px solid var(--mfd-line);
	padding: 20px;
}

.woocommerce-addresses .woocommerce-Address-title {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	margin-bottom: 14px;
	padding-bottom: 10px;
	border-bottom: var(--mfd-border);
}

.woocommerce-addresses .woocommerce-Address-title h3 {
	font-family: var(--mfd-font-body);
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	margin: 0;
}

.woocommerce-addresses .woocommerce-Address-title a {
	font-size: 11px;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--mfd-tan);
	text-decoration: none;
}

address.woocommerce-Address__first-name,
address {
	font-style: normal;
	font-size: 14px;
	line-height: 1.7;
	color: var(--mfd-ink);
}

@media (max-width: 640px) {
	.woocommerce-addresses {
		grid-template-columns: 1fr;
	}
}

/* My-account orders table */
table.woocommerce-orders-table {
	width: 100%;
	border-collapse: collapse;
}

table.woocommerce-orders-table thead th {
	font-family: var(--mfd-font-body);
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--mfd-muted);
	padding: 12px 10px;
	border-bottom: var(--mfd-border);
	background: var(--mfd-cream-soft);
	text-align: left;
}

table.woocommerce-orders-table tbody td {
	padding: 14px 10px;
	font-size: 13px;
	border-bottom: var(--mfd-border);
	vertical-align: middle;
}

table.woocommerce-orders-table .woocommerce-button {
	font-size: 11px;
	padding: 7px 14px;
	letter-spacing: 0.08em;
}

@media (max-width: 640px) {
	table.woocommerce-orders-table {
		display: block;
	}

	table.woocommerce-orders-table thead {
		display: none;
	}

	table.woocommerce-orders-table tbody,
	table.woocommerce-orders-table tr,
	table.woocommerce-orders-table td {
		display: block;
	}

	table.woocommerce-orders-table td[data-title]::before {
		content: attr(data-title) ": ";
		display: block;
		font-size: 10px;
		font-weight: 700;
		letter-spacing: 0.08em;
		text-transform: uppercase;
		color: var(--mfd-muted);
		margin-bottom: 4px;
	}
}

/* ── 12p. FORM ROWS — generic (login, register, lost-pw) ─────
 * Used on account pages that don't use the billing wrapper grid.
 * ---------------------------------------------------------------- */
.woocommerce form p.form-row,
.woocommerce form p.woocommerce-form-row {
	margin-bottom: 16px;
}

.woocommerce form .form-row-first,
.woocommerce form .form-row-last {
	width: 48%;
	display: inline-block;
	vertical-align: top;
}

.woocommerce form .form-row-first {
	margin-right: 4%;
}

@media (max-width: 640px) {
	.woocommerce form .form-row-first,
	.woocommerce form .form-row-last {
		width: 100%;
		margin-right: 0;
		display: block;
	}
}

/* ── 12q. ACCOUNT FORM HEADINGS ──────────────────────────────
 * h2 / h3 inside .woocommerce-MyAccount-content
 * ---------------------------------------------------------------- */
.woocommerce-MyAccount-content h3 {
	font-family: var(--mfd-font-body);
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	margin-bottom: 16px;
	padding-bottom: 10px;
	border-bottom: var(--mfd-border);
}

/* ── 12r. MISCELLANEOUS WC ELEMENTS ──────────────────────────
 * Small elements that WooCommerce's bundled CSS handled generically.
 * ---------------------------------------------------------------- */

/* Clearfix for WC floated elements (coupon + update button) */
.woocommerce-cart-form::after,
.cart::after {
	content: "";
	display: table;
	clear: both;
}

/* Coupon form */
.coupon {
	display: flex;
	gap: 8px;
	align-items: center;
}

.coupon label {
	display: none; /* MFD cart template hides label; make it sr-only for screen readers */
	position: absolute;
	width: 1px;
	height: 1px;
	overflow: hidden;
	clip: rect(0 0 0 0);
}

.coupon #coupon_code {
	flex: 1;
	max-width: 200px;
	padding: 10px 14px;
	font-family: var(--mfd-font-body);
	font-size: 13px;
	border: 1px solid var(--mfd-line);
	background: var(--mfd-white);
	color: var(--mfd-ink);
}

.coupon #coupon_code:focus {
	outline: none;
	border-color: var(--mfd-tan);
}

/* Loading spinner overlay (WooCommerce uses this on cart/checkout updates) */
.blockOverlay {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(255, 255, 255, 0.75);
	z-index: 1000;
	cursor: wait;
}

.blockUI.blockOverlay::before {
	content: "";
	display: block;
	width: 24px;
	height: 24px;
	margin: 40px auto 0;
	border: 2px solid var(--mfd-line);
	border-top-color: var(--mfd-tan);
	border-radius: 50%;
	animation: mfd-spin 0.6s linear infinite;
}

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

/* Product stock messages */
.woocommerce-product-details__short-description p,
.stock {
	font-size: 13px;
}

.in-stock {
	color: #5B8C5A;
	font-weight: 600;
}

.out-of-stock {
	color: #c0392b;
	font-weight: 600;
}

.available-on-backorder {
	color: var(--mfd-tan);
	font-weight: 600;
}

/* WooCommerce Privacy Policy notice on checkout */
.woocommerce-privacy-policy-text {
	font-size: 12px;
	color: var(--mfd-muted);
	margin-bottom: 16px;
}

.woocommerce-privacy-policy-text a {
	color: var(--mfd-tan);
}

/* "Terms and conditions" checkbox row */
.woocommerce-terms-and-conditions-wrapper {
	margin-bottom: 16px;
}

.woocommerce-form__label-for-checkbox {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	font-size: 13px;
	line-height: 1.5;
	cursor: pointer;
}

.woocommerce-form__label-for-checkbox input[type="checkbox"] {
	flex-shrink: 0;
	width: 16px;
	height: 16px;
	accent-color: var(--mfd-tan);
	margin-top: 2px;
}

/* Lost-password / register links */
.woocommerce-LostPassword,
.woocommerce-RegisterPrompt {
	margin-top: 12px;
	font-size: 13px;
}

.woocommerce-LostPassword a,
.woocommerce-RegisterPrompt a {
	color: var(--mfd-tan);
	text-decoration: none;
}

.woocommerce-LostPassword a:hover,
.woocommerce-RegisterPrompt a:hover {
	text-decoration: underline;
}

/* Cart collaterals (shipping calculator etc) */
.cart-collaterals .shipping-calculator-form {
	margin-top: 12px;
}

.cart-collaterals .shipping-calculator-form p {
	margin-bottom: 10px;
}

.cart-collaterals .shipping-calculator-button {
	font-size: 12px;
	color: var(--mfd-tan);
	text-decoration: none;
	cursor: pointer;
}

/* Order-received (thank-you) details list */
.woocommerce-order-overview {
	list-style: none;
	margin: 0 0 24px;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

.woocommerce-order-overview li {
	font-size: 14px;
	font-weight: 600;
	color: var(--mfd-muted);
}

.woocommerce-order-overview li strong {
	display: block;
	font-size: 18px;
	font-weight: 800;
	color: var(--mfd-ink);
}

/* Customer details section on order-received */
.woocommerce-customer-details address {
	font-style: normal;
	font-size: 14px;
	line-height: 1.7;
	padding: 20px;
	border: 1px solid var(--mfd-line);
	margin-top: 12px;
}

/* Order details table (single order view in my-account) */
table.woocommerce-table--order-details {
	width: 100%;
	border-collapse: collapse;
}

table.woocommerce-table--order-details thead th {
	font-family: var(--mfd-font-body);
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--mfd-muted);
	padding: 10px 0;
	border-bottom: var(--mfd-border);
	text-align: left;
}

table.woocommerce-table--order-details tbody td {
	padding: 12px 0;
	font-size: 14px;
	border-bottom: var(--mfd-border);
	vertical-align: middle;
}

table.woocommerce-table--order-details tfoot th,
table.woocommerce-table--order-details tfoot td {
	padding: 10px 0;
	font-size: 14px;
	border-bottom: var(--mfd-border);
}

table.woocommerce-table--order-details tfoot .order-total th,
table.woocommerce-table--order-details tfoot .order-total td {
	font-size: 18px;
	font-weight: 800;
	font-style: italic;
	border-bottom: none;
}

/* Mobile fix: WooCommerce product loop grid stays 2-up on phones (was 1 column). */
@media ( max-width: 640px ) {
	.woocommerce ul.products {
		grid-template-columns: 1fr 1fr;
		gap: 16px;
	}
}

/* ============================================================
 * WVS Variation Swatches — colour swatches must be circles [R2-06]
 * WVS plugin renders .wvs-style-squared by default; override border-radius.
 * ============================================================ */
.variable-item.color-variable-item,
.wvs-style-squared .variable-item.color-variable-item {
	border-radius: 50% !important;
	width: 28px;
	height: 28px;
}

/* WVS button swatches (size, text attributes) — styled boxes [R2-13] */
.variable-item.button-variable-item {
	border: 1.5px solid var(--mfd-line);
	border-radius: 0;
	padding: 6px 12px;
	font-family: var(--mfd-font-body);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.08em;
	background: var(--mfd-white);
	color: var(--mfd-ink);
	cursor: pointer;
	transition: border-color 0.2s ease, background 0.2s ease;
}

.variable-item.button-variable-item:hover,
.variable-item.button-variable-item.selected {
	border-color: var(--mfd-tan);
	background: var(--mfd-cream);
}

/* WVS swatch focus ring for keyboard accessibility [R2-30] */
.variable-item:focus-visible {
	outline: 2px solid var(--mfd-ink);
	outline-offset: 2px;
}

/* Checkout <select> and Select2 — match MFD input style [R2-21] */
.woocommerce-checkout select,
.woocommerce-checkout .select2-container .select2-selection--single {
	border: 1px solid var(--mfd-line) !important;
	font-family: var(--mfd-font-body) !important;
	border-radius: 0 !important;
}

.woocommerce-checkout .select2-container .select2-selection--single {
	height: 46px;
	line-height: 44px;
}

.woocommerce-checkout .select2-container .select2-selection--single .select2-selection__rendered {
	font-family: var(--mfd-font-body);
	color: var(--mfd-ink);
	padding-left: 14px;
	line-height: 44px;
}

/* CF7 success/error message styling [R2-28] */
.wpcf7 .wpcf7-mail-sent-ok {
	border: 1px solid var(--mfd-tan);
	background: var(--mfd-cream);
	color: var(--mfd-ink);
	font-family: var(--mfd-font-body);
	font-size: 14px;
	padding: 14px 18px;
	border-radius: 0;
	margin-top: 12px;
}

.wpcf7 .wpcf7-validation-errors,
.wpcf7 .wpcf7-acceptance-missing {
	border: 1px solid #c0392b;
	background: #fff5f5;
	color: var(--mfd-ink);
	font-family: var(--mfd-font-body);
	font-size: 14px;
	padding: 14px 18px;
	border-radius: 0;
	margin-top: 12px;
}

/* Breadcrumb separator responsive spacing [R2-15] */
@media ( max-width: 768px ) {
	.mfd-breadcrumb__sep {
		margin: 0 4px;
	}
}

/* Point de vente map — responsive height [R2-24] */
@media ( max-width: 768px ) {
	.wpgmza-map-container,
	#wpgmza_map_1 {
		height: 260px !important;
	}
}

/* Mobile nav — prevent hamburger clip at 320px [R2-26] */
@media ( max-width: 375px ) {
	.mfd-header__home-link,
	.mfd-header__wordmark {
		max-width: calc(100% - 52px);
	}

	.mfd-hamburger {
		flex-shrink: 0;
	}
}

/* ============================================================
 * PW WooCommerce Gift Cards — MFD theme integration
 * ============================================================ */

/* ── Cartes-cadeau page layout ── */
.mfd-carte-config__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(32px, 5vw, 64px);
	align-items: start;
}

@media ( max-width: 768px ) {
	.mfd-carte-config__grid {
		grid-template-columns: 1fr;
	}
}

/* ── Visual gift card preview (left) ── */
.mfd-carte-visual {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 12px;
	padding: clamp(32px, 5vw, 56px) clamp(24px, 4vw, 48px);
	border: var(--mfd-frame);
	background: var(--mfd-cream);
	min-height: 260px;
	text-align: center;
}

.mfd-carte-visual__label {
	font-size: 11px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--mfd-muted);
	margin: 0;
}

.mfd-carte-visual__amount {
	font-family: var(--mfd-font-serif);
	font-style: italic;
	font-size: clamp(2.5rem, 6vw, 4rem);
	color: var(--mfd-tan);
	margin: 0;
	line-height: 1;
	transition: all 0.25s ease;
}

.mfd-carte-visual__brand {
	font-family: var(--mfd-font-serif);
	font-style: italic;
	font-size: 1.15rem;
	color: var(--mfd-ink);
	margin: 0;
}

.mfd-carte-visual__validity {
	font-size: 10px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--mfd-muted);
	margin: 0;
}

/* ── Form column (right) ── */
.mfd-carte-form {
	display: flex;
	flex-direction: column;
	gap: 0;
}

.mfd-carte-form .mfd-section-title {
	font-family: var(--mfd-font-display);
	font-size: clamp(1.4rem, 2.5vw, 1.9rem);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	margin: 0 0 24px;
}

.mfd-carte-form__notice {
	color: var(--mfd-muted);
	font-size: 14px;
	padding: 20px 0;
}

/* ── WC product wrapper on the page ── */
.mfd-carte-wc-product {
	width: 100%;
}

/* Hide redundant elements from the WC product form on this page */
.mfd-carte-wc-product .product_title,
.mfd-carte-wc-product .woocommerce-product-gallery,
.mfd-carte-wc-product .woocommerce-tabs,
.mfd-carte-wc-product .related,
.mfd-carte-wc-product .up-sells,
.mfd-carte-wc-product .woocommerce-product-rating,
.mfd-carte-wc-product .woocommerce-breadcrumb {
	display: none !important;
}

/* ── PW Gift Card variation amount selector ── */
.mfd-carte-wc-product .variations,
.mfd-carte-wc-product .variations_form .variations {
	width: 100%;
	border: none;
	margin-bottom: 24px;
}

.mfd-carte-wc-product .variations td,
.mfd-carte-wc-product .variations th {
	padding: 0 0 10px 0;
	border: none;
	vertical-align: top;
	display: block;
	width: 100%;
}

.mfd-carte-wc-product .variations label {
	display: block;
	font-family: var(--mfd-font-body);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--mfd-ink);
	margin-bottom: 10px;
}

/* Amount dropdown → styled select */
.mfd-carte-wc-product .variations select {
	width: 100%;
	padding: 12px 16px;
	border: var(--mfd-border);
	background: var(--mfd-white);
	font-family: var(--mfd-font-body);
	font-size: 14px;
	color: var(--mfd-ink);
	appearance: auto;
	cursor: pointer;
	transition: border-color var(--mfd-transition);
}

.mfd-carte-wc-product .variations select:focus {
	outline: none;
	border-color: var(--mfd-tan);
}

/* ── PW Gift Card custom amount field ── */
.mfd-carte-wc-product #pwgc-custom-amount-container,
.mfd-carte-wc-product .pwgc-custom-amount-container {
	margin-bottom: 20px;
}

.mfd-carte-wc-product #pwgc-custom-amount,
.mfd-carte-wc-product input[name="pwgc-custom-amount"] {
	width: 100%;
	padding: 12px 16px;
	border: var(--mfd-border);
	background: var(--mfd-white);
	font-family: var(--mfd-font-body);
	font-size: 14px;
	color: var(--mfd-ink);
	transition: border-color var(--mfd-transition);
	box-sizing: border-box;
}

.mfd-carte-wc-product #pwgc-custom-amount:focus,
.mfd-carte-wc-product input[name="pwgc-custom-amount"]:focus {
	outline: none;
	border-color: var(--mfd-tan);
}

/* ── PW Gift Card recipient / from / message fields ── */
#pwgc-purchase-container {
	margin-top: 4px;
	margin-bottom: 20px;
}

.pwgc-field-container {
	margin-bottom: 18px !important;
}

.pwgc-label {
	display: block;
	font-family: var(--mfd-font-body) !important;
	font-size: 11px !important;
	font-weight: 700 !important;
	letter-spacing: 0.12em !important;
	text-transform: uppercase !important;
	color: var(--mfd-ink) !important;
	margin-bottom: 8px !important;
}

.pwgc-input-text,
.mfd-carte-wc-product .pwgc-input-text,
.mfd-carte-wc-product #pwgc-to,
.mfd-carte-wc-product #pwgc-from {
	width: 100% !important;
	padding: 12px 16px !important;
	border: var(--mfd-border) !important;
	background: var(--mfd-white) !important;
	font-family: var(--mfd-font-body) !important;
	font-size: 14px !important;
	color: var(--mfd-ink) !important;
	transition: border-color var(--mfd-transition) !important;
	box-sizing: border-box !important;
	border-radius: 0 !important;
}

.pwgc-input-text:focus,
.mfd-carte-wc-product #pwgc-to:focus,
.mfd-carte-wc-product #pwgc-from:focus {
	outline: none !important;
	border-color: var(--mfd-tan) !important;
}

#pwgc-message,
.mfd-carte-wc-product #pwgc-message {
	width: 100% !important;
	height: 110px !important;
	padding: 12px 16px !important;
	border: var(--mfd-border) !important;
	background: var(--mfd-white) !important;
	font-family: var(--mfd-font-body) !important;
	font-size: 14px !important;
	color: var(--mfd-ink) !important;
	resize: vertical !important;
	transition: border-color var(--mfd-transition) !important;
	box-sizing: border-box !important;
	border-radius: 0 !important;
}

#pwgc-message:focus,
.mfd-carte-wc-product #pwgc-message:focus {
	outline: none !important;
	border-color: var(--mfd-tan) !important;
}

.pwgc-subtitle {
	font-size: 11px !important;
	color: var(--mfd-muted) !important;
	margin-top: 4px !important;
	font-family: var(--mfd-font-body) !important;
	line-height: 1.5 !important;
}

/* ── PW Gift Card add-to-cart button ── */
.mfd-carte-wc-product .single_add_to_cart_button,
.mfd-carte-wc-product button.single_add_to_cart_button {
	background: var(--mfd-tan) !important;
	color: var(--mfd-white) !important;
	font-family: var(--mfd-font-body) !important;
	font-weight: 700 !important;
	font-size: 11px !important;
	letter-spacing: 0.12em !important;
	text-transform: uppercase !important;
	padding: 16px 36px !important;
	border: none !important;
	border-radius: 0 !important;
	cursor: pointer !important;
	transition: background var(--mfd-transition) !important;
	width: 100% !important;
	margin-top: 8px !important;
}

.mfd-carte-wc-product .single_add_to_cart_button:hover,
.mfd-carte-wc-product button.single_add_to_cart_button:hover {
	background: var(--mfd-tan-dark) !important;
}

/* ── PW Gift Card quantity field ── */
.mfd-carte-wc-product .quantity input.qty {
	border: var(--mfd-border);
	padding: 10px 12px;
	font-family: var(--mfd-font-body);
	font-size: 14px;
	width: 64px;
	text-align: center;
}

/* ── Cart — applied gift card row ── */
.cart-pw-gift-card td {
	color: var(--mfd-muted);
	font-family: var(--mfd-font-body);
	font-size: 13px;
}

/* ── Cart — redeem gift card form ── */
#pwgc-redeem-gift-card-form {
	margin-bottom: 20px;
}

#pwgc-redeem-gift-card-container {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

#pwgc-redeem-gift-card-container label {
	display: block;
	font-family: var(--mfd-font-body);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--mfd-ink);
}

#pwgc-redeem-gift-card-number {
	padding: 12px 16px;
	border: var(--mfd-border);
	background: var(--mfd-white);
	font-family: var(--mfd-font-body);
	font-size: 14px;
	color: var(--mfd-ink);
	transition: border-color var(--mfd-transition);
	width: 100%;
	box-sizing: border-box;
}

#pwgc-redeem-gift-card-number:focus {
	outline: none;
	border-color: var(--mfd-tan);
}

#pwgc-redeem-button,
button#pwgc-redeem-button {
	background: var(--mfd-ink) !important;
	color: var(--mfd-white) !important;
	font-family: var(--mfd-font-body) !important;
	font-size: 11px !important;
	font-weight: 700 !important;
	letter-spacing: 0.12em !important;
	text-transform: uppercase !important;
	padding: 12px 24px !important;
	border: none !important;
	border-radius: 0 !important;
	cursor: pointer !important;
	transition: background var(--mfd-transition) !important;
	align-self: flex-start;
}

#pwgc-redeem-button:hover {
	background: var(--mfd-muted) !important;
}

#pwgc-redeem-error {
	color: #c0392b;
	font-size: 13px;
	font-family: var(--mfd-font-body);
}

/* ── Checkout — gift card redemption field ── */
#pw-gift-cards-checkout-container {
	margin-bottom: 20px;
}

.pw-gift-cards-checkout label {
	display: block;
	font-family: var(--mfd-font-body);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--mfd-ink);
	margin-bottom: 8px;
}

.pw-gift-cards-checkout input[type="text"] {
	width: 100%;
	padding: 12px 16px;
	border: var(--mfd-border);
	background: var(--mfd-white);
	font-family: var(--mfd-font-body);
	font-size: 14px;
	color: var(--mfd-ink);
	transition: border-color var(--mfd-transition);
	box-sizing: border-box;
}

.pw-gift-cards-checkout input[type="text"]:focus {
	outline: none;
	border-color: var(--mfd-tan);
}

.pw-gift-cards-checkout button,
.pw-gift-cards-checkout input[type="submit"] {
	background: var(--mfd-ink);
	color: var(--mfd-white);
	font-family: var(--mfd-font-body);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	padding: 12px 24px;
	border: none;
	border-radius: 0;
	cursor: pointer;
	transition: background var(--mfd-transition);
	margin-top: 8px;
}

.pw-gift-cards-checkout button:hover,
.pw-gift-cards-checkout input[type="submit"]:hover {
	background: var(--mfd-muted);
}

/* Applied gift card in cart totals */
.cart-discount.pw-gift-card td,
.cart-discount.pw-gift-card th {
	color: var(--mfd-ink);
}

/* ── Checkout — coupon area gift card box ── */
#coupon-area-pw-gift-card,
.coupon-area-pw-gift-card {
	border: var(--mfd-border);
	padding: 20px;
	margin-bottom: 20px;
	background: var(--mfd-cream);
}

/* ── Mobile responsive ── */
@media ( max-width: 640px ) {
	.mfd-carte-visual {
		min-height: 200px;
		padding: 32px 24px;
	}

	.mfd-carte-visual__amount {
		font-size: 2.5rem;
	}

	.mfd-carte-wc-product .single_add_to_cart_button {
		font-size: 12px !important;
		padding: 14px 24px !important;
	}
}

/* ── Inline form validation (replaces native alert() — gift card, etc.) ── */
.mfd-input-invalid,
input.mfd-input-invalid,
textarea.mfd-input-invalid,
select.mfd-input-invalid {
	border-color: #b3261e !important;
	box-shadow: 0 0 0 1px #b3261e;
}

.mfd-field-error {
	display: block;
	margin-top: 6px;
	color: #b3261e;
	font-size: 13px;
	line-height: 1.45;
	font-weight: 600;
}

/* ── Checkout: the single order review rendered inside the summary box ── */
.mfd-checkout-summary #order_review {
	margin-bottom: 18px;
}

.mfd-checkout-summary .woocommerce-checkout-review-order-table {
	width: 100%;
	margin: 0;
	border: 0;
	font-size: 14px;
}

.mfd-checkout-summary .woocommerce-checkout-review-order-table th,
.mfd-checkout-summary .woocommerce-checkout-review-order-table td {
	padding: 11px 0;
	border: 0;
	border-bottom: 1px solid #e8e0cf;
	vertical-align: top;
}

.mfd-checkout-summary .woocommerce-checkout-review-order-table thead th {
	font-size: 11px;
	letter-spacing: .09em;
	text-transform: uppercase;
	color: #8a7d63;
}

.mfd-checkout-summary .woocommerce-checkout-review-order-table tfoot .order-total th,
.mfd-checkout-summary .woocommerce-checkout-review-order-table tfoot .order-total td {
	border-bottom: 0;
	padding-top: 14px;
	font-size: 16px;
	font-weight: 700;
}

.mfd-checkout-summary .woocommerce-shipping-methods {
	margin: 0;
	padding: 0;
	list-style: none;
}
