.ovm-bb {
	--ovm-bb-border: #d9d0c2;
	--ovm-bb-bg: #fffaf2;
	--ovm-bb-ink: #1f1711;
	--ovm-bb-muted: #6d6256;
	--ovm-bb-accent: #704020;
	margin: 2rem auto;
	padding: clamp(1rem, 3vw, 2rem);
	background: var(--ovm-bb-bg);
	border: 1px solid var(--ovm-bb-border);
	border-radius: 24px;
	color: var(--ovm-bb-ink);
	box-shadow: 0 18px 60px rgba(31, 23, 17, 0.08);
}

.ovm-bb * {
	box-sizing: border-box;
}

.ovm-bb__header {
	margin-bottom: 1.5rem;
}

.ovm-bb__eyebrow {
	margin: 0 0 0.35rem;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	font-size: 0.78rem;
	color: var(--ovm-bb-accent);
	font-weight: 700;
}

.ovm-bb h2 {
	margin: 0.1rem 0 0.5rem;
	font-size: clamp(2rem, 4vw, 3rem);
	line-height: 1;
}

.ovm-bb h3 {
	margin: 0 0 1rem;
	font-size: 1.15rem;
}

.ovm-bb p {
	color: var(--ovm-bb-muted);
}

.ovm-bb__layout {
	display: grid;
	grid-template-columns: minmax(280px, 430px) 1fr;
	gap: clamp(1rem, 3vw, 2rem);
}

.ovm-bb__preview-card,
.ovm-bb__form {
	background: #fff;
	border: 1px solid var(--ovm-bb-border);
	border-radius: 20px;
	padding: 1rem;
}

.ovm-bb__preview-frame {
	position: relative;
	display: grid;
	place-items: center;
	min-height: 310px;
	background: linear-gradient(135deg, #f6efe3, #fff);
	border-radius: 16px;
	overflow: hidden;
	border: 1px solid #eadfce;
}

.ovm-bb__preview-frame img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	display: block;
}

.ovm-bb__preview-placeholder {
	font-weight: 800;
	text-align: center;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: #b59b7d;
}

.ovm-bb__summary {
	padding: 1rem 0 0;
}

.ovm-bb__summary dl {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 0.45rem 0.75rem;
	margin: 0;
}

.ovm-bb__summary dt {
	font-weight: 700;
	color: var(--ovm-bb-muted);
}

.ovm-bb__summary dd {
	margin: 0;
	text-align: right;
}

.ovm-bb__total {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: 1rem;
	padding-top: 1rem;
	border-top: 1px solid var(--ovm-bb-border);
}

.ovm-bb__total strong {
	font-size: 1.7rem;
	color: var(--ovm-bb-accent);
}

.ovm-bb__note {
	font-size: 0.9rem;
	margin: 0.7rem 0 0;
}

.ovm-bb__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem;
}

.ovm-bb__step {
	margin-bottom: 1rem;
}

.ovm-bb label,
.ovm-bb legend {
	font-weight: 800;
	color: var(--ovm-bb-ink);
}

.ovm-bb select,
.ovm-bb input[type="number"] {
	width: 100%;
	margin-top: 0.4rem;
	border: 1px solid var(--ovm-bb-border);
	border-radius: 12px;
	padding: 0.75rem;
	background: #fff;
	color: var(--ovm-bb-ink);
}

.ovm-bb__addons,
.ovm-bb__delivery {
	border: 1px solid var(--ovm-bb-border);
	border-radius: 16px;
	padding: 1rem;
	margin: 1rem 0;
}

.ovm-bb__addons legend,
.ovm-bb__delivery legend {
	padding: 0 0.5rem;
}

.ovm-bb__addon,
.ovm-bb__delivery-option {
	display: flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.65rem 0.25rem;
	border-bottom: 1px solid #f0e7d9;
}

.ovm-bb__addon:last-child,
.ovm-bb__delivery-option:last-child {
	border-bottom: 0;
}

.ovm-bb__addon span,
.ovm-bb__delivery-option strong {
	margin-left: auto;
	color: var(--ovm-bb-muted);
	font-weight: 700;
}

.ovm-bb__delivery p {
	margin: 0.35rem 0 0;
	font-size: 0.9rem;
}

.ovm-bb__delivery[hidden],
.ovm-bb__delivery-option[hidden] {
	display: none !important;
}

.ovm-bb__actions {
	display: flex;
	flex-wrap: wrap;
	align-items: end;
	gap: 0.75rem;
}

.ovm-bb__qty {
	max-width: 90px;
}

.ovm-bb__actions .button {
	border-radius: 999px !important;
	padding: 0.72rem 1.1rem !important;
	height: auto !important;
}

.ovm-bb__add {
	background: var(--ovm-bb-accent) !important;
	border-color: var(--ovm-bb-accent) !important;
	color: #fff !important;
}

.ovm-bb__message {
	margin-top: 1rem;
	font-weight: 700;
	color: #9f1d1d;
}

.ovm-bb__add:disabled {
	opacity: 0.55;
	cursor: not-allowed;
}

@media (max-width: 850px) {
	.ovm-bb__layout,
	.ovm-bb__grid {
		grid-template-columns: 1fr;
	}
}

@media print {
	body * {
		visibility: hidden !important;
	}

	.ovm-bb,
	.ovm-bb * {
		visibility: visible !important;
	}

	.ovm-bb {
		position: absolute;
		inset: 0 auto auto 0;
		width: 100%;
		box-shadow: none;
		border: 0;
		background: #fff;
	}

	.ovm-bb__form,
	.ovm-bb__actions,
	.ovm-bb__message {
		display: none !important;
	}

	.ovm-bb__layout {
		display: block;
	}

	.ovm-bb__preview-card {
		border: 0;
	}

	.ovm-bb__preview-frame {
		max-height: 260px;
	}

	.ovm-bb__summary {
		font-size: 13pt;
	}

	.ovm-bb__total strong {
		font-size: 20pt;
	}
}