/* v5.25.5: cart icon ALWAYS visible in nav (was hidden <1100px). On mobile,
 * sits to the left of the hamburger so users can reach the drawer / cart
 * anchor without opening the mobile menu first. Override of main.css line
 * 645 (.nav__icon-btn @media (min-width: 1100px) { display: flex }). */
.nav__icon-btn.cart-btn {
	display: flex !important;
}

/**
 * KATA cart + mini-cart drawer + remove confirm modal styles
 * v5.25.2 — fixes Bruno feedback round 2
 *
 * Major changes from v5.25.1:
 *  - Cart head moved out of .kata-page--cart into shared .util-hero (dark
 *    band giving the fixed nav breathing room, matches Compat pattern).
 *  - Cart-empty drops own head band (was duplicating vehicle-selector title).
 *  - .li now uses grid-template-areas so wmeta + addons + remove btn
 *    (collected in .li__extras) span full width. Drives consistent layout
 *    in BOTH cart page and drawer (no narrow column wrapping).
 *  - Drawer footer CTAs in a single centered row (subtle ghost + primary).
 *  - WC notices live INSIDE cream section (after head) — no nav overlap.
 *  - Double-border bug fix: .li now uses adjacent-sibling for top border.
 *  - Reduced padding-block on cart section.
 */

/* ============================================================================
 * 1. CART PAGE — full-width cream section + dark util-hero on top
 * ========================================================================= */
.util-hero--cart {
	background: var(--c-black);
	color: var(--c-white);
	border-bottom: 0;
	/* Top padding clears the fixed nav (mirrors checkout) so the logo never
	   overlaps the eyebrow on mobile, where clamp(48px…) fell short of nav height.
	   Bottom stays tight — short title, no lede. */
	padding: calc(var(--nav-h, 84px) + 1.5rem) clamp(20px, 4vw, 48px) clamp(24px, 3vw, 40px);
}
.util-hero--cart .util-hero__title { color: var(--c-white); margin: 0; }
.util-hero--cart .eyebrow { color: var(--c-mute); }

.kata-page--cart {
	background: var(--c-cream);
	color: var(--c-ink);
	padding-block: clamp(2rem, 4vw, 3.5rem);
	width: 100%;
}

/* Inner 2-col grid */
.kata-page--cart .cart-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
}
@media (min-width: 960px) {
	.kata-page--cart .cart-grid {
		grid-template-columns: 2fr 1fr;
		gap: 2.5rem;
		align-items: start;
	}
	.kata-page--cart .cart-grid__aside {
		position: sticky;
		top: calc(var(--nav-h) + 1rem);
	}
}

/* WC notices in-section (success / info / error) */
.cart-notices {
	margin-bottom: 1.5rem;
}
.cart-notices:empty { display: none; }

/* ============================================================================
 * 2. CART ITEMS — sectioned tag + cards
 * ========================================================================= */
.cart-items {
	background: var(--c-white);
	border-radius: var(--r-card);
	border: 1px solid var(--c-ink-line);
	padding: .75rem 1.5rem;
}
.cart-items + .cart-items { margin-top: 1rem; }

.cart-section-tag {
	display: flex;
	align-items: center;
	gap: .625rem;
	padding-bottom: .625rem;
	margin-bottom: 0;
	/* No border-bottom — .li below provides its own visual separator via padding */
}
.cart-section-tag .eyebrow { margin: 0; }
.cart-section-tag__count {
	margin-left: .375rem;
	padding: 1px 8px;
	background: var(--c-cream);
	color: var(--c-ink);
	border-radius: var(--r-pill);
	font-size: 10px;
	font-weight: 600;
	font-family: var(--ff-mono);
}

/* ============================================================================
 * 3. LINE ITEM — grid-template-areas so .li__extras spans full width
 *    Layout: [media] [body] [price]  -- row 1
 *            [extras extras extras]  -- row 2 (wmeta + addons + remove)
 * ========================================================================= */
.li {
	display: grid;
	grid-template-columns: 88px 1fr auto;
	grid-template-areas:
		"media body price"
		"extras extras extras";
	column-gap: 1rem;
	row-gap: .5rem;
	padding: 1rem 0;
	border-top: 1px solid var(--c-ink-line);
	align-items: start;
}
/* First item in a section has no top border (visual sep is the section-tag) */
.cart-section-tag + .li,
.cart-items > .li:first-of-type {
	border-top: 0;
	padding-top: .25rem;
}
.li:last-of-type { padding-bottom: .25rem; }

.li__media { grid-area: media; }
.li__media {
	aspect-ratio: 16 / 9;
	background: var(--c-cream);
	border-radius: var(--r-sm);
	overflow: hidden;
}
.li__media img,
.li__media a img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.li__body { grid-area: body; min-width: 0; }

.li__title {
	font-family: var(--ff-body);
	font-weight: 500;
	font-size: 1rem;
	color: var(--c-ink);
	margin: 0 0 .25rem;
	line-height: 1.3;
}
.li__title a { color: inherit; text-decoration: none; }
.li__title a:hover { text-decoration: underline; text-underline-offset: 3px; }

.li__variation {
	font-size: .8125rem;
	color: var(--c-ink-mute);
	margin: 0;
}

.li__price,
.li__price-stack {
	grid-area: price;
	font-family: var(--ff-body);
	font-weight: 600;
	font-size: 1rem;
	color: var(--c-ink);
	text-align: right;
	font-variant-numeric: tabular-nums;
	white-space: nowrap;
}
.li__price-stack {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: .125rem;
}
.li__price-unit {
	font-size: .75rem;
	font-weight: 400;
	color: var(--c-ink-mute);
}

.li__extras {
	grid-area: extras;
	display: flex;
	flex-direction: column;
	gap: .5rem;
}

.li__remove {
	background: transparent;
	border: 0;
	font-size: .75rem;
	color: var(--c-ink-mute);
	text-decoration: underline;
	text-underline-offset: 3px;
	padding: .25rem 0;
	cursor: pointer;
	transition: color var(--dur-fast) var(--ease-out);
	font-family: inherit;
	font-weight: 500;
	align-self: flex-start;
}
.li__remove:hover { color: var(--c-err); }

/* ============================================================================
 * 4. WIZARD META — Fulfilment / Vehicle / Wheelarches definition list
 *    Now full-width (within .li__extras) — no narrow-column wrapping.
 * ========================================================================= */
.wmeta {
	margin: 0;
	padding: .625rem .875rem;
	background: var(--c-cream);
	border-radius: var(--r-sm);
	display: grid;
	grid-template-columns: max-content 1fr;
	gap: .25rem .875rem;
	font-size: .8125rem;
}
.wmeta dt {
	font-family: var(--ff-mono);
	font-size: .6875rem;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
	margin: 0;
	font-weight: 600;
	align-self: baseline;
}
.wmeta dd {
	margin: 0;
	color: var(--c-ink);
	font-weight: 500;
}
.wmeta dd em {
	font-style: normal;
	color: var(--c-gold-secondary);
	font-weight: 600;
}

/* ============================================================================
 * 5. ADDONS — bundled with parent kit · gold-secondary left rail
 * ========================================================================= */
.addons {
	margin: 0;
	padding: 0 0 0 .875rem;
	border-left: 2px solid var(--c-gold-secondary);
	list-style: none;
}
.addon {
	display: grid;
	grid-template-columns: 44px 1fr auto;
	gap: .625rem;
	padding: .5rem 0;
	border-top: 1px dashed var(--c-ink-line);
	align-items: center;
}
.addon:first-child { border-top: 0; padding-top: 0; }
.addon:last-child  { padding-bottom: 0; }
.addon__media {
	aspect-ratio: 16 / 9;
	border-radius: var(--r-sm);
	background: var(--c-cream);
	overflow: hidden;
}
.addon__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.addon__body { font-size: .8125rem; min-width: 0; }
.addon__title { font-weight: 500; color: var(--c-ink); margin: 0; line-height: 1.3; font-size: .875rem; }
.addon__bundle {
	display: block;
	margin-top: .125rem;
	font-size: .6875rem;
	color: var(--c-ink-mute);
	letter-spacing: .04em;
	text-transform: uppercase;
	font-family: var(--ff-mono);
}
.addon__price {
	font-weight: 600;
	font-size: .875rem;
	color: var(--c-ink);
	font-variant-numeric: tabular-nums;
}

/* ============================================================================
 * 6. RESERVATION — gold-tinted card distinguishing FC reservation deposits
 * ========================================================================= */
.li--reservation {
	background: linear-gradient(135deg, rgba(254, 197, 62, .08), rgba(254, 197, 62, .02));
	border-radius: var(--r-md);
	border-top: 0 !important;
	padding: 1rem;
	margin-top: .5rem;
}
.li--reservation__media {
	aspect-ratio: 16 / 9;
	background: linear-gradient(135deg, rgba(254, 197, 62, .45), rgba(254, 197, 62, .1));
	border-radius: var(--r-sm);
}
.li--reservation__badge-wrap { margin-top: 0; }

.badge {
	display: inline-block;
	padding: .1875rem .625rem;
	font-family: var(--ff-mono);
	font-size: .625rem;
	letter-spacing: .1em;
	text-transform: uppercase;
	background: var(--c-gold);
	color: var(--c-ink);
	border-radius: var(--r-pill);
	font-weight: 700;
}
.badge--soft { background: rgba(254, 197, 62, .22); color: var(--c-ink); }

/* ============================================================================
 * 7. QTY STEPPER — standalone accessories only
 * ========================================================================= */
.qty {
	display: inline-flex;
	align-items: center;
	border: 1px solid var(--c-ink-line);
	border-radius: var(--r-sm);
	overflow: hidden;
	align-self: flex-start;
}
.qty button {
	width: 32px; height: 32px;
	background: transparent;
	border: 0;
	font-size: 1rem;
	color: var(--c-ink);
	cursor: pointer;
	font-family: inherit;
	transition: background var(--dur-fast) var(--ease-out);
}
.qty button:hover { background: rgba(0, 0, 0, .05); }
.qty button:disabled { opacity: .4; cursor: not-allowed; }
.qty input {
	width: 40px; height: 32px;
	text-align: center;
	border: 0;
	border-left: 1px solid var(--c-ink-line);
	border-right: 1px solid var(--c-ink-line);
	background: transparent;
	font: inherit;
	-moz-appearance: textfield;
	color: var(--c-ink);
}
.qty input::-webkit-outer-spin-button,
.qty input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

/* ============================================================================
 * 8. EMPTY CART HEADLINE + CTA BAND
 *    v5.25.4: own headline ("Your cart is empty.") rendered ABOVE the
 *    vehicle-selector partial; the partial's own section__head is hidden
 *    here (Bruno feedback — empty cart should read "Your cart is empty"
 *    as primary title, not "What are you driving?").
 * ========================================================================= */
.kata-cart-empty-headline {
	background: var(--c-black);
	color: var(--c-white);
	padding: clamp(48px, 6vw, 80px) clamp(20px, 4vw, 48px) clamp(24px, 3vw, 40px);
}
.kata-cart-empty-headline .section__head {
	text-align: center;
}
.kata-cart-empty-headline .section__title {
	color: var(--c-white);
	margin-top: 1rem;
}
.kata-cart-empty-headline .section__lede {
	color: var(--c-mute);
	margin-top: .875rem;
	margin-inline: auto;
}

/* Hide vehicle-selector's own header in cart-empty context (we render ours above) */
.woo-main--full .vehicles .section__head { display: none; }
.woo-main--full .vehicles { padding-top: 0; padding-bottom: 0; }
.kata-cart-empty-cta {
	background: var(--c-black);
	padding-top: clamp(1.25rem, 2.5vw, 2rem);
	padding-bottom: clamp(4rem, 8vw, 7rem);
	text-align: center;
}
.kata-cart-empty-cta .kata-container {
	display: flex;
	justify-content: center;
}

/* ============================================================================
 * 9. ORDER SUMMARY — sticky sidebar card
 * ========================================================================= */
.summary {
	background: var(--c-white);
	border-radius: var(--r-card);
	border: 1px solid var(--c-ink-line);
	padding: 1.5rem;
}
.summary__title {
	font-family: var(--ff-display);
	font-weight: 400;
	font-size: clamp(1.5rem, 2.2vw, 1.75rem);
	letter-spacing: .04em;
	line-height: 1;
	text-transform: uppercase;
	margin: 0 0 1rem;
	color: var(--c-ink);
}

.summary__rows { display: grid; gap: 0; }

.summary__row {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	padding: .375rem 0;
	font-size: .875rem;
	color: var(--c-ink);
}
.summary__row span:last-child { font-variant-numeric: tabular-nums; }
.summary__row .calc-pending { color: var(--c-ink-mute); font-style: italic; font-size: .8125rem; }
.summary__row--tax span { color: var(--c-ink-mute); }
.summary__row--promo span { color: var(--c-gold-dark); font-weight: 600; }

.summary__row--total {
	margin-top: .75rem;
	padding: .875rem 0 .375rem;
	border-top: 1px solid var(--c-ink-line);
	font-family: var(--ff-display);
	font-weight: 400;
	font-size: 1.625rem;
	letter-spacing: .04em;
	text-transform: uppercase;
}
.summary__total-val { color: var(--c-ink); }

.summary__gst-note {
	font-size: .75rem;
	color: var(--c-ink-mute);
	margin: .25rem 0 0;
}

/* Coupon */
.summary__coupon { margin-top: .875rem; }
.coupon-toggle {
	background: transparent;
	border: 0;
	padding: .5rem 0;
	font-size: .8125rem;
	color: var(--c-ink);
	text-decoration: underline;
	text-underline-offset: 3px;
	display: inline-flex;
	align-items: center;
	gap: .375rem;
	cursor: pointer;
	font-family: inherit;
}
.coupon-toggle svg { width: 14px; height: 14px; flex-shrink: 0; }
.coupon-form {
	display: none;
	margin-top: .5rem;
	gap: .5rem;
	grid-template-columns: 1fr auto;
}
.coupon-form.is-open { display: grid; }
.coupon-form .input,
.coupon-form input[type="text"] {
	padding: .625rem .75rem;
	font-size: .8125rem;
	background: var(--c-white);
	border: 1px solid var(--c-ink-line);
	border-radius: var(--r-md);
	color: var(--c-ink);
	font-family: inherit;
	transition: border-color var(--dur-fast) var(--ease-out);
}
.coupon-form input:focus {
	outline: none;
	border-color: var(--c-ink);
	box-shadow: 0 0 0 1px var(--c-ink);
}

/* Checkout CTA — full width within the summary card */
.summary__cta { margin-top: 1.25rem; }
.summary__cta .btn {
	width: 100%;
	justify-content: center;
}

/* Trust strip — 4 small items */
.summary__trust {
	margin-top: 1.25rem;
	padding-top: 1.125rem;
	border-top: 1px solid var(--c-ink-line);
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: .625rem 1rem;
	font-size: .75rem;
	color: var(--c-ink-mute);
}
.summary__trust > div {
	display: inline-flex;
	align-items: flex-start;
	gap: .5rem;
	line-height: 1.35;
}
.summary__trust svg {
	width: 16px;
	height: 16px;
	color: var(--c-gold-secondary);
	flex-shrink: 0;
	display: block;
}

/* Help strip — dark bg, white text/icons (Bruno feedback v5.25.3) */
.summary__help {
	margin-top: 1rem;
	padding: .75rem 1rem;
	background: var(--c-dark);
	border-radius: var(--r-md);
	display: flex;
	align-items: center;
	gap: .75rem;
	font-size: .8125rem;
	color: var(--c-off);
	flex-wrap: wrap;
}
.summary__help a {
	color: var(--c-off);
	font-weight: 500;
	text-decoration: underline;
	text-underline-offset: 3px;
	transition: color var(--dur-fast) var(--ease-out);
}
.summary__help a:hover { color: var(--c-gold); }
.summary__help-icons {
	display: inline-flex;
	gap: .375rem;
	margin-left: auto;
}
.summary__help-icons a {
	display: inline-grid;
	place-items: center;
	width: 30px;
	height: 30px;
	border: 1px solid rgba(255, 255, 255, .18);
	border-radius: 50%;
	color: var(--c-off);
	transition: border-color var(--dur-fast) var(--ease-out),
				background var(--dur-fast) var(--ease-out),
				color var(--dur-fast) var(--ease-out);
}
.summary__help-icons a:hover {
	border-color: var(--c-gold);
	background: var(--c-gold);
	color: var(--c-ink);
}
.summary__help-icons svg {
	width: 14px;
	height: 14px;
}

/* ============================================================================
 * 10. MOBILE STICKY BOTTOMBAR — REMOVED (v5.47.0, Bruno feedback)
 *     The bar overlapped content and was unwanted. Markup (cart.php) +
 *     kata-on-cart body class / whatsapp-fab hide (functions.php) were removed
 *     alongside. The summary card CTA already provides the mobile checkout entry.
 * ========================================================================= */

/* ============================================================================
 * 11. MINI-CART OFFCANVAS DRAWER
 *     .li markup is shared with cart page (grid-template-areas spans extras
 *     across all columns → wmeta + addons render full drawer width).
 * ========================================================================= */
.mc-drawer {
	position: fixed;
	top: 0; right: 0;
	width: 100%;
	max-width: 420px;
	height: 100dvh;
	background: var(--c-dark);
	color: var(--c-off);
	z-index: 1000;
	display: flex;
	flex-direction: column;
	transform: translateX(100%);
	transition: transform var(--dur-snap) var(--ease-out);
	box-shadow: -1.5rem 0 3.75rem rgba(0, 0, 0, .35);
	visibility: hidden;
}
.mc-drawer.is-open { transform: translateX(0); visibility: visible; }

.mc-drawer__backdrop {
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, 0);
	z-index: 999;
	pointer-events: none;
	transition: background var(--dur-snap) var(--ease-out);
}
.mc-drawer__backdrop.is-active {
	background: rgba(0, 0, 0, .5);
	pointer-events: auto;
}

.mc-drawer__head {
	padding: 1.375rem 1.5rem 1.125rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	border-bottom: 1px solid var(--c-line);
	flex-shrink: 0;
}
.mc-drawer__title {
	font-family: var(--ff-display);
	font-weight: 400;
	font-size: 1.375rem;
	letter-spacing: .06em;
	text-transform: uppercase;
	color: var(--c-off);
	margin: 0;
}
.mc-drawer__count {
	font-family: var(--ff-mono);
	font-size: .75rem;
	color: var(--c-gold);
	letter-spacing: .08em;
	margin-left: .5rem;
	text-transform: uppercase;
}
.mc-drawer__close {
	background: transparent;
	border: 0;
	width: 36px; height: 36px;
	display: grid;
	place-items: center;
	color: var(--c-off);
	border-radius: 50%;
	cursor: pointer;
	transition: background var(--dur-fast) var(--ease-out);
}
.mc-drawer__close:hover { background: rgba(255, 255, 255, .08); }

.mc-drawer__body {
	flex: 1;
	overflow-y: auto;
	overscroll-behavior: contain;
	padding: 0 1.5rem 1.5rem;
	-webkit-overflow-scrolling: touch;
}

/* Drawer-scoped overrides — line item dark variant.
 * Markup inherits grid-template-areas so extras (wmeta + addons + remove)
 * span the full drawer body width — no narrow-column wrapping. */
.mc-drawer .li {
	border-top-color: var(--c-line);
	grid-template-columns: 64px 1fr auto;
	column-gap: .75rem;
}
.mc-drawer .li__title { color: var(--c-off); font-size: .9375rem; }
.mc-drawer .li__variation { color: var(--c-mute); }
.mc-drawer .li__price { color: var(--c-off); font-size: .9375rem; }
.mc-drawer .li__remove { color: var(--c-mute); }
.mc-drawer .li__remove:hover { color: var(--c-gold); }
.mc-drawer .wmeta { background: rgba(255, 255, 255, .04); }
.mc-drawer .wmeta dt { color: var(--c-mute); }
.mc-drawer .wmeta dd { color: var(--c-off); }
.mc-drawer .addon { border-top-color: var(--c-line); }
.mc-drawer .addon__title { color: var(--c-off); }
.mc-drawer .addon__bundle { color: var(--c-mute); }
.mc-drawer .addon__price { color: var(--c-off); }
.mc-drawer .addon__media { background: rgba(255, 255, 255, .04); }
.mc-drawer .li__media { background: rgba(255, 255, 255, .04); }
.mc-drawer .li--reservation {
	background: linear-gradient(135deg, rgba(254, 197, 62, .08), rgba(254, 197, 62, .02));
}

.mc-drawer__foot {
	padding: 1.125rem 1.5rem 1.375rem;
	border-top: 1px solid var(--c-line);
	flex-shrink: 0;
	background: var(--c-dark-2);
}
.mc-drawer__subtotal {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	margin-bottom: .5rem;
	font-size: .875rem;
}
.mc-drawer__subtotal-val {
	font-family: var(--ff-display);
	font-weight: 400;
	font-size: 1.5rem;
	color: var(--c-off);
	letter-spacing: .04em;
	font-variant-numeric: tabular-nums;
}
.mc-drawer__gst {
	font-size: .6875rem;
	color: var(--c-mute-2);
	margin: 0 0 1rem;
}

/* CTAs in a single centered row, subtle weights */
.mc-drawer__cta-row {
	display: flex;
	gap: .5rem;
	align-items: stretch;
}
.mc-drawer__cta-row .btn {
	flex: 1;
	justify-content: center;
	text-align: center;
}

/* Drawer EMPTY state */
.mc-drawer__empty {
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 2rem 1.5rem;
	text-align: center;
	gap: 1.125rem;
}
.mc-drawer__illus {
	width: 110px;
	height: 110px;
	border-radius: 50%;
	background: radial-gradient(circle at 30% 30%, rgba(254, 197, 62, .12), transparent 60%);
	display: grid;
	place-items: center;
	color: var(--c-gold);
}
.mc-drawer__empty-h {
	font-family: var(--ff-display);
	font-weight: 400;
	font-size: 1.625rem;
	letter-spacing: .04em;
	text-transform: uppercase;
	margin: 0;
	color: var(--c-off);
}
.mc-drawer__empty-p {
	font-size: .875rem;
	color: var(--c-mute);
	max-width: 26ch;
	margin: 0;
}

/* Body lock when drawer open */
body.kata-cart-drawer-open { overflow: hidden; }

/* ============================================================================
 * 12. REMOVE CONFIRM MODAL — JS-injected overlay
 * ========================================================================= */
.kata-modal-backdrop {
	position: fixed;
	inset: 0;
	background: rgba(15, 15, 15, .6);
	display: grid;
	place-items: center;
	padding: 1.5rem;
	z-index: 1100;
	opacity: 0;
	transition: opacity var(--dur-snap) var(--ease-out);
}
.kata-modal-backdrop.is-open { opacity: 1; }

.kata-modal {
	background: var(--c-white);
	color: var(--c-ink);
	border-radius: var(--r-card);
	padding: 1.75rem;
	max-width: 440px;
	width: 100%;
	display: grid;
	gap: .875rem;
	transform: scale(.96);
	transition: transform var(--dur-snap) var(--ease-out);
}
.kata-modal-backdrop.is-open .kata-modal { transform: scale(1); }

.kata-modal__title {
	font-family: var(--ff-display);
	font-weight: 400;
	font-size: 1.5rem;
	letter-spacing: .04em;
	line-height: 1.1;
	text-transform: uppercase;
	margin: 0;
	color: var(--c-ink);
}
.kata-modal__body { font-size: .875rem; color: var(--c-ink-mute); margin: 0; }
.kata-modal__body b { color: var(--c-ink); font-weight: 500; }
.kata-modal__list {
	list-style: disc;
	padding-left: 1.25rem;
	font-size: .8125rem;
	color: var(--c-ink-mute);
	margin: 0;
}
.kata-modal__btns {
	display: flex;
	gap: .625rem;
	justify-content: flex-end;
	margin-top: .375rem;
	flex-wrap: wrap;
}

/* ============================================================================
 * 13. WC NOTICES — dark editorial style override (no green WC defaults)
 *     Sits INSIDE the cream cart section now (before cart-grid) — no nav overlap.
 * ========================================================================= */
.cart-notices .woocommerce-message,
.cart-notices .woocommerce-info,
.cart-notices .woocommerce-error {
	background: var(--c-white);
	color: var(--c-ink);
	border: 1px solid var(--c-ink-line);
	border-left: 3px solid var(--c-gold-secondary);
	padding: .875rem 1.125rem;
	margin: 0 0 .75rem;
	border-radius: var(--r-md);
	font-size: .875rem;
	list-style: none;
	display: flex;
	align-items: center;
	gap: .875rem;
	flex-wrap: wrap;
}
.cart-notices .woocommerce-message::before,
.cart-notices .woocommerce-info::before,
.cart-notices .woocommerce-error::before { display: none; }
.cart-notices .woocommerce-error { border-left-color: var(--c-err); }
.cart-notices .woocommerce-message .button,
.cart-notices .woocommerce-info .button {
	margin-left: auto;
	background: var(--c-ink);
	color: var(--c-white);
	padding: 6px 14px;
	border-radius: var(--r-pill);
	font-size: .75rem;
	font-weight: 600;
	text-decoration: none;
}
.cart-notices .woocommerce-message .button:hover {
	background: var(--c-gold);
	color: var(--c-ink);
}

/* ============================================================================
 * 14. REDUCED MOTION
 * ========================================================================= */
@media (prefers-reduced-motion: reduce) {
	.mc-drawer,
	.mc-drawer__backdrop,
	.kata-modal-backdrop,
	.kata-modal,
	.li__remove,
	.qty button,
	.summary__help-icons a {
		transition: none !important;
	}
}
