/* ===========================================================================
   Box-builder additions.
   Everything heavy (.builder-step, .flavour-card, .builder-summary, etc.)
   is already in style.css — this file only adds the bits unique to the box
   product page: the illustrated cavity-fill SVG, the per-card raspberry
   swatch ring when something's picked, and the review-step coloured dot.
   =========================================================================== */

/* --- box illustration inside the summary aside ------------------------ */
.builder-summary__box-figure {
	margin: 0 0 var(--space-md);
	width: 100%;
	background: linear-gradient(160deg, var(--color-cream) 0%, var(--color-creme-pat, #F0E0B7) 100%);
	border-radius: var(--border-radius-lg, 12px);
	padding: var(--space-md);
	box-shadow: inset 0 0 0 1.5px rgba(183, 121, 43, 0.18), 0 8px 24px rgba(60, 30, 15, 0.12);
}
.builder-summary__box-figure svg {
	display: block;
	width: 100%;
	height: auto;
	border-radius: var(--border-radius);
	filter: drop-shadow(0 6px 16px rgba(60, 30, 15, 0.20));
}

/* --- HTML box tray ---------------------------------------------------- */
.box-tray {
	display: grid;
	grid-template-columns: repeat(var(--cb-cols, 3), 1fr);
	gap: clamp(5px, 1.2vw, 9px);
	padding: var(--space-md);
	background: linear-gradient(160deg, #FBF2D9 0%, #EDD9A8 100%);
	border-radius: var(--border-radius);
	aspect-ratio: 2.38;
	box-shadow:
		inset 0 0 0 2px rgba(183, 121, 43, 0.28),
		inset 0 6px 16px rgba(60, 30, 15, 0.08);
}

/* --- cavity states ---------------------------------------------------- */
.cb-cavity {
	position: relative;
	aspect-ratio: 1;
}
.cb-cavity__ring {
	position: absolute;
	inset: 10%;
	border-radius: 50%;
	border: 2px dashed rgba(183, 121, 43, 0.55);
	transition: opacity 0.4s ease;
}
.cb-cavity__fill {
	position: absolute;
	inset: 10%;
	border-radius: 50%;
	background-color: transparent;
	transform-origin: center;
	transform: scale(0.6);
	transition: transform 0.45s cubic-bezier(0.4, 1.6, 0.4, 1), background-color 0.35s ease;
}
.cb-cavity[data-empty="0"] .cb-cavity__ring { opacity: 0; }
.cb-cavity[data-empty="0"] .cb-cavity__fill { transform: scale(1); }

/* --- step progress on the box product page — full container width --- */
.step-progress {
	width: 100%;
	margin: 0 0 var(--space-md);
}

/* --- flavour-card raspberry highlight when picked -------------------- */
.flavour-card .flavour-card__qty-val[data-qty]:not([data-qty="0"]) {
	color: var(--color-raspberry-red);
	font-weight: 700;
}
.flavour-card:has(.flavour-card__qty-val[data-qty]:not([data-qty="0"])) {
	border-color: var(--cb-swatch, var(--color-golden-bun));
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--cb-swatch, var(--color-golden-bun)) 18%, transparent);
}

/* --- step 3 review card --------------------------------------------- */
.builder-review {
	margin: var(--space-lg) 0;
}
.builder-review__card {
	background: #fff;
	border: 1.5px solid var(--color-biscuit);
	border-radius: var(--border-radius-xl);
	overflow: hidden;
	box-shadow: 0 14px 32px rgba(60, 30, 15, 0.10);
}

/* Hero strip — box image + name + price */
.builder-review__hero {
	display: flex;
	align-items: center;
	gap: var(--space-lg);
	padding: var(--space-lg) var(--space-xl);
	background: linear-gradient(135deg, var(--color-cream) 0%, var(--color-creme-pat, #F0E0B7) 100%);
	border-bottom: 1.5px dashed var(--color-biscuit);
}
.builder-review__hero-img {
	flex: 0 0 72px;
	width: 72px;
	height: 72px;
	border-radius: var(--border-radius-lg, 12px);
	overflow: hidden;
	box-shadow: 0 6px 16px rgba(60, 30, 15, 0.18);
}
.builder-review__hero-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.builder-review__hero-body {
	flex: 1 1 auto;
	min-width: 0;
}
.builder-review__eyebrow {
	display: block;
	font-size: var(--text-xs);
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--color-golden-bun);
	font-weight: 700;
	margin-bottom: 2px;
}
.builder-review__name-lg {
	margin: 0;
	font-size: var(--text-lg);
	font-weight: 800;
	color: var(--color-chocolate-brown);
	line-height: 1.1;
}
.builder-review__size {
	margin: 4px 0 0;
	font-size: var(--text-sm);
	color: var(--color-text-muted);
	font-style: italic;
}
.builder-review__price {
	flex: 0 0 auto;
	font-size: var(--text-xl, 1.5rem);
	font-weight: 800;
	color: var(--color-raspberry-red);
	font-feature-settings: 'tnum' 1;
	white-space: nowrap;
}

/* Flavour list — thumbnail rows */
.builder-review__list {
	list-style: none;
	margin: 0;
	padding: var(--space-md) var(--space-lg);
	display: grid;
	gap: 6px;
}
.builder-review__item {
	display: flex;
	align-items: center;
	gap: var(--space-md);
	padding: 8px 10px;
	border-radius: var(--border-radius);
	transition: background var(--transition-fast);
}
.builder-review__item:hover {
	background: var(--color-cream);
}
.builder-review__thumb {
	flex: 0 0 40px;
	width: 40px;
	height: 40px;
	border-radius: 9px;
	overflow: hidden;
	background: var(--color-cream);
	box-shadow: inset 0 0 0 1px rgba(60, 30, 15, 0.08);
}
.builder-review__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.builder-review__thumb--swatch {
	border-radius: 9px;
}
.builder-review__name {
	flex: 1 1 auto;
	min-width: 0;
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: var(--text-sm);
	font-weight: 600;
	color: var(--color-chocolate-brown);
}
.builder-review__swatch {
	flex: 0 0 14px;
	width: 14px;
	height: 14px;
	border-radius: 9999px;
	box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.9);
}
.builder-review__list li span {
	min-width: 14px;
}
.builder-review__qty {
	flex: 0 0 auto;
	font-weight: 800;
	color: var(--color-golden-bun);
	font-feature-settings: 'tnum' 1;
	font-size: var(--text-sm);
}

/* tag-inline used in the "Use [N] slots" hint */
.tag-inline {
	display: inline-block;
	padding: 1px 10px;
	background: var(--color-raspberry-red);
	color: var(--color-vanilla);
	border-radius: 9999px;
	font-weight: 700;
	font-size: 0.85em;
	font-feature-settings: 'tnum' 1;
	margin: 0 2px;
}
