/* ============================================================
   ABH — WooCommerce Complete Branding  (v3)
   ============================================================
   Branding layer over WC default HTML.

     1.  Page-hero + section spacing overrides
     2.  Global — notices, buttons, forms, star ratings, tables
     3.  Shop archive — grid, sorting, pagination
     4.  Single product — gallery, summary, tabs, related
     5.  Cart — table, coupon, totals, cross-sells
     6.  Checkout — billing/shipping, order review, payment
     7.  My Account — navigation, dashboard, orders, addresses
     8.  Order received / Thank you
     9.  Mini cart widget
     10. Responsive

   Tokens live in style.css :root — this file only uses var().
   ============================================================ */


/* ═══════════════════════════════════════════════════════════════
   1 · PAGE-HERO + SECTION SPACING
   ═══════════════════════════════════════════════════════════════ */

/* Collapse 50vh hero on transactional WC pages */
body.woocommerce-cart .page-hero,
body.woocommerce-checkout .page-hero,
body.woocommerce-account .page-hero {
	min-height: auto;
	padding-block: var(--s-5) var(--s-4);
}
body.woocommerce-cart .page-hero__title,
body.woocommerce-checkout .page-hero__title,
body.woocommerce-account .page-hero__title {
	font-size: clamp(1.75rem, 4vw, 2.25rem);
}

/* Reduce the 96px section padding on WC shortcode pages
   (cart, checkout, my-account come through page.php which
   wraps content in <section class="section">) */
body.woocommerce-cart > main > .section,
body.woocommerce-checkout > main > .section,
body.woocommerce-account > main > .section,
body.woocommerce-cart .section,
body.woocommerce-checkout .section,
body.woocommerce-account .section {
	padding-block: var(--s-5);
}

/* Also reduce for WC template-driven pages (shop, single product) */
body.single-product > main > .section,
body.archive.post-type-archive-product > main > .section {
	padding-block: var(--s-5);
}

/* Base reset */
body.woocommerce-page .woocommerce { position: relative; }


/* ═══════════════════════════════════════════════════════════════
   2 · GLOBAL — Notices, buttons, forms, star ratings, tables
   ═══════════════════════════════════════════════════════════════ */

/* ─── Notices ─── */
.woocommerce-message,
.woocommerce-error,
.woocommerce-info {
	font-family: var(--font);
	font-size: var(--t-body);
	color: var(--ink);
	background: var(--surface);
	border-top: 3px solid var(--accent);
	border-radius: 0;
	padding: var(--s-3) var(--s-4);
	margin: 0 0 var(--s-4);
	line-height: var(--lh-body);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--s-3);
	flex-wrap: wrap;
}
.woocommerce-message::before,
.woocommerce-info::before,
.woocommerce-error::before {
	content: none;
}
.woocommerce-message { border-top-color: var(--success); }
.woocommerce-info { border-top-color: var(--accent); }
.woocommerce-error { border-top-color: var(--danger); }

.woocommerce-message .button,
.woocommerce-info .button,
.woocommerce-error .button {
	float: none;
	flex-shrink: 0;
	margin-left: auto;
	font-size: var(--t-meta);
	font-weight: var(--w-med);
	letter-spacing: 0.04em;
	text-transform: uppercase;
	background: transparent;
	color: var(--ink);
	border: 1px solid var(--ink);
	padding: var(--s-2) var(--s-4);
	border-radius: var(--radius);
	text-decoration: none;
	transition: background var(--d-fast) var(--ease), color var(--d-fast) var(--ease);
}
.woocommerce-message .button:hover,
.woocommerce-info .button:hover,
.woocommerce-error .button:hover {
	background: var(--ink);
	color: var(--bg);
}
.woocommerce-error li {
	list-style: none !important;
	padding-left: 0 !important;
	margin-left: 0 !important;
	color: var(--danger);
}

/* ─── Global WC buttons ─── */
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) a.button,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) button.button,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) input.button,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) #respond input#submit,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce a.button,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce button.button,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce input.button,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce #respond input#submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--s-2);
	height: 48px;
	padding: 0 var(--s-5);
	font-family: var(--font);
	font-size: var(--t-meta);
	font-weight: var(--w-med);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	background: var(--ink);
	color: var(--bg);
	border: 1px solid var(--ink);
	border-radius: var(--radius);
	cursor: pointer;
	text-decoration: none;
	text-shadow: none;
	box-shadow: none;
	background-image: none;
	transition: background var(--d-fast) var(--ease),
		color var(--d-fast) var(--ease),
		border-color var(--d-fast) var(--ease);
}
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) a.button:hover,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) button.button:hover,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) input.button:hover,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) #respond input#submit:hover,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce a.button:hover,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce button.button:hover,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce input.button:hover,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce #respond input#submit:hover {
	background: var(--accent);
	border-color: var(--accent);
	color: var(--accent-ink);
	background-image: none;
}

/* Alt / primary CTA buttons (gold) */
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) a.button.alt,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) button.button.alt,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) input.button.alt,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce a.button.alt,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce button.button.alt,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce input.button.alt {
	background: var(--accent);
	border-color: var(--accent);
	color: var(--accent-ink);
	-webkit-font-smoothing: antialiased;
}
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) a.button.alt:hover,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) button.button.alt:hover,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) input.button.alt:hover,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce a.button.alt:hover,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce button.button.alt:hover,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce input.button.alt:hover {
	background: var(--ink);
	border-color: var(--ink);
	color: var(--bg);
}

/* Disabled buttons — clean muted state */
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) a.button:disabled,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) a.button.disabled,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) button.button:disabled,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) button.button.disabled,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) input.button:disabled,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) input.button.disabled,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce a.button:disabled,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce button.button:disabled,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce input.button:disabled,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce a.button.disabled,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce button.button.disabled,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce input.button.disabled {
	background: var(--line) !important;
	border-color: var(--line) !important;
	color: var(--mute) !important;
	opacity: 1;
	cursor: not-allowed;
	pointer-events: none;
}
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) a.button.alt:disabled,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) a.button.alt.disabled,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) button.button.alt:disabled,
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) input.button.alt:disabled,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce a.button.alt:disabled,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce button.button.alt:disabled,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce input.button.alt:disabled,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce a.button.alt.disabled,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce button.button.alt.disabled,
:where(body:not(.woocommerce-block-theme-has-button-styles)):where(:not(.edit-post-visual-editor)) .woocommerce input.button.alt.disabled {
	background: var(--line) !important;
	border-color: var(--line) !important;
	color: var(--mute) !important;
	opacity: 1;
}

/* ─── Global WC form fields ─── */
.woocommerce form .form-row {
	margin-bottom: var(--s-3);
	padding: 0;
}
.woocommerce form .form-row label {
	display: block;
	font-family: var(--font);
	font-size: var(--t-meta);
	font-weight: var(--w-med);
	color: var(--ink);
	margin-bottom: var(--s-1);
	letter-spacing: 0.02em;
}
.woocommerce form .form-row label .required {
	color: var(--danger);
	font-weight: var(--w-bold);
}
.woocommerce form .form-row label .optional {
	color: var(--mute);
	font-size: 0.85em;
	font-weight: var(--w-reg);
}
.woocommerce form .form-row .input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
	display: block;
	width: 100%;
	height: 48px;
	padding: 0 var(--s-4);
	font-family: var(--font);
	font-size: var(--t-body);
	color: var(--ink);
	background: var(--bg);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	transition: border-color var(--d-fast) var(--ease);
	box-sizing: border-box;
}
.woocommerce form .form-row textarea {
	height: auto;
	min-height: 80px;
	padding: var(--s-3) var(--s-4);
	resize: vertical;
	line-height: var(--lh-body);
}
/* Tighten the label-to-input gap */
.woocommerce form .form-row .woocommerce-input-wrapper {
	display: block;
}
/* Select2 outer container spacing */
.woocommerce form .form-row .select2-container {
	margin-top: 0;
}
.woocommerce form .form-row .input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
	outline: none;
	border-color: var(--ink);
}
.woocommerce form .form-row .input-text::placeholder,
.woocommerce form .form-row textarea::placeholder {
	color: var(--mute);
}
.woocommerce form .form-row select {
	appearance: none;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 7'><path fill='none' stroke='%23111' stroke-width='1.5' d='M1 1l5 5 5-5'/></svg>");
	background-repeat: no-repeat;
	background-position: right var(--s-3) center;
	background-size: 12px 7px;
	padding-right: var(--s-6);
}
.woocommerce form .form-row.woocommerce-validated .input-text { border-color: var(--success); }
.woocommerce form .form-row.woocommerce-invalid .input-text  { border-color: var(--danger); }

/* Select2 */
.woocommerce form .form-row .select2-container .select2-selection--single {
	height: 48px;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	background: var(--bg);
}
.woocommerce form .form-row .select2-container .select2-selection--single .select2-selection__rendered {
	line-height: 48px;
	padding-left: var(--s-4);
	color: var(--ink);
	font-family: var(--font);
	font-size: var(--t-body);
}
.woocommerce form .form-row .select2-container .select2-selection--single .select2-selection__arrow {
	height: 48px;
	right: var(--s-3);
}

/* ─── Login / register / coupon forms ─── */
.woocommerce form.login,
.woocommerce form.checkout_coupon,
.woocommerce form.register {
	border: 1px solid var(--line);
	background: var(--surface);
	padding: var(--s-4);
	margin: 0 0 var(--s-4);
	border-radius: var(--radius);
}
.woocommerce form.login h2,
.woocommerce form.register h2 {
	font-size: var(--t-h4);
	font-weight: var(--w-med);
	color: var(--ink);
	margin: 0 0 var(--s-3);
}
.woocommerce .woocommerce-form-login__rememberme {
	display: inline-flex;
	align-items: center;
	gap: var(--s-2);
	font-size: var(--t-meta);
	color: var(--ink-2);
	margin-top: var(--s-2);
}
.woocommerce .woocommerce-form-login__rememberme input[type="checkbox"] {
	width: 18px;
	height: 18px;
	accent-color: var(--accent);
}
.woocommerce .lost_password a {
	font-size: var(--t-meta);
	color: var(--mute);
	text-decoration: underline;
	text-underline-offset: 3px;
}
.woocommerce .lost_password a:hover { color: var(--accent); }

/* ─── Remove link ─── */
.woocommerce a.remove {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	font-size: 18px;
	font-weight: 700;
	line-height: 1;
	color: var(--mute) !important;
	border: 1px solid var(--line);
	border-radius: 0;
	text-decoration: none;
	transition: all var(--d-fast) var(--ease);
}
.woocommerce a.remove:hover {
	background: var(--danger) !important;
	border-color: var(--danger);
	color: var(--bg) !important;
}

/* ─── WC breadcrumb (hidden — our hero does this) ─── */
.woocommerce .woocommerce-breadcrumb { display: none; }

/* ─── Star ratings ─── */
.woocommerce .star-rating {
	font-family: "Font Awesome 6 Free";
	font-weight: 900;
	font-size: 13px;
	color: var(--accent);
	letter-spacing: 2px;
	width: auto;
	height: auto;
	overflow: visible;
}
.woocommerce .star-rating::before {
	content: "\f005\f005\f005\f005\f005";
	opacity: 0.25;
	color: var(--accent);
}
.woocommerce .star-rating span { display: block; overflow: hidden; }
.woocommerce .star-rating span::before {
	content: "\f005\f005\f005\f005\f005";
	color: var(--accent);
}

/* ─── Price styling (global) ─── */
.woocommerce div.product span.price,
.woocommerce div.product p.price {
	color: var(--ink);
	font-size: var(--t-h3);
}
.woocommerce ul.products li.product .price { color: var(--ink); }

/* ─── Shop tables (global) ─── */
.woocommerce table.shop_table {
	border: 1px solid var(--line);
	border-radius: var(--radius);
	border-spacing: 0;
	border-collapse: separate;
	font-family: var(--font);
	width: 100%;
}
.woocommerce table.shop_table th {
	font-size: var(--t-meta);
	font-weight: var(--w-med);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--mute);
	padding: var(--s-3) var(--s-4);
	border-bottom: 1px solid var(--line);
	background: var(--surface);
}
.woocommerce table.shop_table td {
	padding: var(--s-3) var(--s-4);
	border-top: 1px solid var(--line);
	color: var(--ink);
	vertical-align: middle;
	font-size: var(--t-body);
}
.woocommerce table.shop_table tbody:first-child tr:first-child th,
.woocommerce table.shop_table tbody:first-child tr:first-child td { border-top: 0; }
.woocommerce table.shop_table tfoot th,
.woocommerce table.shop_table tfoot td {
	font-weight: var(--w-med);
	border-top: 1px solid var(--line);
}

/* ─── Quantity input ─── */
.woocommerce .quantity .qty {
	width: 60px;
	height: 44px;
	border: 1px solid var(--line);
	background: var(--bg);
	text-align: center;
	font-family: var(--font);
	font-size: var(--t-body);
	color: var(--ink);
	border-radius: var(--radius);
	-moz-appearance: textfield;
}
.woocommerce .quantity .qty::-webkit-outer-spin-button,
.woocommerce .quantity .qty::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.woocommerce .quantity .qty:focus { outline: none; border-color: var(--ink); }


/* ═══════════════════════════════════════════════════════════════
   3 · SHOP ARCHIVE — Grid, sorting, pagination
   ═══════════════════════════════════════════════════════════════ */

/* ─── Top bar ─── */
.woocommerce .woocommerce-result-count,
.woocommerce-page .woocommerce-result-count {
	margin: 0 0 var(--s-4);
	font-size: var(--t-meta);
	color: var(--mute);
	letter-spacing: 0.04em;
	text-transform: uppercase;
	float: left;
	line-height: 44px;
}
.woocommerce .woocommerce-ordering,
.woocommerce-page .woocommerce-ordering { margin: 0 0 var(--s-4); float: right; }
.woocommerce .woocommerce-ordering select.orderby {
	height: 44px;
	padding: 0 2.5rem 0 var(--s-3);
	border: 1px solid var(--line);
	background: var(--bg);
	font-family: var(--font);
	font-size: var(--t-meta);
	color: var(--ink);
	cursor: pointer;
	border-radius: var(--radius);
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23333' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 14px center;
	background-size: 12px 7px;
}
.woocommerce .woocommerce-ordering select.orderby:focus { outline: none; border-color: var(--ink); }
.woocommerce::after,
.woocommerce-page .products::before { content: ""; display: table; clear: both; }

/* ─── Product grid ─── */
.woocommerce ul.products,
.woocommerce-page ul.products {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: var(--s-6) var(--s-4);
	margin: 0;
	padding: 0;
	list-style: none;
	clear: both;
}
.woocommerce ul.products::before,
.woocommerce ul.products::after,
.woocommerce-page ul.products::before,
.woocommerce-page ul.products::after {
	display: none !important;
	content: none !important;
}
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
	margin: 0 !important;
	padding: 0;
	width: auto !important;
	float: none !important;
	clear: none !important;
	list-style: none;
}

/* ─── Product card ─── */
.woocommerce li.product {
	display: flex;
	flex-direction: column;
	gap: var(--s-2);
	background: transparent;
	position: relative;
}
.woocommerce li.product > a.woocommerce-LoopProduct-link {
	display: flex;
	flex-direction: column;
	gap: var(--s-2);
	color: var(--ink);
	text-decoration: none;
}
.woocommerce li.product > a.woocommerce-LoopProduct-link:hover { color: var(--ink); }

/* Card image */
.woocommerce li.product .attachment-woocommerce_thumbnail,
.woocommerce li.product img:first-of-type {
	width: 100%;
	aspect-ratio: 4 / 5;
	object-fit: cover;
	background: var(--surface);
	margin: 0 0 var(--s-1);
	transition: opacity var(--d-fast) var(--ease);
}
.woocommerce li.product:hover .attachment-woocommerce_thumbnail { opacity: 0.92; }

/* Sale badge */
.woocommerce li.product span.onsale,
.woocommerce span.onsale {
	position: absolute !important;
	top: var(--s-2) !important;
	left: var(--s-2) !important;
	right: auto !important;
	bottom: auto !important;
	z-index: 2;
	background: var(--danger);
	color: var(--bg);
	font-size: 11px;
	font-weight: var(--w-bold);
	letter-spacing: var(--tr-wide);
	text-transform: uppercase;
	padding: 5px 10px;
	border-radius: 0;
	min-height: 0 !important;
	min-width: 0 !important;
	width: auto !important;
	height: auto !important;
	line-height: 1.4;
	margin: 0 !important;
	line-height: 1;
	margin: 0;
}

/* Card title */
.woocommerce li.product .woocommerce-loop-product__title {
	font-size: var(--t-body);
	font-weight: var(--w-med);
	color: var(--ink);
	line-height: 1.35;
	margin: 0;
	padding: 0;
}

/* Card price — del first, then ins */
.woocommerce li.product .price {
	font-size: var(--t-body);
	color: var(--ink);
	font-weight: var(--w-med);
	display: flex;
	align-items: baseline;
	gap: var(--s-2);
	flex-wrap: wrap;
	margin: 0;
}
.woocommerce li.product .price ins {
	background: transparent;
	text-decoration: none;
	color: var(--ink);
	font-weight: var(--w-bold);
}
.woocommerce li.product .price del {
	color: var(--mute);
	font-weight: var(--w-reg);
	order: -1;
}
.woocommerce li.product .price del .woocommerce-Price-amount {
	font-size: var(--t-meta);
	text-decoration: line-through;
}

/* Card add-to-cart */
.woocommerce li.product a.button.add_to_cart_button,
.woocommerce li.product a.added_to_cart {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 42px;
	padding: 0 var(--s-4);
	background: transparent;
	color: var(--ink);
	border: 1px solid var(--line);
	font-family: var(--font);
	font-size: var(--t-meta);
	font-weight: var(--w-med);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	border-radius: var(--radius);
	margin-top: var(--s-2);
	text-decoration: none;
	transition: all var(--d-fast) var(--ease);
}
.woocommerce li.product a.button.add_to_cart_button:hover {
	background: var(--ink);
	color: var(--bg);
	border-color: var(--ink);
}
.woocommerce li.product a.added_to_cart {
	background: var(--surface);
	color: var(--success);
	border-color: var(--line);
}

/* ─── Pagination ─── */
.woocommerce nav.woocommerce-pagination {
	text-align: center;
	margin-top: var(--s-6);
	clear: both;
}
.woocommerce nav.woocommerce-pagination ul,
.woocommerce nav.woocommerce-pagination ul li { border: 0; margin: 0; }
.woocommerce nav.woocommerce-pagination ul {
	display: inline-flex;
	gap: var(--s-2);
}
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 var(--s-3);
	border: 1px solid var(--line);
	background: var(--bg);
	color: var(--ink);
	font-size: var(--t-meta);
	font-weight: var(--w-med);
}
.woocommerce nav.woocommerce-pagination ul li a:hover { border-color: var(--ink); }
.woocommerce nav.woocommerce-pagination ul li span.current {
	background: var(--ink);
	border-color: var(--ink);
	color: var(--bg);
}


/* ═══════════════════════════════════════════════════════════════
   4 · SINGLE PRODUCT — Gallery, summary, tabs, related
   ═══════════════════════════════════════════════════════════════ */

/* ─── Product wrapper — float layout preserved ─── */
body.single-product div.product {
	position: relative;
	margin: 0 0 var(--s-5);
	display: flow-root;
}
body.single-product div.product::after { content: ""; display: table; clear: both; }

/* Sale badge */
body.single-product div.product > span.onsale {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 2;
	background: var(--danger);
	color: var(--bg);
	font-size: 11px;
	font-weight: var(--w-bold);
	letter-spacing: var(--tr-wide);
	text-transform: uppercase;
	padding: 6px 12px;
	border-radius: 0;
	width: auto; height: auto;
	min-height: 0; min-width: 0;
	line-height: 1;
	margin: 0;
}

/* ─── Gallery ─── */
.woocommerce-product-gallery { min-width: 0; }
.woocommerce-product-gallery .flex-viewport,
.woocommerce-product-gallery__wrapper {
	background: var(--surface);
	overflow: hidden;
}
.woocommerce-product-gallery__wrapper { position: relative; }
.woocommerce-product-gallery__image img,
.woocommerce-product-gallery__wrapper > a img { width: 100%; height: auto; display: block; }
.woocommerce-product-gallery .flex-control-thumbs {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: var(--s-2);
	margin-top: var(--s-3);
	padding: 0;
	list-style: none;
}
.woocommerce-product-gallery .flex-control-thumbs li {
	aspect-ratio: 1;
	cursor: pointer;
	margin: 0;
	width: auto;
}
.woocommerce-product-gallery .flex-control-thumbs li img {
	width: 100%; height: 100%;
	object-fit: cover;
	opacity: 0.5;
	transition: opacity var(--d-fast) var(--ease);
	border: 1px solid transparent;
}
.woocommerce-product-gallery .flex-control-thumbs li img.flex-active,
.woocommerce-product-gallery .flex-control-thumbs li img:hover {
	opacity: 1;
	border-color: var(--ink);
}

/* Zoom trigger */
.woocommerce-product-gallery__trigger {
	position: absolute;
	top: var(--s-3); right: var(--s-3);
	z-index: 3;
	width: 40px; height: 40px;
	background: var(--bg);
	border: 1px solid var(--line);
	color: var(--ink);
	font-size: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.woocommerce-product-gallery__trigger::before {
	content: "\f00e";
	font-family: "Font Awesome 6 Free";
	font-weight: 900;
	font-size: 14px;
}

/* ─── Summary column ─── */
.summary.entry-summary {
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: var(--s-4);
}
/* Reset WC's default spacing on all children */
.summary.entry-summary > * { margin-top: 0 !important; margin-bottom: 0 !important; }

/* Product title */
.summary .product_title {
	font-size: var(--t-h2);
	font-weight: var(--w-light);
	letter-spacing: -0.02em;
	line-height: var(--lh-tight);
	color: var(--ink);
}

/* ─── Price ─── */
.summary .price {
	display: flex;
	align-items: baseline;
	gap: var(--s-3);
	padding-bottom: var(--s-4);
	border-bottom: 1px solid var(--line);
}
.summary .price > .woocommerce-Price-amount,
.summary .price ins .woocommerce-Price-amount {
	font-size: var(--t-h3);
	font-weight: var(--w-med);
	color: var(--ink);
}
.summary .price ins {
	background: transparent;
	text-decoration: none;
	color: var(--accent);
}
.summary .price ins .woocommerce-Price-amount { color: var(--accent); }
.summary .price del { color: var(--mute); font-weight: var(--w-reg); }
.summary .price del .woocommerce-Price-amount {
	font-size: var(--t-lead);
	text-decoration: line-through;
}

/* Rating row */
.summary .woocommerce-product-rating {
	display: flex;
	align-items: center;
	gap: var(--s-2);
}
.summary .woocommerce-product-rating .star-rating { float: none; margin: 0; }
.summary .woocommerce-product-rating .woocommerce-review-link {
	color: var(--mute);
	font-size: var(--t-meta);
	text-decoration: underline;
	text-underline-offset: 3px;
}

/* Short description */
.summary .woocommerce-product-details__short-description {
	color: var(--ink-2);
	line-height: var(--lh-body);
	font-size: var(--t-body);
}
.summary .woocommerce-product-details__short-description p:last-child { margin-bottom: 0; }

/* ─── Add-to-cart form ─── */
.summary form.cart {
	display: flex;
	flex-wrap: wrap;
	gap: var(--s-2);
	align-items: stretch;
	padding-top: var(--s-2);
}
.summary form.cart .quantity {
	display: inline-flex;
	align-items: center;
	border: 1px solid var(--line);
	background: var(--bg);
	flex-shrink: 0;
}
.summary form.cart .quantity input.qty {
	width: 60px; height: 52px;
	border: 0; background: transparent;
	text-align: center;
	font-family: var(--font);
	font-size: var(--t-body);
	color: var(--ink);
	-moz-appearance: textfield;
}
.summary form.cart .quantity input.qty::-webkit-outer-spin-button,
.summary form.cart .quantity input.qty::-webkit-inner-spin-button { -webkit-appearance: none; }
.summary form.cart .quantity .screen-reader-text { display: none; }

.summary form.cart .single_add_to_cart_button {
	flex: 1 1 200px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 52px;
	padding: 0 var(--s-5);
	background: var(--accent);
	color: var(--accent-ink);
	border: 1px solid var(--accent);
	font-family: var(--font);
	font-size: var(--t-body);
	font-weight: var(--w-med);
	letter-spacing: 0.02em;
	border-radius: var(--radius);
	cursor: pointer;
	text-transform: none;
	transition: all var(--d-fast) var(--ease);
}
.summary form.cart .single_add_to_cart_button:hover {
	background: var(--ink);
	border-color: var(--ink);
	color: var(--bg);
}

/* Variations */
.summary form.cart .variations { width: 100%; border-collapse: collapse; margin: 0; }
.summary form.cart .variations tbody { display: block; }
.summary form.cart .variations tr { display: block; padding-block: var(--s-2); }
.summary form.cart .variations td { display: block; padding: 0; border: 0; background: transparent; }
.summary form.cart .variations td.label { margin-bottom: var(--s-1); }
.summary form.cart .variations td.label label {
	font-size: var(--t-meta);
	font-weight: var(--w-med);
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--mute);
}
.summary form.cart .variations select {
	width: 100%; height: 48px;
	padding: 0 var(--s-3);
	border: 1px solid var(--line);
	background: var(--bg);
	font-family: var(--font);
	font-size: var(--t-body);
	color: var(--ink);
}
.summary form.cart .variations select:focus { outline: none; border-color: var(--ink); }
.summary form.cart .reset_variations {
	font-size: var(--t-meta);
	color: var(--mute);
	text-decoration: underline;
	margin-top: var(--s-1);
}

/* Product meta */
.summary .product_meta {
	font-size: var(--t-meta);
	color: var(--mute);
	padding-top: var(--s-4);
	border-top: 1px solid var(--line);
	display: flex;
	flex-direction: column;
	gap: 4px;
}
.summary .product_meta > span { display: block; }
.summary .product_meta a {
	color: var(--ink-2);
	text-decoration: underline;
	text-underline-offset: 3px;
}
.summary .product_meta a:hover { color: var(--accent); }

/* Stock */
.summary .stock { font-size: var(--t-meta); }
.summary .stock.in-stock { color: var(--success); }
.summary .stock.out-of-stock { color: var(--danger); }

/* ─── Tabs ─── */
body.single-product .woocommerce-tabs {
	clear: both;
	margin-top: var(--s-6);
	padding-top: var(--s-4);
	border-top: 1px solid var(--line);
}
body.single-product .woocommerce-tabs ul.tabs {
	display: flex;
	gap: var(--s-5);
	margin: 0 0 var(--s-4);
	padding: 0 0 var(--s-3);
	border-bottom: 1px solid var(--line);
	flex-wrap: wrap;
	list-style: none;
}
body.single-product .woocommerce-tabs ul.tabs::before,
body.single-product .woocommerce-tabs ul.tabs::after { content: none; }
body.single-product .woocommerce-tabs ul.tabs li {
	display: inline-flex;
	margin: 0; padding: 0;
	border: 0; background: transparent;
	border-radius: 0;
}
body.single-product .woocommerce-tabs ul.tabs li::before,
body.single-product .woocommerce-tabs ul.tabs li::after { content: none; }
body.single-product .woocommerce-tabs ul.tabs li a {
	display: inline-block;
	padding: var(--s-2) 0;
	font-size: var(--t-meta);
	font-weight: var(--w-med);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--mute);
	border-bottom: 2px solid transparent;
	margin-bottom: -3px;
	text-decoration: none;
	transition: color var(--d-fast) var(--ease);
}
body.single-product .woocommerce-tabs ul.tabs li.active a {
	color: var(--ink);
	border-bottom-color: var(--accent);
}
body.single-product .woocommerce-tabs ul.tabs li a:hover { color: var(--ink); }
body.single-product .woocommerce-tabs .panel { max-width: 880px; padding: 0; }
body.single-product .woocommerce-tabs .panel h2 {
	font-size: var(--t-h4);
	font-weight: var(--w-med);
	color: var(--ink);
	margin: 0 0 var(--s-3);
}
body.single-product .woocommerce-tabs .panel p {
	color: var(--ink-2);
	line-height: var(--lh-body);
}

/* Additional info table */
body.single-product .woocommerce-tabs table.shop_attributes {
	border: 0;
	border-top: 1px solid var(--line);
}
body.single-product .woocommerce-tabs table.shop_attributes th {
	background: transparent;
	font-size: var(--t-meta);
	font-weight: var(--w-med);
	color: var(--mute);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	padding: var(--s-3) var(--s-4) var(--s-3) 0;
	border-bottom: 1px solid var(--line);
	width: 180px;
}
body.single-product .woocommerce-tabs table.shop_attributes td {
	padding: var(--s-3) 0;
	border-bottom: 1px solid var(--line);
	font-style: normal;
	color: var(--ink-2);
}
body.single-product .woocommerce-tabs table.shop_attributes tr:nth-child(even) td,
body.single-product .woocommerce-tabs table.shop_attributes tr:nth-child(even) th { background: transparent; }

/* ─── Related / upsell products ─── */
body.single-product .related.products,
body.single-product .upsells.products {
	clear: both;
	margin-top: var(--s-6);
	padding-top: var(--s-5);
	border-top: 1px solid var(--line);
	display: flow-root;
}
body.single-product .related.products > h2,
body.single-product .upsells.products > h2 {
	font-size: var(--t-h3);
	font-weight: var(--w-light);
	letter-spacing: -0.01em;
	margin: 0 0 var(--s-4);
	color: var(--ink);
}
body.single-product .related.products ul.products,
body.single-product .upsells.products ul.products { margin-top: 0; }


/* ═══════════════════════════════════════════════════════════════
   5 · CART PAGE
   ═══════════════════════════════════════════════════════════════ */

.woocommerce-cart table.cart {
	border: 1px solid var(--line);
	border-radius: var(--radius);
}
.woocommerce-cart table.cart img {
	width: 80px;
	height: auto;
	border: 0;
	box-shadow: none;
	background: var(--surface);
}
.woocommerce-cart table.cart .product-name a {
	color: var(--ink);
	font-weight: var(--w-med);
	text-decoration: none;
}
.woocommerce-cart table.cart .product-name a:hover { color: var(--accent); }
.woocommerce-cart table.cart .product-price,
.woocommerce-cart table.cart .product-subtotal {
	font-weight: var(--w-med);
	color: var(--ink);
}
.woocommerce-cart table.cart .product-quantity .quantity {
	display: inline-flex;
	align-items: center;
}

/* Coupon bar */
.woocommerce-cart table.cart td.actions {
	padding: var(--s-3) var(--s-4);
	border-top: 1px solid var(--line);
	background: var(--surface);
}
.woocommerce-cart table.cart td.actions .coupon {
	display: inline-flex;
	gap: var(--s-2);
	align-items: stretch;
}
.woocommerce-cart table.cart td.actions .coupon .input-text {
	width: 200px; height: 44px;
	padding: 0 var(--s-3);
	border: 1px solid var(--line);
	background: var(--bg);
	font-family: var(--font);
	font-size: var(--t-body);
	color: var(--ink);
	border-radius: var(--radius);
	box-sizing: border-box;
}
.woocommerce-cart table.cart td.actions .coupon .input-text:focus { outline: none; border-color: var(--ink); }
.woocommerce-cart table.cart td.actions .coupon .button { height: 44px; }
.woocommerce-cart table.cart td.actions > .button { float: right; height: 44px; }

/* Cart totals */
.woocommerce-cart .cart-collaterals {
	margin-top: var(--s-5);
	display: flow-root;
}
.woocommerce-cart .cart-collaterals .cart_totals {
	float: right;
	width: 380px;
	max-width: 100%;
}
.woocommerce-cart .cart-collaterals .cart_totals > h2 {
	font-size: var(--t-h4);
	font-weight: var(--w-med);
	color: var(--ink);
	margin: 0 0 var(--s-3);
}
.woocommerce-cart .cart-collaterals .cart_totals table {
	border: 1px solid var(--line);
	border-radius: var(--radius);
}
.woocommerce-cart .cart-collaterals .cart_totals table th {
	font-size: var(--t-meta);
	font-weight: var(--w-med);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--mute);
	padding: var(--s-3) var(--s-4);
	width: 35%;
	background: transparent;
}
.woocommerce-cart .cart-collaterals .cart_totals table td {
	padding: var(--s-3) var(--s-4);
	color: var(--ink);
	font-weight: var(--w-med);
}
.woocommerce-cart .cart-collaterals .cart_totals table tr.order-total th,
.woocommerce-cart .cart-collaterals .cart_totals table tr.order-total td {
	font-size: var(--t-lead);
	font-weight: var(--w-bold);
	color: var(--ink);
	border-top: 2px solid var(--ink);
}
.woocommerce-cart .cart-collaterals .cart_totals .discount td { color: var(--success); }

/* Proceed to checkout */
.woocommerce-cart .wc-proceed-to-checkout { padding: var(--s-3) 0 0; }
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%; height: 52px;
	background: var(--accent);
	color: var(--accent-ink);
	border: 1px solid var(--accent);
	font-family: var(--font);
	font-size: var(--t-meta);
	font-weight: var(--w-med);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	border-radius: var(--radius);
	text-decoration: none;
	transition: all var(--d-fast) var(--ease);
}
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:hover {
	background: var(--ink);
	border-color: var(--ink);
	color: var(--bg);
}

/* Empty cart */
.woocommerce-cart .cart-empty {
	text-align: center;
	padding: var(--s-7) 0;
	font-size: var(--t-lead);
	color: var(--ink-2);
}
.woocommerce-cart .return-to-shop { text-align: center; margin-top: var(--s-4); }
.woocommerce-cart .return-to-shop .button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 52px;
	padding: 0 var(--s-5);
}

/* Cross-sells */
.woocommerce-cart .cart-collaterals .cross-sells { float: left; width: 48%; }
.woocommerce-cart .cart-collaterals .cross-sells > h2 {
	font-size: var(--t-h4);
	font-weight: var(--w-med);
	color: var(--ink);
	margin: 0 0 var(--s-4);
}

/* Shipping calculator */
.woocommerce-cart .shipping-calculator-button {
	font-size: var(--t-meta);
	color: var(--mute);
	text-decoration: underline;
	text-underline-offset: 3px;
}
.woocommerce-cart .shipping-calculator-button:hover { color: var(--accent); }
.woocommerce-cart .shipping-calculator-button::after { display: none; }
.woocommerce-cart .shipping-calculator-form { margin-top: var(--s-3); }
.woocommerce-cart .shipping-calculator-form .button { margin-top: var(--s-3); }


/* ═══════════════════════════════════════════════════════════════
   6 · CHECKOUT PAGE
   ═══════════════════════════════════════════════════════════════

   HTML structure (from WC shortcode):
     form.checkout.woocommerce-checkout
       ├─ .col2-set#customer_details
       │    ├─ .col-1  (billing fields)
       │    └─ .col-2  (shipping + additional fields)
       ├─ h3#order_review_heading
       └─ #order_review
            ├─ table (order summary)
            └─ #payment

   Grid: form gets two columns. col2-set spans left,
   order_review_heading + order_review span right.        */

form.checkout.woocommerce-checkout {
	display: grid;
	grid-template-columns: 1fr 380px;
	gap: 0 var(--s-5);
	align-items: start;
}

/* Left column */
form.checkout.woocommerce-checkout > .col2-set {
	grid-column: 1;
	grid-row: 1 / 3;
}

/* Right column — both heading + review start at row 1
   so they sit flush with the billing section top */
form.checkout.woocommerce-checkout > h3#order_review_heading {
	grid-column: 2;
	grid-row: 1;
}
form.checkout.woocommerce-checkout > #order_review {
	grid-column: 2;
	grid-row: 2;
	position: sticky;
	top: var(--s-4);
}

/* Kill default WC margin on the review table so it
   sits tight under the heading */
.woocommerce-checkout .woocommerce-checkout-review-order > .shop_table {
	margin-top: 0;
}

/* col2-set: stack billing + shipping vertically */
.woocommerce-checkout .col2-set {
	display: block;
}
.woocommerce-checkout .col2-set .col-1,
.woocommerce-checkout .col2-set .col-2 {
	float: none;
	width: 100%;
}
.woocommerce-checkout .col2-set .col-2 { margin-top: var(--s-4); }

/* ─── Headings ─── */
.woocommerce-checkout h3 {
	font-size: var(--t-h4);
	font-weight: var(--w-med);
	color: var(--ink);
	margin: 0 0 var(--s-3);
	padding-bottom: var(--s-3);
	border-bottom: 1px solid var(--line);
}
.woocommerce-checkout h3#ship-to-different-address {
	display: flex;
	align-items: center;
	gap: var(--s-3);
	border-bottom: 0;
	padding-bottom: 0;
	margin-top: var(--s-4);
}
.woocommerce-checkout h3#ship-to-different-address label {
	font-size: var(--t-h4);
	font-weight: var(--w-med);
	color: var(--ink);
	margin: 0;
	cursor: pointer;
}
.woocommerce-checkout h3#ship-to-different-address input[type="checkbox"] {
	width: 20px; height: 20px;
	accent-color: var(--accent);
}
.woocommerce-checkout .woocommerce-additional-fields h3 { margin-top: var(--s-4); }
.woocommerce-checkout #order_comments { min-height: 80px; }

/* Order review heading — tight margin so table sits
   right below without a big gap */
.woocommerce-checkout h3#order_review_heading {
	font-size: var(--t-h4);
	font-weight: var(--w-med);
	color: var(--ink);
	margin: 0 0 var(--s-3);
	padding-bottom: var(--s-3);
	border-bottom: 1px solid var(--line);
}
/* Remove any default WC top-margin on order review */
.woocommerce-checkout #order_review { margin-top: 0; }

/* Order review table */
.woocommerce-checkout .woocommerce-checkout-review-order-table {
	border: 1px solid var(--line);
	border-radius: var(--radius);
}
.woocommerce-checkout .woocommerce-checkout-review-order-table th {
	font-size: var(--t-meta);
	font-weight: var(--w-med);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--mute);
	background: var(--surface);
	padding: var(--s-3) var(--s-4);
}
.woocommerce-checkout .woocommerce-checkout-review-order-table td {
	padding: var(--s-3) var(--s-4);
	color: var(--ink);
}
.woocommerce-checkout .woocommerce-checkout-review-order-table .product-name {
	color: var(--ink);
	font-weight: var(--w-reg);
}
.woocommerce-checkout .woocommerce-checkout-review-order-table .product-name .product-quantity {
	color: var(--mute);
	font-weight: var(--w-med);
}
.woocommerce-checkout .woocommerce-checkout-review-order-table tfoot tr.order-total th,
.woocommerce-checkout .woocommerce-checkout-review-order-table tfoot tr.order-total td {
	font-size: var(--t-lead);
	font-weight: var(--w-bold);
	color: var(--ink);
	border-top: 2px solid var(--ink);
}

/* ─── Payment section ─── */
.woocommerce-checkout #payment {
	background: var(--surface);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	margin-top: var(--s-4);
}
.woocommerce-checkout #payment ul.payment_methods {
	padding: var(--s-4);
	border-bottom: 1px solid var(--line);
	margin: 0;
	list-style: none;
}
.woocommerce-checkout #payment ul.payment_methods li {
	margin: 0;
	padding: var(--s-3) 0;
	border-bottom: 1px solid var(--line);
	font-family: var(--font);
	font-size: var(--t-body);
	color: var(--ink);
	line-height: 1.5;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
}
.woocommerce-checkout #payment ul.payment_methods li .payment_box {
	flex-basis: 100%;
}
.woocommerce-checkout #payment ul.payment_methods li:last-child { border-bottom: 0; }
.woocommerce-checkout #payment ul.payment_methods li input[type="radio"] {
	display: inline-block !important;
	margin-right: var(--s-3);
	accent-color: var(--accent);
	width: 18px; height: 18px;
	vertical-align: middle;
	cursor: pointer;
	flex-shrink: 0;
}
.woocommerce-checkout #payment ul.payment_methods li label {
	font-size: var(--t-body);
	font-weight: var(--w-reg);
	color: var(--ink);
	cursor: pointer;
	display: inline;
	margin: 0;
}
.woocommerce-checkout #payment ul.payment_methods li img {
	max-height: 24px;
	vertical-align: middle;
	margin-left: var(--s-2);
}
.woocommerce-checkout #payment div.payment_box {
	background: var(--bg);
	border: 1px solid var(--line);
	color: var(--ink-2);
	padding: var(--s-3);
	margin: var(--s-3) 0;
	font-size: var(--t-meta);
	border-radius: var(--radius);
	line-height: var(--lh-body);
}
.woocommerce-checkout #payment div.payment_box::before {
	border-color: transparent transparent var(--bg) transparent;
}

/* Place order */
.woocommerce-checkout #payment div.form-row { padding: var(--s-4); margin: 0; }
.woocommerce-checkout #payment #place_order {
	width: 100%; height: 52px;
	background: var(--accent);
	color: var(--accent-ink);
	border: 1px solid var(--accent);
	font-family: var(--font);
	font-size: var(--t-meta);
	font-weight: var(--w-med);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	border-radius: var(--radius);
	cursor: pointer;
	transition: all var(--d-fast) var(--ease);
}
.woocommerce-checkout #payment #place_order:hover {
	background: var(--ink);
	border-color: var(--ink);
	color: var(--bg);
}

/* Terms */
.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper { padding: 0 var(--s-4) var(--s-3); }
.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper .woocommerce-form__label {
	display: flex;
	align-items: flex-start;
	gap: var(--s-2);
	font-size: var(--t-meta);
	color: var(--ink-2);
	line-height: 1.5;
	cursor: pointer;
}
.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper input[type="checkbox"] {
	width: 18px; height: 18px;
	flex-shrink: 0;
	margin-top: 2px;
	accent-color: var(--accent);
}
.woocommerce-terms-and-conditions {
	border: 1px solid var(--line);
	background: var(--bg);
	box-shadow: none;
	padding: var(--s-3);
	max-height: 200px;
	overflow-y: auto;
	font-size: var(--t-meta);
	color: var(--ink-2);
	line-height: var(--lh-body);
	margin-bottom: var(--s-3);
}

/* Privacy policy text */
.woocommerce-checkout .woocommerce-privacy-policy-text {
	font-size: var(--t-meta);
	color: var(--ink-2);
	line-height: 1.5;
}
.woocommerce-checkout .woocommerce-privacy-policy-text a {
	color: var(--accent);
	text-decoration: underline;
	text-underline-offset: 2px;
}

/* Coupon toggle & form */
.woocommerce-form-login-toggle .woocommerce-info,
.woocommerce-form-coupon-toggle .woocommerce-info {
	background: var(--surface);
	font-size: var(--t-body);
}
.woocommerce-form-login-toggle .woocommerce-info a,
.woocommerce-form-coupon-toggle .woocommerce-info a {
	color: var(--accent);
	font-weight: var(--w-med);
	text-decoration: underline;
	text-underline-offset: 3px;
}
.woocommerce-checkout form.checkout_coupon {
	display: flex;
	flex-wrap: wrap;
	gap: var(--s-2);
	align-items: stretch;
}
.woocommerce-checkout form.checkout_coupon .form-row { margin: 0; }
.woocommerce-checkout form.checkout_coupon .form-row-first { flex: 1; }
.woocommerce-checkout form.checkout_coupon .form-row-last { flex-shrink: 0; }

/* Inline errors */
.woocommerce-checkout .checkout-inline-error-message {
	color: var(--danger);
	font-size: var(--t-meta);
	margin-top: var(--s-1);
}


/* ═══════════════════════════════════════════════════════════════
   7 · MY ACCOUNT
   ═══════════════════════════════════════════════════════════════ */

/* ─── Master heading reset for My Account ───
   WC prints bare h2/h3 inside my-account content that inherit
   huge global sizes. This resets ALL headings inside the content
   area to a sane default, then individual sections override. */
.woocommerce-account .woocommerce h2,
.woocommerce-account .woocommerce h3 {
	font-family: var(--font);
	font-size: var(--t-h4);
	font-weight: var(--w-med);
	color: var(--ink);
	margin: 0 0 var(--s-3);
	padding: 0;
	border: 0;
	line-height: var(--lh-tight);
}

/* ─── Layout: logged-in (nav + content side-by-side) ───
   Only apply flex when the nav sidebar is present (logged-in).
   WP adds .logged-in to <body> when user is authenticated. */
body.woocommerce-account.logged-in .woocommerce {
	display: flex;
	gap: var(--s-5);
	align-items: flex-start;
}
body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation {
	width: 220px;
	flex-shrink: 0;
}
body.woocommerce-account.logged-in .woocommerce-MyAccount-content {
	flex: 1;
	min-width: 0;
}
.woocommerce-account .woocommerce-MyAccount-content mark {
	background: transparent;
	color: inherit;
	font-weight: var(--w-bold);
}

/* ─── Layout: logged-out (login / register forms) ───
   No nav sidebar present — center the form(s) with max-width. */
body.woocommerce-account:not(.logged-in) .woocommerce {
	max-width: 520px;
	margin-inline: auto;
}
/* Side-by-side login + register (WC "my-account" default) */
body.woocommerce-account:not(.logged-in) #customer_login {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--s-4);
}
body.woocommerce-account:not(.logged-in) #customer_login h2 {
	font-size: var(--t-h4);
	font-weight: var(--w-med);
	color: var(--ink);
	margin: 0 0 var(--s-3);
	padding-bottom: var(--s-3);
	border-bottom: 1px solid var(--line);
}
body.woocommerce-account:not(.logged-in) #customer_login .col-1,
body.woocommerce-account:not(.logged-in) #customer_login .col-2 {
	float: none;
	width: 100%;
	margin: 0; padding: 0;
}
/* Single login form (no register enabled) */
body.woocommerce-account:not(.logged-in) .woocommerce > form.login {
	max-width: 440px;
	margin-inline: auto;
}

/* ─── Navigation ─── */
.woocommerce-MyAccount-navigation ul {
	list-style: none;
	margin: 0; padding: 0;
	display: flex;
	flex-direction: column;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	overflow: hidden;
}
.woocommerce-MyAccount-navigation ul li { list-style: none; margin: 0; }
.woocommerce-MyAccount-navigation ul li a {
	display: flex;
	align-items: center;
	gap: var(--s-3);
	padding: var(--s-3) var(--s-4);
	font-family: var(--font);
	font-size: var(--t-body);
	font-weight: var(--w-reg);
	color: var(--ink-2);
	border-bottom: 1px solid var(--line);
	text-decoration: none;
	transition: all var(--d-fast) var(--ease);
}
.woocommerce-MyAccount-navigation ul li:last-child a { border-bottom: 0; }
.woocommerce-MyAccount-navigation ul li a:hover {
	background: var(--surface);
	color: var(--ink);
}
.woocommerce-MyAccount-navigation ul li.is-active a {
	background: var(--ink);
	color: var(--bg);
	font-weight: var(--w-med);
}
.woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link--customer-logout a {
	color: var(--mute);
}
.woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link--customer-logout a:hover {
	color: var(--danger);
	background: transparent;
}

/* ─── Dashboard ─── */
.woocommerce-account .woocommerce-MyAccount-content > p {
	color: var(--ink-2);
	line-height: var(--lh-body);
	margin-bottom: var(--s-3);
}
.woocommerce-account .woocommerce-MyAccount-content > p a {
	color: var(--accent);
	font-weight: var(--w-med);
	text-decoration: underline;
	text-underline-offset: 3px;
}
.woocommerce-account .woocommerce-MyAccount-content > p a:hover { color: var(--ink); }

/* ─── Orders table ─── */
.woocommerce-account table.my_account_orders {
	font-size: var(--t-body);
	border: 1px solid var(--line);
	border-radius: var(--radius);
}
.woocommerce-account table.my_account_orders th {
	font-size: var(--t-meta);
	font-weight: var(--w-med);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--mute);
	background: var(--surface);
	padding: var(--s-3) var(--s-4);
}
.woocommerce-account table.my_account_orders td {
	padding: var(--s-3) var(--s-4);
	vertical-align: middle;
	border-top: 1px solid var(--line);
}
.woocommerce-account table.my_account_orders td a.button {
	height: 36px;
	padding: 0 var(--s-3);
	font-size: 12px;
}
/* Empty state notices — centered in content area */
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-info,
.woocommerce-account .woocommerce-info {
	text-align: center;
	justify-content: center;
}
/* Notice button inside my-account should center under text */
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-info .button {
	margin-left: 0;
}

/* ─── Wishlist empty state ─── */
.wishlist-empty {
	text-align: center;
	padding: var(--s-6) 0;
}
.wishlist-empty .wishlist-empty__icon {
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 48px;
	color: var(--mute);
	margin-bottom: var(--s-4);
}
.wishlist-empty h3 {
	font-size: var(--t-h3);
	font-weight: var(--w-med);
	margin-bottom: var(--s-2);
}
.wishlist-empty p {
	color: var(--ink-2);
	font-size: var(--t-body);
	margin-bottom: var(--s-4);
	max-width: 420px;
	margin-inline: auto;
}
.wishlist-empty .btn {
	display: inline-flex;
	align-items: center;
	gap: var(--s-1);
}

/* ─── Addresses ─── */
/* The wrapper .woocommerce-Addresses also carries WC's .col2-set class,
   and its children .col-1 / .col-2 get float:left + width:48% by default.
   We must kill those floats for grid to work. */
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses,
.woocommerce-account .woocommerce-MyAccount-content .col2-set.addresses {
	display: grid !important;
	grid-template-columns: 1fr 1fr;
	gap: var(--s-4);
}
.woocommerce-account .woocommerce-Addresses .col-1,
.woocommerce-account .woocommerce-Addresses .col-2,
.woocommerce-account .woocommerce-Addresses .woocommerce-Address {
	float: none !important;
	width: 100% !important;
	margin: 0 !important;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	padding: var(--s-4) var(--s-4) var(--s-5);
}
.woocommerce-account .woocommerce-Addresses .woocommerce-Address .title,
.woocommerce-account .woocommerce-Addresses .col-1 .title,
.woocommerce-account .woocommerce-Addresses .col-2 .title {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: var(--s-2);
	padding-bottom: var(--s-2);
	border-bottom: 1px solid var(--line);
}
/* Kill WC clearfix pseudo-elements on address title header */
.woocommerce-account .woocommerce-Addresses .title::before,
.woocommerce-account .woocommerce-Addresses .title::after,
.woocommerce-account .woocommerce-Addresses .woocommerce-Address-title::before,
.woocommerce-account .woocommerce-Addresses .woocommerce-Address-title::after {
	content: none !important;
	display: none !important;
}
/* High-specificity reset for address card h3 — prevents
   global heading sizes from bleeding through */
.woocommerce-account .woocommerce-Addresses .woocommerce-Address .title h2,
.woocommerce-account .woocommerce-Addresses .woocommerce-Address .title h3,
.woocommerce-account .woocommerce-MyAccount-content .addresses .title h2,
.woocommerce-account .woocommerce-MyAccount-content .addresses .title h3,
.woocommerce-account .woocommerce-Addresses .col-1 .title h3,
.woocommerce-account .woocommerce-Addresses .col-2 .title h3 {
	font-size: var(--t-meta) !important;
	font-weight: var(--w-bold) !important;
	color: var(--ink) !important;
	margin: 0 !important;
	padding: 0 !important;
	border: 0 !important;
	border-bottom: none !important;
	float: none !important;
	line-height: 1.3;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}
.woocommerce-account .woocommerce-Addresses .title .edit,
.woocommerce-account .addresses .title .edit {
	font-size: var(--t-meta);
	font-weight: var(--w-med);
	color: var(--accent);
	text-decoration: underline;
	text-underline-offset: 3px;
	float: none;
}
.woocommerce-account .woocommerce-Addresses .title .edit:hover,
.woocommerce-account .addresses .title .edit:hover { color: var(--ink); }
.woocommerce-account .woocommerce-Addresses address,
.woocommerce-account .addresses address {
	font-style: normal;
	color: var(--ink-2);
	line-height: var(--lh-body);
	font-size: var(--t-body);
	border: 0; padding: 0;
}
/* Kill col2-set clearfix pseudo-elements that break grid */
.woocommerce-account .woocommerce-Addresses::before,
.woocommerce-account .woocommerce-Addresses::after {
	content: none !important;
	display: none !important;
}

/* "You have not set up this type of address yet." */
.woocommerce-account .woocommerce-Addresses .woocommerce-Address > .woocommerce-Address-title ~ em,
.woocommerce-account .addresses address:empty + em {
	color: var(--mute);
	font-style: italic;
	font-size: var(--t-body);
}

/* ─── Edit address form ─── */
.woocommerce-account .woocommerce-MyAccount-content > h3,
.woocommerce-account .woocommerce-MyAccount-content > h2 {
	font-size: var(--t-h4);
	font-weight: var(--w-med);
	color: var(--ink);
	margin: 0 0 var(--s-3);
	padding-bottom: var(--s-3);
	border-bottom: 1px solid var(--line);
}

/* ─── Edit account form ─── */
.woocommerce-account .woocommerce-EditAccountForm h3,
.woocommerce-account .edit-account h3 {
	font-size: var(--t-h4);
	font-weight: var(--w-med);
	color: var(--ink);
	margin: var(--s-5) 0 var(--s-3);
	padding-bottom: var(--s-3);
	border-bottom: 1px solid var(--line);
}
.woocommerce-account .woocommerce-EditAccountForm fieldset {
	border: 1px solid var(--line);
	border-radius: var(--radius);
	padding: var(--s-4);
	margin: var(--s-4) 0;
}
.woocommerce-account .woocommerce-EditAccountForm fieldset legend {
	font-size: var(--t-meta);
	font-weight: var(--w-med);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--mute);
	padding: 0 var(--s-2);
}
/* Save button for edit-account / edit-address */
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Button,
.woocommerce-account .woocommerce-MyAccount-content button[name="save_account_details"],
.woocommerce-account .woocommerce-MyAccount-content button[name="save_address"] {
	margin-top: var(--s-3);
}

/* ─── Downloads ─── */
.woocommerce-account table.woocommerce-MyAccount-downloads {
	border: 1px solid var(--line);
	border-radius: var(--radius);
}
.woocommerce-account table.woocommerce-MyAccount-downloads th {
	font-size: var(--t-meta);
	font-weight: var(--w-med);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--mute);
	background: var(--surface);
	padding: var(--s-3) var(--s-4);
}
.woocommerce-account table.woocommerce-MyAccount-downloads td {
	padding: var(--s-3) var(--s-4);
	border-top: 1px solid var(--line);
}

/* ─── View order detail ─── */
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-order-details h2,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-customer-details h2,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-order-downloads h2 {
	font-size: var(--t-h4);
	font-weight: var(--w-med);
	color: var(--ink);
	margin: 0 0 var(--s-3);
	padding-bottom: var(--s-3);
	border-bottom: 1px solid var(--line);
}
.woocommerce-account .woocommerce-MyAccount-content .order-again { margin-top: var(--s-3); }
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-customer-details .woocommerce-columns {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--s-4);
}
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-customer-details address {
	font-style: normal;
	color: var(--ink-2);
	line-height: var(--lh-body);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	padding: var(--s-4);
}

/* ─── Password strength ─── */
.woocommerce-password-strength {
	font-family: var(--font);
	font-size: var(--t-meta);
	font-weight: var(--w-med);
	padding: var(--s-2) var(--s-3);
	margin-top: var(--s-2);
	text-align: center;
	border-radius: var(--radius);
}
.woocommerce-password-strength.strong { background: color-mix(in srgb, var(--success) 12%, var(--bg)); color: var(--success); }
.woocommerce-password-strength.short  { background: color-mix(in srgb, var(--danger) 12%, var(--bg)); color: var(--danger); }
.woocommerce-password-strength.bad    { background: color-mix(in srgb, var(--accent) 15%, var(--bg)); color: var(--accent); }
.woocommerce-password-strength.good   { background: color-mix(in srgb, var(--accent) 15%, var(--bg)); color: var(--accent); }

/* ─── Lost password / reset form ─── */
body.woocommerce-account:not(.logged-in) .woocommerce .woocommerce-ResetPassword,
body.woocommerce-account:not(.logged-in) .woocommerce form.woocommerce-ResetPassword {
	max-width: 440px;
	margin-inline: auto;
	border: 1px solid var(--line);
	background: var(--surface);
	padding: var(--s-4);
	border-radius: var(--radius);
}
body.woocommerce-account:not(.logged-in) .woocommerce .woocommerce-ResetPassword p {
	color: var(--ink-2);
	line-height: var(--lh-body);
	margin-bottom: var(--s-3);
}


/* ═══════════════════════════════════════════════════════════════
   8 · ORDER RECEIVED / THANK YOU
   ═══════════════════════════════════════════════════════════════ */

.woocommerce-order .woocommerce-thankyou-order-received {
	font-size: var(--t-lead);
	color: var(--ink);
	font-weight: var(--w-med);
	margin-bottom: var(--s-5);
	padding: var(--s-4) var(--s-5);
	background: var(--surface);
	border-left: 3px solid var(--accent);
}
/* Payment note between order summary and order details */
.woocommerce-order > p {
	color: var(--ink-2);
	font-size: var(--t-meta);
	margin-bottom: var(--s-5);
}
.woocommerce-order ul.order_details {
	display: flex;
	flex-wrap: wrap;
	gap: var(--s-4);
	margin: 0 0 var(--s-4);
	padding: var(--s-4);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	list-style: none;
}
.woocommerce-order ul.order_details li {
	font-size: var(--t-meta);
	color: var(--mute);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	padding-right: var(--s-4);
	border-right: 1px solid var(--line);
	float: none; margin: 0;
	line-height: 1.3;
	list-style: none;
}
.woocommerce-order ul.order_details li:last-child { border-right: 0; padding-right: 0; }
.woocommerce-order ul.order_details li strong {
	display: block;
	font-size: var(--t-body);
	font-weight: var(--w-med);
	color: var(--ink);
	text-transform: none;
	letter-spacing: 0;
	margin-top: var(--s-1);
}
/* Reset the global section padding — WC wraps order-details and
   customer-details in <section> tags which inherit padding-block: 96px.  */
section.woocommerce-order-details,
section.woocommerce-customer-details,
section.woocommerce-order-downloads {
	padding-block: 0;
	margin-bottom: var(--s-5);
}
.woocommerce-order-details,
.woocommerce-customer-details,
.woocommerce-order-downloads { margin-bottom: var(--s-5); }
.woocommerce-order-details > h2,
.woocommerce-customer-details > h2,
.woocommerce-order-downloads > h2 {
	font-size: var(--t-meta);
	font-weight: var(--w-bold);
	color: var(--ink);
	margin: 0 0 var(--s-4);
	padding-bottom: var(--s-3);
	border-bottom: 1px solid var(--line);
	text-transform: uppercase;
	letter-spacing: 0.06em;
}
.woocommerce-customer-details .woocommerce-columns {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--s-4);
}
.woocommerce-customer-details .woocommerce-column__title {
	font-size: var(--t-meta);
	font-weight: var(--w-bold);
	color: var(--ink);
	margin: 0 0 var(--s-3);
	text-transform: uppercase;
	letter-spacing: 0.06em;
}
.woocommerce-customer-details address {
	font-style: normal;
	color: var(--ink-2);
	line-height: var(--lh-body);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	padding: var(--s-4);
}
.woocommerce-order .woocommerce-order-details .shop_table {
	border: 1px solid var(--line);
	border-radius: var(--radius);
}
.woocommerce-order .wc-bacs-bank-details-account-name {
	font-weight: var(--w-bold);
	color: var(--ink);
}


/* ═══════════════════════════════════════════════════════════════
   9 · MINI CART WIDGET
   ═══════════════════════════════════════════════════════════════ */

.woocommerce.widget_shopping_cart .total,
.woocommerce .widget_shopping_cart .total {
	border-top: 2px solid var(--ink);
	padding: var(--s-3) 0 0;
	font-size: var(--t-body);
	font-weight: var(--w-med);
	color: var(--ink);
}
.woocommerce.widget_shopping_cart .total strong,
.woocommerce .widget_shopping_cart .total strong { font-weight: var(--w-bold); }

.woocommerce ul.cart_list li,
.woocommerce ul.product_list_widget li {
	padding: var(--s-3) 0;
	border-bottom: 1px solid var(--line);
}
.woocommerce ul.cart_list li:last-child,
.woocommerce ul.product_list_widget li:last-child { border-bottom: 0; }
.woocommerce ul.cart_list li a,
.woocommerce ul.product_list_widget li a {
	color: var(--ink);
	font-weight: var(--w-med);
	text-decoration: none;
}
.woocommerce ul.cart_list li a:hover,
.woocommerce ul.product_list_widget li a:hover { color: var(--accent); }
.woocommerce ul.cart_list li img,
.woocommerce ul.product_list_widget li img {
	width: 48px; height: auto;
	border: 1px solid var(--line);
	box-shadow: none;
}
.woocommerce.widget_shopping_cart .buttons a,
.woocommerce .widget_shopping_cart .buttons a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 40px;
	padding: 0 var(--s-4);
	font-family: var(--font);
	font-size: var(--t-meta);
	font-weight: var(--w-med);
	letter-spacing: 0.04em;
	text-transform: uppercase;
	border-radius: var(--radius);
	text-decoration: none;
	margin: var(--s-2) var(--s-2) 0 0;
}
.woocommerce .widget_price_filter .ui-slider .ui-slider-handle { background-color: var(--accent); }
.woocommerce .widget_price_filter .ui-slider .ui-slider-range { background-color: var(--accent); }
.woocommerce .widget_price_filter .price_slider_wrapper .ui-widget-content { background-color: var(--line); }


/* ═══════════════════════════════════════════════════════════════
   10 · RESPONSIVE
   ═══════════════════════════════════════════════════════════════ */

/* ── Large tablet (≤ 1024px) ── */
@media (max-width: 1024px) {

	/* Shop grid: 3 cols */
	.woocommerce ul.products,
	.woocommerce-page ul.products { grid-template-columns: repeat(3, minmax(0, 1fr)); }

	/* Single product: stack */
	body.single-product .woocommerce-product-gallery,
	body.single-product div.product .summary.entry-summary {
		float: none !important;
		width: 100% !important;
		margin-right: 0 !important;
		margin-left: 0 !important;
	}
	body.single-product .summary.entry-summary { margin-top: var(--s-5); }

	/* Cart collaterals: stack */
	.woocommerce-cart .cart-collaterals .cart_totals,
	.woocommerce-cart .cart-collaterals .cross-sells {
		float: none;
		width: 100%;
	}
	.woocommerce-cart .cart-collaterals .cross-sells { margin-top: var(--s-5); }

	/* Checkout: single column */
	form.checkout.woocommerce-checkout {
		grid-template-columns: 1fr;
	}
	form.checkout.woocommerce-checkout > .col2-set,
	form.checkout.woocommerce-checkout > h3#order_review_heading,
	form.checkout.woocommerce-checkout > #order_review {
		grid-column: 1;
		grid-row: auto;
	}
	form.checkout.woocommerce-checkout > #order_review {
		position: static;
	}
	form.checkout.woocommerce-checkout > h3#order_review_heading {
		margin-top: var(--s-5);
	}

	/* My Account: stack */
	body.woocommerce-account.logged-in .woocommerce {
		flex-direction: column;
	}
	body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation {
		width: 100%;
	}

	/* Horizontal account nav on tablet */
	.woocommerce-MyAccount-navigation ul {
		flex-direction: row;
		flex-wrap: wrap;
		border: 0;
		gap: var(--s-2);
	}
	.woocommerce-MyAccount-navigation ul li a {
		border: 1px solid var(--line);
		border-radius: var(--radius);
		padding: var(--s-2) var(--s-3);
		font-size: var(--t-meta);
		white-space: nowrap;
	}
	.woocommerce-MyAccount-navigation ul li:last-child a { border-bottom: 1px solid var(--line); }
	.woocommerce-MyAccount-navigation ul li.is-active a {
		background: var(--ink);
		color: var(--bg);
		border-color: var(--ink);
	}

	/* Addresses + thank-you columns */
	.woocommerce-customer-details .woocommerce-columns { grid-template-columns: 1fr; }
	.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses { grid-template-columns: 1fr; }
	.woocommerce-account .woocommerce-MyAccount-content .woocommerce-customer-details .woocommerce-columns { grid-template-columns: 1fr; }

	/* Logged-out form: full width on tablet */
	body.woocommerce-account:not(.logged-in) .woocommerce { max-width: 100%; }
}



/* ── Mobile (≤ 768px) ── */
@media (max-width: 768px) {

	/* Hero even smaller */
	body.woocommerce-cart .page-hero,
	body.woocommerce-checkout .page-hero,
	body.woocommerce-account .page-hero {
		padding-block: var(--s-4) var(--s-3);
	}
	body.woocommerce-cart .page-hero__title,
	body.woocommerce-checkout .page-hero__title,
	body.woocommerce-account .page-hero__title {
		font-size: clamp(1.25rem, 5vw, 1.75rem);
	}

	/* Cart table: responsive stack */
	.woocommerce-cart table.cart thead { display: none; }
	.woocommerce-cart table.cart tr {
		display: block;
		padding: var(--s-4);
		border-bottom: 1px solid var(--line);
		position: relative;
	}
	.woocommerce-cart table.cart td {
		display: block;
		text-align: left;
		padding: var(--s-1) 0;
		border: 0;
	}
	.woocommerce-cart table.cart td::before {
		content: attr(data-title);
		font-size: var(--t-meta);
		font-weight: var(--w-med);
		color: var(--mute);
		text-transform: uppercase;
		letter-spacing: 0.04em;
		display: block;
		margin-bottom: var(--s-1);
	}
	.woocommerce-cart table.cart td.product-remove::before,
	.woocommerce-cart table.cart td.actions::before { display: none; }
	.woocommerce-cart table.cart td.product-remove {
		position: absolute;
		top: var(--s-3);
		right: var(--s-3);
	}
	.woocommerce-cart table.cart td.product-thumbnail {
		text-align: center;
		padding-bottom: var(--s-3);
	}
	.woocommerce-cart table.cart td.product-thumbnail img {
		width: 100px;
		margin: 0 auto;
	}
	.woocommerce-cart table.cart td.actions {
		text-align: left;
		padding: var(--s-3) 0;
	}
	.woocommerce-cart table.cart td.actions .coupon {
		display: flex;
		flex-direction: column;
		gap: var(--s-2);
		width: 100%;
		float: none;
		margin-bottom: var(--s-3);
	}
	.woocommerce-cart table.cart td.actions .coupon .input-text { width: 100%; }
	.woocommerce-cart table.cart td.actions > .button { float: none; width: 100%; }

	/* Place order full-width */
	.woocommerce-checkout #payment #place_order { float: none; width: 100%; }

	/* Thank-you details vertical */
	.woocommerce-order ul.order_details { flex-direction: column; gap: var(--s-3); }
	.woocommerce-order ul.order_details li {
		border-right: 0; padding-right: 0;
		border-bottom: 1px solid var(--line);
		padding-bottom: var(--s-3);
	}
	.woocommerce-order ul.order_details li:last-child { border-bottom: 0; padding-bottom: 0; }

	/* Orders table responsive */
	.woocommerce-account table.my_account_orders thead { display: none; }
	.woocommerce-account table.my_account_orders tr {
		display: block;
		padding: var(--s-3) 0;
		border-bottom: 1px solid var(--line);
	}
	.woocommerce-account table.my_account_orders td {
		display: block;
		text-align: left;
		padding: var(--s-1) 0;
		border: 0;
	}
	.woocommerce-account table.my_account_orders td::before {
		content: attr(data-title) ": ";
		font-weight: var(--w-med);
		color: var(--mute);
	}

	/* Notices stack on mobile */
	.woocommerce-message,
	.woocommerce-error,
	.woocommerce-info {
		flex-direction: column;
		text-align: center;
		gap: var(--s-2);
	}
	.woocommerce-message .button,
	.woocommerce-info .button,
	.woocommerce-error .button {
		margin-left: 0;
		width: 100%;
	}
}


/* ── Small mobile (≤ 720px) ── */
@media (max-width: 720px) {
	.woocommerce ul.products,
	.woocommerce-page ul.products {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: var(--s-4) var(--s-3);
	}
	.woocommerce-product-gallery .flex-control-thumbs {
		grid-template-columns: repeat(4, 1fr);
	}
}



/* ── Extra small (≤ 480px) ── */
@media (max-width: 480px) {
	.woocommerce ul.products li.product,
	.woocommerce-page ul.products li.product {
		grid-column: span 1;
	}
	.woocommerce li.product .woocommerce-loop-product__title { font-size: var(--t-body); }
	.woocommerce li.product .price { font-size: var(--t-meta); }

	/* Cart */
	.woocommerce-cart table.cart td.product-thumbnail { display: none; }
	.woocommerce-cart .cart-collaterals { padding: var(--s-3); }

	/* Checkout */
	.woocommerce form.checkout .col-1,
	.woocommerce form.checkout .col-2 { grid-column: span 1; }

	/* My Account */
	.woocommerce-account table.my_account_orders thead { display: none; }
	.woocommerce-account table.my_account_orders tr {
		display: block;
		padding: var(--s-3) 0;
		border-bottom: 1px solid var(--line);
	}
	.woocommerce-account table.my_account_orders td {
		display: block;
		padding: var(--s-1) 0;
		border: 0;
		text-align: left;
	}
	.woocommerce-account table.my_account_orders td::before {
		content: attr(data-title) ": ";
		font-weight: var(--w-med);
		color: var(--ink);
	}
}
