/* ============================================================
 * NB E-Commerce — Shop archive, single product, my account,
 *                 and size guide modal styles.
 *
 * Loaded only on /shop/, /product/*, /my-account/*, /cart/, and
 * /checkout/ pages. Aesthetic match with the rest of the site
 * (Atelier × Witchy: midnight + parchment + candle gold + wine).
 * ============================================================ */


/* ─────────────────────────────────────────────────────────────────
 * 1. SHOP ARCHIVE — Editorial grid
 * ───────────────────────────────────────────────────────────── */

body.post-type-archive-product main.site-main,
body.tax-product_cat main.site-main,
body.tax-product_tag main.site-main {
	background: var(--night);
	color: var(--parchment);
	max-width: none !important;
	width: 100% !important;
	padding: 0 !important;
}

body.post-type-archive-product .woocommerce,
body.tax-product_cat .woocommerce,
body.tax-product_tag .woocommerce {
	max-width: 1320px;
	margin: 0 auto;
	padding: 56px clamp(20px, 4vw, 56px) 96px;
	color: var(--parchment);
}

/* Page header (replaces WC's default page title) */
body.post-type-archive-product .page-title,
body.tax-product_cat .page-title {
	font-family: 'Cinzel', serif !important;
	font-weight: 400 !important;
	font-size: clamp(2.4rem, 5vw, 3.6rem) !important;
	line-height: 1.1 !important;
	color: var(--parchment) !important;
	margin: 0 0 12px !important;
	padding: 0 !important;
	border: 0 !important;
	text-align: left !important;
}

/* Result count + sort dropdown row */
.woocommerce-result-count,
.woocommerce-ordering {
	font-family: 'EB Garamond', serif;
	font-style: italic;
	font-size: 14px;
	color: var(--parchment-dim);
	margin: 0 0 32px;
}
.woocommerce-ordering select {
	background: var(--night-soft) !important;
	color: var(--parchment) !important;
	border: 1px solid var(--rule) !important;
	padding: 8px 14px !important;
	font-family: 'EB Garamond', serif !important;
	font-size: 14px !important;
}

/* The product grid */
ul.products {
	display: grid !important;
	grid-template-columns: repeat(3, 1fr) !important;
	gap: 48px 32px !important;
	list-style: none !important;
	padding: 0 !important;
	margin: 24px 0 0 !important;
}
ul.products::before, ul.products::after { display: none !important; }

ul.products li.product {
	width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
	float: none !important;
	clear: none !important;
	background: transparent;
	border: 0;
	display: flex;
	flex-direction: column;
	gap: 14px;
}

ul.products li.product a:not(.button):not(.add_to_cart_button) {
	color: var(--parchment);
	text-decoration: none;
	display: flex;
	flex-direction: column;
	gap: 10px;
}

ul.products li.product .woocommerce-loop-product__link,
ul.products li.product a.woocommerce-LoopProduct-link {
	display: block;
	overflow: hidden;
	background: var(--night-soft);
	aspect-ratio: 4 / 5;
	position: relative;
}
ul.products li.product img {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover !important;
	margin: 0 !important;
	transition: transform 0.5s ease;
	display: block;
}
ul.products li.product:hover img {
	transform: scale(1.04);
}

/* Product title in editorial italic */
ul.products li.product .nb-product-title,
ul.products li.product h2.woocommerce-loop-product__title {
	font-family: 'EB Garamond', serif !important;
	font-style: italic !important;
	font-weight: 500 !important;
	font-size: 20px !important;
	line-height: 1.25 !important;
	color: var(--parchment) !important;
	margin: 14px 0 4px !important;
	padding: 0 !important;
	transition: color 0.2s;
}
ul.products li.product:hover .nb-product-title,
ul.products li.product:hover h2.woocommerce-loop-product__title {
	color: var(--candle) !important;
}

/* Price in Cinzel candle-gold */
ul.products li.product .price,
ul.products li.product span.price {
	font-family: 'Cinzel', serif !important;
	font-weight: 500 !important;
	font-size: 16px !important;
	letter-spacing: 0.04em !important;
	color: var(--candle) !important;
	margin: 0 0 4px !important;
	display: block !important;
}
ul.products li.product .price del {
	color: var(--parchment-dim) !important;
	font-size: 14px !important;
	margin-right: 8px;
	font-weight: 400;
}
ul.products li.product .price ins {
	background: transparent !important;
	color: var(--candle) !important;
	text-decoration: none !important;
}

/* Add to cart button — make it look like our .cta */
ul.products li.product .button,
ul.products li.product .add_to_cart_button,
ul.products li.product a.added_to_cart {
	font-family: 'Cinzel', serif !important;
	font-weight: 500 !important;
	font-size: 11px !important;
	letter-spacing: 0.22em !important;
	text-transform: uppercase !important;
	background: transparent !important;
	color: var(--candle) !important;
	border: 1px solid var(--candle) !important;
	border-radius: 0 !important;
	padding: 12px 18px !important;
	margin: 6px 0 0 !important;
	text-decoration: none !important;
	text-align: center;
	display: inline-block;
	align-self: flex-start;
	cursor: pointer;
	transition: background 0.2s, color 0.2s;
}
ul.products li.product .button:hover,
ul.products li.product .add_to_cart_button:hover,
ul.products li.product a.added_to_cart:hover {
	background: var(--candle) !important;
	color: var(--night) !important;
}
ul.products li.product .added_to_cart {
	margin-left: 8px !important;
	font-size: 11px !important;
}

/* Stock urgency on cards */
.nb-stock-urgency {
	font-family: 'Cinzel', serif !important;
	font-weight: 500;
	font-size: 11px !important;
	letter-spacing: 0.18em !important;
	text-transform: uppercase;
	color: var(--wine, #8b3a2a) !important;
	margin: 0 !important;
	display: flex;
	align-items: center;
	gap: 6px;
}
.nb-stock-urgency .nb-stock-glyph {
	color: var(--candle);
	font-size: 10px;
}

/* Out of stock state */
ul.products li.product.outofstock .price,
ul.products li.product.outofstock .nb-product-title {
	opacity: 0.5;
}

/* Pagination */
.woocommerce-pagination {
	margin: 56px 0 0 !important;
	text-align: center;
}
.woocommerce-pagination ul.page-numbers {
	border: 0 !important;
	display: inline-flex;
	gap: 4px;
}
.woocommerce-pagination ul.page-numbers li {
	border: 0 !important;
	margin: 0;
}
.woocommerce-pagination .page-numbers {
	font-family: 'Cinzel', serif !important;
	font-weight: 500 !important;
	font-size: 13px !important;
	letter-spacing: 0.14em !important;
	color: var(--parchment) !important;
	background: var(--night-soft) !important;
	border: 1px solid var(--rule) !important;
	padding: 10px 14px !important;
	min-width: 40px;
	text-align: center;
	text-decoration: none;
}
.woocommerce-pagination .page-numbers:hover {
	border-color: var(--candle) !important;
	color: var(--candle) !important;
}
.woocommerce-pagination .page-numbers.current {
	background: var(--candle) !important;
	color: var(--night) !important;
	border-color: var(--candle) !important;
}


@media (max-width: 1000px) {
	ul.products {
		grid-template-columns: repeat(2, 1fr) !important;
		gap: 36px 24px !important;
	}
}
@media (max-width: 600px) {
	ul.products {
		grid-template-columns: 1fr !important;
		gap: 32px !important;
	}
}


/* ─────────────────────────────────────────────────────────────────
 * 2. SINGLE PRODUCT
 * ───────────────────────────────────────────────────────────── */

body.single-product main.site-main {
	background: var(--night);
	color: var(--parchment);
	max-width: none !important;
	width: 100% !important;
	padding: 0 !important;
}

body.single-product .woocommerce {
	max-width: 1320px;
	margin: 0 auto;
	padding: 56px clamp(20px, 4vw, 56px) 96px;
	color: var(--parchment);
}

/* Two-column product layout */
body.single-product .product {
	display: grid !important;
	grid-template-columns: 1fr 1fr !important;
	gap: 64px !important;
	align-items: start;
}
body.single-product .product .woocommerce-product-gallery {
	grid-column: 1;
	width: 100% !important;
	float: none !important;
}
body.single-product .product .summary {
	grid-column: 2;
	width: 100% !important;
	float: none !important;
	margin: 0 !important;
}
body.single-product .product .woocommerce-tabs,
body.single-product .product .related,
body.single-product .product .upsells {
	grid-column: 1 / -1;
	width: 100%;
	margin-top: 64px;
}

@media (max-width: 900px) {
	body.single-product .product {
		grid-template-columns: 1fr !important;
		gap: 32px !important;
	}
	body.single-product .product .woocommerce-product-gallery,
	body.single-product .product .summary {
		grid-column: 1;
	}
}

/* Gallery */
.woocommerce-product-gallery {
	background: var(--night-soft);
	padding: 0;
}
.woocommerce-product-gallery__image img {
	width: 100% !important;
	height: auto !important;
	display: block;
}
.flex-control-thumbs {
	display: grid !important;
	grid-template-columns: repeat(4, 1fr) !important;
	gap: 8px !important;
	list-style: none !important;
	padding: 8px !important;
	margin: 0 !important;
}
.flex-control-thumbs li {
	width: auto !important;
	margin: 0 !important;
	cursor: pointer;
}
.flex-control-thumbs img {
	width: 100% !important;
	height: auto !important;
	opacity: 0.6;
	transition: opacity 0.2s;
}
.flex-control-thumbs img.flex-active,
.flex-control-thumbs img:hover {
	opacity: 1;
}

/* Title */
body.single-product .product_title {
	font-family: 'Cinzel', serif !important;
	font-weight: 400 !important;
	font-size: clamp(1.8rem, 3.5vw, 2.8rem) !important;
	line-height: 1.1 !important;
	color: var(--parchment) !important;
	margin: 0 0 14px !important;
	padding: 0 !important;
}

/* Price */
body.single-product .summary .price,
body.single-product .summary p.price {
	font-family: 'Cinzel', serif !important;
	font-weight: 500 !important;
	font-size: 1.6rem !important;
	letter-spacing: 0.04em !important;
	color: var(--candle) !important;
	margin: 0 0 24px !important;
	padding-bottom: 24px !important;
	border-bottom: 1px solid var(--rule) !important;
}
body.single-product .summary .price del {
	color: var(--parchment-dim) !important;
	font-size: 1.1rem !important;
	margin-right: 12px;
	font-weight: 400;
}
body.single-product .summary .price ins {
	background: transparent !important;
	color: var(--candle) !important;
	text-decoration: none !important;
}

/* Short description */
body.single-product .woocommerce-product-details__short-description {
	font-family: 'EB Garamond', serif;
	font-size: 17px;
	line-height: 1.6;
	color: var(--parchment);
	margin-bottom: 28px;
}
body.single-product .woocommerce-product-details__short-description p {
	margin: 0 0 0.85em;
}

/* Variations table */
body.single-product table.variations {
	border: 0 !important;
	background: transparent !important;
	margin: 0 0 20px !important;
	width: 100%;
}
body.single-product table.variations tr {
	display: block;
	margin-bottom: 16px;
}
body.single-product table.variations td.label,
body.single-product table.variations th.label {
	display: block !important;
	background: transparent !important;
	border: 0 !important;
	padding: 0 0 8px !important;
	font-family: 'Cinzel', serif !important;
	font-weight: 500;
	font-size: 11px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--parchment);
}
body.single-product table.variations td.label label {
	margin: 0;
	color: var(--parchment);
}
body.single-product table.variations td.value,
body.single-product table.variations td {
	display: block !important;
	background: transparent !important;
	border: 0 !important;
	padding: 0 !important;
}
body.single-product table.variations select {
	width: 100% !important;
	font-family: 'EB Garamond', serif !important;
	font-size: 17px !important;
	color: var(--parchment) !important;
	background: var(--night-soft) !important;
	border: 1px solid var(--rule) !important;
	padding: 12px 14px !important;
	border-radius: 0 !important;
	height: auto !important;
}
body.single-product .reset_variations {
	font-family: 'EB Garamond', serif !important;
	font-style: italic;
	font-size: 13px !important;
	color: var(--parchment-dim) !important;
	margin: 6px 0 0 !important;
	display: inline-block;
}

/* Single variation price (appears after selection) */
body.single-product .single_variation .price {
	font-family: 'Cinzel', serif !important;
	font-weight: 500 !important;
	font-size: 1.4rem !important;
	color: var(--candle) !important;
	margin: 0 0 16px !important;
}
body.single-product .stock {
	font-family: 'EB Garamond', serif !important;
	font-style: italic !important;
	font-size: 14px !important;
	color: var(--parchment-dim) !important;
	margin: 8px 0 16px !important;
}
body.single-product .stock.in-stock {
	color: var(--candle) !important;
}
body.single-product .stock.out-of-stock {
	color: var(--wine) !important;
}

/* Quantity input */
body.single-product .quantity {
	display: inline-flex;
	align-items: stretch;
	margin-right: 12px !important;
}
body.single-product .quantity input.qty {
	width: 70px !important;
	height: 50px !important;
	text-align: center !important;
	font-family: 'EB Garamond', serif !important;
	font-size: 16px !important;
	background: var(--night-soft) !important;
	color: var(--parchment) !important;
	border: 1px solid var(--rule) !important;
	border-radius: 0 !important;
	box-shadow: none !important;
}

/* Add to cart button */
body.single-product .single_add_to_cart_button,
body.single-product button.alt {
	font-family: 'Cinzel', serif !important;
	font-weight: 600 !important;
	font-size: 13px !important;
	letter-spacing: 0.22em !important;
	text-transform: uppercase !important;
	background: var(--candle) !important;
	color: var(--night) !important;
	border: 0 !important;
	border-radius: 0 !important;
	padding: 16px 28px !important;
	height: 50px;
	cursor: pointer;
	transition: background 0.2s;
	box-shadow: none !important;
	text-shadow: none !important;
}
body.single-product .single_add_to_cart_button:hover,
body.single-product button.alt:hover {
	background: #e6b56a !important;
}
body.single-product .single_add_to_cart_button:disabled {
	background: var(--rule) !important;
	color: var(--parchment-dim) !important;
	cursor: not-allowed;
}

/* Product meta (sku, categories) */
body.single-product .product_meta {
	margin: 28px 0 0 !important;
	padding: 20px 0 0 !important;
	border-top: 1px solid var(--rule) !important;
	font-family: 'EB Garamond', serif;
	font-size: 13px;
	color: var(--parchment-dim);
}
body.single-product .product_meta > span {
	display: block;
	margin-bottom: 6px;
}
body.single-product .product_meta a {
	color: var(--candle);
	text-decoration: none;
}
body.single-product .product_meta a:hover {
	text-decoration: underline;
}

/* Tabs (description, additional info, reviews) */
body.single-product .woocommerce-tabs ul.tabs {
	display: flex;
	gap: 0;
	border: 0 !important;
	border-bottom: 1px solid var(--rule) !important;
	padding: 0 !important;
	margin: 0 0 24px !important;
}
body.single-product .woocommerce-tabs ul.tabs::before {
	display: none !important;
}
body.single-product .woocommerce-tabs ul.tabs li {
	background: transparent !important;
	border: 0 !important;
	border-radius: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
}
body.single-product .woocommerce-tabs ul.tabs li::before,
body.single-product .woocommerce-tabs ul.tabs li::after {
	display: none !important;
}
body.single-product .woocommerce-tabs ul.tabs li a {
	font-family: 'Cinzel', serif !important;
	font-weight: 500 !important;
	font-size: 12px !important;
	letter-spacing: 0.22em !important;
	text-transform: uppercase !important;
	color: var(--parchment-dim) !important;
	padding: 16px 24px !important;
	display: block;
	border-bottom: 2px solid transparent !important;
	margin-bottom: -1px;
	text-decoration: none;
}
body.single-product .woocommerce-tabs ul.tabs li.active a,
body.single-product .woocommerce-tabs ul.tabs li a:hover {
	color: var(--candle) !important;
	border-bottom-color: var(--candle) !important;
}
body.single-product .woocommerce-tabs .panel {
	font-family: 'EB Garamond', serif;
	font-size: 17px;
	line-height: 1.65;
	color: var(--parchment);
	background: transparent;
	padding: 0;
}
body.single-product .woocommerce-tabs .panel h2 {
	font-family: 'Cinzel', serif !important;
	font-weight: 400 !important;
	font-size: 1.4rem !important;
	color: var(--parchment) !important;
	margin: 0 0 16px !important;
}

/* Related / upsells section */
body.single-product .related h2,
body.single-product .upsells h2 {
	font-family: 'Cinzel', serif !important;
	font-weight: 400 !important;
	font-size: 1.6rem !important;
	color: var(--parchment) !important;
	margin: 0 0 24px !important;
	padding-bottom: 14px !important;
	border-bottom: 1px solid var(--rule) !important;
}


/* ─────────────────────────────────────────────────────────────────
 * 3. SIZE GUIDE — modal + trigger
 * ───────────────────────────────────────────────────────────── */

.nb-size-guide-trigger {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-family: 'Cinzel', serif;
	font-weight: 500;
	font-size: 11px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--candle);
	background: transparent;
	border: 0;
	padding: 6px 0;
	margin: 4px 0 12px;
	cursor: pointer;
	text-decoration: underline;
	text-underline-offset: 4px;
}
.nb-size-guide-trigger:hover {
	color: #e6b56a;
}
.nb-size-guide-glyph {
	font-size: 9px;
	color: var(--candle);
}

.nb-size-guide-overlay {
	position: fixed;
	inset: 0;
	background: rgba(14, 8, 20, 0.8);
	backdrop-filter: blur(4px);
	z-index: 99999;
	display: none;
	align-items: center;
	justify-content: center;
	padding: 24px;
}
.nb-size-guide-overlay.is-open {
	display: flex;
}
.nb-size-guide-modal {
	background: var(--night-soft);
	border: 1px solid var(--candle);
	max-width: 760px;
	width: 100%;
	max-height: 90vh;
	overflow-y: auto;
	padding: 36px 36px 32px;
	position: relative;
	color: var(--parchment);
}
.nb-size-guide-close {
	position: absolute;
	top: 16px;
	right: 20px;
	background: transparent;
	border: 0;
	font-size: 32px;
	color: var(--parchment-dim);
	cursor: pointer;
	padding: 4px 8px;
	line-height: 1;
}
.nb-size-guide-close:hover {
	color: var(--candle);
}
.nb-size-guide-header {
	margin-bottom: 24px;
	padding-right: 40px;
}
.nb-size-guide-header .eyebrow {
	display: block;
	margin-bottom: 8px;
}
.nb-size-guide-title {
	font-family: 'Cinzel', serif !important;
	font-weight: 400;
	font-size: clamp(1.4rem, 3vw, 1.8rem);
	line-height: 1.1;
	color: var(--parchment);
	margin: 0 0 10px;
}
.nb-size-guide-intro {
	font-family: 'EB Garamond', serif;
	font-size: 15px;
	line-height: 1.55;
	color: var(--parchment-dim);
	margin: 0;
}

.nb-size-guide-tabs {
	display: flex;
	gap: 0;
	border-bottom: 1px solid var(--rule);
	margin: 0 0 24px;
}
.nb-size-tab {
	background: transparent;
	border: 0;
	font-family: 'Cinzel', serif;
	font-weight: 500;
	font-size: 11px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--parchment-dim);
	padding: 14px 20px;
	cursor: pointer;
	border-bottom: 2px solid transparent;
	margin-bottom: -1px;
	transition: color 0.2s, border-color 0.2s;
}
.nb-size-tab.is-active,
.nb-size-tab:hover {
	color: var(--candle);
	border-bottom-color: var(--candle);
}

.nb-size-panel {
	display: none;
}
.nb-size-panel.is-active {
	display: block;
}

.nb-size-table {
	width: 100%;
	border-collapse: collapse;
	margin: 0 0 16px;
	background: transparent;
}
.nb-size-table th {
	font-family: 'Cinzel', serif !important;
	font-weight: 500;
	font-size: 11px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--parchment-dim);
	padding: 12px 8px;
	text-align: left;
	border-bottom: 1px solid var(--candle);
}
.nb-size-table td {
	font-family: 'EB Garamond', serif;
	font-size: 16px;
	color: var(--parchment);
	padding: 10px 8px;
	border-bottom: 1px solid var(--rule-soft);
}
.nb-size-table tr:hover td {
	background: rgba(212, 160, 86, 0.05);
}
.nb-size-table td:first-child {
	font-family: 'Cinzel', serif !important;
	font-weight: 500;
	color: var(--candle);
	font-size: 14px;
	letter-spacing: 0.06em;
}

.nb-size-fit-note {
	font-family: 'EB Garamond', serif;
	font-size: 13px;
	color: var(--parchment-dim);
	margin: 12px 0 0;
}

.nb-measure-guide {
	margin: 0;
}
.nb-measure-guide dt {
	font-family: 'Cinzel', serif !important;
	font-weight: 500;
	font-size: 12px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--candle);
	margin: 16px 0 6px;
}
.nb-measure-guide dt:first-child {
	margin-top: 0;
}
.nb-measure-guide dd {
	font-family: 'EB Garamond', serif;
	font-size: 16px;
	line-height: 1.55;
	color: var(--parchment);
	margin: 0 0 12px;
	padding: 0;
}

@media (max-width: 600px) {
	.nb-size-guide-modal {
		padding: 28px 22px 24px;
	}
	.nb-size-guide-tabs {
		overflow-x: auto;
	}
	.nb-size-tab {
		padding: 12px 14px;
		font-size: 10px;
		letter-spacing: 0.16em;
		flex-shrink: 0;
	}
	.nb-size-table th,
	.nb-size-table td {
		padding: 8px 4px;
		font-size: 13px;
	}
}


/* ─────────────────────────────────────────────────────────────────
 * 4. MY ACCOUNT
 * ───────────────────────────────────────────────────────────── */

body.woocommerce-account main.site-main {
	background: var(--night);
	color: var(--parchment);
	max-width: none !important;
	width: 100% !important;
	padding: 0 !important;
}
body.woocommerce-account .woocommerce {
	max-width: 1320px;
	margin: 0 auto;
	padding: 56px clamp(20px, 4vw, 56px) 96px;
	color: var(--parchment);
}

body.woocommerce-account .woocommerce-MyAccount-navigation {
	background: var(--night-soft);
	border: 1px solid var(--rule);
	padding: 24px;
	float: none !important;
	width: 22% !important;
	display: inline-block;
	vertical-align: top;
	margin-right: 4%;
}
body.woocommerce-account .woocommerce-MyAccount-navigation ul {
	list-style: none;
	margin: 0;
	padding: 0;
}
body.woocommerce-account .woocommerce-MyAccount-navigation ul li {
	margin: 0;
	padding: 0;
	border-bottom: 1px solid var(--rule-soft);
}
body.woocommerce-account .woocommerce-MyAccount-navigation ul li:last-child {
	border-bottom: 0;
}
body.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
	display: block;
	font-family: 'Cinzel', serif !important;
	font-weight: 500;
	font-size: 11px !important;
	letter-spacing: 0.18em !important;
	text-transform: uppercase;
	color: var(--parchment) !important;
	padding: 14px 0 !important;
	text-decoration: none;
	transition: color 0.2s;
}
body.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover,
body.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a {
	color: var(--candle) !important;
}
body.woocommerce-account .woocommerce-MyAccount-content {
	width: 74% !important;
	display: inline-block;
	vertical-align: top;
}
body.woocommerce-account .woocommerce-MyAccount-content h2,
body.woocommerce-account .woocommerce-MyAccount-content h3 {
	font-family: 'Cinzel', serif !important;
	font-weight: 400 !important;
	font-size: 1.6rem !important;
	color: var(--parchment) !important;
	margin: 0 0 22px !important;
	padding-bottom: 12px !important;
	border-bottom: 1px solid var(--rule) !important;
}
body.woocommerce-account .woocommerce-MyAccount-content h2:not(:first-child) {
	margin-top: 36px !important;
}
body.woocommerce-account .woocommerce-MyAccount-content p {
	font-family: 'EB Garamond', serif;
	font-size: 17px;
	line-height: 1.6;
	color: var(--parchment);
}
body.woocommerce-account .woocommerce-MyAccount-content a {
	color: var(--candle);
}

/* Order list table */
body.woocommerce-account .woocommerce-orders-table,
body.woocommerce-account .my_account_orders {
	width: 100% !important;
	border-collapse: collapse !important;
	background: transparent !important;
}
body.woocommerce-account .woocommerce-orders-table th {
	font-family: 'Cinzel', serif !important;
	font-weight: 500;
	font-size: 10px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--parchment-dim) !important;
	background: transparent !important;
	padding: 12px 8px;
	border-bottom: 1px solid var(--rule);
	text-align: left;
}
body.woocommerce-account .woocommerce-orders-table td {
	font-family: 'EB Garamond', serif;
	font-size: 15px;
	color: var(--parchment) !important;
	background: transparent !important;
	padding: 14px 8px;
	border-bottom: 1px solid var(--rule-soft);
}
body.woocommerce-account .woocommerce-orders-table .button {
	font-family: 'Cinzel', serif !important;
	font-weight: 500 !important;
	font-size: 10px !important;
	letter-spacing: 0.18em !important;
	text-transform: uppercase !important;
	background: transparent !important;
	color: var(--candle) !important;
	border: 1px solid var(--candle) !important;
	border-radius: 0 !important;
	padding: 8px 12px !important;
	margin: 0 4px 0 0 !important;
}
body.woocommerce-account .woocommerce-orders-table .button:hover {
	background: var(--candle) !important;
	color: var(--night) !important;
}

/* Login / Register form */
body.woocommerce-account .u-columns,
body.woocommerce-account .col2-set,
body.woocommerce-account .woocommerce > .u-columns {
	display: grid !important;
	grid-template-columns: 1fr 1fr;
	gap: 56px;
}
body.woocommerce-account .u-columns .col-1,
body.woocommerce-account .u-columns .col-2,
body.woocommerce-account .col2-set .col-1,
body.woocommerce-account .col2-set .col-2 {
	float: none !important;
	width: 100% !important;
	max-width: 100% !important;
	padding: 0 !important;
}
body.woocommerce-account .login,
body.woocommerce-account .register {
	background: var(--night-soft);
	border: 1px solid var(--rule);
	padding: 32px;
	margin: 0 !important;
}
body.woocommerce-account .login .button,
body.woocommerce-account .register .button {
	font-family: 'Cinzel', serif !important;
	font-weight: 600 !important;
	font-size: 13px !important;
	letter-spacing: 0.22em !important;
	text-transform: uppercase !important;
	background: var(--candle) !important;
	color: var(--night) !important;
	border: 0 !important;
	border-radius: 0 !important;
	padding: 14px 24px !important;
	cursor: pointer;
}
body.woocommerce-account .login .button:hover,
body.woocommerce-account .register .button:hover {
	background: #e6b56a !important;
}
body.woocommerce-account .lost_password a {
	font-family: 'EB Garamond', serif;
	font-style: italic;
	color: var(--candle);
}

@media (max-width: 800px) {
	body.woocommerce-account .woocommerce-MyAccount-navigation,
	body.woocommerce-account .woocommerce-MyAccount-content {
		width: 100% !important;
		display: block;
		margin-right: 0;
	}
	body.woocommerce-account .woocommerce-MyAccount-navigation {
		margin-bottom: 24px;
	}
	body.woocommerce-account .u-columns,
	body.woocommerce-account .col2-set {
		grid-template-columns: 1fr !important;
		gap: 24px !important;
	}
}

/* Address blocks */
body.woocommerce-account .woocommerce-Addresses {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 24px;
}
body.woocommerce-account .woocommerce-Address {
	background: var(--night-soft);
	border: 1px solid var(--rule);
	padding: 24px;
	width: 100% !important;
	float: none !important;
	margin: 0 !important;
}
body.woocommerce-account .woocommerce-Address-title h3 {
	margin: 0 0 12px !important;
	font-size: 1.2rem !important;
	border: 0 !important;
	padding: 0 !important;
}
body.woocommerce-account .woocommerce-Address-title .edit {
	font-family: 'Cinzel', serif !important;
	font-weight: 500;
	font-size: 10px !important;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--candle);
	text-decoration: none;
}
body.woocommerce-account .woocommerce-Address address {
	font-family: 'EB Garamond', serif;
	font-style: normal;
	font-size: 15px;
	line-height: 1.55;
	color: var(--parchment);
}

@media (max-width: 600px) {
	body.woocommerce-account .woocommerce-Addresses {
		grid-template-columns: 1fr;
	}
}
/* ============================================================
 * Phase 8.2 — Shop hero, category nav, card-style products.
 * Append to assets/css/woo-shop.css
 * ============================================================ */


/* ─────────────────────────────────────────────────────────────────
 * Shop hero (replaces default page title)
 * ───────────────────────────────────────────────────────────── */

.nb-shop-hero {
	text-align: center;
	margin: 0 auto 32px;
	padding: 16px 0 36px;
	border-bottom: 1px solid var(--rule);
	max-width: 780px;
}

.nb-shop-hero .eyebrow {
	display: block;
	margin-bottom: 12px;
	color: var(--candle);
	font-size: 11px;
	letter-spacing: 0.32em;
}

.nb-shop-hero-title {
	font-family: 'Cinzel', serif !important;
	font-weight: 400 !important;
	font-size: clamp(2.5rem, 6vw, 4rem) !important;
	line-height: 1.05 !important;
	color: var(--parchment) !important;
	margin: 0 0 14px !important;
	padding: 0 !important;
	border: 0 !important;
	letter-spacing: 0.005em;
}

.nb-shop-hero-blurb {
	font-family: 'EB Garamond', serif;
	font-style: italic;
	font-size: 18px;
	line-height: 1.5;
	color: var(--parchment-dim);
	max-width: 56ch;
	margin: 0 auto;
}

.nb-shop-hero.is-category .nb-shop-hero-title {
	font-size: clamp(2rem, 5vw, 3.2rem) !important;
}


/* ─────────────────────────────────────────────────────────────────
 * Category navigation pills
 * ───────────────────────────────────────────────────────────── */

.nb-shop-category-nav {
	margin: 0 0 36px;
	padding-bottom: 28px;
	border-bottom: 1px solid var(--rule);
}

.nb-shop-cats {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	justify-content: center;
}

.nb-shop-cat {
	margin: 0;
	padding: 0;
}

.nb-shop-cat a {
	display: inline-block;
	font-family: 'Cinzel', serif;
	font-weight: 500;
	font-size: 11px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--parchment);
	background: transparent;
	border: 1px solid var(--rule);
	padding: 12px 22px;
	text-decoration: none;
	transition: background 0.2s, color 0.2s, border-color 0.2s;
}

.nb-shop-cat a:hover {
	border-color: var(--candle);
	color: var(--candle);
}

.nb-shop-cat.is-active a {
	background: var(--candle);
	border-color: var(--candle);
	color: var(--night);
}

@media (max-width: 600px) {
	.nb-shop-cat a {
		padding: 10px 16px;
		font-size: 10px;
		letter-spacing: 0.16em;
	}
}


/* ─────────────────────────────────────────────────────────────────
 * Page-level result count + ordering — push down a bit, calmer style
 * ───────────────────────────────────────────────────────────── */

.woocommerce-result-count,
.woocommerce-ordering {
	margin-bottom: 32px !important;
}


/* ─────────────────────────────────────────────────────────────────
 * Card-style products (replaces minimalist version from Phase 8)
 *
 * Structure:
 *   <li.product>
 *     <a.woocommerce-loop-product__link>     ← image + title + price wrap
 *       <img>
 *       <h2.nb-product-title>
 *       <span.price>
 *     </a>
 *     <p.nb-stock-urgency>                    (optional)
 *     <a.add_to_cart_button>                  ← sibling button
 *   </li>
 * ───────────────────────────────────────────────────────────── */

ul.products {
	gap: 32px 28px !important;
}

ul.products li.product {
	background: var(--night-soft) !important;
	border: 1px solid var(--rule-soft) !important;
	border-radius: 0 !important;
	display: flex !important;
	flex-direction: column !important;
	gap: 0 !important;
	padding: 0 !important;
	overflow: hidden;
	position: relative;
	transition: border-color 0.3s ease, transform 0.3s ease, box-shadow 0.3s ease;
}

ul.products li.product:hover {
	border-color: var(--candle) !important;
	transform: translateY(-3px);
	box-shadow: 0 12px 32px -8px rgba(0, 0, 0, 0.5);
}

/* The wrapping <a> that contains image + title + price */
ul.products li.product > a.woocommerce-loop-product__link,
ul.products li.product > a.woocommerce-LoopProduct-link {
	display: flex !important;
	flex-direction: column;
	color: inherit !important;
	text-decoration: none !important;
	flex: 1 1 auto;
	padding: 0 !important;
	margin: 0 !important;
	background: transparent !important;
	aspect-ratio: auto !important;
}

/* Image — fills top of card */
ul.products li.product img,
ul.products li.product picture img,
ul.products li.product > a img {
	display: block !important;
	width: 100% !important;
	aspect-ratio: 4 / 5 !important;
	height: auto !important;
	object-fit: cover !important;
	margin: 0 !important;
	transition: transform 0.6s ease;
}

ul.products li.product:hover img {
	transform: scale(1.04);
}

/* Title with internal padding */
ul.products li.product .nb-product-title,
ul.products li.product h2.woocommerce-loop-product__title,
ul.products li.product h2.product_title {
	font-family: 'EB Garamond', serif !important;
	font-style: italic !important;
	font-weight: 500 !important;
	font-size: 21px !important;
	line-height: 1.25 !important;
	color: var(--parchment) !important;
	margin: 0 !important;
	padding: 22px 22px 6px !important;
	transition: color 0.2s;
}

ul.products li.product:hover .nb-product-title,
ul.products li.product:hover h2.woocommerce-loop-product__title {
	color: var(--candle) !important;
}

/* Price with internal padding */
ul.products li.product .price,
ul.products li.product span.price {
	display: block !important;
	font-family: 'Cinzel', serif !important;
	font-weight: 500 !important;
	font-size: 16px !important;
	letter-spacing: 0.06em !important;
	color: var(--candle) !important;
	margin: 0 !important;
	padding: 0 22px 18px !important;
}

ul.products li.product .price del {
	color: var(--parchment-dim) !important;
	font-size: 14px !important;
	margin-right: 8px;
	font-weight: 400 !important;
}
ul.products li.product .price ins {
	background: transparent !important;
	color: var(--candle) !important;
	text-decoration: none !important;
}

/* Stock urgency inside card */
ul.products li.product .nb-stock-urgency {
	margin: 0 !important;
	padding: 0 22px 16px !important;
}

/* Add to cart button — full-width inside card padding */
ul.products li.product > .button,
ul.products li.product > a.button,
ul.products li.product > .add_to_cart_button,
ul.products li.product > a.add_to_cart_button,
ul.products li.product > a.added_to_cart {
	display: block !important;
	margin: 0 22px 22px !important;
	width: auto !important;
	text-align: center !important;
	padding: 12px 18px !important;
	font-family: 'Cinzel', serif !important;
	font-weight: 500 !important;
	font-size: 11px !important;
	letter-spacing: 0.22em !important;
	text-transform: uppercase !important;
	background: transparent !important;
	color: var(--candle) !important;
	border: 1px solid var(--candle) !important;
	border-radius: 0 !important;
	text-decoration: none !important;
	transition: background 0.2s, color 0.2s;
	align-self: stretch;
}
ul.products li.product > .button:hover,
ul.products li.product > .add_to_cart_button:hover,
ul.products li.product > a.added_to_cart:hover {
	background: var(--candle) !important;
	color: var(--night) !important;
}

ul.products li.product > a.added_to_cart {
	margin-top: -10px !important;
}

/* Out-of-stock state */
ul.products li.product.outofstock {
	opacity: 0.6;
}
ul.products li.product.outofstock::after {
	content: 'Out of stock';
	position: absolute;
	top: 16px;
	right: 16px;
	background: var(--night);
	color: var(--parchment-dim);
	font-family: 'Cinzel', serif;
	font-weight: 500;
	font-size: 10px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	padding: 6px 10px;
	border: 1px solid var(--rule);
}


/* ─────────────────────────────────────────────────────────────────
 * Empty state — "No products were found"
 * ───────────────────────────────────────────────────────────── */

.woocommerce-info.woocommerce-no-products-found,
.woocommerce-info:not(.woocommerce-form-coupon-toggle .woocommerce-info):not(.woocommerce-form-login-toggle .woocommerce-info) {
	text-align: center;
	padding: 56px 32px;
	font-family: 'EB Garamond', serif;
	font-style: italic;
	font-size: 18px;
	color: var(--parchment-dim);
	background: var(--night-soft) !important;
	border: 1px dashed var(--rule) !important;
	border-left-width: 1px !important;
}
/* ============================================================
 * Phase 8.3 — AJAX shop filter loading state
 * Append to assets/css/woo-shop.css
 * ============================================================ */

[data-nb-shop-grid] {
	transition: opacity 200ms ease;
	min-height: 200px;
}

/* Scroll lockdown when category pill triggers a swap */
.nb-shop-category-nav a:focus {
	outline: 2px solid var(--candle);
	outline-offset: 2px;
}


/* === BEGIN nb-account-rebuild === */
/* Phase 9.6: rebuild the WC my-account two-column layout using CSS grid.
 * The earlier `display: inline-block` + percentage widths wasn't reliable
 * once Cinzel uppercase labels (with letter-spacing) widened the side
 * nav past 22%. Grid is the right tool here.
 *
 * This block has higher specificity / comes later than the earlier
 * `body.woocommerce-account .woocommerce` rules, so it wins on the
 * properties it touches without us having to delete anything. */

body.woocommerce-account .woocommerce {
	display: grid !important;
	grid-template-columns: 240px 1fr !important;
	gap: 56px !important;
	max-width: 1320px !important;
	margin: 0 auto !important;
	padding: 0 clamp(20px, 4vw, 56px) 96px !important;
	align-items: start;
}

/* Header spans both columns. */
body.woocommerce-account .woocommerce .nb-woo-page-header {
	grid-column: 1 / -1;
	margin-top: 56px;
}

/* Notices span both columns (so they don't squeeze into the side nav). */
body.woocommerce-account .woocommerce > .woocommerce-notices-wrapper,
body.woocommerce-account .woocommerce > .woocommerce-message,
body.woocommerce-account .woocommerce > .woocommerce-error,
body.woocommerce-account .woocommerce > .woocommerce-info {
	grid-column: 1 / -1;
}

body.woocommerce-account .woocommerce-MyAccount-navigation {
	display: block !important;
	width: auto !important;
	float: none !important;
	margin: 0 !important;
	padding: 22px !important;
}
body.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
	display: block !important;
	width: 100% !important;
	white-space: normal !important;
	word-break: keep-all;
	letter-spacing: 0.14em !important;
	font-size: 11px !important;
	line-height: 1.4;
}

body.woocommerce-account .woocommerce-MyAccount-content {
	display: block !important;
	width: auto !important;
	min-width: 0;
	margin: 0 !important;
}

/* On narrower viewports collapse to single column with the side nav stacked. */
@media (max-width: 900px) {
	body.woocommerce-account .woocommerce {
		grid-template-columns: 1fr !important;
		gap: 28px !important;
	}
	body.woocommerce-account .woocommerce-MyAccount-navigation {
		padding: 18px !important;
	}
	body.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
		font-size: 12px !important;
	}
}


/* ───── Login / register form (when logged out) ───── */
/* The login/register pair sits inside .woocommerce as a single column on
 * the my-account page when logged-out. Span both grid columns. */

body.woocommerce-account.logged-out .woocommerce > .u-columns,
body.woocommerce-account.logged-out .woocommerce > .col2-set,
body.woocommerce-account .woocommerce > form.login,
body.woocommerce-account .woocommerce > form.register {
	grid-column: 1 / -1;
}


/* ───── Buttons inside account content ───── */
/* Generic button styling so action buttons (Edit, Make default, View, etc)
 * match the rest of the site rather than WC's default. */

body.woocommerce-account .woocommerce-MyAccount-content .button:not(.checkout-button) {
	display: inline-block;
	padding: 10px 18px;
	background: transparent;
	border: 1px solid var(--candle);
	color: var(--candle);
	font-family: 'Cinzel', serif;
	font-weight: 500;
	font-size: 11px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	text-decoration: none;
	border-radius: 0;
	transition: background 0.2s ease, color 0.2s ease;
	cursor: pointer;
}
body.woocommerce-account .woocommerce-MyAccount-content .button:not(.checkout-button):hover {
	background: var(--candle);
	color: var(--night);
}

/* Primary submit buttons (Save changes, Login, Register) */
body.woocommerce-account .woocommerce-MyAccount-content button[type="submit"],
body.woocommerce-account form.login button[type="submit"],
body.woocommerce-account form.register button[type="submit"],
body.woocommerce-account .woocommerce-MyAccount-content .button.button-primary {
	display: inline-block;
	padding: 14px 24px;
	background: var(--candle);
	color: var(--night);
	border: 0;
	font-family: 'Cinzel', serif;
	font-weight: 600;
	font-size: 12px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	border-radius: 0;
	cursor: pointer;
	transition: background 0.2s ease;
}
body.woocommerce-account .woocommerce-MyAccount-content button[type="submit"]:hover,
body.woocommerce-account form.login button[type="submit"]:hover,
body.woocommerce-account form.register button[type="submit"]:hover {
	background: var(--candle-bright, #e6b56a);
}


/* ───── Subscriptions list (WC Subscriptions) ───── */

body.woocommerce-account .my_account_subscriptions,
body.woocommerce-account .woocommerce-orders-table--subscriptions {
	width: 100% !important;
	border-collapse: collapse !important;
	background: transparent !important;
}
body.woocommerce-account .my_account_subscriptions th,
body.woocommerce-account .woocommerce-orders-table--subscriptions th {
	font-family: 'Cinzel', serif !important;
	font-weight: 500;
	font-size: 10px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--parchment-dim) !important;
	background: transparent !important;
	padding: 12px 8px;
	border-bottom: 1px solid var(--rule);
	text-align: left;
}
body.woocommerce-account .my_account_subscriptions td,
body.woocommerce-account .woocommerce-orders-table--subscriptions td {
	font-family: 'EB Garamond', serif;
	font-size: 15px;
	color: var(--parchment) !important;
	background: transparent !important;
	padding: 14px 8px;
	border-bottom: 1px solid var(--rule-soft);
}
body.woocommerce-account .subscription-status,
body.woocommerce-account mark.subscription-status {
	display: inline-block;
	padding: 3px 10px;
	font-family: 'Cinzel', serif;
	font-size: 10px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	background: transparent !important;
	border: 1px solid var(--rule);
	color: var(--parchment-dim);
}
body.woocommerce-account .subscription-status.active,
body.woocommerce-account .subscription-status.status-active {
	border-color: var(--candle);
	color: var(--candle);
}
body.woocommerce-account .subscription-status.on-hold,
body.woocommerce-account .subscription-status.status-on-hold {
	border-color: var(--wine);
	color: var(--wine);
}

/* Subscription detail page */
body.woocommerce-account .subscription_details,
body.woocommerce-account .order_details {
	background: var(--night-soft);
	border: 1px solid var(--rule);
	padding: 24px !important;
	margin: 0 0 32px;
}


/* ───── Form rows (edit address, account details) ───── */

body.woocommerce-account .woocommerce-MyAccount-content form .form-row,
body.woocommerce-account .woocommerce-EditAccountForm .form-row {
	margin: 0 0 18px !important;
}
body.woocommerce-account .woocommerce-MyAccount-content form label,
body.woocommerce-account .woocommerce-EditAccountForm label {
	display: block;
	font-family: 'Cinzel', serif !important;
	font-weight: 500;
	font-size: 11px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--parchment-dim) !important;
	margin-bottom: 8px;
}
body.woocommerce-account .woocommerce-MyAccount-content form input[type="text"],
body.woocommerce-account .woocommerce-MyAccount-content form input[type="email"],
body.woocommerce-account .woocommerce-MyAccount-content form input[type="tel"],
body.woocommerce-account .woocommerce-MyAccount-content form input[type="password"],
body.woocommerce-account .woocommerce-MyAccount-content form select,
body.woocommerce-account .woocommerce-MyAccount-content form textarea,
body.woocommerce-account form.login input[type="text"],
body.woocommerce-account form.login input[type="email"],
body.woocommerce-account form.login input[type="password"],
body.woocommerce-account form.register input[type="text"],
body.woocommerce-account form.register input[type="email"],
body.woocommerce-account form.register input[type="password"] {
	width: 100%;
	padding: 12px 14px !important;
	background: var(--night) !important;
	border: 1px solid var(--rule) !important;
	color: var(--parchment) !important;
	font-family: 'EB Garamond', serif !important;
	font-size: 15px !important;
	border-radius: 0;
	box-sizing: border-box;
}
body.woocommerce-account .woocommerce-MyAccount-content form input:focus,
body.woocommerce-account .woocommerce-MyAccount-content form select:focus,
body.woocommerce-account .woocommerce-MyAccount-content form textarea:focus,
body.woocommerce-account form.login input:focus,
body.woocommerce-account form.register input:focus {
	border-color: var(--candle) !important;
	outline: none;
}


/* ───── Empty states ───── */

body.woocommerce-account .woocommerce-Message,
body.woocommerce-account .woocommerce-message,
body.woocommerce-account .woocommerce-info {
	background: var(--night-soft);
	border: 1px solid var(--rule);
	color: var(--parchment);
	padding: 18px 22px;
	font-family: 'EB Garamond', serif;
	font-size: 15px;
}

/* === END nb-account-rebuild === */


/* === BEGIN nb-account-cards === */
/* Phase 9.6.1: style the WC pages we missed in 9.6 — anything that
 * renders "card"-shaped boxes inside the my-account content area
 * (address book, subscription detail, order detail, order-received
 * overview, plus the dashboard intro). */


/* ───── Dashboard intro paragraphs ───── */

body.woocommerce-account .woocommerce-MyAccount-content > p:first-of-type,
body.woocommerce-account .woocommerce-MyAccount-content > .woocommerce-MyAccount-introduction {
	font-family: 'EB Garamond', serif;
	font-size: 17px;
	line-height: 1.6;
	color: var(--parchment);
	margin: 0 0 18px;
}
body.woocommerce-account .woocommerce-MyAccount-content > p strong {
	color: var(--candle);
}


/* ───── Address book — two-column card grid ───── */

body.woocommerce-account .woocommerce-Addresses,
body.woocommerce-account .woocommerce-Addresses.col2-set,
body.woocommerce-account .woocommerce-Addresses.u-columns {
	display: grid !important;
	grid-template-columns: repeat(2, 1fr) !important;
	gap: 24px !important;
	margin: 24px 0 0 !important;
}
@media (max-width: 700px) {
	body.woocommerce-account .woocommerce-Addresses {
		grid-template-columns: 1fr !important;
	}
}

body.woocommerce-account .woocommerce-Address {
	background: var(--night-soft);
	border: 1px solid var(--rule);
	padding: 24px 26px;
	float: none !important;
	width: auto !important;
	max-width: none !important;
	margin: 0 !important;
}
body.woocommerce-account .woocommerce-Address-title {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	margin: 0 0 14px !important;
	padding-bottom: 12px !important;
	border-bottom: 1px solid var(--rule) !important;
}
body.woocommerce-account .woocommerce-Address-title h2,
body.woocommerce-account .woocommerce-Address-title h3 {
	margin: 0 !important;
	padding: 0 !important;
	border: 0 !important;
	font-family: 'Cinzel', serif !important;
	font-size: 13px !important;
	font-weight: 500 !important;
	letter-spacing: 0.18em !important;
	text-transform: uppercase !important;
	color: var(--parchment) !important;
}
body.woocommerce-account .woocommerce-Address-title .edit {
	font-family: 'Cinzel', serif;
	font-size: 11px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--candle) !important;
	text-decoration: none;
}
body.woocommerce-account .woocommerce-Address-title .edit:hover {
	color: var(--candle-bright, #e6b56a) !important;
}
body.woocommerce-account .woocommerce-Address address {
	font-family: 'EB Garamond', serif;
	font-style: normal;
	font-size: 15px;
	line-height: 1.6;
	color: var(--parchment);
	margin: 0;
}


/* ───── Subscription detail page ───── */
/* Layout for /my-account/view-subscription/N/ — WC Subscriptions outputs
 * .subscription_details (table), .related-orders, plus various wrapper
 * boxes. Make them all read as cards in our palette. */

body.woocommerce-account .subscription_details,
body.woocommerce-account .order_details,
body.woocommerce-account .related-orders,
body.woocommerce-account .woocommerce-customer-details {
	background: var(--night-soft) !important;
	border: 1px solid var(--rule) !important;
	padding: 24px 26px !important;
	margin: 24px 0 !important;
	width: 100% !important;
}
body.woocommerce-account .subscription_details thead th,
body.woocommerce-account .order_details thead th,
body.woocommerce-account .shop_table.subscription_details thead th {
	font-family: 'Cinzel', serif !important;
	font-weight: 500;
	font-size: 10px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--parchment-dim) !important;
	background: transparent !important;
	padding: 12px 8px !important;
	border-bottom: 1px solid var(--rule) !important;
	text-align: left;
}
body.woocommerce-account .subscription_details tbody td,
body.woocommerce-account .order_details tbody td,
body.woocommerce-account .shop_table.subscription_details tbody td {
	font-family: 'EB Garamond', serif;
	font-size: 15px;
	color: var(--parchment) !important;
	background: transparent !important;
	padding: 14px 8px !important;
	border-bottom: 1px solid var(--rule-soft) !important;
}

/* Subscription action buttons (Cancel, Reactivate, Change payment method) */
body.woocommerce-account .subscription_details .actions,
body.woocommerce-account .related-orders .actions,
body.woocommerce-account .order_details .actions {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	padding-top: 18px;
}
body.woocommerce-account .subscription_details .button,
body.woocommerce-account .related-orders .button {
	display: inline-block !important;
	padding: 10px 18px !important;
	background: transparent !important;
	border: 1px solid var(--candle) !important;
	color: var(--candle) !important;
	font-family: 'Cinzel', serif !important;
	font-size: 11px !important;
	letter-spacing: 0.18em !important;
	text-transform: uppercase !important;
	text-decoration: none !important;
	border-radius: 0 !important;
	margin: 0 !important;
}
body.woocommerce-account .subscription_details .button:hover,
body.woocommerce-account .related-orders .button:hover {
	background: var(--candle) !important;
	color: var(--night) !important;
}

/* Customer details / billing + shipping side-by-side on order detail */
body.woocommerce-account .woocommerce-customer-details .col2-set {
	display: grid !important;
	grid-template-columns: repeat(2, 1fr) !important;
	gap: 32px !important;
}
@media (max-width: 700px) {
	body.woocommerce-account .woocommerce-customer-details .col2-set {
		grid-template-columns: 1fr !important;
	}
}


/* ───── Order received page — overview list ───── */
/* The "Order number / Date / Email / Total / Payment method" block at
 * the top of /checkout/order-received/ uses .woocommerce-order-overview.
 * WC default is a horizontal row of <li>s separated by borders. Reflow
 * as a tidy 5-column card. */

body.woocommerce-order-received .woocommerce-order-overview,
.woocommerce-order-overview.woocommerce-thankyou-order-details {
	display: grid !important;
	grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)) !important;
	gap: 20px !important;
	list-style: none !important;
	background: var(--night-soft) !important;
	border: 1px solid var(--rule) !important;
	padding: 24px 26px !important;
	margin: 24px 0 !important;
}
body.woocommerce-order-received .woocommerce-order-overview li,
.woocommerce-order-overview.woocommerce-thankyou-order-details li {
	display: flex !important;
	flex-direction: column !important;
	gap: 4px;
	padding: 0 !important;
	border: 0 !important;
	text-align: left !important;
	font-family: 'EB Garamond', serif !important;
	font-size: 16px !important;
	color: var(--parchment) !important;
	text-transform: none !important;
}
body.woocommerce-order-received .woocommerce-order-overview li strong,
.woocommerce-order-overview.woocommerce-thankyou-order-details li strong {
	font-family: 'Cinzel', serif !important;
	font-size: 13px !important;
	font-weight: 500 !important;
	letter-spacing: 0.04em !important;
	color: var(--candle) !important;
	order: -1; /* render the value first, then the label below — looks like card stacks */
}

/* Thank-you message at top of received page */
body.woocommerce-order-received .woocommerce-thankyou-order-received,
body.woocommerce-checkout p.woocommerce-thankyou-order-received {
	font-family: 'EB Garamond', serif;
	font-style: italic;
	font-size: 22px;
	line-height: 1.4;
	color: var(--parchment);
	margin: 0 0 8px;
}


/* ───── Form action rows ───── */
/* Generic .form-row with a submit button at the end of edit-account /
 * edit-address / login forms. Pad and align consistently. */

body.woocommerce-account .woocommerce-MyAccount-content .form-row {
	margin: 0 0 18px !important;
}
body.woocommerce-account .woocommerce-MyAccount-content .form-row.form-row-wide {
	width: 100% !important;
}
body.woocommerce-account .woocommerce-MyAccount-content fieldset {
	border: 1px solid var(--rule);
	padding: 18px 22px;
	margin: 18px 0;
	background: var(--night-soft);
}
body.woocommerce-account .woocommerce-MyAccount-content fieldset legend {
	font-family: 'Cinzel', serif;
	font-size: 12px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--parchment-dim);
	padding: 0 8px;
}

/* === END nb-account-cards === */


/* === BEGIN nb-account-rewrite === */
/* Phase 9.7.3 — account layout (carry-over from v2) + stronger address
 * padding rules (CJ reports cards still feel un-padded). The rules
 * below are deliberately specificity-stacked so they outrank any
 * earlier rule including the original Phase 8 CSS still in this file. */

body.woocommerce-account .page-title,
body.woocommerce-account .entry-title,
body.woocommerce-account h1.page-title,
body.woocommerce-account h1.entry-title {
	display: none !important;
}

body.woocommerce-account form.search-form,
body.woocommerce-account .search-form,
body.woocommerce-account #searchform,
body.woocommerce-account .wp-block-search,
body.woocommerce-account .widget_search,
body.woocommerce-account .site-main input[type="search"] {
	display: none !important;
}

body.woocommerce-account .woocommerce {
	display: block !important;
	max-width: 760px !important;
	width: 100% !important;
	margin: 0 auto !important;
	padding: 32px clamp(20px, 5vw, 48px) 96px !important;
	box-sizing: border-box !important;
	color: var(--parchment);
}

body.woocommerce-account .nb-woo-page-header {
	max-width: 100% !important;
	padding-left: 0 !important;
	padding-right: 0 !important;
}

body.woocommerce-account .woocommerce-MyAccount-navigation {
	display: block !important;
	float: none !important;
	width: 100% !important;
	margin: 0 0 36px !important;
	padding: 0 !important;
	background: transparent !important;
	border: 0 !important;
	vertical-align: baseline !important;
}
body.woocommerce-account .woocommerce-MyAccount-navigation ul {
	list-style: none !important;
	margin: 0 !important;
	padding: 0 !important;
	border: 1px solid var(--rule);
	background: var(--night-soft);
}
body.woocommerce-account .woocommerce-MyAccount-navigation ul li {
	margin: 0 !important;
	padding: 0 !important;
	border-bottom: 1px solid var(--rule-soft) !important;
}
body.woocommerce-account .woocommerce-MyAccount-navigation ul li:last-child {
	border-bottom: 0 !important;
}
body.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
	display: block !important;
	padding: 14px 20px !important;
	font-family: 'Cinzel', serif !important;
	font-weight: 500 !important;
	font-size: 11px !important;
	letter-spacing: 0.18em !important;
	text-transform: uppercase !important;
	color: var(--parchment-dim) !important;
	text-decoration: none !important;
	transition: color 0.2s, background 0.2s;
}
body.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
	color: var(--candle) !important;
	background: rgba(212, 160, 86, 0.05) !important;
}
body.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a {
	color: var(--candle) !important;
	background: rgba(212, 160, 86, 0.10) !important;
	border-left: 2px solid var(--candle) !important;
	padding-left: 18px !important;
}

body.woocommerce-account .woocommerce-MyAccount-content {
	display: block !important;
	float: none !important;
	width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
	vertical-align: baseline !important;
}


/* ── Address cards: hammer the padding from multiple selector levels ── */

body.woocommerce-account .woocommerce-Addresses,
body.woocommerce-account .woocommerce-Addresses.col2-set,
body.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Addresses {
	display: block !important;
	grid-template-columns: unset !important;
	width: 100% !important;
	margin: 28px 0 0 !important;
	padding: 0 !important;
}

body.woocommerce-account .woocommerce-Address,
body.woocommerce-account .woocommerce-Address.col-1,
body.woocommerce-account .woocommerce-Address.col-2,
body.woocommerce-account .woocommerce-Address.woocommerce-Address--billing,
body.woocommerce-account .woocommerce-Address.woocommerce-Address--shipping,
body.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Address {
	display: block !important;
	float: none !important;
	width: 100% !important;
	max-width: none !important;
	margin: 0 0 24px !important;
	padding: 32px 36px !important;
	background: var(--night-soft) !important;
	border: 1px solid var(--rule) !important;
	box-sizing: border-box !important;
}
body.woocommerce-account .woocommerce-Address:last-child {
	margin-bottom: 0 !important;
}

body.woocommerce-account .woocommerce-Address > header,
body.woocommerce-account .woocommerce-Address-title,
body.woocommerce-account .woocommerce-Address-title.title {
	display: flex !important;
	align-items: baseline !important;
	justify-content: space-between !important;
	gap: 20px !important;
	margin: 0 0 18px !important;
	padding: 0 0 14px !important;
	border-bottom: 1px solid var(--rule-soft) !important;
}
body.woocommerce-account .woocommerce-Address-title h3 {
	font-family: 'Cinzel', serif !important;
	font-weight: 400 !important;
	font-size: 13px !important;
	letter-spacing: 0.22em !important;
	text-transform: uppercase !important;
	color: var(--parchment) !important;
	margin: 0 !important;
	padding: 0 !important;
	border: 0 !important;
	flex: 1 1 auto !important;
}
body.woocommerce-account .woocommerce-Address-title .edit {
	display: inline-block !important;
	font-family: 'Cinzel', serif !important;
	font-size: 10px !important;
	letter-spacing: 0.18em !important;
	text-transform: uppercase !important;
	color: var(--candle) !important;
	text-decoration: none !important;
	flex: 0 0 auto !important;
	white-space: nowrap !important;
}
body.woocommerce-account .woocommerce-Address-title .edit:hover {
	color: var(--candle-bright, #e6b56a) !important;
}
body.woocommerce-account .woocommerce-Address address {
	font-family: 'EB Garamond', serif !important;
	font-style: normal !important;
	font-size: 16px !important;
	line-height: 1.65 !important;
	color: var(--parchment-dim) !important;
	margin: 0 !important;
	padding: 0 !important;
}


/* ── Login/register col2-set: also single column ─────────────────── */

body.woocommerce-account .u-columns,
body.woocommerce-account .col2-set,
body.woocommerce-account .woocommerce > .u-columns {
	display: block !important;
	grid-template-columns: unset !important;
}
body.woocommerce-account .u-columns .col-1,
body.woocommerce-account .u-columns .col-2,
body.woocommerce-account .col2-set .col-1,
body.woocommerce-account .col2-set .col-2 {
	width: 100% !important;
	max-width: none !important;
	margin: 0 0 28px !important;
	padding: 0 !important;
}


/* ── Edit-address / edit-account forms — same card treatment ──────── */

body.woocommerce-account form.woocommerce-EditAccountForm,
body.woocommerce-account form.edit-account,
body.woocommerce-account form.woocommerce-address-fields,
body.woocommerce-edit-address form.woocommerce-address-fields,
body.woocommerce-account .woocommerce-MyAccount-content form[name="account"],
body.woocommerce-account .woocommerce-MyAccount-content form[action*="edit-address"],
body.woocommerce-account .woocommerce-MyAccount-content form[action*="edit-account"] {
	display: block !important;
	margin: 28px 0 0 !important;
	padding: 32px 36px !important;
	background: var(--night-soft) !important;
	border: 1px solid var(--rule) !important;
	box-sizing: border-box !important;
}


/* ── Inputs (all account types) ──────────────────────────────────── */

body.woocommerce-account input[type="text"],
body.woocommerce-account input[type="email"],
body.woocommerce-account input[type="tel"],
body.woocommerce-account input[type="password"],
body.woocommerce-account input[type="number"],
body.woocommerce-account input[type="url"],
body.woocommerce-account input[type="search"],
body.woocommerce-account textarea,
body.woocommerce-account select {
	width: 100% !important;
	font-family: 'EB Garamond', serif !important;
	font-size: 17px !important;
	color: var(--parchment) !important;
	background: var(--night-soft) !important;
	border: 1px solid var(--rule) !important;
	border-radius: 0 !important;
	padding: 12px 14px !important;
	line-height: 1.4 !important;
	box-shadow: none !important;
	height: auto !important;
	box-sizing: border-box !important;
}
body.woocommerce-account input[type="text"]:focus,
body.woocommerce-account input[type="email"]:focus,
body.woocommerce-account input[type="tel"]:focus,
body.woocommerce-account input[type="password"]:focus,
body.woocommerce-account input[type="number"]:focus,
body.woocommerce-account input[type="url"]:focus,
body.woocommerce-account input[type="search"]:focus,
body.woocommerce-account textarea:focus,
body.woocommerce-account select:focus {
	border-color: var(--candle) !important;
	background: var(--night) !important;
	outline: none !important;
}

@media (max-width: 900px) {
	body.woocommerce-account .woocommerce {
		padding: 24px 20px 64px !important;
	}
	body.woocommerce-account .woocommerce-Address,
	body.woocommerce-account form.woocommerce-EditAccountForm,
	body.woocommerce-account form.woocommerce-address-fields {
		padding: 24px 20px !important;
	}
}

/* === END nb-account-rewrite === */
