/* =========================================================================
   Furniture Handicraft — Site-wide design language
   Loaded on every front-end page so non-home pages (shop, single product,
   cart, checkout, my-account, archive, blog) share the cream/dark palette,
   DM Sans typography, pill buttons, and same spacing as the homepage.
   ========================================================================= */

:root {
	/* Surfaces & color */
	--fhc-bg:           #F6F3EB;
	--fhc-bg-soft:      #EFEADD;
	--fhc-card:         #ECE5D2;
	--fhc-card-img:     #F2EDDF;
	--fhc-border:       #E0D9C8;
	--fhc-ink:          #14191A;
	--fhc-ink-soft:     #3A3F40;
	--fhc-muted:        #7A766D;
	--fhc-dark:         #14191A;
	--fhc-gold:         #F5B100;

	/* Radii */
	--fhc-radius-sm:    12px;
	--fhc-radius-md:    18px;
	--fhc-radius-lg:    28px;
	--fhc-radius-pill:  999px;

	/* Shadows */
	--fhc-shadow-sm:    0 2px 8px rgba(15,20,20,0.04);
	--fhc-shadow-md:    0 8px 28px rgba(15,20,20,0.06);

	/* Font families */
	--fhc-font-sans:    'DM Sans', "Helvetica Neue", Helvetica, Arial, sans-serif;

	/* Spacing scale */
	--fhc-space-1:  4px;  --fhc-space-2:  8px;  --fhc-space-3:  12px;
	--fhc-space-4:  16px; --fhc-space-5:  22px; --fhc-space-6:  28px;
	--fhc-space-7:  32px; --fhc-space-8:  44px; --fhc-space-9:  56px;
	--fhc-space-10: 60px; --fhc-space-11: 80px; --fhc-space-12: 96px;
}

/* Site-wide body reset: every page gets DM Sans + cream surface. The .fhc-home
   class on the homepage runs an additional, more aggressive reset. */
body {
	margin: 0;
	font-family: var(--fhc-font-sans);
	color: var(--fhc-ink);
	background: var(--fhc-bg);
	-webkit-font-smoothing: antialiased;
}
body:not(.fhc-home) h1,
body:not(.fhc-home) h2,
body:not(.fhc-home) h3,
body:not(.fhc-home) h4,
body:not(.fhc-home) h5 {
	font-family: var(--fhc-font-sans);
	color: var(--fhc-ink);
	letter-spacing: -0.01em;
}

/* Generic page wrapper used by page.php, single.php, woocommerce.php */
.fhc-page {
	min-height: 60vh;
	padding-block: 56px;
}
.fhc-page .fhc-container {
	/* max-width: 1200px; */
	margin: 0 auto;
	padding-inline: 60px;
	box-sizing: border-box;
}
.fhc-page__title {
	font-size: clamp(28px, 3.2vw, 38px);
	font-weight: 600;
	margin-bottom: 24px;
	line-height: 1.2;
	color: var(--fhc-ink);
}
.fhc-page__content {
	color: var(--fhc-ink-soft);
	line-height: 1.7;
	font-size: 15px;
}
.fhc-page__content p { margin: 0 0 16px; }
.fhc-page__content a { color: var(--fhc-ink); text-decoration: underline; }

/* WC pages already render their own h1 via woocommerce templates, so suppress
   the generic page title that page.php adds when WC is involved. */
.fhc-wc { padding-block: 32px; }

@media (max-width: 960px) {
	.fhc-page .fhc-container { padding-inline: 32px; }
	.fhc-page { padding-block: 40px; }
}
@media (max-width: 640px) {
	.fhc-page .fhc-container { padding-inline: 20px; }
	.fhc-page { padding-block: 32px; }
}

/* =========================================================================
   WooCommerce — site-wide overrides
   Targets `.woocommerce` & `.woocommerce-page` body classes that WC adds
   to shop, single-product, cart, checkout, and my-account.
   ========================================================================= */

/* Page scaffold */
.woocommerce-page,
.woocommerce {
	color: var(--fhc-ink);
}
.woocommerce-page main.site-main,
.woocommerce main.site-main { padding-block: var(--fhc-space-9); }

/* Page title */
.woocommerce .page-title,
.woocommerce-products-header__title {
	font-size: clamp(28px, 3.2vw, 38px);
	font-weight: 600;
	margin-bottom: var(--fhc-space-4);
	letter-spacing: -0.01em;
}

/* Result count + sort dropdown row — floated so they sit side-by-side */
.woocommerce .woocommerce-result-count {
	float: left;
	margin: 0 0 24px !important;
	padding: 10px 0;
	color: var(--fhc-muted);
	font-size: 13.5px;
}
.woocommerce .woocommerce-ordering {
	float: right;
	margin: 0 0 24px !important;
}
.woocommerce .woocommerce-ordering select,
.woocommerce-ordering select.orderby {
	width: auto !important;
	max-width: 100%;
	min-width: 180px;
	appearance: none !important;
	-webkit-appearance: none !important;
	-moz-appearance: none !important;
	background: #fff url("data:image/svg+xml;charset=US-ASCII,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2314191A' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E") no-repeat right 14px center !important;
	padding: 10px 38px 10px 18px !important;
	border: 1px solid var(--fhc-border) !important;
	border-radius: var(--fhc-radius-pill) !important;
	font-size: 13.5px !important;
	color: var(--fhc-ink) !important;
	font-family: var(--fhc-font-sans) !important;
	cursor: pointer;
	height: auto !important;
	box-shadow: none !important;
}
.woocommerce .woocommerce-ordering select:focus { outline: 0; border-color: var(--fhc-ink) !important; }

/* Clear the floats so the products grid starts on its own row */
.woocommerce ul.products,
.woocommerce-page ul.products { clear: both; }

/* ---- Product loop / archive cards ---- */
.woocommerce ul.products,
.woocommerce-page ul.products {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 22px;
	padding: 0;
	margin: 0;
	list-style: none;
}
.woocommerce ul.products li.product {
	background: var(--fhc-card);
	border-radius: var(--fhc-radius-md);
	padding: 14px;
	margin: 0;
	width: auto !important;
	float: none !important;
	display: flex;
	flex-direction: column;
	gap: 12px;
	transition: transform .25s ease, box-shadow .25s ease;
}
.woocommerce ul.products li.product:hover {
	transform: translateY(-3px);
	box-shadow: var(--fhc-shadow-md);
}
.woocommerce ul.products li.product a {
	color: inherit;
	text-decoration: none;
}
/* The wrapping link contains image + title + price. Force it to a flex
   column so its block children (img / h2) and inline price stack vertically
   inside the card instead of overflowing below it. */
.woocommerce ul.products li.product > a.woocommerce-LoopProduct-link,
.woocommerce ul.products li.product > a.woocommerce-loop-product__link {
	display: flex !important;
	flex-direction: column;
	gap: 8px;
	width: 100%;
}
.woocommerce ul.products li.product img {
	border-radius: var(--fhc-radius-sm);
	background: var(--fhc-card-img);
	margin: 0 !important;
	aspect-ratio: 1 / 0.92;
	object-fit: cover;
	width: 100% !important;
	height: auto;
	display: block;
}
.woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-size: 15px !important;
	font-weight: 500 !important;
	color: var(--fhc-ink);
	padding: 0 4px !important;
	margin: 4px 0 0 !important;
	font-family: var(--fhc-font-sans);
	line-height: 1.35 !important;
	display: block;
}
.woocommerce ul.products li.product .price {
	display: block !important;
	font-size: 13.5px !important;
	color: var(--fhc-ink-soft);
	font-weight: 600;
	padding: 0 4px !important;
	margin: 0 0 6px !important;
}
.woocommerce ul.products li.product .price ins {
	background: transparent;
	font-weight: 600;
}
.woocommerce ul.products li.product .price del { opacity: 0.55; }
.woocommerce ul.products li.product .star-rating {
	margin: 4px;
	font-size: 12px;
	color: var(--fhc-gold);
}

/* ---- Buttons (everywhere in WC) ---- */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce ul.products li.product .button,
.woocommerce-page a.button,
.woocommerce-page button.button {
	background: var(--fhc-dark) !important;
	color: #fff !important;
	border: 1px solid var(--fhc-dark) !important;
	border-radius: var(--fhc-radius-pill) !important;
	padding: 11px 26px !important;
	font-weight: 500;
	font-size: 13.5px;
	font-family: var(--fhc-font-sans);
	letter-spacing: 0;
	text-shadow: none;
	transition: all .2s ease;
	line-height: 1.2 !important;
	box-shadow: none !important;
	text-transform: none !important;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover {
	background: #1d2727 !important;
	border-color: #1d2727 !important;
	color: #fff !important;
}
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt {
	background: var(--fhc-dark) !important;
	color: #fff !important;
}

/* "Added to cart" / view-cart small button */
.woocommerce a.added_to_cart {
	display: inline-block;
	margin-top: 8px;
	padding: 8px 18px;
	border-radius: var(--fhc-radius-pill);
	background: #fff;
	border: 1px solid var(--fhc-ink);
	color: var(--fhc-ink);
	font-size: 12.5px;
	font-weight: 500;
}

/* ---- Single product page ---- */
.woocommerce div.product .product_title {
	font-size: clamp(24px, 2.8vw, 34px);
	font-weight: 600;
	margin-bottom: var(--fhc-space-3);
	letter-spacing: -0.01em;
}
.woocommerce div.product p.price,
.woocommerce div.product span.price {
	color: var(--fhc-ink) !important;
	font-size: 22px !important;
	font-weight: 600 !important;
}
.woocommerce div.product .woocommerce-product-rating { margin-bottom: var(--fhc-space-4); }
.woocommerce div.product .woocommerce-product-details__short-description {
	color: var(--fhc-muted);
	line-height: 1.65;
	margin-bottom: var(--fhc-space-5);
}
.woocommerce div.product form.cart {
	margin-top: var(--fhc-space-5);
	display: flex;
	gap: 12px;
	align-items: center;
	flex-wrap: wrap;
}
.woocommerce div.product form.cart .quantity input.qty {
	width: 70px;
	height: 44px;
	padding: 8px 10px;
	border: 1px solid var(--fhc-border);
	border-radius: var(--fhc-radius-pill);
	background: #fff;
	font-family: var(--fhc-font-sans);
	text-align: center;
	font-size: 14px;
}

/* Tabs */
.woocommerce div.product .woocommerce-tabs ul.tabs {
	border-bottom: 1px solid var(--fhc-border);
	padding: 0;
	margin-bottom: var(--fhc-space-5);
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before { display: none; }
.woocommerce div.product .woocommerce-tabs ul.tabs li {
	background: transparent !important;
	border: 0 !important;
	border-radius: 0 !important;
	padding: 0 !important;
	margin: 0 var(--fhc-space-4) 0 0 !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	padding: 12px 0 !important;
	color: var(--fhc-muted) !important;
	font-weight: 500 !important;
	font-family: var(--fhc-font-sans);
	border-bottom: 2px solid transparent;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
	color: var(--fhc-ink) !important;
	border-bottom-color: var(--fhc-ink);
}

/* Related products heading */
.woocommerce .related > h2,
.woocommerce .upsells > h2 {
	font-size: 22px;
	font-weight: 600;
	margin-bottom: var(--fhc-space-5);
}

/* ---- Cart page ---- */
.woocommerce table.shop_table {
	border: 1px solid var(--fhc-border);
	border-radius: var(--fhc-radius-md);
	border-collapse: separate !important;
	border-spacing: 0;
	overflow: hidden;
	background: #fff;
}
.woocommerce table.shop_table th {
	background: var(--fhc-card);
	color: var(--fhc-ink);
	font-weight: 600;
	font-family: var(--fhc-font-sans);
	padding: 16px 14px;
	font-size: 13.5px;
}
.woocommerce table.shop_table td {
	border-top: 1px solid var(--fhc-border);
	padding: 16px 14px;
	font-size: 14px;
}
.woocommerce table.shop_table tr:first-child td { border-top: 0; }
.woocommerce table.cart img {
	width: 64px;
	height: 64px;
	border-radius: 10px;
	object-fit: cover;
}
.woocommerce table.cart .product-name a {
	color: var(--fhc-ink);
	font-weight: 500;
}
.woocommerce table.cart .product-remove a.remove {
	color: var(--fhc-muted) !important;
	background: transparent !important;
	font-size: 18px;
}
.woocommerce table.cart .product-remove a.remove:hover {
	color: var(--fhc-ink) !important;
	background: transparent !important;
}

/* Coupon + cart actions */
.woocommerce-cart .cart-collaterals {
	margin-top: var(--fhc-space-7);
}
.woocommerce-cart .cart_totals h2 {
	font-size: 20px;
	margin-bottom: var(--fhc-space-4);
	font-weight: 600;
}
.woocommerce-cart-form input.input-text,
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
	background: #fff;
	border: 1px solid var(--fhc-border);
	border-radius: 12px;
	padding: 11px 14px;
	font-family: var(--fhc-font-sans);
	font-size: 14px;
	color: var(--fhc-ink);
	width: 100%;
	box-sizing: border-box;
	box-shadow: none;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
	outline: 0;
	border-color: var(--fhc-ink);
}
.woocommerce form .form-row label {
	font-size: 13px;
	color: var(--fhc-ink-soft);
	font-weight: 500;
	margin-bottom: 6px;
}

/* ---- Checkout ---- */
.woocommerce-checkout #order_review_heading,
.woocommerce-checkout h3 {
	font-size: 20px;
	font-weight: 600;
	margin-bottom: var(--fhc-space-4);
	margin-top: var(--fhc-space-6);
}
.woocommerce-checkout #payment {
	background: var(--fhc-card);
	border-radius: var(--fhc-radius-md);
	padding: var(--fhc-space-4);
}
.woocommerce-checkout #payment ul.payment_methods {
	border-bottom: 1px solid var(--fhc-border);
	padding-bottom: var(--fhc-space-3);
}
.woocommerce-checkout #payment div.payment_box {
	background: #fff;
	border-radius: 12px;
	padding: 14px;
	color: var(--fhc-ink-soft);
	font-size: 13.5px;
	margin-top: 8px;
}
.woocommerce-checkout #payment div.payment_box::before { display: none; }

/* ---- Notices / messages ---- */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	border-radius: var(--fhc-radius-md);
	background: #fff !important;
	border: 1px solid var(--fhc-border) !important;
	padding: 14px 18px !important;
	color: var(--fhc-ink) !important;
	font-size: 14px;
	box-shadow: var(--fhc-shadow-sm);
}
.woocommerce-message::before,
.woocommerce-info::before,
.woocommerce-error::before { color: var(--fhc-ink); }
.woocommerce-message { border-left: 3px solid #5a8a5a !important; }
.woocommerce-error { border-left: 3px solid #c44545 !important; }

/* ---- My-account ---- */
.woocommerce-account .woocommerce-MyAccount-navigation {
	background: var(--fhc-card);
	border-radius: var(--fhc-radius-md);
	padding: var(--fhc-space-3);
}
.woocommerce-account .woocommerce-MyAccount-navigation ul {
	list-style: none;
	margin: 0;
	padding: 0;
}
.woocommerce-account .woocommerce-MyAccount-navigation li {
	border: 0;
}
.woocommerce-account .woocommerce-MyAccount-navigation li a {
	display: block;
	padding: 11px 14px;
	border-radius: 12px;
	color: var(--fhc-ink-soft);
	font-weight: 500;
	font-size: 14px;
	text-decoration: none;
}
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation li a:hover {
	background: #fff;
	color: var(--fhc-ink);
}

/* Login / Register form */
.woocommerce-account .woocommerce form.login,
.woocommerce-account .woocommerce form.register {
	background: var(--fhc-card);
	border-radius: var(--fhc-radius-md);
	padding: var(--fhc-space-6);
	max-width: 480px;
	margin: 0 auto;
}

/* ---- Pagination ---- */
.woocommerce nav.woocommerce-pagination ul {
	border: 0;
	display: inline-flex;
	gap: 4px;
}
.woocommerce nav.woocommerce-pagination ul li {
	border: 0;
	margin: 0;
}
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
	border: 1px solid var(--fhc-border);
	border-radius: 999px;
	padding: 8px 14px;
	background: #fff;
	color: var(--fhc-ink);
	font-size: 13.5px;
	font-weight: 500;
}
.woocommerce nav.woocommerce-pagination ul li span.current {
	background: var(--fhc-dark);
	color: #fff;
	border-color: var(--fhc-dark);
}

/* ---- Breadcrumbs ---- */
.woocommerce-breadcrumb {
	color: var(--fhc-muted);
	font-size: 13px;
	margin-bottom: var(--fhc-space-5);
}
.woocommerce-breadcrumb a { color: var(--fhc-ink-soft); }
.woocommerce-breadcrumb a:hover { color: var(--fhc-ink); }

/* =========================================================================
   Responsive — tablet / mobile
   ========================================================================= */
@media (max-width: 960px) {
	.woocommerce ul.products,
	.woocommerce-page ul.products {
		grid-template-columns: repeat(2, 1fr);
		gap: 16px;
	}
	.woocommerce-page main.site-main,
	.woocommerce main.site-main { padding-block: var(--fhc-space-7); }
}
@media (max-width: 640px) {
	.woocommerce ul.products,
	.woocommerce-page ul.products {
		grid-template-columns: 1fr;
		gap: 14px;
	}
	.woocommerce table.shop_table {
		display: block;
		overflow-x: auto;
		white-space: nowrap;
	}
	.woocommerce div.product .images,
	.woocommerce div.product .summary {
		float: none !important;
		width: 100% !important;
		margin: 0 0 var(--fhc-space-5) !important;
	}
	.woocommerce div.product form.cart {
		flex-direction: column;
		align-items: stretch;
	}
	.woocommerce div.product form.cart .quantity input.qty { width: 100%; }
	.woocommerce-account .woocommerce-MyAccount-navigation,
	.woocommerce-account .woocommerce-MyAccount-content {
		float: none !important;
		width: 100% !important;
		margin-bottom: var(--fhc-space-4);
	}
	.woocommerce-cart .cart-collaterals .cart_totals,
	.woocommerce-cart .cart-collaterals .shipping_calculator,
	.woocommerce-cart .cart-collaterals .cross-sells {
		float: none !important;
		width: 100% !important;
	}
	.woocommerce #payment #place_order,
	.woocommerce-page #payment #place_order { width: 100%; }
}

/* =========================================================================
   Custom single-product page — Trendo-style layout
   Powered by woocommerce/content-single-product.php override.
   ========================================================================= */

.fhc-product {
	/* max-width: 1200px; */
	margin: 0 auto;
	padding: 0 0 80px;
	color: var(--fhc-ink);
	font-family: var(--fhc-font-sans);
}

/* Hide WooCommerce default summary/title/price wrappers since we render our own */
.fhc-product .product_title,
.fhc-product .summary > .price,
.fhc-product > .summary,
.fhc-product .woocommerce-product-rating,
.fhc-product .woocommerce-product-details__short-description,
.fhc-product > p.price { display: none; }

/* Breadcrumb */
.fhc-product__breadcrumb {
	font-size: 13px;
	color: var(--fhc-muted);
	margin-bottom: 28px;
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
}
.fhc-product__breadcrumb a {
	color: var(--fhc-ink-soft);
	text-decoration: none;
	transition: color .2s;
}
.fhc-product__breadcrumb a:hover { color: var(--fhc-ink); }
.fhc-product__breadcrumb span { color: var(--fhc-border); }

/* 2-column layout: gallery left, details right */
.fhc-product__layout {
	display: grid;
	grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
	gap: 60px;
	align-items: start;
}

/* Gallery — vertical thumbs + main image */
.fhc-product__gallery {
	display: grid;
	grid-template-columns: 84px 1fr;
	gap: 16px;
	align-items: start;
}
.fhc-product__thumbs {
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.fhc-product__thumb {
	width: 84px;
	height: 84px;
	background: var(--fhc-card-img);
	border: 1.5px solid transparent;
	border-radius: 14px;
	overflow: hidden;
	padding: 4px;
	cursor: pointer;
	transition: border-color .2s, transform .15s;
}
.fhc-product__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 10px;
	display: block;
}
.fhc-product__thumb:hover { transform: translateY(-1px); }
.fhc-product__thumb.is-active { border-color: var(--fhc-ink); }

.fhc-product__main {
	background: var(--fhc-card-img);
	border-radius: 24px;
	overflow: hidden;
	aspect-ratio: 1 / 1;
	display: flex;
	align-items: center;
	justify-content: center;
}
.fhc-product__main img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Details column */
.fhc-product__details {
	display: flex;
	flex-direction: column;
	gap: 18px;
	padding-top: 8px;
}

.fhc-product__brand {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 14px;
	color: var(--fhc-ink);
	font-weight: 500;
}
.fhc-product__brand-mark {
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: var(--fhc-dark);
	color: #fff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.05em;
}

.fhc-product__title {
	font-family: var(--fhc-font-sans);
	font-size: clamp(22px, 2.4vw, 30px);
	font-weight: 600;
	line-height: 1.2;
	margin: 0;
	letter-spacing: -0.01em;
	color: var(--fhc-ink);
}
.fhc-product__cat {
	font-size: 13.5px;
	color: var(--fhc-muted);
	margin-top: -8px;
}

.fhc-product__rating {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 13px;
}
.fhc-product__stars {
	color: var(--fhc-gold);
	letter-spacing: 2px;
	font-size: 14px;
}
.fhc-product__rating-text strong {
	font-weight: 600;
	color: var(--fhc-ink);
	margin-right: 4px;
}
.fhc-product__rating-count {
	color: var(--fhc-muted);
	font-size: 12.5px;
}

.fhc-product__price {
	font-size: clamp(24px, 2.4vw, 32px);
	font-weight: 600;
	color: var(--fhc-ink);
	margin: 4px 0;
}
.fhc-product__price .woocommerce-Price-amount { font-weight: 600; }
.fhc-product__price del { opacity: 0.45; font-weight: 500; margin-right: 8px; font-size: 0.7em; }

/* Color swatches */
.fhc-product__swatches-row {
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.fhc-product__swatches-label {
	font-size: 12.5px;
	color: var(--fhc-muted);
	font-weight: 500;
}
.fhc-product__swatches {
	display: flex;
	gap: 12px;
}
.fhc-swatch {
	width: 30px;
	height: 30px;
	border-radius: 50%;
	border: 1.5px solid transparent;
	cursor: pointer;
	transition: transform .15s, box-shadow .2s;
	box-shadow: inset 0 0 0 1px rgba(0,0,0,0.06), 0 0 0 2px transparent;
	box-sizing: border-box;
}
.fhc-swatch:hover { transform: scale(1.08); }
.fhc-swatch.is-active {
	box-shadow: inset 0 0 0 1px rgba(0,0,0,0.06), 0 0 0 2px var(--fhc-ink);
}

/* Form & quantity stepper -------------------------------------------------*/
.fhc-product__form {
	display: flex !important;
	flex-direction: column !important;
	gap: 14px !important;
	margin: 0 !important;
	width: 100%;
}

.fhc-product__qty-row {
	display: flex !important;
	justify-content: space-between !important;
	align-items: center;
	width: 100%;
	font-size: 13px;
	font-weight: 500;
	margin: 0 !important;
}
.fhc-product__qty-label {
	color: var(--fhc-ink);
	font-weight: 500;
}
.fhc-product__guide {
	color: var(--fhc-ink) !important;
	text-decoration: underline !important;
	text-underline-offset: 3px;
	font-size: 12.5px;
	font-weight: 500;
}

.fhc-product__actions {
	display: flex !important;
	gap: 10px;
	align-items: stretch;
	width: 100%;
	margin: 0 !important;
	flex-wrap: wrap;
}

/* Unified rounded quantity stepper: −  [ 1 ]  + */
.fhc-product__form .quantity {
	display: inline-flex !important;
	align-items: center;
	background: #fff;
	border: 1px solid var(--fhc-border);
	border-radius: 14px;
	height: 56px;
	overflow: hidden;
	flex: 0 0 auto;
	margin: 0 !important;
	padding: 0 !important;
}
.fhc-product__form .quantity input.qty {
	width: 56px !important;
	height: 100% !important;
	border: 0 !important;
	border-radius: 0 !important;
	background: transparent !important;
	font-family: var(--fhc-font-sans) !important;
	font-size: 15px !important;
	font-weight: 600 !important;
	text-align: center;
	color: var(--fhc-ink);
	padding: 0 !important;
	box-shadow: none !important;
	-moz-appearance: textfield;
	appearance: textfield;
}
.fhc-product__form .quantity input.qty:focus { outline: 0; }
.fhc-product__form .quantity input.qty::-webkit-inner-spin-button,
.fhc-product__form .quantity input.qty::-webkit-outer-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

/* Plus / minus buttons (Bricks/WC variants) — make them sit flush inside
   the rounded quantity pill instead of floating outside as raw text. */
.fhc-product__form .quantity .plus,
.fhc-product__form .quantity .minus,
.fhc-product__form .quantity button.plus,
.fhc-product__form .quantity button.minus,
.fhc-product__form .quantity .qty-plus,
.fhc-product__form .quantity .qty-minus,
.fhc-product__form .quantity button[type="button"] {
	width: 40px !important;
	height: 100% !important;
	border: 0 !important;
	background: transparent !important;
	color: var(--fhc-ink) !important;
	font-size: 16px !important;
	font-weight: 500 !important;
	cursor: pointer;
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	padding: 0 !important;
	border-radius: 0 !important;
	line-height: 1 !important;
	box-shadow: none !important;
	transition: background .15s ease;
}
.fhc-product__form .quantity .plus:hover,
.fhc-product__form .quantity .minus:hover,
.fhc-product__form .quantity .qty-plus:hover,
.fhc-product__form .quantity .qty-minus:hover,
.fhc-product__form .quantity button[type="button"]:hover {
	background: var(--fhc-bg-soft) !important;
}

.fhc-product__add {
	flex: 1;
	min-height: 56px;
	border: 0;
	border-radius: 14px !important;
	background: var(--fhc-dark) !important;
	color: #fff !important;
	font-size: 14px !important;
	font-weight: 500 !important;
	font-family: var(--fhc-font-sans) !important;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 0 24px !important;
	transition: background .2s;
	letter-spacing: 0;
	text-transform: none !important;
	margin-top: 0;
}
.fhc-product__add:hover { background: #1d2727 !important; }
.fhc-product__add:focus { outline: 0; }

.fhc-product__wishlist {
	width: 56px;
	height: 56px;
	border: 1px solid var(--fhc-border);
	border-radius: 14px;
	background: #fff;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--fhc-ink);
	transition: background .2s, border-color .2s;
	flex-shrink: 0;
}
.fhc-product__wishlist:hover {
	background: var(--fhc-bg-soft);
	border-color: var(--fhc-ink);
}

.fhc-product__shipping {
	font-size: 12.5px;
	color: var(--fhc-muted);
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin-top: 6px;
	justify-content: center;
}

/* Long description below the fold */
.fhc-product__longdesc {
	margin-top: 80px;
	padding: 40px 0;
	border-top: 1px solid var(--fhc-border);
	max-width: 720px;
}
.fhc-product__longdesc h2 {
	font-size: 22px;
	font-weight: 600;
	margin-bottom: 16px;
	color: var(--fhc-ink);
	font-family: var(--fhc-font-sans);
}
.fhc-product__longdesc p {
	font-size: 14.5px;
	color: var(--fhc-ink-soft);
	line-height: 1.7;
	margin-bottom: 14px;
}

/* Related products styling tweak */
.fhc-product .related.products {
	margin-top: 80px;
	padding-top: 40px;
	border-top: 1px solid var(--fhc-border);
}
.fhc-product .related.products > h2 {
	font-size: 22px;
	font-weight: 600;
	margin-bottom: 24px;
	font-family: var(--fhc-font-sans);
}

/* Responsive — tablet */
@media (max-width: 960px) {
	.fhc-product { padding: 24px 32px 60px; }
	.fhc-product__layout { gap: 36px; }
	.fhc-product__gallery {
		grid-template-columns: 70px 1fr;
		gap: 12px;
	}
	.fhc-product__thumb { width: 70px; height: 70px; border-radius: 12px; }
}

/* Responsive — mobile */
@media (max-width: 760px) {
	.fhc-product { padding: 20px 20px 60px; }
	.fhc-product__layout {
		grid-template-columns: 1fr;
		gap: 24px;
	}
	.fhc-product__gallery {
		grid-template-columns: 1fr;
	}
	/* On mobile: thumbs go horizontal under the main image */
	.fhc-product__gallery {
		display: flex;
		flex-direction: column;
		gap: 12px;
	}
	.fhc-product__main { order: -1; border-radius: 18px; }
	.fhc-product__thumbs {
		flex-direction: row;
		overflow-x: auto;
		padding-bottom: 4px;
		scrollbar-width: thin;
	}
	.fhc-product__thumb {
		width: 64px;
		height: 64px;
		flex-shrink: 0;
		border-radius: 10px;
	}
	.fhc-product__details { padding-top: 0; gap: 14px; }
	.fhc-product__title { font-size: 22px; }
	.fhc-product__price { font-size: 24px; }
	.fhc-product__longdesc,
	.fhc-product .related.products {
		margin-top: 50px;
		padding-top: 28px;
	}
}

/* Narrow mobile — drop "Add to cart" to its own full-width row,
   keep quantity stepper on the left and wishlist on the right above it. */
@media (max-width: 480px) {
	.fhc-product__form .quantity { order: 1; }
	.fhc-product__wishlist     { order: 2; margin-left: auto; }
	.fhc-product__add {
		order: 3;
		flex: 1 1 100% !important;
		width: 100%;
	}
}
