/* OZB Variation Swatches — pack mode "pick N" picker (module e). Self-contained. */

.ozb-vs-pack {
	margin: 0 0 18px;
}

.ozb-vs-pack-head {
	margin: 0 0 10px;
	font-weight: 600;
}

.ozb-vs-pack-slot {
	display: flex;
	align-items: center;
	gap: 12px;
	margin: 0 0 10px;
}

.ozb-vs-pack-slot-label {
	flex: 0 0 auto;
	min-width: 84px;
	font-size: .92em;
	color: #555;
}

.ozb-vs-pack-swatches {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

/* Round dots, geometry pinned so theme button styles can't squash them. */
.ozb-vs-pack .ozb-vs-swatch {
	flex: 0 0 auto;
	box-sizing: border-box !important;
	display: inline-block !important;
	width: 30px !important;
	height: 30px !important;
	min-width: 30px !important;
	min-height: 30px !important;
	max-width: 30px !important;
	padding: 0 !important;
	margin: 0 !important;
	border: 1px solid #d3d3d3 !important;
	border-radius: 50% !important;
	line-height: 0 !important;
	aspect-ratio: 1 / 1;
	background: #fff;
	cursor: pointer;
	overflow: hidden;
	vertical-align: middle;
	box-shadow: none;
	transition: transform .12s ease, box-shadow .12s ease;
	-webkit-appearance: none;
	appearance: none;
}

.ozb-vs-pack .ozb-vs-swatch .ozb-vs-chip {
	display: block;
	width: 100%;
	height: 100%;
	border-radius: 50%;
}

.ozb-vs-pack .ozb-vs-swatch:hover {
	transform: scale(1.1);
}

.ozb-vs-pack .ozb-vs-swatch.is-selected {
	box-shadow: 0 0 0 2px #fff, 0 0 0 4px #222;
	border-color: #222 !important;
}

.ozb-vs-pack .ozb-vs-swatch:focus-visible {
	outline: 2px solid #222;
	outline-offset: 2px;
}

.ozb-vs-pack-status {
	margin: 4px 0 0;
	font-size: .9em;
	color: #777;
}

/* The native add-to-cart button while the pack is incomplete. */
.single_add_to_cart_button.ozb-vs-disabled {
	opacity: .5;
	cursor: not-allowed;
}

/*
 * In Flatsome's sticky add-to-cart bar we replace the duplicate picker with a single
 * "Choose your colours" button that scrolls up to the real picker. Hide the sticky's own
 * quantity + add-to-cart so only that button shows.
 */
.sticky-add-to-cart .ozb-vs-pack-jump ~ .quantity,
.sticky-add-to-cart .ozb-vs-pack-jump ~ .single_add_to_cart_button,
.sticky-add-to-cart .ozb-vs-pack-jump ~ button.single_add_to_cart_button {
	display: none !important;
}

.ozb-vs-pack-jump {
	white-space: nowrap;
}

/* Respect reduced-motion preferences. */
@media (prefers-reduced-motion: reduce) {
	.ozb-vs-pack .ozb-vs-swatch { transition: none; }
	.ozb-vs-pack .ozb-vs-swatch:hover { transform: none; }
}

/* Live "Your selection" preview strip (pack mode). */
.ozb-vs-pack-preview-head {
	margin: 10px 0 6px;
	font-size: .85em;
	font-weight: 600;
	color: #555;
}
.ozb-vs-pack-preview {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin: 0 0 6px;
}
.ozb-vs-pack-preview-item {
	display: flex;
	flex-direction: column;
	align-items: center;
	width: 84px;
}
.ozb-vs-pack-preview-img {
	display: block;
	width: 84px;
	height: 84px;
	border-radius: 8px;
	border: 1px solid #e2e2e2;
	background: #fafafa;
	overflow: hidden;
}
.ozb-vs-pack-preview-img.is-empty {
	border-style: dashed;
	border-color: #cfcfcf;
}
.ozb-vs-pack-preview-img img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.ozb-vs-pack-preview-label {
	margin-top: 4px;
	font-size: .82em;
	color: #555;
	text-align: center;
	line-height: 1.2;
}
