/* ============================================================================
 * Craft My Prototype — WooCommerce design layer
 * Mirrors frontend-v1: ShopGrid, ui/Card (ProductCard), ProductInfo,
 * ProductDetailGallery, CartView, CheckoutForm, AccountView.
 * Built entirely on the shared design tokens (tokens.css).
 * ========================================================================== */

/* Strip WooCommerce's default typographic chrome we don't use. */
.cmp-theme .woocommerce-breadcrumb,
.cmp-theme .woocommerce-products-header,
.cmp-theme .woocommerce-result-count,
.cmp-theme .woocommerce-ordering { display: none; }

/* ── Shop header banner spacing ─────────────────────────────────────────── */
.cmp-shop-header { position: relative; }

/* ── Filter / sort bar (ShopGrid) ───────────────────────────────────────── */
.cmp-shop__bar {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	margin-bottom: 2rem;
}
.cmp-shop__pills { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.cmp-shop__pill {
	border: 1px solid var(--border-hair);
	border-radius: var(--r-pill);
	background: transparent;
	padding: 0.375rem 1rem;
	font-family: var(--font-mono);
	font-size: 0.78rem;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--body);
	cursor: pointer;
	transition: border-color var(--dur-fast) var(--ease-standard),
		background-color var(--dur-fast) var(--ease-standard),
		color var(--dur-fast) var(--ease-standard);
}
.cmp-shop__pill:hover { border-color: var(--amber); }
.cmp-shop__pill.is-active {
	border-color: var(--amber);
	background: var(--amber-tint);
	color: var(--amber-text);
}
.cmp-shop__tools { display: flex; align-items: center; gap: 0.75rem; }
.cmp-shop__count { white-space: nowrap; font-variant-numeric: tabular-nums; color: var(--muted); }
.cmp-shop__sort {
	cursor: pointer;
	border: 1px solid var(--border-hair);
	border-radius: var(--r-sm);
	background: var(--card);
	padding: 0.5rem 0.75rem;
	font-family: var(--font-mono);
	font-size: 0.78rem;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--ink);
	outline: none;
	transition: border-color var(--dur-fast) var(--ease-standard);
}
.cmp-shop__sort:focus { border-color: var(--amber); }

@media (min-width: 640px) {
	.cmp-shop__bar { flex-direction: row; align-items: center; justify-content: space-between; }
}

/* ── Product grid (ul.products) ─────────────────────────────────────────── */
.cmp-shop ul.products {
	display: grid;
	grid-auto-rows: 1fr;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1rem;
	margin: 0;
	padding: 0;
	list-style: none;
}
.cmp-shop ul.products::before,
.cmp-shop ul.products::after { content: none; }
.cmp-shop ul.products li.product {
	width: auto !important;
	margin: 0 !important;
	float: none !important;
	clear: none !important;
}
@media (min-width: 640px) { .cmp-shop ul.products { grid-template-columns: repeat(3, minmax(0, 1fr)); } }
@media (min-width: 1024px) { .cmp-shop ul.products { grid-template-columns: repeat(4, minmax(0, 1fr)); } }

/* ── Spec-sheet product card (ui/Card.tsx) ──────────────────────────────── */
.cmp-pcard { display: flex; }
.cmp-pcard__inner {
	position: relative;
	display: flex;
	flex-direction: column;
	width: 100%;
	height: 100%;
	overflow: hidden;
	border: 1px solid var(--border-hair);
	border-radius: var(--r-md);
	background: var(--card);
	box-shadow: var(--shadow-rest);
	transition: transform var(--dur-base) var(--ease-standard),
		box-shadow var(--dur-base) var(--ease-standard),
		border-color var(--dur-base) var(--ease-standard);
}
.cmp-pcard__inner:hover {
	transform: translateY(-0.25rem);
	border-color: var(--amber-tint-border);
	box-shadow: var(--shadow-hover);
}
.cmp-pcard__overlay {
	position: absolute;
	inset: 0;
	z-index: 2;
	border-radius: var(--r-md);
}
.cmp-pcard__overlay:focus-visible { outline: 2px solid var(--amber); outline-offset: 2px; }

.cmp-pcard__rail {
	position: relative;
	z-index: 3;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.5rem;
	padding: 0.75rem 0.875rem 0;
	pointer-events: none;
}
.cmp-pcard__idx,
.cmp-pcard__fig {
	font-family: var(--font-mono);
	font-size: 0.7rem;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	font-variant-numeric: tabular-nums;
	color: var(--muted);
}
.cmp-pcard__badge {
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	border-radius: var(--r-pill);
	background: var(--amber);
	padding: 0.1rem 0.5rem;
	font-family: var(--font-mono);
	font-size: 0.6rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--on-amber);
}
.cmp-pcard__badge-dot { width: 0.4rem; height: 0.4rem; border-radius: 50%; background: var(--on-amber); }

.cmp-pcard__plate {
	position: relative;
	margin: 0.625rem 0.875rem 0;
	overflow: hidden;
	border: 1px solid var(--border-hair);
	border-radius: var(--r-sm);
	aspect-ratio: 1 / 1;
}
.cmp-pcard__reg {
	position: absolute;
	left: 50%;
	z-index: 1;
	width: 1px;
	height: 0.5rem;
	transform: translateX(-50%);
	background: var(--border-hair);
	pointer-events: none;
}
.cmp-pcard__reg--t { top: 0.5rem; }
.cmp-pcard__reg--b { bottom: 0.5rem; }
.cmp-pcard__img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	padding: 0.75rem;
	transition: transform var(--dur-base) var(--ease-spring);
}
.cmp-pcard__inner:hover .cmp-pcard__img { transform: scale(1.06); }
.cmp-pcard__viewer { position: absolute; inset: 0; z-index: 2; }
.cmp-pcard__viewer model-viewer { width: 100%; height: 100%; }
.cmp-pcard__spin {
	position: absolute;
	bottom: 0.5rem;
	right: 0.5rem;
	z-index: 4;
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	border-radius: var(--r-pill);
	padding: 0.25rem 0.625rem;
	font-family: var(--font-mono);
	font-size: 0.66rem;
	font-weight: 500;
	color: var(--ink);
	cursor: pointer;
	border: 0;
	opacity: 0;
	transition: opacity var(--dur-fast) var(--ease-standard), color var(--dur-fast) var(--ease-standard);
}
.cmp-pcard__inner:hover .cmp-pcard__spin,
.cmp-pcard__spin:focus-visible { opacity: 1; }
.cmp-pcard__spin:hover { color: var(--amber-text); }

.cmp-pcard__foot {
	position: relative;
	z-index: 3;
	margin-top: auto;
	padding: 0.75rem 0.875rem 0.875rem;
	pointer-events: none;
}
.cmp-pcard__hairline { margin-bottom: 0.75rem; opacity: 0.7; }
.cmp-pcard__row { display: flex; align-items: flex-end; justify-content: space-between; gap: 0.75rem; }
.cmp-pcard__name-wrap { min-width: 0; }
.cmp-pcard__name {
	margin: 0;
	font-family: var(--font-display);
	font-size: 1.02rem;
	font-weight: 600;
	line-height: 1.15;
	color: var(--ink);
}
.cmp-pcard__trait {
	margin: 0.25rem 0 0;
	overflow: hidden;
	white-space: nowrap;
	text-overflow: ellipsis;
	font-family: var(--font-mono);
	font-size: 0.66rem;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--muted);
}
.cmp-pcard__price-wrap { flex-shrink: 0; text-align: right; }
.cmp-pcard__price {
	font-family: var(--font-mono);
	font-weight: 700;
	font-size: 1.15rem;
	font-variant-numeric: tabular-nums;
	color: var(--ink);
}
.cmp-pcard__price .woocommerce-Price-currencySymbol {
	vertical-align: super;
	font-size: 0.55em;
	font-weight: 600;
	color: var(--muted);
}
.cmp-pcard__price del { color: var(--muted); font-weight: 400; opacity: 0.7; margin-right: 0.25rem; }
.cmp-pcard__price ins { text-decoration: none; }
.cmp-pcard__add {
	position: relative;
	z-index: 4;
	pointer-events: auto;
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	margin-top: 0.125rem;
	font-family: var(--font-mono);
	font-size: 0.7rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	color: var(--amber-text);
	transition: opacity var(--dur-fast) var(--ease-standard);
}
.cmp-pcard__add:hover { opacity: 0.8; }
.cmp-pcard__add.loading { opacity: 0.5; }
.cmp-pcard__add.added::after { content: " ✓"; }
.cmp-pcard__ships {
	margin: 0.5rem 0 0;
	font-family: var(--font-mono);
	font-size: 0.7rem;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	font-variant-numeric: tabular-nums;
	color: var(--muted);
}

/* ── Shop footer register line ──────────────────────────────────────────── */
.cmp-shop__footer { margin-top: 2.25rem; display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.cmp-shop__footer-rule { flex: 1; opacity: 0.7; }
.cmp-shop__footer-label { flex-shrink: 0; white-space: nowrap; font-variant-numeric: tabular-nums; color: var(--muted); }

/* ── Slide-in cart drawer (CartDrawer.tsx) ──────────────────────────────── */
.cmp-cart-drawer { position: fixed; inset: 0; z-index: 1000; visibility: hidden; }
.cmp-cart-drawer.is-open { visibility: visible; }
.cmp-cart-drawer__scrim {
	position: absolute; inset: 0;
	background: rgba(14, 13, 12, 0.45);
	opacity: 0;
	transition: opacity var(--dur-base) var(--ease-standard);
}
.cmp-cart-drawer.is-open .cmp-cart-drawer__scrim { opacity: 1; }
.cmp-cart-drawer__panel {
	position: absolute; top: 0; right: 0; bottom: 0;
	width: min(92vw, 400px);
	display: flex; flex-direction: column;
	background: var(--canvas);
	border-left: 1px solid var(--border-hair);
	box-shadow: var(--shadow-hover);
	transform: translateX(100%);
	transition: transform var(--dur-base) var(--ease-spring);
}
.cmp-cart-drawer.is-open .cmp-cart-drawer__panel { transform: translateX(0); }
.cmp-cart-drawer__head {
	display: flex; align-items: center; justify-content: space-between;
	padding: 1.25rem 1.5rem;
	border-bottom: 1px solid var(--border-hair);
}
.cmp-cart-drawer__title { display: inline-flex; align-items: center; gap: 0.5rem; font-family: var(--font-display); font-weight: 700; color: var(--ink); }
.cmp-cart-drawer__check { display: grid; place-items: center; width: 1.25rem; height: 1.25rem; border-radius: 50%; background: var(--green-tint); color: var(--green); font-size: 0.7rem; }
.cmp-cart-drawer__close { border: 0; background: transparent; font-size: 1.5rem; line-height: 1; color: var(--muted); cursor: pointer; }
.cmp-cart-drawer__close:hover { color: var(--ink); }
.cmp-cart-drawer__body { flex: 1; overflow-y: auto; padding: 1.25rem 1.5rem; }

/* mini-cart line items (clean + consistent — see woocommerce/cart/mini-cart.php) */
.cmp-mini-cart { list-style: none; margin: 0; padding: 0; }
.cmp-mini-cart__item { position: relative; display: flex; align-items: center; gap: 0.75rem; padding: 0.875rem 1.75rem 0.875rem 0; border-bottom: 1px solid var(--border-hair); }
.cmp-mini-cart__item:first-child { padding-top: 0; }
.cmp-mini-cart__thumb { flex-shrink: 0; width: 3rem; height: 3rem; display: block; overflow: hidden; border: 1px solid var(--border-hair); border-radius: var(--r-sm); background: var(--card); }
.cmp-mini-cart__thumb img { width: 100%; height: 100%; object-fit: contain; padding: 0.25rem; }
.cmp-mini-cart__body { min-width: 0; flex: 1; }
.cmp-mini-cart__name { display: block; font-family: var(--font-display); font-size: 0.9rem; font-weight: 600; line-height: 1.2; color: var(--ink); text-decoration: none; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
a.cmp-mini-cart__name:hover { color: var(--amber-text); }
.cmp-mini-cart__variant { margin: 0.2rem 0 0; display: flex; align-items: center; gap: 0.35rem; font-family: var(--font-mono); font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted); }
.cmp-mini-cart__dot { width: 0.55rem; height: 0.55rem; border-radius: 50%; border: 1px solid var(--border-hair); display: inline-block; flex-shrink: 0; }
.cmp-mini-cart__qty { margin: 0.25rem 0 0; font-family: var(--font-mono); font-size: 0.8rem; font-variant-numeric: tabular-nums; color: var(--muted); }
.cmp-mini-cart__qty .woocommerce-Price-amount { font-weight: 700; color: var(--ink); }
.cmp-mini-cart__qty .woocommerce-Price-currencySymbol,
.cmp-mini-cart__subtotal-value .woocommerce-Price-currencySymbol { vertical-align: super; font-size: 0.7em; color: var(--muted); }
.cmp-mini-cart__remove { position: absolute; top: 0.875rem; right: 0; display: grid; place-items: center; width: 1.25rem; height: 1.25rem; border-radius: 50%; font-size: 1.05rem; line-height: 1; color: var(--muted); text-decoration: none; transition: color var(--dur-fast) var(--ease-standard), background-color var(--dur-fast) var(--ease-standard); }
.cmp-mini-cart__item:first-child .cmp-mini-cart__remove { top: 0; }
.cmp-mini-cart__remove:hover { color: var(--error, #d7263d); background: var(--canvas-sunk); }
.cmp-mini-cart__subtotal { display: flex; align-items: baseline; justify-content: space-between; margin: 1.25rem 0 0; font-family: var(--font-mono); font-size: 0.95rem; color: var(--ink); }
.cmp-mini-cart__subtotal-value { font-weight: 700; font-variant-numeric: tabular-nums; }
.woocommerce-mini-cart__buttons, .cmp-cart-drawer__body .woocommerce-mini-cart__total { display: none; }

/* Sit below the WP admin bar when it's present (logged-in users), or the drawer
   header is hidden behind it. */
.admin-bar .cmp-cart-drawer__panel { top: 32px; }
@media screen and (max-width: 782px) { .admin-bar .cmp-cart-drawer__panel { top: 46px; } }
.cmp-cart-drawer__empty { color: var(--muted); font-size: 0.9rem; }
.cmp-cart-drawer__foot { display: grid; gap: 0.6rem; padding: 1.25rem 1.5rem; border-top: 1px solid var(--border-hair); }
html.cmp-cart-open { overflow: hidden; }

/* ── Quantity stepper (shared on WC pages; mirrors quote-engine stepper) ──── */
.cmp-stepper { display: inline-flex; align-items: center; gap: 0.25rem; border: 1px solid var(--border-hair); border-radius: var(--r-sm); padding: 0.25rem; }
.cmp-stepper__btn { display: grid; place-items: center; width: 2rem; height: 2rem; border: 0; background: transparent; color: var(--ink); font-size: 1.15rem; line-height: 1; border-radius: var(--r-xs); cursor: pointer; transition: background-color var(--dur-fast) var(--ease-standard); }
.cmp-stepper__btn:hover { background: var(--canvas-sunk); }
.cmp-stepper__val { min-width: 2.5rem; text-align: center; font-family: var(--font-mono); font-variant-numeric: tabular-nums; color: var(--ink); }

/* ── Single product (ProductDetailGallery + ProductInfo) ────────────────── */
.cmp-pdp__crumbs { margin-bottom: 2rem; }
.cmp-pdp__crumbs-list { display: flex; flex-wrap: wrap; gap: 0.4rem; align-items: center; list-style: none; margin: 0; padding: 0; }
.cmp-pdp__crumbs-list li { display: inline-flex; align-items: center; gap: 0.4rem; color: var(--muted); }
.cmp-pdp__crumbs-list li:not(:last-child)::after { content: "/"; color: var(--border-strong); }
.cmp-pdp__crumbs-list a { color: var(--muted); transition: color var(--dur-fast); }
.cmp-pdp__crumbs-list a:hover { color: var(--ink); }

.cmp-pdp__grid { display: grid; grid-template-columns: 1fr; gap: 2.5rem; }
@media (min-width: 1024px) { .cmp-pdp__grid { grid-template-columns: 1fr 1fr; gap: 3.5rem; } }

.cmp-pdp__gallery { align-self: start; }
@media (min-width: 1024px) { .cmp-pdp__gallery { position: sticky; top: 6rem; } }
.cmp-pdp__viewport { position: relative; aspect-ratio: 1 / 1; width: 100%; overflow: hidden; border: 1px solid var(--border-strong); border-radius: var(--r-lg); background: var(--card); box-shadow: var(--shadow-rest); }
.cmp-pdp__main { width: 100%; height: 100%; object-fit: contain; padding: 1.5rem; }
.cmp-pdp__viewer { position: absolute; inset: 0; z-index: 2; }
.cmp-pdp__viewer model-viewer { width: 100%; height: 100%; }
.cmp-pdp__badge { position: absolute; left: 0.75rem; top: 0.75rem; z-index: 3; border-radius: var(--r-xs); padding: 0.25rem 0.625rem; font-family: var(--font-mono); font-size: 0.66rem; font-weight: 500; text-transform: uppercase; letter-spacing: 0.04em; color: var(--ink); }
.cmp-pdp__spin { position: absolute; bottom: 0.75rem; right: 0.75rem; z-index: 4; display: inline-flex; align-items: center; gap: 0.375rem; border: 0; border-radius: var(--r-pill); padding: 0.375rem 0.75rem; font-family: var(--font-mono); font-size: 0.72rem; font-weight: 500; color: var(--ink); cursor: pointer; transition: color var(--dur-fast); }
.cmp-pdp__spin:hover { color: var(--amber-text); }

.cmp-pdp__thumbs { margin-top: 1rem; display: flex; flex-wrap: wrap; gap: 0.75rem; }
.cmp-pdp__thumb { position: relative; width: 4rem; height: 4rem; overflow: hidden; border: 1px solid var(--border-hair); border-radius: var(--r-sm); background: var(--card); cursor: pointer; padding: 0; transition: border-color var(--dur-fast); }
.cmp-pdp__thumb img { width: 100%; height: 100%; object-fit: contain; padding: 0.375rem; }
.cmp-pdp__thumb:hover { border-color: var(--border-strong); }
.cmp-pdp__thumb.is-active { border-color: var(--amber); }
.cmp-pdp__thumb--3d { display: grid; place-items: center; color: var(--muted); }
.cmp-pdp__thumb--3d.is-active { color: var(--amber-text); }

.cmp-pdp__eyebrow { margin-bottom: 0.75rem; }
.cmp-pdp__title { margin: 0; font-family: var(--font-display); font-size: clamp(2rem, 1.4rem + 2vw, 2.8rem); font-weight: 800; line-height: 1.04; letter-spacing: -0.02em; color: var(--ink); }
.cmp-pdp__price-row { margin-top: 0.75rem; display: flex; align-items: center; flex-wrap: wrap; gap: 0.75rem; }
.cmp-pdp__price { font-family: var(--font-mono); font-size: 1.9rem; font-weight: 700; font-variant-numeric: tabular-nums; color: var(--ink); }
.cmp-pdp__price .woocommerce-Price-currencySymbol { vertical-align: super; font-size: 0.5em; font-weight: 600; color: var(--muted); }
.cmp-pdp__stock { display: inline-flex; align-items: center; gap: 0.375rem; border-radius: var(--r-pill); background: var(--green-tint); padding: 0.25rem 0.625rem; font-family: var(--font-mono); font-size: 0.66rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--green); }
.cmp-pdp__desc { margin-top: 1.25rem; max-width: none; font-size: 1.0625rem; }

.cmp-pdp__opt { margin-top: 2rem; }
.cmp-pdp__opt-head { margin-bottom: 0.625rem; display: flex; align-items: center; gap: 0.625rem; }
.cmp-pdp__opt-idx { font-family: var(--font-mono); font-size: 0.7rem; font-variant-numeric: tabular-nums; color: var(--amber-text); }
.cmp-pdp__opt-label { font-family: var(--font-mono); font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.14em; color: var(--muted); }
.cmp-pdp__swatches { display: flex; flex-wrap: wrap; gap: 0.625rem; }
.cmp-pdp__swatch { width: 2.25rem; height: 2.25rem; border: 0; border-radius: var(--r-xs); cursor: pointer; box-shadow: inset 0 0 0 1px rgba(22,20,18,0.14), 0 0 0 1px var(--border-strong); transition: transform var(--dur-fast) var(--ease-standard), box-shadow var(--dur-fast) var(--ease-standard); }
.cmp-pdp__swatch:hover { transform: scale(1.05); }
.cmp-pdp__swatch.is-active { transform: scale(1.1); box-shadow: inset 0 0 0 1px rgba(22,20,18,0.14), 0 0 0 2px var(--amber), 0 0 0 4px var(--canvas); }

.cmp-pdp__buy { margin-top: 2rem; display: flex; flex-wrap: wrap; align-items: flex-end; gap: 1rem; }
.cmp-pdp__qty .cmp-pdp__opt-label { display: block; margin-bottom: 0.625rem; }
.cmp-pdp__add { flex: 1; min-width: 220px; justify-content: center; padding-block: 0.875rem; }

.cmp-pdp__rule { margin-top: 2.25rem; }
.cmp-pdp__specs { margin-top: 1.25rem; display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem 1.5rem; }
@media (min-width: 640px) { .cmp-pdp__specs { grid-template-columns: repeat(4, 1fr); } }
.cmp-pdp__specs dt { font-family: var(--font-mono); font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.14em; color: var(--muted); }
.cmp-pdp__specs dd { margin: 0.25rem 0 0; font-family: var(--font-display); font-size: 0.95rem; font-weight: 600; color: var(--ink); }
.cmp-pdp__trust { margin-top: 1.5rem; display: flex; flex-wrap: wrap; gap: 0.5rem 1.25rem; font-family: var(--font-mono); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--muted); }
.cmp-pdp__trust span { display: inline-flex; align-items: center; gap: 0.375rem; }

/* related + CTA */
.cmp-pdp-related__head { margin-bottom: 2rem; }
.cmp-pdp-related__head .cmp-eyebrow { margin-bottom: 0.75rem; }
.cmp-pdp-cta { background: var(--canvas-sunk); border-top: 1px solid var(--border-hair); border-bottom: 1px solid var(--border-hair); padding-block: 3.5rem; }
.cmp-pdp-cta__inner { text-align: center; max-width: 40rem; margin-inline: auto; }
.cmp-pdp-cta__title { margin: 0.75rem 0 0; }
.cmp-pdp-cta__body { margin: 1rem auto 1.75rem; }

/* ── Cart page (CartView.tsx) ───────────────────────────────────────────── */
.cmp-cart__head { display: flex; align-items: baseline; gap: 0.75rem; margin: 1.75rem 0 2.5rem; }
.cmp-cart__count { font-family: var(--font-mono); font-size: 1.2rem; font-variant-numeric: tabular-nums; color: var(--muted); }
.cmp-cart__grid { display: grid; grid-template-columns: 1fr; gap: 2.5rem; }
@media (min-width: 1024px) { .cmp-cart__grid { grid-template-columns: 7fr 5fr; gap: 3rem; } }

/* Empty cart — centred state inside the container (replaces the full-bleed WC default) */
.cmp-cart__empty { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 0.85rem; padding: 3.5rem 1.5rem; }
.cmp-cart__empty-icon { display: inline-flex; align-items: center; justify-content: center; width: 3.5rem; height: 3.5rem; border-radius: 50%; background: var(--amber-tint, #fdeee4); color: var(--amber-text, #c24a09); margin-bottom: 0.25rem; }
.cmp-cart__empty-title { font-size: 1.35rem; font-weight: 700; color: var(--ink); margin: 0; }
.cmp-cart__empty-sub { color: var(--muted); max-width: 30rem; margin: 0; line-height: 1.5; }
.cmp-cart__empty-actions { display: flex; flex-wrap: wrap; justify-content: center; gap: 0.75rem; margin-top: 0.75rem; }

.cmp-cart__list { list-style: none; margin: 0; padding: 0; }
.cmp-cart__item { display: flex; gap: 1.25rem; padding: 1.25rem 0; border-bottom: 1px solid var(--border-hair); }
.cmp-cart__thumb { position: relative; width: 6rem; height: 6rem; flex-shrink: 0; overflow: hidden; border: 1px solid var(--border-hair); border-radius: var(--r-sm); background: var(--card); display: block; }
.cmp-cart__thumb img { width: 100%; height: 100%; object-fit: contain; padding: 0.5rem; }
.cmp-cart__body { display: flex; flex-direction: column; flex: 1; min-width: 0; }
.cmp-cart__top { display: flex; align-items: flex-start; justify-content: space-between; gap: 0.75rem; }
.cmp-cart__name { font-family: var(--font-display); font-size: 1.05rem; font-weight: 600; line-height: 1.15; color: var(--ink); transition: color var(--dur-fast); }
a.cmp-cart__name:hover { color: var(--amber-text); }
.cmp-cart__variant { margin: 0.25rem 0 0; display: flex; align-items: center; gap: 0.375rem; font-family: var(--font-mono); font-size: 0.68rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted); }
.cmp-cart__dot { width: 0.625rem; height: 0.625rem; border-radius: 50%; border: 1px solid var(--border-hair); display: inline-block; }
.cmp-cart__line-total { flex-shrink: 0; font-family: var(--font-mono); font-size: 1.05rem; font-weight: 700; font-variant-numeric: tabular-nums; color: var(--ink); }
.cmp-cart__line-total .woocommerce-Price-currencySymbol { vertical-align: super; font-size: 0.6em; color: var(--muted); }
.cmp-cart__bottom { margin-top: auto; padding-top: 0.75rem; display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.cmp-cart__remove { font-family: var(--font-mono); font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted); transition: color var(--dur-fast); }
.cmp-cart__remove:hover { color: var(--error, #d7263d); }
.cmp-cart__update { display: none; }
.cmp-cart__continue { margin-top: 1.5rem; display: inline-flex; align-items: center; gap: 0.5rem; font-family: var(--font-mono); font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--amber-text); transition: opacity var(--dur-fast); }
.cmp-cart__continue:hover { opacity: 0.8; }

.cmp-stepper__input { width: 2.5rem; border: 0; background: transparent; text-align: center; font-family: var(--font-mono); font-variant-numeric: tabular-nums; color: var(--ink); -moz-appearance: textfield; }
.cmp-stepper__input::-webkit-outer-spin-button, .cmp-stepper__input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.cmp-stepper__input:focus { outline: none; }

.cmp-cart__aside { align-self: start; }
@media (min-width: 1024px) { .cmp-cart__aside { position: sticky; top: 6rem; } }
.cmp-cart__summary { border: 1px solid var(--border-hair); border-radius: var(--r-lg); background: var(--card); padding: 1.5rem; box-shadow: var(--shadow-rest); }
@media (min-width: 640px) { .cmp-cart__summary { padding: 1.75rem; } }
.cmp-cart__summary-eyebrow { margin-bottom: 1.25rem; }
.cmp-cart__ship { margin-bottom: 1.25rem; }
.cmp-cart__ship-label { margin: 0 0 0.375rem; font-family: var(--font-mono); font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted); }
.cmp-cart__ship-label .cmp-amber-text, .cmp-amber-text { color: var(--amber-text); }
.cmp-cart__ship-ok { color: var(--green); }
.cmp-cart__ship-track { height: 0.375rem; width: 100%; overflow: hidden; border-radius: var(--r-pill); background: var(--canvas-sunk); }
.cmp-cart__ship-fill { height: 100%; border-radius: var(--r-pill); background: var(--amber); transition: width var(--dur-medium, 0.4s) var(--ease-standard); }
.cmp-cart__totals { margin: 0; display: grid; gap: 0.625rem; font-family: var(--font-mono); font-size: 0.9rem; }
.cmp-cart__totals > div { display: flex; justify-content: space-between; color: var(--body); }
.cmp-cart__totals dt, .cmp-cart__totals dd { margin: 0; }
.cmp-cart__totals dd { font-variant-numeric: tabular-nums; }
.cmp-cart__muted { color: var(--muted); }
.cmp-cart__summary-rule { margin: 1rem 0; }
.cmp-cart__grand { display: flex; align-items: baseline; justify-content: space-between; }
.cmp-cart__grand-label { font-family: var(--font-display); font-size: 1rem; font-weight: 600; color: var(--ink); }
.cmp-cart__grand-value { font-family: var(--font-mono); font-size: 1.6rem; font-weight: 700; font-variant-numeric: tabular-nums; color: var(--ink); }
.cmp-cart__grand-value .woocommerce-Price-currencySymbol { vertical-align: super; font-size: 0.5em; color: var(--muted); }
.cmp-cart__checkout { margin-top: 1.25rem; }
.cmp-cart__trust { margin-top: 1rem; display: flex; align-items: center; justify-content: space-between; gap: 0.75rem; font-family: var(--font-mono); font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted); }
.cmp-cart__secure { display: inline-flex; align-items: center; gap: 0.375rem; }

/* empty cart */
.cmp-cart__empty { display: flex; flex-direction: column; align-items: center; gap: 1.25rem; border: 1px solid var(--border-hair); border-radius: var(--r-lg); background: var(--canvas-sunk); padding: 5rem 1.5rem; text-align: center; }
.cmp-cart__empty-icon { display: grid; place-items: center; width: 4rem; height: 4rem; border-radius: 50%; background: var(--card); color: var(--muted); box-shadow: var(--shadow-rest); }

/* ── Checkout (CheckoutForm.tsx) ────────────────────────────────────────── */
.cmp-checkout__title { margin: 1.75rem 0 2.5rem; }
.cmp-checkout__grid { display: grid; grid-template-columns: 1fr; gap: 2.5rem; }
@media (min-width: 1024px) { .cmp-checkout__grid { grid-template-columns: 7fr 5fr; gap: 3rem; align-items: start; } }

.cmp-checkout__sec { margin-bottom: 2.25rem; }
.cmp-checkout__sec-head { display: flex; align-items: center; gap: 0.625rem; margin-bottom: 1rem; }
.cmp-checkout__num { font-family: var(--font-mono); font-size: 0.7rem; font-variant-numeric: tabular-nums; color: var(--amber-text); }
.cmp-checkout__sec-label { font-family: var(--font-mono); font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.14em; color: var(--ink); }
.cmp-checkout__sec--shipping:empty { display: none; }

/* WooCommerce field styling */
.cmp-checkout-form .form-row { margin: 0 0 1rem; padding: 0; }
.cmp-checkout-form .form-row label { display: block; margin-bottom: 0.375rem; font-family: var(--font-mono); font-size: 0.66rem; text-transform: uppercase; letter-spacing: 0.12em; color: var(--muted); }
.cmp-checkout-form .form-row label .required { color: var(--amber-text); border: 0; }
.cmp-checkout-form .woocommerce-input-wrapper { width: 100%; }
.cmp-checkout-form input.input-text,
.cmp-checkout-form textarea,
.cmp-checkout-form select,
.cmp-checkout-form .select2-selection {
	width: 100%;
	border: 1px solid var(--border-hair);
	border-radius: var(--r-sm);
	background: var(--card);
	padding: 0.625rem 0.875rem;
	font-family: var(--font-sans);
	font-size: 0.95rem;
	color: var(--ink);
	outline: none;
	transition: border-color var(--dur-fast) var(--ease-standard);
}
.cmp-checkout-form input.input-text:focus,
.cmp-checkout-form textarea:focus,
.cmp-checkout-form select:focus { border-color: var(--amber); }
.cmp-checkout-form .select2-container--default .select2-selection--single { height: auto; }
.cmp-checkout-form .col2-set, .cmp-checkout-form #customer_details.col2-set { width: 100%; }
.cmp-checkout-form #customer_details { display: block; }
.cmp-checkout-form .woocommerce-billing-fields h3,
.cmp-checkout-form .woocommerce-shipping-fields h3,
.cmp-checkout-form .woocommerce-additional-fields h3 { font-family: var(--font-mono); font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.14em; color: var(--ink); margin: 0 0 1rem; }
.cmp-checkout-form .woocommerce-account-fields,
.cmp-checkout-form .woocommerce-additional-fields { margin-top: 1.5rem; }

/* order summary aside */
.cmp-checkout__aside { align-self: start; }
@media (min-width: 1024px) { .cmp-checkout__aside { position: sticky; top: 6rem; } }
.cmp-checkout__summary { border: 1px solid var(--border-hair); border-radius: var(--r-lg); background: var(--card); padding: 1.75rem; box-shadow: var(--shadow-rest); }
.cmp-checkout__sum-head { margin-bottom: 1.25rem; }

.cmp-corder__list { list-style: none; margin: 0; padding: 0; display: grid; gap: 0.875rem; }
.cmp-corder__item { display: flex; align-items: center; gap: 0.75rem; }
.cmp-corder__thumb { position: relative; width: 3.5rem; height: 3.5rem; flex-shrink: 0; overflow: hidden; border: 1px solid var(--border-hair); border-radius: var(--r-sm); background: var(--card); }
.cmp-corder__thumb img { width: 100%; height: 100%; object-fit: contain; padding: 0.25rem; }
.cmp-corder__qty { position: absolute; top: -0.375rem; right: -0.375rem; display: grid; place-items: center; height: 1.25rem; min-width: 1.25rem; padding: 0 0.25rem; border-radius: 999px; background: var(--ink); font-family: var(--font-mono); font-size: 0.6rem; font-weight: 700; color: var(--canvas); }
.cmp-corder__meta { min-width: 0; flex: 1; }
.cmp-corder__name { margin: 0; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; font-family: var(--font-display); font-size: 0.9rem; font-weight: 600; color: var(--ink); }
.cmp-corder__variant { margin: 0.125rem 0 0; display: flex; align-items: center; gap: 0.3rem; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; font-family: var(--font-mono); font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted); }
.cmp-corder__dot { width: 0.55rem; height: 0.55rem; border-radius: 50%; border: 1px solid var(--border-hair); display: inline-block; }
.cmp-corder__total { font-family: var(--font-mono); font-size: 0.85rem; font-weight: 700; font-variant-numeric: tabular-nums; color: var(--ink); }
.cmp-corder__total .woocommerce-Price-currencySymbol { vertical-align: super; font-size: 0.6em; color: var(--muted); }
.cmp-corder__rule { margin: 1.25rem 0; }
.cmp-corder__totals { margin: 0; display: grid; gap: 0.625rem; font-family: var(--font-mono); font-size: 0.9rem; }
.cmp-corder__row { display: flex; justify-content: space-between; color: var(--body); }
.cmp-corder__row dt, .cmp-corder__row dd { margin: 0; }
.cmp-corder__row dd { font-variant-numeric: tabular-nums; }
.cmp-corder__muted { color: var(--muted); }
.cmp-corder__grand { display: flex; align-items: baseline; justify-content: space-between; }
.cmp-corder__grand-label { font-family: var(--font-display); font-size: 1rem; font-weight: 600; color: var(--ink); }
.cmp-corder__grand-value { font-family: var(--font-mono); font-size: 1.6rem; font-weight: 700; font-variant-numeric: tabular-nums; color: var(--ink); }
.cmp-corder__grand-value .woocommerce-Price-currencySymbol { vertical-align: super; font-size: 0.5em; color: var(--muted); }

/* payment box + place order */
#payment { margin-top: 1.5rem; border: 1px solid var(--border-hair); border-radius: var(--r-md); background: var(--canvas-sunk); padding: 1.25rem; }
#payment ul.payment_methods { list-style: none; margin: 0 0 1rem; padding: 0; display: grid; gap: 0.5rem; border: 0; }
#payment ul.payment_methods li { display: flex; flex-wrap: wrap; align-items: center; gap: 0.5rem; font-family: var(--font-sans); font-size: 0.9rem; color: var(--ink); }
#payment ul.payment_methods li label { margin: 0; font-weight: 600; }
#payment .payment_box { flex-basis: 100%; margin: 0.25rem 0 0; padding: 0.75rem; background: var(--card); border-radius: var(--r-sm); font-size: 0.82rem; color: var(--muted); }
#payment .payment_box::before { display: none; }
#payment .place-order { margin-top: 1.25rem; padding: 0; }
#payment #place_order, #place_order {
	width: 100%;
	display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem;
	border: 0; border-radius: var(--r-pill);
	background: var(--amber); color: var(--on-amber);
	font-family: var(--font-sans); font-size: 1rem; font-weight: 600;
	padding: 0.875rem 1.5rem; cursor: pointer;
	transition: background-color var(--dur-fast) var(--ease-standard);
}
#place_order:hover { background: var(--amber-hover); }
#payment .woocommerce-terms-and-conditions-wrapper { margin-bottom: 1rem; font-size: 0.8rem; color: var(--muted); }
.cmp-checkout__back { display: block; margin-top: 0.75rem; text-align: center; font-family: var(--font-mono); font-size: 0.76rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted); text-decoration: underline; text-underline-offset: 4px; transition: color var(--dur-fast); }
.cmp-checkout__back:hover { color: var(--amber-text); }

/* checkout login / coupon toggles */
.woocommerce-form-login-toggle, .woocommerce-form-coupon-toggle { margin-bottom: 1.5rem; }
.cmp-checkout .woocommerce-info, .cmp-cart .woocommerce-info, .cmp-checkout .woocommerce-message {
	border-top: 2px solid var(--amber); background: var(--canvas-sunk); padding: 1rem 1.25rem; border-radius: var(--r-sm); font-size: 0.9rem; list-style: none; margin-bottom: 1.25rem;
}

/* ── My Account (AccountView.tsx) ───────────────────────────────────────── */
.cmp-account__title { margin: 1.75rem 0 2.5rem; }
.cmp-account__grid { display: grid; grid-template-columns: 1fr; gap: 3rem; }
@media (min-width: 1024px) { .cmp-account__grid { grid-template-columns: 7fr 5fr; gap: 3.5rem; align-items: start; } }

.cmp-account__tabs { display: inline-flex; margin-bottom: 1.75rem; border: 1px solid var(--border-hair); border-radius: var(--r-pill); padding: 0.25rem; }
.cmp-account__tab { border: 0; background: transparent; border-radius: var(--r-pill); padding: 0.375rem 1rem; font-family: var(--font-mono); font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--body); cursor: pointer; transition: color var(--dur-fast), background-color var(--dur-fast); }
.cmp-account__tab:hover { color: var(--ink); }
.cmp-account__tab.is-active { background: var(--amber); color: var(--on-amber); }

.cmp-account__form { max-width: 440px; }
.cmp-account__form .form-row { margin: 0 0 1.25rem; padding: 0; }
.cmp-account__form label { display: block; margin-bottom: 0.375rem; font-family: var(--font-mono); font-size: 0.66rem; text-transform: uppercase; letter-spacing: 0.12em; color: var(--muted); }
.cmp-account__form input.input-text, .cmp-account__form input[type="password"], .cmp-account__form input[type="email"], .cmp-account__form input[type="text"] {
	width: 100%; border: 1px solid var(--border-hair); border-radius: var(--r-sm); background: var(--card); padding: 0.625rem 0.875rem; font-family: var(--font-sans); font-size: 0.95rem; color: var(--ink); outline: none; transition: border-color var(--dur-fast); }
.cmp-account__form input:focus { border-color: var(--amber); }
.cmp-account__row-submit { display: grid; gap: 1rem; }
.cmp-account__remember { display: inline-flex; align-items: center; gap: 0.5rem; font-family: var(--font-mono); font-size: 0.72rem; text-transform: none; letter-spacing: 0; color: var(--muted); }
.cmp-account__remember input { width: auto; }
.cmp-account__lost { margin: 0.75rem 0 0; }
.cmp-account__lost a { font-family: var(--font-mono); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted); text-decoration: underline; text-underline-offset: 3px; }
.cmp-account__lost a:hover { color: var(--amber-text); }

/* dark perks card (logged-out aside) */
.cmp-amber-mesh { background: radial-gradient(120% 90% at 80% 0%, rgba(232,89,13,0.35) 0%, rgba(232,89,13,0.08) 35%, transparent 65%), #0E0D0C; }
.cmp-account__perks { position: relative; overflow: hidden; border-radius: var(--r-lg); padding: 2rem; color: #fff; }
@media (min-width: 640px) { .cmp-account__perks { padding: 2.25rem; } }
.cmp-account__perks-eyebrow { margin: 0; font-family: var(--font-mono); font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.18em; color: rgba(255,255,255,0.55); }
.cmp-account .cmp-account__perks-title { margin: 1rem 0 0; font-family: var(--font-display); font-size: 1.6rem; font-weight: 700; line-height: 1.15; color: #fff; }
.cmp-account__perks-list { list-style: none; margin: 1.5rem 0 0; padding: 0; display: grid; gap: 1rem; }
.cmp-account__perk { display: flex; gap: 0.75rem; }
.cmp-account__perk-icon { margin-top: 0.125rem; display: grid; place-items: center; width: 2rem; height: 2rem; flex-shrink: 0; border-radius: 50%; border: 1px solid rgba(255,255,255,0.2); color: var(--amber); }
.cmp-account__perk-title { margin: 0; font-family: var(--font-display); font-size: 0.95rem; font-weight: 600; color: #fff; }
.cmp-account__perk-text { margin: 0.125rem 0 0; font-size: 0.85rem; line-height: 1.5; color: rgba(255,255,255,0.6); }

/* dashboard (logged-in) */
.cmp-account__dash-head { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 0.75rem; margin: 1.75rem 0 1.5rem; }
.cmp-account__signout { font-family: var(--font-mono); font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted); transition: color var(--dur-fast); }
.cmp-account__signout:hover { color: var(--amber-text); }
.cmp-account__dash-grid { display: grid; grid-template-columns: 1fr; gap: 3rem; }
@media (min-width: 1024px) { .cmp-account__dash-grid { grid-template-columns: 8fr 4fr; gap: 3rem; align-items: start; } }
.cmp-account__perks-box { border: 1px solid var(--border-hair); border-radius: var(--r-lg); background: var(--canvas-sunk); padding: 1.5rem; }
.cmp-account__perks-eyebrow2 { margin-bottom: 1rem; }
.cmp-account__perk-icon--light { border-color: color-mix(in srgb, var(--amber) 40%, transparent); color: var(--amber-text); }
.cmp-account__perk-title--light { color: var(--ink); }
.cmp-account__perk-text--light { color: var(--muted); }

/* free-print banner + recent orders */
.cmp-account__freeprint { margin-bottom: 2.25rem; display: flex; align-items: center; gap: 1rem; border: 1px solid var(--amber-tint-border); border-radius: var(--r-md); background: var(--amber-tint); padding: 1.25rem; }
.cmp-account__freeprint-icon { display: grid; place-items: center; width: 2.75rem; height: 2.75rem; flex-shrink: 0; border-radius: 50%; background: var(--amber); color: var(--on-amber); }
.cmp-account__freeprint-title { margin: 0; font-family: var(--font-display); font-size: 1.05rem; font-weight: 600; color: var(--ink); }
.cmp-account__freeprint-text { margin: 0.125rem 0 0; font-size: 0.9rem; color: var(--body); }
.cmp-account__freeprint .cmp-btn { margin-left: auto; flex-shrink: 0; }
.cmp-account__orders-head { margin: 0 0 0.75rem; font-family: var(--font-mono); font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.14em; color: var(--muted); }

/* WooCommerce account navigation + tables */
.woocommerce-MyAccount-navigation ul { display: flex; flex-wrap: wrap; gap: 0.5rem; list-style: none; margin: 0 0 1.75rem; padding: 0; }
.woocommerce-MyAccount-navigation li a { display: inline-block; border: 1px solid var(--border-hair); border-radius: var(--r-pill); padding: 0.375rem 0.875rem; font-family: var(--font-mono); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--body); transition: border-color var(--dur-fast), color var(--dur-fast); }
.woocommerce-MyAccount-navigation li.is-active a, .woocommerce-MyAccount-navigation li a:hover { border-color: var(--amber); color: var(--amber-text); }
.cmp-account__content .woocommerce-Address, .cmp-account__content table.account-orders-table, .cmp-account__content table.shop_table { width: 100%; border-collapse: collapse; }
.cmp-account__content table.shop_table th, .cmp-account__content table.shop_table td { text-align: left; padding: 0.75rem 0.5rem; border-bottom: 1px solid var(--border-hair); font-size: 0.9rem; }
.cmp-account__content .button, .cmp-account__content .woocommerce-Button { display: inline-flex; align-items: center; gap: 0.4rem; border: 1px solid var(--border-hair); border-radius: var(--r-pill); padding: 0.45rem 1rem; font-family: var(--font-mono); font-size: 0.74rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--ink); background: var(--card); }
.cmp-account__content .button:hover { border-color: var(--amber); color: var(--amber-text); }

/* dashboard order cards */
.cmp-account__order { border: 1px solid var(--border-hair); border-radius: var(--r-md); background: var(--card); padding: 1.25rem; box-shadow: var(--shadow-rest); margin-bottom: 1rem; }
.cmp-account__order-top { display: flex; align-items: center; justify-content: space-between; gap: 0.75rem; }
.cmp-account__order-no { font-family: var(--font-mono); font-size: 0.85rem; font-weight: 600; color: var(--ink); }
.cmp-account__order-no:hover { color: var(--amber-text); }
.cmp-account__order-status { display: inline-flex; align-items: center; gap: 0.4rem; border-radius: var(--r-pill); padding: 0.25rem 0.625rem; font-family: var(--font-mono); font-size: 0.66rem; text-transform: uppercase; letter-spacing: 0.04em; background: var(--blue-tint, #e6eefc); color: var(--blue, #2f6fe8); }
.cmp-account__order-dot { width: 0.4rem; height: 0.4rem; border-radius: 50%; background: currentColor; }
.cmp-account__order-status--completed { background: var(--green-tint); color: var(--green); }
.cmp-account__order-status--processing { background: var(--blue-tint, #e6eefc); color: var(--blue, #2f6fe8); }
.cmp-account__order-body { margin-top: 1rem; display: flex; align-items: center; gap: 0.75rem; }
.cmp-account__order-thumbs { display: flex; align-items: center; flex-wrap: wrap; gap: 0.4rem; min-width: 0; }
.cmp-account__order-thumb { display: inline-flex; flex: 0 0 auto; position: relative; width: 3rem; height: 3rem; overflow: hidden; border: 1px solid var(--border-hair); border-radius: var(--r-sm); background: var(--card); }
.cmp-account__order-thumb img { width: 100%; height: 100%; object-fit: contain; padding: 0.25rem; }
.cmp-account__order-total { margin-left: auto; font-family: var(--font-mono); font-size: 1rem; font-weight: 700; font-variant-numeric: tabular-nums; color: var(--ink); }
.cmp-account__order-total .woocommerce-Price-currencySymbol { vertical-align: super; font-size: 0.6em; color: var(--muted); }
.cmp-account__no-orders { border: 1px dashed var(--border-strong); border-radius: var(--r-md); background: var(--canvas-sunk); padding: 2rem; text-align: center; }
.cmp-account__no-orders p { margin: 0 0 1rem; color: var(--body); }

/* ── Order received (OrderConfirmed.tsx) ────────────────────────────────── */
.cmp-confirm__inner { max-width: 660px; margin-inline: auto; }
.cmp-confirm__head { text-align: center; }
.cmp-confirm__check { display: grid; place-items: center; width: 4rem; height: 4rem; margin: 0 auto; border-radius: 50%; background: var(--green-tint); color: var(--green); }
.cmp-confirm__eyebrow { margin-top: 1.5rem; justify-content: center; }
.cmp-confirm__eyebrow::before { display: none; }
.cmp-confirm__title { margin-top: 0.75rem; }
.cmp-confirm__lead { max-width: 52ch; margin: 1rem auto 0; text-wrap: balance; }
.cmp-confirm__no { font-family: var(--font-mono); font-weight: 600; color: var(--ink); }
.cmp-confirm__card { margin-top: 2.5rem; border: 1px solid var(--border-hair); border-radius: var(--r-lg); background: var(--card); padding: 1.75rem; box-shadow: var(--shadow-rest); text-align: left; }
.cmp-confirm__card-eyebrow { margin-bottom: 1.25rem; }
.cmp-confirm__cta { margin-top: 2rem; display: flex; flex-wrap: wrap; justify-content: center; gap: 0.75rem; }

/* Hide WooCommerce's auto-appended "View cart" link on cards — the slide-in
   cart drawer is the post-add affordance, so the inline link is redundant. */
.cmp-pcard .added_to_cart,
.cmp-pcard__foot .added_to_cart { display: none !important; }

/* WooCommerce store notices (added-to-cart / info / error) print inside a
   full-bleed .woocommerce shortcode wrapper on cart/checkout/account. Constrain
   that wrapper to the page container so notices don't run edge-to-edge. */
.woocommerce-cart .woocommerce > .woocommerce-notices-wrapper,
.woocommerce-checkout .woocommerce > .woocommerce-notices-wrapper,
.woocommerce-account .woocommerce > .woocommerce-notices-wrapper {
	width: 100%;
	max-width: var(--container);
	margin: 1.5rem auto 0;
	padding-inline: var(--gutter);
	box-sizing: border-box;
}
