:root {
	/* Design tokens (Option A) */
	--color-bg: #F3EFEA; /* warm stone */
	--color-surface: #FFFFFF;

	--color-text: #4A3F36; /* walnut */
	--color-heading: #4A3F36;
	--color-muted: #6B5F56;

	--color-border: #E1D8CF;

	--color-primary: #E6A34A; /* honey/wood amber */
	--color-primary-contrast: #2C241D;
	--color-primary-hover: #D8943D;
	--color-primary-active: #C9862F;

	--color-accent: #5B2E8A; /* deep aubergine */
	--color-accent-contrast: #FFFFFF;
	--color-accent-hover: #4C2575;
	--color-accent-active: #3F1F62;

	--color-success: #3F6B4F; /* muted forest */
	--color-success-contrast: #FFFFFF;

	--color-link: var(--color-accent);
	--color-link-hover: var(--color-primary);
	--color-link-underline: rgba(91, 46, 138, 0.35);
	--color-link-underline-hover: rgba(230, 163, 74, 0.45);

	--color-accent-soft: rgba(91, 46, 138, 0.35);
	--color-tint: rgba(230, 163, 74, 0.10);
	--color-tint-hover: rgba(230, 163, 74, 0.16);

	--color-focus-ring: rgba(91, 46, 138, 0.25);
	--color-focus-outline: rgba(91, 46, 138, 0.45);
	--radius: 14px;
	--shadow: 0 6px 20px rgba(0, 0, 0, 0.06);
	--shadow-strong: 0 14px 40px rgba(0, 0, 0, 0.10);
	--shadow-button: 0 10px 24px rgba(0, 0, 0, 0.10);

	--space-1: 0.25rem;
	--space-2: 0.5rem;
	--space-3: 0.75rem;
	--space-4: 1rem;
	--space-5: 1.5rem;
	--space-6: 2rem;
	--space-7: 3rem;
	--space-8: 4rem;

	--font-body: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	--font-heading: ui-serif, Georgia, Cambria, "Times New Roman", Times, serif;

	--content-max: 1120px;
	--focus: 0 0 0 3px var(--color-focus-ring);
}

* { box-sizing: border-box; }

html { font-size: 16px; }

body {
	margin: 0;
	font-family: var(--font-body);
	line-height: 1.6;
	color: var(--color-text);
	background: var(--color-bg);
	text-rendering: optimizeLegibility;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

button,
input,
select,
textarea {
	font: inherit;
}

.skip-link {
	position: absolute;
	left: -999px;
	top: var(--space-4);
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: 999px;
	padding: 0.5rem 0.9rem;
	z-index: 1000;
}

.skip-link:focus {
	left: var(--space-4);
	outline: none;
	box-shadow: var(--focus);
}

:focus-visible {
	outline: 3px solid var(--color-focus-outline);
	outline-offset: 3px;
}

img { max-width: 100%; height: auto; }

.ahw-container {
	max-width: var(--content-max);
	margin-left: auto;
	margin-right: auto;
	padding-left: var(--space-5);
	padding-right: var(--space-5);
}

@media (max-width: 768px) {
	.ahw-container {
		padding-left: var(--space-4);
		padding-right: var(--space-4);
	}
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-heading);
	letter-spacing: -0.01em;
	line-height: 1.15;
	margin: 0 0 var(--space-4);
}

h1 { font-size: clamp(2.2rem, 3.1vw, 3.1rem); }
h2 { font-size: clamp(1.7rem, 2.2vw, 2.35rem); }
h3 { font-size: clamp(1.25rem, 1.5vw, 1.75rem); }

p { margin: 0 0 var(--space-4); color: var(--color-muted); }

/* Some imported WP content includes inline `font-family` declarations.
   Keep typography consistent with the header menu by forcing those to inherit. */
.entry-content,
.woocommerce div.product .summary,
.woocommerce div.product .woocommerce-Tabs-panel {
	font-family: var(--font-body);
}

.entry-content :where(p, li, span, div, td, th, a),
.woocommerce div.product .summary :where(p, li, span, div, td, th, a),
.woocommerce div.product .woocommerce-Tabs-panel :where(p, li, span, div, td, th, a) {
	font-family: inherit;
}

.entry-content :where(p, li, span, div, td, th, a)[style*="font-family"],
.woocommerce div.product .summary :where(p, li, span, div, td, th, a)[style*="font-family"],
.woocommerce div.product .woocommerce-Tabs-panel :where(p, li, span, div, td, th, a)[style*="font-family"] {
	font-family: inherit !important;
}

.entry-content :where(h1, h2, h3, h4, h5, h6),
.woocommerce div.product .summary :where(h1, h2, h3, h4, h5, h6),
.woocommerce div.product .woocommerce-Tabs-panel :where(h1, h2, h3, h4, h5, h6) {
	font-family: var(--font-heading);
}

a {
	color: var(--color-link);
	text-decoration: none;
	text-underline-offset: 0.15em;
}

a:hover {
	color: var(--color-link-hover);
	text-decoration: underline;
	text-decoration-color: var(--color-link-underline-hover);
}

.site-header {
	background: var(--color-surface);
	border-bottom: 1px solid var(--color-border);
	position: sticky;
	top: 0;
	z-index: 100;
}

.ahw-header-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-5);
	padding: var(--space-4) 0;
}

.site-header__right {
	display: flex;
	align-items: center;
	gap: var(--space-3);
	position: relative; /* anchors the mobile dropdown */
}

/* Desktop header order: menu, then cart (far right), with the mobile toggle last. */
.site-header__right .site-nav--desktop { order: 1; }
.site-header__right .header-shop { order: 2; }
.site-header__right .header-cart { order: 3; }
.site-header__right .nav-details { order: 4; }

.site-nav--desktop {
	display: flex;
}

.nav-details {
	display: inline-flex;
	align-items: center;
	height: 44px;
}

/* Hide the default disclosure triangle. */
.nav-details > summary::-webkit-details-marker { display: none; }
.nav-details > summary::marker { content: ""; }

.nav-details > summary {
	list-style: none;
	-webkit-appearance: none;
	appearance: none;
	margin: 0;
	height: 44px;
	min-height: 44px;
	line-height: 1;
}

/* Desktop: show the full menu, hide the burger toggle + mobile dropdown. */
@media (min-width: 861px) {
	.nav-details { display: none; }
	.site-nav--desktop { display: block; }

	/* Ensure cart stays on the far right. */
	.site-header__right .header-cart { margin-left: auto; }
}

.site-header a.header-shop {
	display: none;
	align-items: center;
	justify-content: center;
	border-radius: 999px;
	border: 1px solid var(--color-border) !important;
	background: var(--color-surface) !important;
	color: var(--color-text) !important;
	padding: 0.6rem 0.9rem !important;
	height: 44px;
	font-weight: 650;
	text-decoration: none;
}

.site-header a.header-shop:hover {
	border-color: var(--color-accent-soft);
	background: var(--color-tint-hover);
	color: var(--color-link-hover);
	text-decoration: none;
}

.nav-details[open] > summary.nav-toggle {
	background: var(--color-tint);
	border-color: var(--color-accent-soft);
}

.nav-toggle__icon {
	position: relative;
	width: 18px;
	height: 12px;
	display: inline-block;
}

.nav-toggle__icon::before,
.nav-toggle__icon::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	height: 2px;
	background: currentColor;
	border-radius: 2px;
}

.nav-toggle__icon::before { top: 0; }
.nav-toggle__icon::after { bottom: 0; }

.nav-toggle__icon {
	background:
		linear-gradient(currentColor, currentColor) center / 100% 2px no-repeat;
	border-radius: 2px;
}

.header-cart {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: 999px;
	border: 1px solid var(--color-border);
	background: var(--color-tint);
	color: var(--color-text);
	text-decoration: none;
	position: relative;
}

.header-cart:hover {
	border-color: var(--color-accent-soft);
	background: var(--color-tint-hover);
}

.header-cart:focus-visible {
	outline: none;
	box-shadow: var(--focus);
}

.header-cart__count {
	position: absolute;
	top: -6px;
	right: -6px;
	min-width: 20px;
	height: 20px;
	padding: 0 6px;
	border-radius: 999px;
	background: var(--color-accent);
	color: var(--color-accent-contrast);
	font-size: 0.75rem;
	font-weight: 750;
	line-height: 20px;
	text-align: center;
	border: 2px solid var(--color-surface);
}

.header-cart__count:empty {
	display: none;
}

.site-branding .site-title {
	margin: 0;
	font-family: var(--font-heading);
	font-size: 1.2rem;
	line-height: 1;
}

.site-branding .site-title a { color: var(--color-text); }
.site-branding .site-description { margin: 0; font-size: 0.9rem; }

/* Header logo sizing */
.custom-logo-link img,
.site-branding img {
	max-width: 520px;
	height: 120px;
	width: auto;
	object-fit: contain;
}

/* Extra specificity for WP custom logo markup (and to beat optimisation plugins). */
.site-header .custom-logo-link {
	display: inline-flex;
	align-items: center;
	max-width: 520px;
	overflow: hidden;
}

.site-header .custom-logo-link .custom-logo {
	max-width: 520px !important;
	max-height: 120px !important;
	width: auto !important;
	height: 120px !important;
	object-fit: contain;
}

@media (max-width: 768px) {
	.custom-logo-link img,
	.site-branding img {
		height: 88px;
	}

	.site-header .custom-logo-link {
		max-width: 380px;
	}

	.site-header .custom-logo-link .custom-logo {
		max-width: 380px !important;
		max-height: 88px !important;
		height: 88px !important;
	}
}

.site-nav .menu {
	list-style: none;
	display: flex;
	gap: var(--space-4);
	padding: 0;
	margin: 0;
	align-items: center;
}

.site-nav .menu a {
	color: var(--color-text);
	font-weight: 600;
	padding: 0.4rem 0.2rem;
}

.site-nav .menu a:hover { color: var(--color-primary); }

/* Header primary menu: desktop dropdown for sub-menus (e.g. Shop children). */
.site-nav--desktop .menu--primary li {
	position: relative;
}

.site-nav--desktop .menu--primary .sub-menu {
	display: none;
	position: absolute;
	top: 100%;
	left: 0;
	min-width: 220px;
	padding: 10px;
	margin: 0;
	list-style: none;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	z-index: 300;
}

.site-nav--desktop .menu--primary .sub-menu::before {
	/* Hover bridge so moving the mouse into the submenu doesn't close it. */
	content: "";
	position: absolute;
	top: -10px;
	left: 0;
	right: 0;
	height: 10px;
}

.site-nav--desktop .menu--primary .sub-menu li {
	position: static;
}

.site-nav--desktop .menu--primary .sub-menu a {
	display: block;
	padding: 0.55rem 0.65rem;
	border-radius: 10px;
	white-space: nowrap;
}

.site-nav--desktop .menu--primary .sub-menu a:hover,
.site-nav--desktop .menu--primary .sub-menu a:focus-visible {
	background: var(--color-tint);
	text-decoration: none;
}

.site-nav--desktop .menu--primary li:hover > .sub-menu,
.site-nav--desktop .menu--primary li:focus-within > .sub-menu {
	display: block;
}

.nav-toggle {
	display: none;
	border: 1px solid var(--color-border);
	background: transparent;
	border-radius: 999px;
	padding: 0 0.9rem;
	height: 44px;
	min-height: 44px;
	font-weight: 650;
	color: var(--color-text);
	align-items: center;
	gap: 0.55rem;
	cursor: pointer;
}

@media (max-width: 860px) {
	.nav-toggle { display: inline-flex; }

	.site-header a.header-shop { display: inline-flex; }

	/* Mobile header order: Shop link, burger, cart (rightmost). */
	.site-header__right .header-shop { order: 1; }
	.site-header__right .nav-details { order: 2; }
	.site-header__right .header-cart { order: 3; }
	.site-header__right .site-nav--desktop { display: none; }

	.site-nav--mobile {
		display: none;
		position: absolute;
		left: 0;
		right: 0;
		top: 100%;
		background: var(--color-surface);
		border-bottom: 1px solid var(--color-border);
		z-index: 200;
		box-shadow: var(--shadow);
	}
	.nav-details[open] .site-nav--mobile { display: block; }
	.site-nav .menu {
		flex-direction: column;
		align-items: flex-start;
		padding: var(--space-4) var(--space-5);
		gap: var(--space-3);
	}
}

.site-main {
	padding: var(--space-8) 0;
}

@media (max-width: 768px) {
	.site-main { padding: var(--space-7) 0; }
}

.entry {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	padding: var(--space-6);
}

.entry + .entry { margin-top: var(--space-6); }

.entry-title a { color: var(--color-text); }

.ahw-btn,
button,
input[type="submit"],
input[type="button"],
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
/* Woo blocks (Products grid / Cart / Checkout) sometimes uses different button classes. */
.wc-block-grid .wc-block-grid__product-add-to-cart a,
.wc-block-grid .wp-block-button__link,
.wc-block-components-product-button__button,
.wp-block-woocommerce-cart .wc-block-components-button,
.wp-block-woocommerce-checkout .wc-block-components-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 999px;
	border: 1px solid transparent;
	padding: 0.75rem 1.35rem;
	font-weight: 650;
	background: var(--color-primary);
	color: var(--color-primary-contrast);
	cursor: pointer;
	transition: transform 0.15s ease, box-shadow 0.15s ease, background-color 0.15s ease;
	box-shadow: var(--shadow-button);
}

.ahw-btn:hover,
button:hover,
input[type="submit"]:hover,
input[type="button"]:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.wc-block-grid .wc-block-grid__product-add-to-cart a:hover,
.wc-block-grid .wp-block-button__link:hover,
.wc-block-components-product-button__button:hover,
.wp-block-woocommerce-cart .wc-block-components-button:hover,
.wp-block-woocommerce-checkout .wc-block-components-button:hover {
	background: var(--color-primary-hover);
	transform: translateY(-1px);
}

/* Commissions page: match shop behavior by hiding "Read more" links entirely. */
.page-template-page-commissions .more-link,
.page-template-page-commissions .wp-block-post-excerpt__more-link,
.page-template-page-commissions .wp-block-read-more {
	display: none !important;
}

/* Commissions page: also hide Woo loop "Read more" buttons (class="button product_type_simple"). */
.page-template-page-commissions .woocommerce a.button.product_type_simple,
.page-template-page-commissions .woocommerce a.button.product_type_simple:hover,
.page-template-page-commissions .woocommerce a.button.product_type_simple:focus,
.page-template-page-commissions .woocommerce a.button.product_type_simple:focus-visible {
	display: none !important;
}

input[type="text"],
input[type="email"],
input[type="tel"],
input[type="password"],
input[type="search"],
select,
textarea,
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea {
	width: 100%;
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	padding: 0.8rem 0.95rem;
	background: var(--color-surface);
	color: var(--color-text);
}

input:focus,
select:focus,
textarea:focus {
	outline: none;
	box-shadow: var(--focus);
	border-color: var(--color-accent);
}

.ahw-form {
	margin-top: var(--space-6);
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	padding: var(--space-6);
}

.site-footer {
	background: var(--color-tint);
	border-top: 1px solid var(--color-border);
	padding: var(--space-8) 0 var(--space-6);
}

.footer-grid {
	display: grid;
	grid-template-columns: 1.2fr 1fr 1fr;
	gap: var(--space-7);
}

@media (max-width: 900px) {
	.footer-grid { grid-template-columns: 1fr; gap: var(--space-5); }
}

.footer-title {
	font-size: 0.95rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	margin-bottom: var(--space-3);
}

.footer-links,
.menu--footer {
	list-style: none;
	padding: 0;
	margin: 0;
}

.footer-links li + li,
.menu--footer li + li { margin-top: var(--space-2); }

.site-smallprint {
	margin: var(--space-6) 0 0;
	padding-top: var(--space-4);
	border-top: 1px solid var(--color-border);
	font-size: 0.9rem;
	color: var(--color-muted);
}

/* Footer: WPConsent "Cookie Settings" should look like a normal footer link. */
.site-footer a.wpconsent-open-preferences {
	display: inline;
	border: 0;
	background: transparent;
	padding: 0;
	font-weight: inherit;
	color: var(--color-link);
	text-decoration: none;
}

.site-footer a.wpconsent-open-preferences:hover {
	color: var(--color-link-hover);
	text-decoration: underline;
	text-decoration-color: var(--color-link-underline-hover);
}

/* WooCommerce */
.ahw-back {
	margin: 0 0 var(--space-4);
}

.ahw-back a {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	color: var(--color-text);
	font-weight: 650;
	border: 1px solid var(--color-border);
	border-radius: 999px;
	padding: 0.45rem 0.75rem;
	background: var(--color-surface);
}

.ahw-back a:hover {
	color: var(--color-link-hover);
	border-color: var(--color-accent-soft);
}

.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	border-radius: var(--radius);
	border: 1px solid var(--color-border);
	background: var(--color-surface);
	padding: var(--space-4) var(--space-5);
	box-shadow: var(--shadow);
	margin-bottom: var(--space-5);
}

.woocommerce ul.products {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: var(--space-6);
}

@media (min-width: 1024px) {
	.woocommerce ul.products {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

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

.woocommerce ul.products li.product {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	padding: var(--space-4);
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	position: relative;
}

/* Shop tiles: out-of-stock should be immediately obvious. */
.woocommerce ul.products li.product.outofstock {
	opacity: 0.92;
}

.woocommerce ul.products li.product.outofstock img {
	filter: grayscale(35%) saturate(80%);
	transition: filter 160ms ease;
}

/* On hover, let out-of-stock products look like normal products. */
.woocommerce ul.products li.product.outofstock:hover img,
.woocommerce ul.products li.product.outofstock a.woocommerce-LoopProduct-link:hover img,
.woocommerce ul.products li.product.outofstock a.woocommerce-LoopProduct-link:focus-visible img {
	filter: none;
}

.ahw-badge {
	position: absolute;
	top: var(--space-4);
	right: var(--space-4);
	z-index: 3;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.35rem 0.6rem;
	border-radius: 999px;
	font-weight: 750;
	font-size: 0.85rem;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	line-height: 1;
	border: 1px solid rgba(0, 0, 0, 0.06);
	box-shadow: var(--shadow-button);
}

.ahw-badge--oos {
	background: var(--color-text);
	color: #fff;
}

.woocommerce ul.products li.product a.woocommerce-LoopProduct-link {
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	flex: 1;
	min-height: 100%;
	color: inherit;
	text-decoration: none;
}

.woocommerce ul.products li.product a.woocommerce-LoopProduct-link:focus-visible {
	outline: 3px solid var(--color-focus-outline);
	outline-offset: 4px;
	border-radius: calc(var(--radius) - 4px);
}

.woocommerce ul.products li.product a.woocommerce-LoopProduct-link:hover .woocommerce-loop-product__title {
	text-decoration: underline;
	text-decoration-color: var(--color-link-underline-hover);
	text-underline-offset: 0.15em;
}

.ahw-stock-filter {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	margin: 0;
}

.woocommerce .woocommerce-ordering {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	margin: 0;
}

.ahw-shop-controls {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	gap: var(--space-3);
	flex-wrap: wrap;
	margin: 0 0 var(--space-5);
}

.woocommerce .woocommerce-ordering select,
.ahw-stock-filter select {
	appearance: none;
	-webkit-appearance: none;
	border: 1px solid var(--color-border);
	border-radius: 999px;
	background: var(--color-tint);
	padding: 0.55rem 2.2rem 0.55rem 0.9rem;
	font-weight: 650;
	color: var(--color-text);
	box-shadow: 0 1px 0 rgba(0, 0, 0, 0.02);
	background-image:
		linear-gradient(45deg, transparent 50%, var(--color-muted) 50%),
		linear-gradient(135deg, var(--color-muted) 50%, transparent 50%);
	background-position:
		calc(100% - 1.15rem) 50%,
		calc(100% - 0.85rem) 50%;
	background-size: 6px 6px;
	background-repeat: no-repeat;
}

.woocommerce .woocommerce-ordering select:hover,
.ahw-stock-filter select:hover {
	border-color: var(--color-accent-soft);
	background: var(--color-tint-hover);
}

.woocommerce .woocommerce-ordering select:active,
.ahw-stock-filter select:active {
	transform: translateY(1px);
}

.woocommerce .woocommerce-ordering select:focus-visible,
.ahw-stock-filter select:focus-visible {
	outline: none;
	box-shadow: var(--focus);
}

.woocommerce span.onsale {
	position: absolute;
	top: var(--space-4);
	left: var(--space-4);
	z-index: 3;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.35rem 0.6rem;
	border-radius: 999px;
	background: var(--color-accent);
	color: var(--color-accent-contrast);
	font-weight: 750;
	font-size: 0.85rem;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	line-height: 1;
	border: 1px solid rgba(0, 0, 0, 0.06);
	box-shadow: var(--shadow-button);
}

.single-product .woocommerce div.product {
	position: relative;
}

.woocommerce ul.products li.product img {
	border-radius: calc(var(--radius) - 2px);
	aspect-ratio: 4 / 3;
	object-fit: cover;
	width: 100%;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-size: 1.05rem;
	margin: 0;
	color: var(--color-text);
	font-family: var(--font-body);
}

.woocommerce ul.products li.product .price {
	font-weight: 650;
	color: var(--color-text);
	margin: 0;
}

.single-product div.product {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-6);
}

/* Always stack: gallery first row, summary below */
.woocommerce div.product div.images,
.woocommerce div.product .summary {
	width: 100%;
	max-width: none;
	float: none;
}

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

/* Product gallery: centered main image, horizontal thumbnail strip */
.woocommerce div.product div.images {
	display: flex;
	flex-direction: column;
	align-items: center;
}

.woocommerce div.product .woocommerce-product-gallery {
	/* Woo sometimes starts at opacity:0 until JS runs; ensure images are always visible. */
	opacity: 1 !important;
}

.woocommerce div.product .woocommerce-product-gallery {
	width: 100%;
	max-width: 980px;
	margin-left: auto;
	margin-right: auto;
}

.woocommerce div.product .woocommerce-product-gallery__wrapper {
	margin: 0;
	width: 100%;
}

.woocommerce div.product .woocommerce-product-gallery__wrapper a {
	display: flex;
	justify-content: center;
}

.woocommerce div.product .woocommerce-product-gallery__wrapper img {
	display: block;
	max-width: 100%;
	width: 100%;
	height: auto;
	max-height: 780px;
	max-height: clamp(420px, 72vh, 780px);
	object-fit: contain;
}

@media (max-width: 768px) {
	.woocommerce div.product .woocommerce-product-gallery__wrapper img {
		width: 100%;
		max-height: none;
	}
}

.woocommerce div.product .woocommerce-product-gallery__trigger {
	display: none !important;
}

.woocommerce div.product .flex-control-nav.flex-control-thumbs {
	display: flex;
	gap: var(--space-3);
	flex-wrap: nowrap;
	overflow-x: auto;
	overflow-y: hidden;
	-webkit-overflow-scrolling: touch;
	padding: var(--space-3) 0 0;
	margin: 0;
	list-style: none;
	scroll-snap-type: x mandatory;
	justify-content: center;
}

.woocommerce div.product .flex-control-nav.flex-control-thumbs li {
	flex: 0 0 auto;
	width: 90px !important;
	scroll-snap-align: start;
	margin: 0;
}

.woocommerce div.product .flex-control-nav.flex-control-thumbs img {
	width: 100%;
	height: 72px;
	object-fit: cover;
	border-radius: calc(var(--radius) - 4px);
	border: 1px solid var(--color-border);
	background: var(--color-surface);
}

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

.woocommerce div.product .summary {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	padding: var(--space-6);
}

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

.woocommerce div.product form.cart {
	margin-top: var(--space-5);
}

.woocommerce div.product form.cart .quantity {
	display: none;
}

.woocommerce div.product .single_add_to_cart_button {
	display: inline-flex;
	justify-content: center;
}

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

.woocommerce div.product .woocommerce-tabs .woocommerce-Tabs-panel {
	display: block !important;
}

.woocommerce div.product .woocommerce-tabs .woocommerce-Tabs-panel > h2 {
	display: none;
}

.woocommerce div.product .summary .ahw-stock {
	margin: var(--space-3) 0 var(--space-4);
}

.woocommerce div.product .summary .ahw-stock .stock {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	border-radius: 999px;
	border: 1px solid var(--color-border);
	background: var(--color-tint);
	padding: 0.35rem 0.65rem;
	font-weight: 650;
	color: var(--color-text);
	margin: 0;
}

.woocommerce div.product .summary .ahw-stock .stock.out-of-stock {
	border-color: var(--color-accent-soft);
	color: var(--color-accent);
}

.woocommerce div.product .product_title {
	font-family: var(--font-body);
	letter-spacing: -0.01em;
}

.woocommerce div.product .woocommerce-tabs {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	padding: var(--space-6);
}

.woocommerce div.product .summary .woocommerce-tabs {
	background: transparent;
	border: 0;
	box-shadow: none;
	padding: var(--space-5) 0 0;
	margin-top: var(--space-5);
	border-top: 1px solid var(--color-border);
}

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

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

.woocommerce div.product .woocommerce-tabs ul.tabs li {
	margin: 0;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	display: inline-flex;
	align-items: center;
	padding: 0.55rem 0.9rem;
	font-weight: 650;
	color: var(--color-text);
	text-decoration: none;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
	border-radius: 999px;
	border: 1px solid var(--color-border);
	background: var(--color-tint-hover);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active {
	background: var(--color-accent);
	border-color: var(--color-accent);
}

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

.woocommerce div.product .woocommerce-tabs .panel {
	margin: 0;
}

/* We prefer a no-tabs layout: show panels stacked, hide the tab buttons. */
.woocommerce div.product .woocommerce-tabs ul.tabs {
	display: none !important;
}

.woocommerce div.product .woocommerce-tabs .woocommerce-Tabs-panel {
	display: block !important;
}

.woocommerce div.product .woocommerce-tabs .woocommerce-Tabs-panel > h2 {
	display: none;
}

.woocommerce table.shop_table {
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	overflow: hidden;
	background: var(--color-surface);
}

/* Checkout (classic shortcode checkout) */
.woocommerce-checkout form.checkout {
	display: grid;
	gap: var(--space-6);
}

.woocommerce-checkout #order_review_heading {
	margin: 0 0 var(--space-3);
	color: var(--color-heading);
}

.woocommerce-checkout .col2-set,
.woocommerce-checkout #customer_details {
	display: grid;
	gap: var(--space-6);
}

.woocommerce-checkout .col2-set > *,
.woocommerce-checkout #customer_details > * {
	min-width: 0;
}

@media (min-width: 920px) {
	.woocommerce-checkout .col2-set {
		grid-template-columns: 1fr 1fr;
		align-items: start;
	}
}

.woocommerce form .form-row {
	margin: 0 0 var(--space-4);
}

.woocommerce form .form-row label {
	display: block;
	font-weight: 650;
	color: var(--color-text);
	margin: 0 0 0.35rem;
}

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

.woocommerce form .form-row .input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
	width: 100%;
}

/* Select2 (country/state) */
.woocommerce .select2-container .select2-selection--single {
	height: auto;
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	background: var(--color-surface);
	padding: 0.55rem 0.8rem;
}

.woocommerce .select2-container {
	max-width: 100%;
}

.woocommerce .select2-container--default .select2-selection--single .select2-selection__rendered {
	color: var(--color-text);
	line-height: 1.2;
	padding: 0;
}

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

.woocommerce .select2-container--open .select2-selection--single,
.woocommerce .select2-container .select2-selection--single:focus {
	outline: none;
	box-shadow: var(--focus);
	border-color: var(--color-accent);
}

/* Order review table (classic checkout) */
.woocommerce-checkout-review-order-table {
	width: 100%;
	border-collapse: collapse;
}

.woocommerce-checkout-review-order-table th,
.woocommerce-checkout-review-order-table td {
	padding: 0.85rem 0.9rem;
	border-bottom: 1px solid var(--color-border);
	vertical-align: top;
}

.woocommerce-checkout-review-order-table tfoot th,
.woocommerce-checkout-review-order-table tfoot td {
	font-weight: 750;
}

/* Shipping methods (cart + checkout, classic templates) */
.woocommerce ul#shipping_method,
.woocommerce ul.woocommerce-shipping-methods {
	list-style: none;
	padding: 0;
	margin: var(--space-3) 0 0;
	display: grid;
	gap: var(--space-2);
}

.woocommerce ul#shipping_method li,
.woocommerce ul.woocommerce-shipping-methods li {
	list-style: none !important;
}

.woocommerce ul#shipping_method li::marker,
.woocommerce ul.woocommerce-shipping-methods li::marker {
	content: "";
}

.woocommerce ul#shipping_method li,
.woocommerce ul.woocommerce-shipping-methods li {
	margin: 0;
	display: flex;
	align-items: flex-start;
	gap: 0.6rem;
}

.woocommerce ul#shipping_method li input,
.woocommerce ul.woocommerce-shipping-methods li input {
	margin-top: 0.25rem;
	accent-color: var(--color-accent);
}

.woocommerce ul#shipping_method li label,
.woocommerce ul.woocommerce-shipping-methods li label {
	flex: 1;
	display: flex;
	justify-content: space-between;
	gap: var(--space-3);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	background: var(--color-surface);
	padding: 0.75rem 0.9rem;
	cursor: pointer;
}

.woocommerce ul#shipping_method li input:checked + label,
.woocommerce ul.woocommerce-shipping-methods li input:checked + label {
	border-color: var(--color-accent);
	background: var(--color-tint);
}

.woocommerce ul#shipping_method li label .amount,
.woocommerce ul.woocommerce-shipping-methods li label .amount {
	white-space: nowrap;
	font-weight: 750;
	color: var(--color-text);
}

/* Woo Blocks shipping options (cart + checkout blocks) */
.wp-block-woocommerce-cart .wc-block-components-shipping-rates-control__package,
.wp-block-woocommerce-checkout .wc-block-components-shipping-rates-control__package,
.wp-block-woocommerce-cart .wc-block-components-shipping-rates-control,
.wp-block-woocommerce-checkout .wc-block-components-shipping-rates-control {
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	background: var(--color-surface);
	box-shadow: var(--shadow);
	padding: var(--space-4);
}

.wp-block-woocommerce-cart .wc-block-components-radio-control__option,
.wp-block-woocommerce-checkout .wc-block-components-radio-control__option {
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	background: var(--color-surface);
	padding: 0.75rem 0.9rem;
}

.wp-block-woocommerce-cart .wc-block-components-radio-control__option[aria-checked="true"],
.wp-block-woocommerce-checkout .wc-block-components-radio-control__option[aria-checked="true"] {
	border-color: var(--color-accent);
	background: var(--color-tint);
}

/* Woo Blocks: remove list bullets for shipping/payment radio option lists. */
.wp-block-woocommerce-cart .wc-block-components-radio-control__options,
.wp-block-woocommerce-checkout .wc-block-components-radio-control__options {
	list-style: none;
	padding-left: 0;
	margin-left: 0;
}

.wp-block-woocommerce-cart .wc-block-components-radio-control__options li,
.wp-block-woocommerce-checkout .wc-block-components-radio-control__options li {
	list-style: none;
}

.wp-block-woocommerce-cart .wc-block-components-radio-control__options li::marker,
.wp-block-woocommerce-checkout .wc-block-components-radio-control__options li::marker {
	content: "";
}

/* Woo Blocks checkout: prevent inputs overflowing their containers on mobile. */
.wp-block-woocommerce-checkout .wc-block-components-form,
.wp-block-woocommerce-checkout .wc-block-components-form * {
	min-width: 0;
}

.wp-block-woocommerce-checkout,
.wp-block-woocommerce-checkout * {
	box-sizing: border-box;
}

.woocommerce-checkout .wp-block-woocommerce-checkout,
.woocommerce-checkout .wc-block-checkout,
.woocommerce-checkout .wc-block-checkout__form,
.woocommerce-checkout .wc-block-components-main,
.woocommerce-checkout .wc-block-components-sidebar,
.woocommerce-checkout .wc-block-components-form {
	max-width: 100%;
}

/* Some WC Blocks layouts use negative margins or wide wrappers; neutralize inside the padded entry. */
.woocommerce-checkout .wp-block-woocommerce-checkout,
.woocommerce-checkout .wc-block-checkout {
	margin-left: 0 !important;
	margin-right: 0 !important;
}

.wp-block-woocommerce-checkout .wc-block-components-text-input,
.wp-block-woocommerce-checkout .wc-block-components-select,
.wp-block-woocommerce-checkout .wc-block-components-textarea,
.wp-block-woocommerce-checkout .wc-block-components-text-input__control,
.wp-block-woocommerce-checkout .wc-block-components-select__control,
.wp-block-woocommerce-checkout .wc-block-components-textarea__control {
	margin-left: 0 !important;
	margin-right: 0 !important;
}

.wp-block-woocommerce-checkout .wc-block-components-text-input,
.wp-block-woocommerce-checkout .wc-block-components-select,
.wp-block-woocommerce-checkout .wc-block-components-textarea {
	flex: 1 1 0;
}

.wp-block-woocommerce-checkout .wc-block-components-text-input,
.wp-block-woocommerce-checkout .wc-block-components-text-input__input,
.wp-block-woocommerce-checkout .wc-block-components-select,
.wp-block-woocommerce-checkout .wc-block-components-select__control,
.wp-block-woocommerce-checkout .wc-block-components-textarea,
.wp-block-woocommerce-checkout .wc-block-components-textarea textarea {
	max-width: 100%;
	box-sizing: border-box;
}

.wp-block-woocommerce-checkout .wc-block-components-text-input input,
.wp-block-woocommerce-checkout .wc-block-components-text-input__input,
.wp-block-woocommerce-checkout .wc-block-components-select select,
.wp-block-woocommerce-checkout .wc-block-components-select__control,
.wp-block-woocommerce-checkout .wc-block-components-textarea textarea {
	width: 100%;
}

.wp-block-woocommerce-checkout .wc-block-components-text-input,
.wp-block-woocommerce-checkout .wc-block-components-select,
.wp-block-woocommerce-checkout .wc-block-components-textarea,
.wp-block-woocommerce-checkout .wc-block-components-text-input__control,
.wp-block-woocommerce-checkout .wc-block-components-select__control,
.wp-block-woocommerce-checkout .wc-block-components-textarea__control {
	min-width: 0 !important;
}

/* Last-resort guard: some block styles set fixed input min-widths. */
.wp-block-woocommerce-checkout input:not([type="checkbox"]):not([type="radio"]),
.wp-block-woocommerce-checkout select,
.wp-block-woocommerce-checkout textarea {
	max-width: 100% !important;
	box-sizing: border-box;
}

/* If any blocks still overrun their card/panel, prevent horizontal overflow on checkout. */
.woocommerce-checkout .wp-block-woocommerce-checkout,
.woocommerce-checkout .wc-block-checkout,
.woocommerce-checkout .wc-block-components-main,
.woocommerce-checkout .wc-block-components-sidebar {
	max-width: 100%;
	min-width: 0;
	overflow-x: visible;
}

/* Checkout page template wrapper: keep blocks from pushing wider than the card. */
.woocommerce-checkout .entry,
.woocommerce-checkout .entry-content {
	max-width: 100%;
	overflow-x: visible;
}

.woocommerce-checkout .entry-content .alignwide,
.woocommerce-checkout .entry-content .alignfull,
.woocommerce-checkout .wp-block-woocommerce-checkout.alignwide,
.woocommerce-checkout .wp-block-woocommerce-checkout.alignfull,
.woocommerce-checkout .wc-block-checkout.alignwide,
.woocommerce-checkout .wc-block-checkout.alignfull {
	width: 100% !important;
	max-width: 100% !important;
	margin-left: 0 !important;
	margin-right: 0 !important;
}

.woocommerce-checkout .wc-block-components-main,
.woocommerce-checkout .wc-block-components-sidebar,
.woocommerce-checkout .wc-block-components-form {
	margin-left: 0 !important;
	margin-right: 0 !important;
}

/* Payment methods */
.woocommerce-checkout #payment {
	background: transparent;
}

.woocommerce-checkout #payment ul.payment_methods {
	list-style: none;
	padding: 0;
	margin: 0 0 var(--space-4);
	display: grid;
	gap: var(--space-3);
}

.woocommerce-checkout #payment ul.payment_methods li {
	margin: 0;
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	background: var(--color-surface);
	padding: 0.9rem;
}

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

.woocommerce-checkout #payment div.payment_box {
	margin-top: var(--space-3);
	padding: 0.8rem 0.9rem;
	border-radius: calc(var(--radius) - 4px);
	background: var(--color-tint);
	border: 1px solid var(--color-border);
	color: var(--color-muted);
}

.woocommerce-checkout #payment .place-order {
	margin-top: var(--space-4);
}

.woocommerce-checkout #payment .place-order .button {
	width: 100%;
}

.woocommerce-checkout .woocommerce-privacy-policy-text {
	color: var(--color-muted);
	font-size: 0.95rem;
}

.woocommerce-cart .cart-collaterals .cart_totals,
.woocommerce-checkout .woocommerce-checkout-review-order,
.woocommerce-checkout .woocommerce-checkout-payment {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	padding: var(--space-5);
}

/* Cart: "Proceed to checkout" in a bubble (classic cart + WC Blocks cart). */
.woocommerce-cart .wc-proceed-to-checkout,
.woocommerce-cart .wc-block-cart__submit-container {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: calc(var(--radius) * 1.25);
	box-shadow: var(--shadow);
	padding: var(--space-4);
}

/* Cart (Woo Blocks): prevent "empty cart" placeholder blink during hydration when cookie says items exist. */
html.ahw-cart-has-items-cookie .woocommerce-cart .wc-block-cart__empty-cart,
html.ahw-cart-has-items-cookie .woocommerce-cart .wc-block-cart__empty-cart-message {
	display: none !important;
}

.woocommerce-cart .wc-proceed-to-checkout a.checkout-button,
.woocommerce-cart .wc-block-cart__submit-container .wc-block-cart__submit-button {
	width: 100%;
	border-radius: 999px;
	padding: 14px 18px;
	text-align: center;
}
