/*
 * Cart / checkout add-ons rail — aligns with Made By Me Templates “program-split” palette (see mbm-templates.css).
 */

/* -------------------------------------------------------------------------
   Placement: above order summary (Cart / Checkout block columns)
   ------------------------------------------------------------------------- */

.mbm-cart-add-ons-anchor {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}

.mbm-cart-add-ons-anchor--above-order-summary {
	margin-top: 0;
	margin-bottom: 1rem;
}

.wp-block-woocommerce-cart .mbm-cart-add-ons-anchor--above-order-summary,
.wc-block-cart .mbm-cart-add-ons-anchor--above-order-summary {
	width: 100%;
}

/* -------------------------------------------------------------------------
   Brand rail — Woo Cart block look (blue type + rules); pink frame only here
   ------------------------------------------------------------------------- */

.mbm-cart-add-ons.mbm-cart-add-ons--mbm-brand {
	--mbm-cart-accent: #0073aa;
	--mbm-cart-accent-soft: rgba(0, 115, 170, 0.1);
	--mbm-cart-line: rgba(0, 115, 170, 0.28);
	--mbm-pink-frame: #d4236a;
	--mbm-pink-frame-soft: rgba(212, 35, 106, 0.08);
	--mbm-panel-bg: #fffdf9;
	--mbm-muted: #5c6378;
	/* Unified MBM pill CTA (pink · yellow ring · glow) */
	--mbm-split-pink: #ff1493;
	--mbm-split-yellow-ring: #fedf00;
	--mbm-split-shadow: 0 4px 15px rgba(255, 20, 147, 0.4);
	--mbm-split-yellow-focus: #fedf00;
	--mbm-split-display: Nunito, system-ui, -apple-system, 'Segoe UI', sans-serif;

	margin: clamp(1.25rem, 2.5vw, 1.85rem) 0;
	font-family: inherit;
	color: var(--mbm-cart-accent);
	-webkit-font-smoothing: antialiased;
}

.mbm-cart-add-ons:not(.mbm-cart-add-ons--mbm-brand) {
	--mbm-addon-rose: rgba(251, 113, 182, 0.95);
	--mbm-addon-rose-soft: rgba(253, 164, 175, 0.45);
	--mbm-addon-sky: #219ebc;
	--mbm-addon-cream: #fffdf9;
	margin: clamp(1.85rem, 3vw, 2.85rem) 0 clamp(1.65rem, 3vw, 2.65rem);
	font-family:
		'Nunito',
		system-ui,
		-apple-system,
		BlinkMacSystemFont,
		'Segoe UI',
		sans-serif;
}

.mbm-cart-add-ons:last-child {
	margin-bottom: 0;
}

.mbm-cart-add-ons__panel {
	position: relative;
	border-radius: clamp(1.15rem, 2.5vw, 1.55rem);
	overflow: visible;
	isolation: isolate;
	padding: clamp(1.05rem, 2.85vw, 1.85rem)
		clamp(0.75rem, 2.5vw, 1.6rem)
		clamp(1.15rem, 3vw, 2rem);
}

.mbm-cart-add-ons--mbm-brand .mbm-cart-add-ons__panel {
	border-radius: 6px;
	padding: clamp(0.85rem, 2vw, 1.15rem) clamp(1rem, 2.5vw, 1.35rem) clamp(1rem, 2.5vw, 1.25rem);
	background: var(--mbm-panel-bg);
	border: 2px solid var(--mbm-pink-frame);
	box-shadow: none;
}

.mbm-cart-add-ons--mbm-brand .mbm-cart-add-ons__panel::before {
	display: none;
}

.mbm-cart-add-ons--mbm-brand .mbm-cart-add-ons__confetti {
	display: none;
}

.mbm-cart-add-ons:not(.mbm-cart-add-ons--mbm-brand) .mbm-cart-add-ons__panel {
	border: 2px dashed rgba(34, 34, 45, 0.12);
	box-shadow:
		0 1.15rem 2.85rem rgba(33, 158, 188, 0.16),
		0 8px 0 rgba(251, 191, 36, 0.28);
	background:
		radial-gradient(120px 92px at 12% -8%, rgba(251, 113, 182, 0.18), transparent 75%),
		radial-gradient(160px 120px at 96% 8%, rgba(33, 158, 188, 0.16), transparent 75%),
		linear-gradient(135deg, #fffdf9 0%, #fdf3ff 100%);
}

.mbm-cart-add-ons.is-checkout:not(.mbm-cart-add-ons--mbm-brand) .mbm-cart-add-ons__panel {
	box-shadow:
		0 0.95rem 2.15rem rgba(33, 158, 188, 0.12),
		0 6px 0 rgba(251, 191, 36, 0.22);
}

.is-checkout.mbm-cart-add-ons--mbm-brand .mbm-cart-add-ons__panel {
	box-shadow: none;
}

.mbm-cart-add-ons--mbm-brand .mbm-cart-add-ons__panel::after {
	opacity: 0;
	display: none;
}

.mbm-cart-add-ons__panel::after {
	content: '';
	position: absolute;
	inset: 0;
	pointer-events: none;
	border-radius: inherit;
	background: radial-gradient(circle at 50% -10%, rgba(255, 255, 255, 0.7), transparent 72%);
	opacity: 0.75;
	z-index: 0;
}

.mbm-cart-add-ons__confetti {
	position: absolute;
	inset: -8% auto auto 8%;
	width: clamp(220px, 34vw, 320px);
	height: clamp(220px, 34vw, 320px);
	background:
		conic-gradient(
			from 120deg at 42% 40%,
			rgba(251, 191, 36, 0.18),
			transparent 140deg,
			rgba(33, 158, 188, 0.16),
			transparent 285deg,
			rgba(251, 113, 182, 0.15)
		);
	filter: blur(30px);
	opacity: 0.55;
	transform: rotate(-6deg);
	pointer-events: none;
	z-index: 0;
}

.mbm-cart-add-ons__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 0.42rem;
	margin: 0 0 0.5rem;
	padding: 0.28rem 0.92rem;
	font-size: 0.73rem;
	font-weight: 800;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: #9d174d;
	border-radius: 999px;
	background: rgba(255, 237, 244, 0.95);
	box-shadow:
		inset 0 0 0 1px rgba(251, 113, 182, 0.45),
		0 12px 32px rgba(251, 113, 182, 0.12);
	position: relative;
	z-index: 1;
}

.mbm-cart-add-ons--mbm-brand .mbm-cart-add-ons__eyebrow {
	margin: 0 0 0.35rem;
	padding: 0.22rem 0.65rem;
	font-size: 0.65rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--mbm-pink-frame);
	background: var(--mbm-pink-frame-soft);
	border: 1px solid rgba(212, 35, 106, 0.45);
	border-radius: 4px;
	box-shadow: none;
}

.mbm-cart-add-ons__headline {
	margin: 0 0 0.5rem;
	font-size: clamp(1.32rem, 3.2vw, 1.92rem);
	font-weight: 800;
	line-height: 1.1;
	color: #1f1630;
	text-wrap: balance;
	position: relative;
	z-index: 1;
}

.mbm-cart-add-ons--mbm-brand .mbm-cart-add-ons__headline {
	margin: 0 0 0.65rem;
	padding-bottom: 0.55rem;
	border-bottom: 1px solid var(--mbm-cart-line);
	font-size: clamp(0.78rem, 1.6vw, 0.85rem);
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	line-height: 1.35;
	color: var(--mbm-cart-accent);
}

.mbm-cart-add-ons__blurb {
	margin: 0 0 1rem;
	max-width: 46ch;
	color: rgba(43, 45, 66, 0.78);
	font-weight: 600;
	line-height: 1.55;
	position: relative;
	z-index: 1;
	text-wrap: pretty;
}

.mbm-cart-add-ons--mbm-brand .mbm-cart-add-ons__blurb {
	margin: 0 0 0.85rem;
	max-width: none;
	font-size: 0.875rem;
	font-weight: 500;
	line-height: 1.55;
	color: var(--mbm-muted);
}

/* Same DOM/classes as Woo Cart block line items table — MBM only adds the pink panel frame */
.mbm-cart-add-ons--wc-table .mbm-cart-add-ons__items {
	width: 100%;
	margin: 0;
	background: transparent !important;
}

.mbm-cart-add-ons--wc-table .mbm-cart-add-ons__items .wc-block-cart-items__header {
	font-size: var(--wp--preset--font-size--small, 14px);
	line-height: 1.4;
	text-transform: uppercase;
}

.mbm-cart-add-ons--wc-table .mbm-cart-add-ons__items tbody .wc-block-cart-items__row {
	border-bottom: 1px solid color-mix(in srgb, currentColor 18%, transparent);
}

.mbm-cart-add-ons--wc-table .mbm-cart-add-ons__items tbody .wc-block-cart-items__row:last-child {
	border-bottom: 0;
}

.mbm-cart-add-ons--wc-table .mbm-cart-add-ons__total-actions {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 0.5rem;
	margin-top: 0.35rem;
}

.mbm-cart-add-ons--wc-table .wc-block-cart-item__total .price {
	text-align: right;
}

.mbm-cart-add-ons__price {
	flex: 1 1 auto;
	min-width: 5.5rem;
	font-weight: 800;
	color: #112;
}

.mbm-cart-add-ons__cta-stack {
	display: flex;
	flex-flow: column nowrap;
	align-items: flex-end;
	gap: 0.35rem;
	flex: 0 1 auto;
	max-width: 100%;
}

.mbm-cart-add-ons__oos {
	max-width: 18ch;
	font-size: 0.72rem;
	font-weight: 700;
	line-height: 1.35;
	text-align: right;
	color: #b45309;
}

.mbm-cart-add-ons__total-actions .mbm-cart-add-ons__pulse-btn {
	justify-self: end;
	flex-shrink: 0;
	box-shadow:
		inset 0 0 0 1px rgba(255, 255, 255, 0.35),
		0 14px 32px rgba(251, 113, 182, 0.2);
	transition:
		transform 160ms ease,
		box-shadow 160ms ease;
}

.mbm-cart-add-ons .mbm-cart-add-ons__pulse-btn:hover {
	transform: translateY(-1px);
	box-shadow:
		inset 0 0 0 1px rgba(255, 255, 255, 0.35),
		0 22px 40px rgba(33, 158, 188, 0.25);
	text-decoration: none !important;
}

.mbm-cart-add-ons--mbm-brand .mbm-cart-add-ons__pulse-btn:hover {
	transform: none;
}

.mbm-cart-add-ons .button.mbm-cart-add-ons__pulse-btn {
	font-weight: 800 !important;
	letter-spacing: 0.01em !important;
	background: linear-gradient(125deg, #fb718a, #fde047 155%) !important;
	color: #0f172a !important;
	border: none !important;
	border-radius: 999px !important;
	padding-inline: clamp(14px, 3vw, 18px);
	text-transform: uppercase;
	font-size: 0.75rem !important;
}

.mbm-cart-add-ons--mbm-brand .button.mbm-cart-add-ons__pulse-btn {
	background: #fff !important;
	color: var(--mbm-cart-accent) !important;
	border: 1px solid var(--mbm-cart-accent) !important;
	border-radius: 4px !important;
	padding: 0.35rem 0.75rem !important;
	font-size: 0.8125rem !important;
	font-weight: 600 !important;
	text-transform: none !important;
	letter-spacing: normal !important;
	box-shadow: none !important;
	text-shadow: none !important;
	min-height: 2.25rem;
	line-height: 1.25 !important;
}

.mbm-cart-add-ons--mbm-brand .button.mbm-cart-add-ons__pulse-btn:hover {
	filter: none;
	background: var(--mbm-cart-accent-soft) !important;
	box-shadow: none !important;
}

.mbm-cart-add-ons--mbm-brand .button.mbm-cart-add-ons__pulse-btn:focus {
	outline: 2px solid var(--mbm-cart-accent);
	outline-offset: 2px;
}

/* Primary add — same pill as templates “Register Now” */
.mbm-cart-add-ons .button.mbm-cart-add-ons__pulse-btn.mbm-cart-add-ons__cta--program-split {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	min-width: min(100%, 12rem);
	box-sizing: border-box;
	margin-top: 0;
	padding: 0.75rem 1.25rem;
	font-family: var(--mbm-split-display);
	font-weight: 800;
	font-size: 1rem;
	letter-spacing: 0.02em;
	line-height: 1.25 !important;
	text-transform: none !important;
	color: #fff !important;
	text-shadow: 0 1px 0 rgba(0, 0, 0, 0.12);
	background: linear-gradient(180deg, #ff3dac 0%, var(--mbm-split-pink) 48%, #e5127e 100%) !important;
	border: 2px solid var(--mbm-split-yellow-ring) !important;
	border-radius: 999px;
	box-shadow: var(--mbm-split-shadow);
	transition: transform 0.15s ease, box-shadow 0.15s ease, filter 0.15s ease;
	text-decoration: none !important;
	cursor: pointer;
	min-height: auto;
}

.mbm-cart-add-ons--mbm-brand .button.mbm-cart-add-ons__pulse-btn.mbm-cart-add-ons__cta--program-split {
	text-shadow: 0 1px 0 rgba(0, 0, 0, 0.12) !important;
}

.mbm-cart-add-ons .button.mbm-cart-add-ons__pulse-btn.mbm-cart-add-ons__cta--program-split:hover {
	filter: brightness(1.05);
	transform: translateY(-2px);
	text-decoration: none !important;
	box-shadow:
		0 6px 18px rgba(255, 20, 147, 0.45),
		0 4px 12px rgba(255, 20, 147, 0.28);
}

.mbm-cart-add-ons--mbm-brand .button.mbm-cart-add-ons__pulse-btn.mbm-cart-add-ons__cta--program-split:hover {
	background: linear-gradient(180deg, #ff3dac 0%, var(--mbm-split-pink) 48%, #e5127e 100%) !important;
	filter: brightness(1.05);
}

.mbm-cart-add-ons .button.mbm-cart-add-ons__pulse-btn.mbm-cart-add-ons__cta--program-split:focus-visible {
	outline: 3px solid var(--mbm-split-yellow-focus);
	outline-offset: 2px;
}

@media (prefers-reduced-motion: reduce) {
	.mbm-cart-add-ons .button.mbm-cart-add-ons__pulse-btn.mbm-cart-add-ons__cta--program-split,
	.mbm-cart-add-ons .button.mbm-cart-add-ons__pulse-btn.mbm-cart-add-ons__cta--program-split:hover {
		transition: none;
		transform: none;
	}
}

.mbm-cart-add-ons .button.mbm-cart-add-ons__pulse-btn.ghost {
	background: transparent !important;
	color: rgba(157, 23, 77, 0.94) !important;
	border: 1px dashed rgba(251, 113, 182, 0.6) !important;
	box-shadow: none !important;
}

.mbm-cart-add-ons .button.mbm-cart-add-ons__pulse-btn.ghost:hover {
	background: rgba(255, 255, 255, 0.65) !important;
}

.mbm-cart-add-ons--mbm-brand .button.mbm-cart-add-ons__pulse-btn.ghost {
	background: #fff !important;
	color: var(--mbm-cart-accent) !important;
	border: 1px dashed rgba(212, 35, 106, 0.55) !important;
	box-shadow: none !important;
}

.mbm-cart-add-ons--mbm-brand .button.mbm-cart-add-ons__pulse-btn.ghost:hover {
	background: rgba(212, 35, 106, 0.06) !important;
}

@media (prefers-reduced-motion: reduce) {
	.mbm-cart-add-ons__total-actions .mbm-cart-add-ons__pulse-btn,
	.mbm-cart-add-ons__total-actions .mbm-cart-add-ons__pulse-btn:hover {
		transition: none;
		transform: none;
	}
}

.mbm-cart-add-ons__price .amount {
	letter-spacing: 0.02em;
}

.mbm-cart-add-ons__price del {
	font-weight: 600;
	opacity: 0.72;
}

.mbm-cart-add-ons__divider {
	display: none;
}

.mbm-cart-add-ons__microproof {
	position: relative;
	z-index: 1;
	margin: 0.85rem 0 0;
	display: flex;
	align-items: flex-start;
	gap: 0.6rem;
	padding: 0.6rem 0.85rem;
	font-size: 0.845rem;
	line-height: 1.45;
	font-weight: 600;
	color: rgba(43, 45, 66, 0.78);
	border-radius: 0.85rem;
	background: rgba(255, 253, 247, 0.88);
	box-shadow: inset 0 0 0 1px rgba(33, 158, 188, 0.14);
}

.mbm-cart-add-ons__pulse-dot {
	width: 11px;
	height: 11px;
	margin-top: 0.4em;
	flex-shrink: 0;
	border-radius: 999px;
	background: radial-gradient(circle at 38% 32%, rgba(253, 224, 71, 0.95), rgba(34, 197, 94, 0.88));
	box-shadow:
		0 0 0 3px rgba(34, 197, 94, 0.15),
		0 12px 18px rgba(33, 158, 188, 0.15);
	animation: mbm-addon-pulse-dot 2.4s ease-in-out infinite;
}

@media (prefers-reduced-motion: reduce) {
	.mbm-cart-add-ons__pulse-dot {
		animation: none;
	}
}

@keyframes mbm-addon-pulse-dot {
	0%,
	100% {
		transform: scale(1);
		box-shadow:
			0 0 0 3px rgba(34, 197, 94, 0.15),
			0 12px 18px rgba(33, 158, 188, 0.15);
	}
	45% {
		transform: scale(1.06);
		box-shadow:
			0 0 0 8px rgba(34, 197, 94, 0.08),
			0 12px 18px rgba(33, 158, 188, 0.12);
	}
}

.mbm-cart-addon-pill {
	display: inline-flex;
	margin-top: 0.35rem;
	padding: 0.15rem 0.55rem;
	font-size: 0.71rem;
	font-weight: 800;
	line-height: 1.35;
	border-radius: 999px;
	color: rgb(157, 23, 77);
	background: rgba(255, 230, 240, 0.95);
	border: 1px solid rgba(251, 113, 182, 0.42);
	flex-wrap: nowrap;
	align-items: center;
	gap: 0.2rem;
}

.mbm-cart-addon-row-accent td:first-child::before {
	content: '';
	display: inline-block;
	width: 12px;
	height: 24px;
	margin-right: 0.45rem;
	background: radial-gradient(circle at 42% 32%, rgba(251, 191, 36, 0.88), transparent 74%);
	vertical-align: -0.3em;
}

