:root {
	/* LIGHT EDITORIAL palette (Option A, chosen 2026-07-01): warm cream base,
	   near-black ink, burnt-orange accent. Dark is opt-in per element (footer,
	   feature strips) via --bl-ink-panel. The homepage uses its own vars file
	   and is unaffected by this. */
	--bl-bg:          #f4efe4;  /* warm cream base */
	--bl-bg-2:        #ffffff;  /* raised panel / card surface */
	--bl-bg-3:        #e3d9c7;  /* warm hairline borders */
	--bl-panel:       #ffffff;  /* content panel */
	--bl-fg:          #1b1712;  /* near-black warm ink */
	--bl-fg-2:        #4c4437;  /* secondary ink */
	--bl-muted:       #8c8375;  /* muted labels */
	--bl-accent:      #d9591f;  /* burnt orange — legible on cream */
	--bl-accent-2:    #b8431a;  /* deep ember */
	--bl-accent-fg:   #ffffff;  /* text on accent */
	--bl-ink-panel:   #17130f;  /* explicit dark for footer / dark strips */
	--bl-surface:     #efe9dd;  /* subtle image mat */
	--bl-surface-2:   #e7e0d3;

	--bl-display: Impact, Haettenschweiler, "Arial Narrow Bold", sans-serif;
	--bl-body:    "Work Sans", "Helvetica Neue", Arial, sans-serif;
	--bl-mono:    "Courier New", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;

	--bl-container: 1400px;
	--bl-pad: clamp(16px, 2.4vw, 40px);
}

body,
body.woocommerce {
	background: var(--bl-bg);
	color: var(--bl-fg);
	font-family: var(--bl-body);
	-webkit-font-smoothing: antialiased;
}

a { color: var(--bl-fg); }
a:hover { color: var(--bl-accent); }

h1, h2, h3,
.entry-title,
.woocommerce-loop-product__title,
.product_title {
	font-family: var(--bl-display);
	text-transform: uppercase;
	letter-spacing: 0.01em;
	color: var(--bl-fg);
	line-height: 0.95;
}

h1, .entry-title { font-size: clamp(40px, 7vw, 96px); }
h2 { font-size: clamp(28px, 4vw, 48px); }
h3 { font-size: clamp(20px, 2.5vw, 28px); }

.bl-eyebrow,
.woocommerce-breadcrumb,
.site-navigation a,
.ast-menu-toggle {
	font-family: var(--bl-mono);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	font-size: 11px;
}

.ast-primary-header,
.main-header-bar,
#masthead {
	background: var(--bl-bg) !important;
	border-bottom: 1px solid var(--bl-bg-3);
}

.site-title,
.ast-site-title a {
	font-family: var(--bl-display);
	color: var(--bl-fg) !important;
	letter-spacing: 0.02em;
	text-transform: uppercase;
}

.main-header-menu .menu-item > a,
.main-header-bar-navigation a {
	color: var(--bl-fg-2) !important;
	font-family: var(--bl-mono);
	font-size: 11px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}
.main-header-menu .menu-item > a:hover {
	color: var(--bl-accent) !important;
}

.ast-header-search svg,
.ast-icon svg,
.astra-cart-drawer-icon svg {
	fill: var(--bl-fg);
}

.button,
button,
input[type="submit"],
.wp-block-button__link,
a.button,
.single_add_to_cart_button,
.checkout-button {
	background: var(--bl-accent) !important;
	color: var(--bl-accent-fg) !important;
	border: none !important;
	border-radius: 2px;
	font-family: var(--bl-mono) !important;
	font-size: 11px !important;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	padding: 14px 22px !important;
	transition: opacity 0.15s ease;
}
.button:hover,
button:hover,
.single_add_to_cart_button:hover {
	opacity: 0.85;
	color: var(--bl-accent-fg) !important;
}

.button.ast-outline-button {
	background: transparent !important;
	color: var(--bl-fg) !important;
	border: 1px solid var(--bl-fg-2) !important;
}

/* Icon / utility buttons must NOT inherit the solid-orange button skin above.
   (They are <button> elements, so the global rule turns them into orange blobs
   unless we reset them here.) Real CTAs keep the orange skin. */
.bl-ih__icon,
.bl-ih-search__close,
.bl-size-guide__close {
	background: transparent !important;
	padding: 0 !important;
	color: var(--bl-fg-2) !important;
}
.bl-ih__icon {
	border: none !important;
	border-radius: 0 !important;
}
.bl-ih-search__close,
.bl-size-guide__close {
	border: 1px solid var(--bl-bg-3) !important;
	border-radius: 50% !important;
}
.bl-ih-search__close:hover,
.bl-size-guide__close:hover {
	border-color: var(--bl-accent) !important;
	color: var(--bl-accent) !important;
}
/* WooCommerce Blocks cart/checkout (React-rendered): the quantity stepper
   and "remove item" control are <button> elements too, so they inherited
   the solid-orange CTA skin above and looked like broken blobs. Give them
   a clean, neutral look instead; real CTAs (Proceed to Checkout, Place
   order) are untouched and stay orange. */
.wc-block-components-quantity-selector {
	border: 1px solid var(--bl-bg-3) !important;
	border-radius: 4px !important;
	background: #fff !important;
	overflow: hidden;
}
.wc-block-components-quantity-selector__button {
	background: transparent !important;
	color: var(--bl-fg) !important;
	border: none !important;
	box-shadow: none !important;
	padding: 0 12px !important;
}
.wc-block-components-quantity-selector__button:hover {
	background: var(--bl-surface) !important;
	color: var(--bl-accent) !important;
	opacity: 1 !important;
}
.wc-block-components-quantity-selector__input {
	background: #fff !important;
	color: var(--bl-fg) !important;
	border: none !important;
	box-shadow: none !important;
}
.wc-block-cart-item__remove-link,
.wc-block-cart-item__remove-link.wc-block-components-button {
	background: transparent !important;
	color: var(--bl-muted) !important;
	border: none !important;
	box-shadow: none !important;
	padding: 6px !important;
	font-family: var(--bl-mono) !important;
	font-size: 11px !important;
	letter-spacing: 0.04em;
	text-transform: none !important;
}
.wc-block-cart-item__remove-link:hover {
	color: var(--bl-accent) !important;
	background: transparent !important;
	opacity: 1 !important;
}
.wc-block-cart-item__remove-link svg,
.wc-block-cart-item__remove-link svg path {
	fill: currentColor !important;
}

/* The "Size guide" trigger is an outlined pill, not a solid button. */
.bl-size-guide-btn {
	background: transparent !important;
	color: var(--bl-fg-2) !important;
	border: 1px solid var(--bl-bg-3) !important;
	padding: 9px 14px !important;
	border-radius: 3px !important;
}
.bl-size-guide-btn:hover {
	border-color: var(--bl-accent) !important;
	color: var(--bl-accent) !important;
}

.bl-ticker {
	background: var(--bl-accent);
	color: var(--bl-accent-fg);
	font-family: var(--bl-mono);
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	padding: 10px 0;
	overflow: hidden;
	white-space: nowrap;
}

.woocommerce ul.products li.product,
.wc-block-grid__product {
	background: transparent;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-size: 18px;
	margin-top: 12px;
}

.woocommerce ul.products li.product .price {
	font-family: var(--bl-mono);
	color: var(--bl-accent);
}

.woocommerce div.product p.price,
.woocommerce div.product span.price {
	color: var(--bl-accent);
	font-family: var(--bl-mono);
}

.woocommerce ul.products li.product a img,
.woocommerce div.product div.images {
	background: var(--bl-surface);
	border-radius: 2px;
}

#colophon,
.ast-footer-overlay {
	background: var(--bl-bg-2) !important;
	color: var(--bl-fg-2);
	border-top: 1px solid var(--bl-bg-3);
}

#colophon a { color: var(--bl-fg-2); }
#colophon a:hover { color: var(--bl-accent); }

#colophon .widget-title,
#colophon h2 {
	font-family: var(--bl-mono);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	font-size: 12px;
	color: var(--bl-fg);
}

input[type="text"],
input[type="email"],
input[type="tel"],
input[type="password"],
input[type="number"],
select,
textarea {
	background: var(--bl-bg-2);
	border: 1px solid var(--bl-bg-3);
	color: var(--bl-fg);
	border-radius: 2px;
}
input::placeholder,
textarea::placeholder {
	color: var(--bl-muted);
}

/* ================================================================== *
 * Beyond Lines — full storefront styling for the Astra/WooCommerce
 * inner pages (shop, category, single product, cart, checkout, account).
 * Everything below matches the editorial dark look of the custom homepage.
 * CSS-only; page/cart/checkout behaviour is untouched.
 * ================================================================== */

/* ---- Header logo contrast fix (the <a> inside .site-title) --------- */
.site-title a,
.site-title a:focus,
.ast-site-title-wrap .site-title a {
	color: var(--bl-fg) !important;
	font-family: var(--bl-display);
	letter-spacing: 0.03em;
	text-transform: uppercase;
}
.site-title a:hover { color: var(--bl-accent) !important; }

.site-description,
.ast-site-title-wrap .site-description { color: var(--bl-muted) !important; }

/* ---- Announcement bar (echoes the homepage) ----------------------- */
.bl-announce {
	background: var(--bl-accent);
	color: var(--bl-accent-fg);
	font-family: var(--bl-mono);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	text-align: center;
	padding: 9px 16px;
}

/* ---- Page width + base wrappers ----------------------------------- */
.ast-container,
.site-content .ast-container { max-width: var(--bl-container); }

.site-content,
#content { background: var(--bl-bg); }

/* Shop / archive page title + toolbar ------------------------------- */
.woocommerce-products-header {
	padding: 40px 0 8px;
	border-bottom: 1px solid var(--bl-bg-3);
	margin-bottom: 28px;
}
.woocommerce-products-header__title,
.woocommerce-products-header .page-title {
	font-family: var(--bl-display);
	text-transform: uppercase;
	color: var(--bl-fg);
	font-size: clamp(36px, 6vw, 80px);
	line-height: 0.92;
}
.woocommerce-breadcrumb,
.woocommerce-breadcrumb a {
	color: var(--bl-muted) !important;
	font-family: var(--bl-mono);
	font-size: 11px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}
.woocommerce-breadcrumb a:hover { color: var(--bl-accent) !important; }

.woocommerce-result-count {
	color: var(--bl-muted);
	font-family: var(--bl-mono);
	font-size: 11px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}
.woocommerce-ordering select,
.woocommerce .woocommerce-ordering select {
	background: var(--bl-bg-2);
	border: 1px solid var(--bl-bg-3);
	color: var(--bl-fg);
	font-family: var(--bl-mono);
	font-size: 11px;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	padding: 10px 12px;
	border-radius: 2px;
}

/* ---- Product grid cards ------------------------------------------- */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
	background: transparent;
	text-align: left;
	margin-bottom: 12px;
}
.woocommerce ul.products li.product a.woocommerce-LoopProduct-link { display: block; }

.woocommerce ul.products li.product a img,
.woocommerce ul.products li.product .attachment-woocommerce_thumbnail {
	background: var(--bl-surface);
	border-radius: 3px;
	margin-bottom: 14px;
	transition: transform 0.5s cubic-bezier(0.2, 0.8, 0.2, 1), box-shadow 0.4s ease;
	aspect-ratio: 1 / 1;
	object-fit: cover;
}
.woocommerce ul.products li.product:hover a img {
	transform: translateY(-6px) scale(1.01);
	box-shadow: 0 22px 40px -24px rgba(0, 0, 0, 0.9);
}

/* Loop title: readable Work Sans (not the heavy Impact used for H1s) */
.woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-family: var(--bl-body) !important;
	text-transform: none;
	letter-spacing: 0;
	line-height: 1.25;
	font-size: 15px !important;
	font-weight: 600;
	color: var(--bl-fg);
	padding: 0;
	margin: 0 0 4px;
}
.woocommerce ul.products li.product .price {
	font-family: var(--bl-mono);
	color: var(--bl-accent);
	font-size: 14px;
	font-weight: 700;
}
.woocommerce ul.products li.product .price del { color: var(--bl-muted); opacity: 0.7; }
.woocommerce ul.products li.product .price ins { text-decoration: none; }

/* Loop "add to cart" -> quiet link, not a loud button */
.woocommerce ul.products li.product .button.add_to_cart_button,
.woocommerce ul.products li.product .added_to_cart {
	background: transparent !important;
	color: var(--bl-fg-2) !important;
	border: 1px solid var(--bl-bg-3) !important;
	margin-top: 10px;
	display: inline-block;
}
.woocommerce ul.products li.product .button.add_to_cart_button:hover {
	border-color: var(--bl-accent) !important;
	color: var(--bl-accent) !important;
	opacity: 1;
}

/* Sale / stock badge */
.woocommerce span.onsale {
	background: var(--bl-accent);
	color: var(--bl-accent-fg);
	font-family: var(--bl-mono);
	font-size: 10px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	border-radius: 2px;
	min-height: auto;
	min-width: auto;
	line-height: 1;
	padding: 6px 9px;
}

/* Pagination */
.woocommerce nav.woocommerce-pagination ul,
.woocommerce nav.woocommerce-pagination ul li { border-color: var(--bl-bg-3); }
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
	background: var(--bl-bg-2);
	color: var(--bl-fg-2);
	font-family: var(--bl-mono);
	font-size: 12px;
}
.woocommerce nav.woocommerce-pagination ul li span.current,
.woocommerce nav.woocommerce-pagination ul li a:hover {
	background: var(--bl-accent);
	color: var(--bl-accent-fg);
}

/* ---- Single product ----------------------------------------------- */
.woocommerce div.product .product_title {
	font-family: var(--bl-display);
	text-transform: uppercase;
	color: var(--bl-fg);
	font-size: clamp(32px, 4.5vw, 62px);
	line-height: 0.95;
}
.woocommerce div.product .woocommerce-product-rating a { color: var(--bl-muted); }
.woocommerce div.product p.price,
.woocommerce div.product span.price {
	color: var(--bl-accent);
	font-family: var(--bl-mono);
	font-size: 22px;
	font-weight: 700;
}
.woocommerce div.product div.images img { background: var(--bl-surface); border-radius: 4px; }
.woocommerce div.product .woocommerce-product-details__short-description { color: var(--bl-fg-2); }

.woocommerce div.product form.cart .quantity .qty {
	background: var(--bl-bg-2);
	border: 1px solid var(--bl-bg-3);
	color: var(--bl-fg);
	padding: 12px 8px;
}
.woocommerce div.product form.cart .variations select {
	background: var(--bl-bg-2);
	border: 1px solid var(--bl-bg-3);
	color: var(--bl-fg);
	font-family: var(--bl-mono);
	text-transform: uppercase;
	font-size: 12px;
	padding: 10px;
}
.woocommerce div.product form.cart .variations th.label { color: var(--bl-muted); font-family: var(--bl-mono); text-transform: uppercase; font-size: 11px; letter-spacing: 0.08em; }

/* Product tabs */
.woocommerce div.product .woocommerce-tabs ul.tabs {
	border-bottom: 1px solid var(--bl-bg-3);
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before { border-color: var(--bl-bg-3); }
.woocommerce div.product .woocommerce-tabs ul.tabs li {
	background: transparent;
	border: none;
	border-radius: 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	color: var(--bl-muted);
	font-family: var(--bl-mono);
	text-transform: uppercase;
	font-size: 12px;
	letter-spacing: 0.08em;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a { color: var(--bl-accent); }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active { border-bottom: 2px solid var(--bl-accent); }
.woocommerce #reviews h2,
.woocommerce div.product .woocommerce-Tabs-panel h2 { font-family: var(--bl-display); text-transform: uppercase; }

/* Related / upsells heading */
.woocommerce .related > h2,
.woocommerce .upsells > h2,
.woocommerce section.related h2 {
	font-family: var(--bl-display);
	text-transform: uppercase;
	font-size: clamp(24px, 3vw, 40px);
	margin-bottom: 24px;
}

/* ---- Cart & checkout ---------------------------------------------- */
.woocommerce table.shop_table {
	background: var(--bl-bg-2);
	border: 1px solid var(--bl-bg-3);
	border-radius: 4px;
}
.woocommerce table.shop_table th {
	font-family: var(--bl-mono);
	text-transform: uppercase;
	font-size: 11px;
	letter-spacing: 0.08em;
	color: var(--bl-muted);
}
.woocommerce table.shop_table td,
.woocommerce table.shop_table td a { color: var(--bl-fg-2); }
.woocommerce table.shop_table,
.woocommerce table.shop_table td,
.woocommerce table.shop_table th,
.woocommerce table.shop_table tbody tr { border-color: var(--bl-bg-3) !important; }
.woocommerce .cart_totals h2,
.woocommerce-checkout h3,
.woocommerce-checkout #order_review_heading {
	font-family: var(--bl-display);
	text-transform: uppercase;
	color: var(--bl-fg);
}
.woocommerce .cart-collaterals .cart_totals,
.woocommerce-checkout #order_review,
.woocommerce-checkout #customer_details .col-1,
.woocommerce-checkout #customer_details .col-2 {
	background: var(--bl-bg-2);
	border: 1px solid var(--bl-bg-3);
	border-radius: 4px;
	padding: 22px;
}
.woocommerce form .form-row label,
.woocommerce-checkout label { color: var(--bl-fg-2); font-size: 13px; }
.woocommerce .cart .actions .coupon .input-text {
	background: var(--bl-bg-2);
	border: 1px solid var(--bl-bg-3);
	color: var(--bl-fg);
}
.woocommerce-info,
.woocommerce-message,
.woocommerce-error {
	background: var(--bl-bg-2);
	border-top: 3px solid var(--bl-accent);
	color: var(--bl-fg-2);
}
.woocommerce-info::before,
.woocommerce-message::before { color: var(--bl-accent); }
.woocommerce-checkout #payment {
	background: var(--bl-bg-2);
	border-radius: 4px;
}
.woocommerce-checkout #payment ul.payment_methods { border-color: var(--bl-bg-3); }
.woocommerce-checkout #payment div.payment_box { background: var(--bl-bg-3); color: var(--bl-fg-2); }
.woocommerce-checkout #payment div.payment_box::before { border-bottom-color: var(--bl-bg-3); }

/* My-account */
.woocommerce-account .woocommerce-MyAccount-navigation ul li {
	border-bottom: 1px solid var(--bl-bg-3);
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
	font-family: var(--bl-mono);
	text-transform: uppercase;
	font-size: 12px;
	letter-spacing: 0.06em;
	color: var(--bl-fg-2);
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a { color: var(--bl-accent); }

/* ---- Mobile polish ------------------------------------------------- */
@media (max-width: 768px) {
	.woocommerce-products-header { padding-top: 24px; }
	.woocommerce ul.products li.product .woocommerce-loop-product__title { font-size: 14px !important; }
}

/* ================================================================== *
 * REFINEMENTS v1.1 — feedback pass:
 *  - warmer, less "suffocating" dark with subtle relief
 *  - branded custom header replaces Astra's flat one
 *  - fix the bright gallery box + oversized thumbnails
 *  - smaller, readable product titles + roomier product summary
 * ================================================================== */

/* Soft warm wash so the cream base feels editorial, not clinical white. */
body,
body.woocommerce {
	background:
		radial-gradient(1200px 620px at 50% -320px, rgba(217, 89, 31, 0.06), transparent 60%),
		var(--bl-bg);
	background-attachment: fixed;
}

/* ---- Hide Astra's plain header; our branded header takes its place -- */
.site-header,
#masthead { display: none !important; }

/* ---- Branded inner-page header ------------------------------------ */
.bl-ih-wrap { position: relative; z-index: 20; }

.bl-ih {
	position: sticky;
	top: 0;
	z-index: 1000;
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	gap: 20px;
	padding: 16px clamp(16px, 3vw, 44px);
	background: rgba(244, 239, 228, 0.82);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	border-bottom: 1px solid var(--bl-bg-3);
}

.bl-ih__brand {
	grid-column: 2;
	justify-self: center;
	font-family: var(--bl-display);
	font-size: clamp(20px, 2.2vw, 28px);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--bl-fg) !important;
	white-space: nowrap;
	line-height: 1;
}
.bl-ih__brand span { color: var(--bl-accent); margin: 0 1px; }
.bl-ih__brand:hover { color: var(--bl-fg) !important; opacity: 0.9; }

.bl-ih__nav { grid-column: 1; justify-self: start; min-width: 0; }
.bl-ih__menu {
	display: flex;
	align-items: center;
	gap: clamp(12px, 1.6vw, 26px);
	margin: 0;
	padding: 0;
	list-style: none;
}
.bl-ih__menu li { margin: 0; }
.bl-ih__menu a {
	font-family: var(--bl-body);
	font-weight: 600;
	font-size: 13px;
	letter-spacing: 0.03em;
	text-transform: uppercase;
	color: var(--bl-fg-2) !important;
	white-space: nowrap;
	padding: 6px 0;
	position: relative;
}
.bl-ih__menu a::after {
	content: "";
	position: absolute;
	left: 0; bottom: 0;
	width: 0; height: 1px;
	background: var(--bl-accent);
	transition: width 0.25s ease;
}
.bl-ih__menu a:hover { color: var(--bl-fg) !important; }
.bl-ih__menu a:hover::after { width: 100%; }

.bl-ih__actions {
	grid-column: 3;
	justify-self: end;
	display: flex;
	align-items: center;
	gap: 14px;
}
.bl-ih__icon {
	display: inline-flex;
	width: 22px; height: 22px;
	color: var(--bl-fg-2) !important;
	position: relative;
	transition: color 0.2s ease, transform 0.2s ease;
}
.bl-ih__icon:hover { color: var(--bl-accent) !important; transform: translateY(-1px); }
.bl-ih__icon svg { width: 100%; height: 100%; }
.bl-ih__cart-count {
	position: absolute;
	top: -7px; right: -9px;
	min-width: 16px; height: 16px;
	padding: 0 4px;
	border-radius: 999px;
	background: var(--bl-accent);
	color: var(--bl-accent-fg);
	font-family: var(--bl-mono);
	font-size: 9px;
	font-weight: 700;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
}
.bl-ih__cart-count.is-empty { display: none; }

@media (max-width: 880px) {
	.bl-ih {
		grid-template-columns: 1fr auto;
		row-gap: 12px;
		padding: 12px 16px;
	}
	.bl-ih__brand { grid-column: 1; justify-self: start; grid-row: 1; }
	.bl-ih__actions { grid-column: 2; grid-row: 1; }
	.bl-ih__nav { grid-column: 1 / -1; grid-row: 2; overflow-x: auto; -webkit-overflow-scrolling: touch; }
	.bl-ih__menu { gap: 18px; padding-bottom: 2px; }
	.bl-ih__menu::-webkit-scrollbar { display: none; }
}

/* ---- Give inner content warm, layered relief ---------------------- */
.site-content,
#content { background: transparent; }
.ast-container { padding-top: 8px; }

/* ---- Single product: readable title + roomier, uncramped summary --- */
.woocommerce div.product { padding-top: 12px; }
.woocommerce div.product .product_title {
	font-size: clamp(24px, 2.8vw, 38px) !important;
	line-height: 1.03;
	letter-spacing: 0.01em;
	margin-bottom: 4px;
}
.woocommerce div.product .summary,
.woocommerce div.product .entry-summary { padding-left: clamp(0px, 1.5vw, 22px); }
.woocommerce div.product .summary > * { margin-bottom: 20px; }
.woocommerce div.product p.price,
.woocommerce div.product span.price { font-size: 26px; margin-top: 2px; }
.woocommerce div.product .woocommerce-product-details__short-description {
	line-height: 1.65;
	font-size: 15px;
	color: var(--bl-fg-2);
}
.woocommerce div.product form.cart { margin: 6px 0 24px; }
.woocommerce div.product .product_meta {
	margin-top: 22px;
	padding-top: 18px;
	border-top: 1px solid var(--bl-bg-3);
	font-size: 12.5px;
	line-height: 2;
	color: var(--bl-muted);
}
.woocommerce div.product .product_meta > span { display: block; margin-bottom: 4px; }
.woocommerce div.product .product_meta a { color: var(--bl-fg-2); }
.woocommerce div.product .product_meta a:hover { color: var(--bl-accent); }

/* ---- Gallery: kill the bright box, use a soft dark mat ------------- */
.woocommerce div.product div.images,
.woocommerce div.product div.images img { background: transparent !important; }
.woocommerce div.product .woocommerce-product-gallery {
	background: var(--bl-panel);
	border: 1px solid var(--bl-bg-3);
	border-radius: 8px;
	padding: 14px;
}
.woocommerce div.product .woocommerce-product-gallery__image img {
	border-radius: 5px;
	object-fit: contain;
}
.woocommerce div.product .woocommerce-product-gallery__trigger { top: 1rem; right: 1rem; }

/* Smaller, tidier gallery thumbnails (below the main image) */
.woocommerce div.product .flex-control-thumbs {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin: 12px 0 0;
	padding: 0;
}
.woocommerce div.product .flex-control-thumbs li {
	width: 62px !important;
	margin: 0 !important;
	list-style: none;
}
.woocommerce div.product .flex-control-thumbs img {
	border-radius: 4px;
	border: 1px solid transparent;
	opacity: 0.55;
	transition: opacity 0.2s ease, border-color 0.2s ease;
}
.woocommerce div.product .flex-control-thumbs img.flex-active,
.woocommerce div.product .flex-control-thumbs img:hover {
	opacity: 1;
	border-color: var(--bl-accent);
}

/* ---- Product grid cards: warm panel relief instead of flat void --- */
.woocommerce ul.products li.product {
	background: var(--bl-panel);
	border: 1px solid var(--bl-bg-3);
	border-radius: 8px;
	padding: 12px 12px 16px;
}
.woocommerce ul.products li.product a img,
.woocommerce ul.products li.product .attachment-woocommerce_thumbnail {
	background: var(--bl-surface);
	margin-bottom: 12px;
}
.woocommerce ul.products li.product .woocommerce-loop-product__title { padding: 0 2px; }
.woocommerce ul.products li.product .price { padding: 0 2px; }

/* Section headings in rich near-black ink on the cream base. */
.woocommerce-products-header__title,
.woocommerce div.product .product_title { color: var(--bl-fg); }

/* ---- Dark footer anchors the light page (light-site / dark-footer) - */
#colophon,
.ast-footer-overlay,
footer.site-footer {
	background: var(--bl-ink-panel) !important;
	color: #d8d0c2;
	border-top: 3px solid var(--bl-accent);
}
#colophon a,
footer.site-footer a { color: #d8d0c2; }
#colophon a:hover,
footer.site-footer a:hover { color: var(--bl-accent); }
#colophon .widget-title,
#colophon h2 { color: #fbf7ee; }

/* ---- 404 / empty pages: match the light theme, kill invisible text -- */
.error404 .site-content,
.search-no-results .site-content { padding: 40px 0 60px; }
.error404 h1,
.error404 .page-title,
.error404 .ast-404-layout-1 .ast-number {
	font-family: var(--bl-display);
	text-transform: uppercase;
	color: var(--bl-fg) !important;
	line-height: 0.95;
}
.error404 p,
.error404 .ast-404-layout-1 p,
.error404 .site-content * { color: var(--bl-fg-2); }
.error404 .search-field,
.search .search-field {
	background: #fff;
	border: 1px solid var(--bl-bg-3);
	color: var(--bl-fg);
}

/* ---- A few contrast guards for the light base ---------------------- */
.woocommerce ul.products li.product .button.add_to_cart_button {
	color: var(--bl-fg) !important;
	border-color: var(--bl-bg-3) !important;
}
.woocommerce-ordering select,
.woocommerce div.product form.cart .variations select,
input[type="text"], input[type="email"], input[type="tel"],
input[type="password"], input[type="number"], select, textarea {
	background: #fff;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a { color: var(--bl-muted); }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a { color: var(--bl-accent); }
.bl-ih__menu a,
.bl-ih__icon { color: var(--bl-fg-2) !important; }

/* ---- About page --------------------------------------------------- */
/* Hide Astra's plain "About" title so the editorial heading leads. */
.page-id-1961 .ast-single-post-title,
.page-id-1961 .entry-title,
.page-id-1961 header.entry-header { display: none !important; }

.bl-about { max-width: 1000px; margin: 0 auto; padding: 8px 0 24px; }
.bl-about__eyebrow {
	font-family: var(--bl-mono);
	font-size: 11px;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--bl-accent);
}
.bl-about__title {
	font-family: var(--bl-display);
	text-transform: uppercase;
	color: var(--bl-fg);
	font-size: clamp(38px, 6vw, 78px);
	line-height: 0.95;
	margin: 12px 0 22px;
}
.bl-about__lead {
	font-size: clamp(17px, 2vw, 21px);
	line-height: 1.55;
	color: var(--bl-fg);
	max-width: 60ch;
}
.bl-about__body {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 28px;
	margin: 40px 0 8px;
	padding-top: 32px;
	border-top: 1px solid var(--bl-bg-3);
}
.bl-about__body p { color: var(--bl-fg-2); line-height: 1.7; font-size: 15px; margin: 0; }

.bl-about__promises {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 18px;
	margin: 44px 0;
}
.bl-about__promises article {
	background: #fff;
	border: 1px solid var(--bl-bg-3);
	border-radius: 10px;
	padding: 24px 22px;
}
.bl-about__promises span {
	font-family: var(--bl-mono);
	font-size: 12px;
	color: var(--bl-accent);
	letter-spacing: 0.1em;
}
.bl-about__promises h3 {
	font-family: var(--bl-display);
	text-transform: uppercase;
	color: var(--bl-fg);
	font-size: 22px;
	margin: 10px 0 8px;
}
.bl-about__promises p { color: var(--bl-fg-2); font-size: 14px; line-height: 1.6; margin: 0; }

.bl-about__cta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	padding: 30px;
	background: var(--bl-ink-panel);
	border-radius: 12px;
}
.bl-about__thanks {
	color: #f4efe4;
	font-family: var(--bl-display);
	text-transform: uppercase;
	font-size: clamp(20px, 2.4vw, 30px);
	line-height: 1.05;
	margin: 0;
	max-width: 22ch;
}
.bl-about__button {
	flex: 0 0 auto;
	display: inline-block;
	background: var(--bl-accent) !important;
	color: #fff !important;
	font-family: var(--bl-mono);
	font-size: 12px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	padding: 15px 28px;
	border-radius: 3px;
	text-decoration: none;
	transition: transform 0.15s ease, background 0.15s ease;
}
.bl-about__button:hover { transform: translateY(-2px); background: var(--bl-accent-2) !important; color: #fff !important; }

@media (max-width: 640px) {
	.bl-about__body,
	.bl-about__promises { grid-template-columns: 1fr; }
}

/* ---- Journal (blog) grid ------------------------------------------- */
.bl-journal-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 24px;
	margin: 8px 0;
}
.bl-journal-card {
	display: flex;
	flex-direction: column;
	background: #fff;
	border: 1px solid var(--bl-bg-3);
	border-radius: 10px;
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.bl-journal-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 20px 40px -20px rgba(0, 0, 0, 0.25);
}
.bl-journal-card__media {
	aspect-ratio: 16 / 10;
	background: var(--bl-surface);
	overflow: hidden;
}
.bl-journal-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.bl-journal-card__body {
	padding: 18px 20px 22px;
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.bl-journal-card__date {
	font-family: var(--bl-mono);
	font-size: 10px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--bl-muted);
}
.bl-journal-card__body h3 {
	font-family: var(--bl-body);
	text-transform: none;
	font-size: 17px;
	font-weight: 700;
	line-height: 1.3;
	color: var(--bl-fg);
	margin: 2px 0 2px;
}
.bl-journal-card__body p {
	font-size: 13.5px;
	line-height: 1.55;
	color: var(--bl-fg-2);
	margin: 0 0 6px;
}
.bl-journal-card__read {
	font-family: var(--bl-mono);
	font-size: 11px;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--bl-accent);
}

/* ---- Shop filter bar ---------------------------------------------- */
.bl-filter-bar {
	display: flex;
	flex-wrap: wrap;
	gap: 14px 40px;
	align-items: center;
	padding: 4px 0 22px;
	margin-bottom: 20px;
	border-bottom: 1px solid var(--bl-bg-3);
}
.bl-filter-group {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
}
.bl-filter-label {
	font-family: var(--bl-mono);
	font-size: 10px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--bl-muted);
	margin-right: 4px;
}
.bl-filter-pill {
	display: inline-block;
	padding: 8px 14px;
	border: 1px solid var(--bl-bg-3);
	border-radius: 999px;
	font-family: var(--bl-mono);
	font-size: 11px;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--bl-fg-2) !important;
	background: #fff;
	transition: border-color 0.2s ease, color 0.2s ease, background 0.2s ease;
}
.bl-filter-pill:hover { border-color: var(--bl-accent); color: var(--bl-accent) !important; }
.bl-filter-pill.is-active {
	background: var(--bl-accent);
	border-color: var(--bl-accent);
	color: var(--bl-accent-fg) !important;
}
.bl-filter-pill--clear { border-style: dashed; background: transparent; }

/* ---- Inner-page live-search overlay ------------------------------- */
.bl-ih-search[hidden] { display: none; }
.bl-ih-search {
	position: fixed;
	inset: 0;
	z-index: 2000;
	display: flex;
	justify-content: center;
	align-items: flex-start;
}
.bl-ih-search__scrim {
	position: absolute;
	inset: 0;
	border: none;
	background: rgba(23, 19, 15, 0.5);
	backdrop-filter: blur(3px);
	cursor: pointer;
}
.bl-ih-search__panel {
	position: relative;
	margin-top: clamp(70px, 12vh, 140px);
	width: min(620px, 92vw);
	background: #fff;
	border: 1px solid var(--bl-bg-3);
	border-radius: 12px;
	box-shadow: 0 40px 120px -40px rgba(0, 0, 0, 0.5);
	padding: 18px;
}
.bl-ih-search__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	font-family: var(--bl-mono);
	font-size: 11px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--bl-muted);
	margin-bottom: 12px;
}
.bl-ih-search__close {
	display: inline-flex;
	width: 28px; height: 28px;
	align-items: center; justify-content: center;
	background: transparent;
	border: 1px solid var(--bl-bg-3);
	border-radius: 50%;
	color: var(--bl-fg-2);
	cursor: pointer;
}
.bl-ih-search__close:hover { border-color: var(--bl-accent); color: var(--bl-accent); }
.bl-ih-search__close svg { width: 15px; height: 15px; }
.bl-ih-search__form input[type="search"] {
	width: 100%;
	background: #faf7ef;
	border: 1px solid var(--bl-bg-3);
	border-radius: 6px;
	color: var(--bl-fg);
	font: 400 17px/1.4 var(--bl-body);
	padding: 14px 16px;
}
.bl-ih-search__form input[type="search"]:focus {
	outline: none;
	border-color: var(--bl-accent);
	box-shadow: 0 0 0 3px rgba(217, 89, 31, 0.12);
}
.bl-ih-search__results {
	margin-top: 12px;
	max-height: 52vh;
	overflow-y: auto;
	display: grid;
	gap: 4px;
}
.bl-ih-search__results > p {
	color: var(--bl-muted);
	font-size: 13px;
	padding: 8px 6px;
	margin: 0;
}

/* ---- Live-search results cards (shared) --------------------------- */
.bl-predictive-card {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 8px;
	border-radius: 6px;
	text-decoration: none;
	color: var(--bl-fg);
}
.bl-predictive-card:hover { background: var(--bl-surface); }
.bl-predictive-card img {
	width: 48px; height: 48px;
	object-fit: cover;
	border-radius: 4px;
	background: var(--bl-surface);
	flex: 0 0 auto;
}
.bl-predictive-card span { display: grid; gap: 2px; }
.bl-predictive-card strong { font-size: 14px; font-weight: 600; line-height: 1.2; }
.bl-predictive-card em {
	font-style: normal;
	font-family: var(--bl-mono);
	font-size: 11px;
	color: var(--bl-muted);
}

/* ---- Contact form ------------------------------------------------- */
.bl-contact-form {
	max-width: 640px;
	margin: 8px 0 8px;
	display: grid;
	gap: 16px;
}
.bl-contact-form .bl-contact-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
}
.bl-contact-form label {
	display: grid;
	gap: 7px;
	font-family: var(--bl-mono);
	font-size: 11px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--bl-muted);
}
.bl-contact-form input,
.bl-contact-form textarea {
	background: #fff;
	border: 1px solid var(--bl-bg-3);
	border-radius: 3px;
	color: var(--bl-fg);
	font: 400 15px/1.5 var(--bl-body);
	padding: 12px 14px;
	text-transform: none;
	letter-spacing: 0;
}
.bl-contact-form input:focus,
.bl-contact-form textarea:focus {
	outline: none;
	border-color: var(--bl-accent);
	box-shadow: 0 0 0 3px rgba(217, 89, 31, 0.12);
}
.bl-contact-form textarea { resize: vertical; }
/* honeypot: keep it in the DOM but out of sight of humans */
.bl-contact-form .bl-hp {
	position: absolute !important;
	left: -9999px !important;
	width: 1px; height: 1px; overflow: hidden;
}
.bl-contact-submit {
	justify-self: start;
	background: var(--bl-accent) !important;
	color: var(--bl-accent-fg) !important;
	border: none;
	border-radius: 3px;
	font-family: var(--bl-mono);
	font-size: 12px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	padding: 14px 28px;
	cursor: pointer;
	transition: transform 0.15s ease, background 0.15s ease;
}
.bl-contact-submit:hover { transform: translateY(-1px); background: var(--bl-accent-2) !important; }
.bl-contact-note {
	padding: 12px 16px;
	border-radius: 3px;
	font-size: 14px;
	margin: 0;
}
.bl-contact-note--ok  { background: #eaf6ec; border: 1px solid #b6ddbf; color: #1f5b2c; }
.bl-contact-note--err { background: #fbecec; border: 1px solid #e4b5b5; color: #8a2b2b; }
@media (max-width: 560px) {
	.bl-contact-form .bl-contact-row { grid-template-columns: 1fr; }
}

/* ---- Footer legal links (inner pages, above dark Astra footer) ----- */
.bl-footer-legal-bar {
	background: var(--bl-ink-panel);
	border-top: 1px solid rgba(245, 241, 232, 0.08);
	padding: 20px var(--bl-pad, 24px);
}
.bl-footer-legal {
	list-style: none;
	margin: 0 auto;
	padding: 0;
	max-width: var(--bl-container);
	display: flex;
	flex-wrap: wrap;
	gap: 8px 26px;
	justify-content: center;
}
.bl-footer-legal li { margin: 0; }
.bl-footer-legal a {
	color: #ded7ca !important;
	font-family: var(--bl-body);
	font-weight: 600;
	font-size: 13px;
	letter-spacing: 0.03em;
	text-transform: uppercase;
}
.bl-footer-legal a:hover { color: var(--bl-accent) !important; }

/* Same admin-only "Coming soon" banner clearance as the homepage — see
   homepage-bridge.css §14 for the full explanation. Applied ONLY to
   #colophon (the actual last element before the fixed banner) — a
   previous version mistakenly also added it to .bl-footer-legal-bar,
   which inserted a second, pointless empty gap ABOVE the real footer. */
body:has(#coming-soon-footer-banner) #colophon {
	margin-bottom: 90px;
}

/* ---- Size guide (T-shirt products) -------------------------------- */
.bl-size-guide-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin: 4px 0 18px;
	padding: 9px 14px;
	background: transparent;
	border: 1px solid var(--bl-bg-3);
	border-radius: 3px;
	color: var(--bl-fg-2);
	font-family: var(--bl-mono);
	font-size: 11px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	cursor: pointer;
	transition: border-color 0.2s ease, color 0.2s ease;
}
.bl-size-guide-btn:hover { border-color: var(--bl-accent); color: var(--bl-accent); }
.bl-size-guide-btn svg { width: 16px; height: 16px; }

.bl-size-guide {
	width: min(560px, 92vw);
	max-width: 560px;
	border: none;
	border-radius: 12px;
	padding: 0;
	background: var(--bl-bg-2);
	color: var(--bl-fg);
	box-shadow: 0 40px 120px -30px rgba(0, 0, 0, 0.55);
}
.bl-size-guide::backdrop { background: rgba(23, 19, 15, 0.55); backdrop-filter: blur(3px); }
.bl-size-guide__panel { padding: 22px 22px 8px; }
.bl-size-guide__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 14px;
}
.bl-size-guide__head h3 {
	font-family: var(--bl-display);
	text-transform: uppercase;
	font-size: 24px;
	color: var(--bl-fg);
	margin: 0;
}
.bl-size-guide__close {
	display: inline-flex;
	width: 30px; height: 30px;
	align-items: center; justify-content: center;
	background: transparent;
	border: 1px solid var(--bl-bg-3);
	border-radius: 50%;
	color: var(--bl-fg-2);
	cursor: pointer;
}
.bl-size-guide__close:hover { border-color: var(--bl-accent); color: var(--bl-accent); }
.bl-size-guide__close svg { width: 16px; height: 16px; }
.bl-size-guide__scroll { overflow-x: auto; }
.bl-size-guide__table {
	width: 100%;
	border-collapse: collapse;
	font-size: 14px;
}
.bl-size-guide__table thead th {
	font-family: var(--bl-mono);
	text-transform: uppercase;
	font-size: 10px;
	letter-spacing: 0.08em;
	color: var(--bl-muted);
	text-align: left;
	padding: 10px 12px;
	border-bottom: 1px solid var(--bl-bg-3);
}
.bl-size-guide__table tbody th,
.bl-size-guide__table tbody td {
	padding: 11px 12px;
	border-bottom: 1px solid var(--bl-bg-3);
	color: var(--bl-fg-2);
	text-align: left;
}
.bl-size-guide__table tbody th {
	font-family: var(--bl-mono);
	font-weight: 700;
	color: var(--bl-accent);
}
.bl-size-guide__table tbody tr:last-child th,
.bl-size-guide__table tbody tr:last-child td { border-bottom: none; }
.bl-size-guide__note {
	font-size: 11px;
	color: var(--bl-muted);
	margin: 12px 2px 0;
}
.bl-size-guide__footer {
	display: flex;
	justify-content: flex-end;
	padding: 14px 22px 20px;
}
.bl-size-guide__done {
	background: var(--bl-accent) !important;
	color: var(--bl-accent-fg) !important;
	border: none;
	border-radius: 3px;
	font-family: var(--bl-mono);
	font-size: 11px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	padding: 11px 20px;
	cursor: pointer;
}
