/* ============================================================
   Vloerplus Design 2.0 — PDP (Product Detail Page)
   Scope: .jvz-pdp container + .jvz-pdp-* descendants
   Loaded only on is_product() via vloerplus_pdp_enqueue_assets.
   ============================================================ */

/* ---------- 0. Reset & shell ---------------------------------- */
.jvz-pdp,
.jvz-pdp * {
	box-sizing: border-box;
}

/* Override legacy `.product` rules that conflict with the new layout:
   - vloerplus-site.css:1556 `.single-product .wc-inner>.product { display:flex; flex-direction:column; gap:1rem }`
   - vloerplus-site.css:1562 `.single-product .wc-inner>.product { opacity:0 }` (used to be a JS reveal flicker)
*/
.jvz-pdp.product,
.single-product .wc-inner > .jvz-pdp.product {
	display: block !important;
	width: 100% !important;
	max-width: none !important;
	margin: 0 !important;
	padding: 0 !important;
	gap: 0 !important;
	opacity: 1 !important;
	background: var(--jvz-cream);
	color: var(--jvz-fg-1);
	font-family: var(--jvz-font-body);
}

/* Neutralise global `section { padding: 5rem 0 }` from vloerplus-site.css for our PDP sections. */
.jvz-pdp section.jvz-pdp-desc,
.jvz-pdp section.jvz-pdp-bundle,
.jvz-pdp section.jvz-pdp-suit {
	padding-top: 0;
	padding-bottom: 0;
}
.jvz-pdp section.jvz-pdp-suit {
	padding: 24px;
}

/* Uniform section rhythm on PDP — override the legacy
   `@media (min-width: 1280px) { section { padding: 7.5rem 0 } }` so the
   below-fold legacy sections (Trustoo reviews, "Wij maken het eenvoudig",
   etc.) use 5rem top/bottom on every viewport, matching `.content-wrapper`. */
body.single-product .content-wrapper section {
	padding-top: 5rem;
	padding-bottom: 5rem;
}
body.single-product .content-wrapper section.no-padding-top {
	padding-top: 0;
}
body.single-product .content-wrapper section.no-padding-bottom {
	padding-bottom: 0;
}

/* Mobile fixes for the legacy `.content-wrapper` chain on single-product.
   Two issues caused by our wc-inner padding reset on mobile:
   (1) content-wrapper padding-top was 80px → too much on a phone
   (2) `.column-section .inner` lost its 24px side-padding because wc-inner
       no longer supplies it. */
@media (max-width: 900px) {
	body.single-product .content-wrapper {
		padding-top: 2.5rem;
	}
	body.single-product .content-wrapper section,
	body.single-product > section,
	body.single-product section.about-columns {
		padding-top: 2.5rem;
		padding-bottom: 2.5rem;
	}
	body.single-product .content-wrapper section.no-padding-top,
	body.single-product > section.no-padding-top,
	body.single-product section.about-columns.no-padding-top {
		padding-top: 0;
	}
	body.single-product .content-wrapper section.no-padding-bottom,
	body.single-product > section.no-padding-bottom,
	body.single-product section.about-columns.no-padding-bottom {
		padding-bottom: 0;
	}
	body.single-product .content-wrapper section > .inner,
	body.single-product .content-wrapper section .inner,
	body.single-product .ervaringen-section > .inner {
		padding-left: 16px;
		padding-right: 16px;
		box-sizing: border-box;
	}
}

.jvz-pdp__shell {
	background: var(--jvz-cream);
	width: 100%;
}

.jvz-pdp__inner {
	max-width: 1400px;
	margin: 0 auto;
	/* Horizontal padding handled by .wc-inner ancestor (24px L/R) — no duplicate.
	   Bottom padding 0: the legacy `.content-wrapper` below already supplies
	   80px of top padding before the next section. */
	padding: 24px 0 0;
}

/* ---------- 1. USP bar — shared component, see `.jvz-uspbar*` rules in
   pop.css. Renders full-width via `woocommerce_before_main_content` priority 1
   (vloerplus_pop_render_uspbar) — outside the .wc-inner shell.
   Mobile: pop.css already gives overflow-x: auto + touch-scroll (carousel). */

/* ---------- 2. Breadcrumb -------------------------------------- */
.jvz-pdp-breadcrumb {
	font-size: 13px;
	color: var(--jvz-fg-3);
	margin-bottom: 20px;
}

.jvz-pdp-breadcrumb a {
	color: var(--jvz-fg-3);
	text-decoration: none;
	transition: color .15s;
}

.jvz-pdp-breadcrumb a:hover {
	color: var(--jvz-navy);
}

.jvz-pdp-breadcrumb__sep {
	margin: 0 6px;
	color: var(--jvz-fg-4);
}

/* ---------- 3. Hero grid (gallery + koopblok) ----------------- */
.jvz-pdp__hero {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 520px;
	gap: 48px;
	align-items: start;
}

.jvz-pdp__col--left,
.jvz-pdp__col--right {
	min-width: 0; /* prevent intrinsic-content overflow inside grid cells */
}

.jvz-pdp__col--right {
	position: sticky;
	top: 24px;
}

@media (max-width: 1100px) {
	.jvz-pdp__hero {
		grid-template-columns: minmax(0, 1fr) 440px;
		gap: 32px;
	}
}

@media (max-width: 900px) {
	/* Reset .wc-inner's 24px L/R padding ONLY on single-product so our
	   PDP shell controls horizontal alignment edge-to-edge. */
	body.single-product .wc-inner {
		padding-left: 0 !important;
		padding-right: 0 !important;
		max-width: 100% !important;
	}

	/* Mobile element order — flatten the hero + cols so the major blocks
	   participate in `.jvz-pdp__inner`'s flex flow. Then reorder via `order`
	   to match the mobile mockup:
	   gallery → koopblok → trust → suit → bundle → description.
	   `display: contents` removes the dissolved boxes from layout but keeps
	   their children part of the parent's layout. */
	.jvz-pdp__hero,
	.jvz-pdp__col--left,
	.jvz-pdp__col--right {
		display: contents;
	}

	.jvz-pdp-gallery--v2 { order: 1; }
	.jvz-pdp-buy         { order: 2; }
	.jvz-pdp-trust       { order: 3; }
	.jvz-pdp-suit        { order: 4; }
	.jvz-pdp-bundle      { order: 5; }
	.jvz-pdp-desc        { order: 6; }
	.jvz-pdp-breadcrumb  { order: 0; }
	.woocommerce-notices-wrapper { order: 0; }

	/* No flex gap on inner — empty/contents children would each accumulate
	   the gap, adding ~160px above the gallery. Use per-block margin-top
	   instead so spacing only applies between the actually visible blocks. */
	.jvz-pdp-gallery--v2 { margin-top: 0 !important; }
	.jvz-pdp-buy { margin-top: 16px !important; }
	.jvz-pdp-trust { margin-top: 16px !important; }
	.jvz-pdp-suit { margin-top: 16px !important; }
	.jvz-pdp-bundle { margin-top: 16px !important; }
	.jvz-pdp-desc { margin-top: 16px !important; }
	.jvz-pdp-buy__price-card,
	.jvz-pdp-buy__swatches-block {
		margin-top: 16px;
	}

	/* Admin-only ACF hints — push to the end so they don't bump the gallery
	   off the top of the flex flow. */
	.jvz-acf-hint {
		order: 99;
		margin-top: 16px !important;
	}

	/* Mobile inner: flex column with 16px content padding; gallery breaks out
	   via negative margin. Sticky CTA overlap-avoidance handled at body level. */
	.jvz-pdp__inner {
		display: flex;
		flex-direction: column;
		gap: 0;
		padding: 0 16px 0;
	}

	/* Reserve bottom space for the fixed sticky CTA only at the page bottom,
	   not inside the inner — keeps section-to-section flow tight. */
	body.single-product {
		padding-bottom: 80px;
	}

	.jvz-pdp__shell {
		overflow-x: hidden;
	}

	/* Hide breadcrumb on mobile (mockup doesn't show one). */
	.jvz-pdp-breadcrumb {
		display: none !important;
	}

	/* Make gallery full-bleed: pull out of inner's 16px padding. */
	.jvz-pdp-gallery--v2 {
		margin-left: -16px;
		margin-right: -16px;
		width: calc(100% + 32px);
	}
}

/* ---------- 4. Gallery (v2 — mockup-fidelity) ---------------- */
.jvz-pdp-gallery--v2 {
	display: grid;
	grid-template-columns: 88px minmax(0, 1fr);
	gap: 16px;
	align-items: start;
	background: transparent;
	border: 0;
	box-shadow: none;
	padding: 0;
	min-width: 0;
}

.jvz-pdp-gallery__main {
	min-width: 0;
}

/* Thumbs are constrained to the main image height; if more thumbs exist, the
   nav arrows scroll the strip vertically. */
.jvz-pdp-gallery__thumbs-wrap {
	position: relative;
	width: 88px;
	overflow: hidden;
	/* aspect-ratio of main image is 4:3 → height = (col-width) * 0.75. The grid
	   parent's row sizes to start, so we mirror that here via a CSS variable. */
	max-height: var(--jvz-pdp-thumbs-h, 488px);
}

.jvz-pdp-gallery__thumbs {
	display: flex;
	flex-direction: column;
	gap: 8px;
	transition: transform .25s ease;
	will-change: transform;
}

.jvz-pdp-gallery__thumb-nav {
	position: absolute;
	left: 0;
	right: 0;
	margin: 0 auto;
	width: 32px;
	height: 24px;
	border: 1px solid var(--jvz-line);
	border-radius: var(--jvz-r-pill);
	background: rgba(255, 255, 255, .96);
	color: var(--jvz-navy);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	box-shadow: var(--jvz-shadow-sm);
	z-index: 5;
	transition: opacity .15s, background .15s;
}

.jvz-pdp-gallery__thumb-nav:hover { background: #fff; }

.jvz-pdp-gallery__thumb-nav--up   { top: -10px; }
.jvz-pdp-gallery__thumb-nav--down { bottom: -10px; }

.jvz-pdp-gallery__thumb-nav[aria-disabled="true"] {
	opacity: 0;
	pointer-events: none;
}

.jvz-pdp-gallery__thumb {
	width: 88px;
	height: 88px;
	min-height: 88px;
	border: 1px solid var(--jvz-line);
	border-radius: 12px;
	overflow: hidden;
	background: #fff;
	padding: 0;
	cursor: pointer;
	transition: border-color .15s, transform .05s;
}

.jvz-pdp-gallery__thumb:hover {
	border-color: var(--jvz-navy);
}

.jvz-pdp-gallery__thumb.is-active {
	border-color: var(--jvz-navy);
	box-shadow: 0 0 0 2px rgba(0, 21, 57, .08);
}

.jvz-pdp-gallery__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.jvz-pdp-gallery__main {
	position: relative;
	aspect-ratio: 4 / 3;
	background: #fff;
	border: 1px solid var(--jvz-line);
	border-radius: 12px;
	overflow: hidden;
	box-shadow: var(--jvz-shadow-md);
}

.jvz-pdp-gallery__slide {
	position: absolute;
	inset: 0;
	display: block;
	opacity: 0;
	transition: opacity .25s ease;
	pointer-events: none;
}

.jvz-pdp-gallery__slide.is-active {
	opacity: 1;
	pointer-events: auto;
}

.jvz-pdp-gallery__slide img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.jvz-pdp-gallery__placeholder {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--jvz-fg-3);
	font-size: 14px;
}

.jvz-pdp-gallery__badge {
	position: absolute;
	top: 16px;
	left: 16px;
	z-index: 3;
	background: var(--jvz-orange);
	color: #fff;
	font: var(--jvz-fw-bold) 12px/1 var(--jvz-font-display);
	padding: 6px 12px;
	border-radius: var(--jvz-r-pill);
}

.jvz-pdp-gallery__util {
	position: absolute;
	top: 16px;
	right: 16px;
	z-index: 3;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.jvz-pdp-gallery__util-btn {
	width: 40px;
	height: 40px;
	border: 0;
	border-radius: var(--jvz-r-pill);
	background: rgba(255, 255, 255, .95);
	color: var(--jvz-navy);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	box-shadow: var(--jvz-shadow-sm);
	transition: background .15s;
}

.jvz-pdp-gallery__util-btn:hover {
	background: #fff;
}

.jvz-pdp-gallery__nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 40px;
	height: 40px;
	border: 0;
	border-radius: var(--jvz-r-pill);
	background: rgba(255, 255, 255, .95);
	color: var(--jvz-navy);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	box-shadow: var(--jvz-shadow-sm);
	z-index: 3;
	transition: background .15s;
}

.jvz-pdp-gallery__nav:hover {
	background: #fff;
}

.jvz-pdp-gallery__nav--prev { left: 12px; }
.jvz-pdp-gallery__nav--next { right: 12px; }

.jvz-pdp-gallery__dots {
	position: absolute;
	bottom: 16px;
	right: 16px;
	z-index: 3;
	display: flex;
	gap: 6px;
}

.jvz-pdp-gallery__dot {
	width: 6px;
	height: 6px;
	border-radius: var(--jvz-r-pill);
	background: rgba(0, 21, 57, .4);
	transition: width .25s, background .15s;
	cursor: pointer;
}

.jvz-pdp-gallery__dot.is-active {
	width: 24px;
	background: var(--jvz-navy);
}

/* ---------- Lightbox modal --------------------------------- */
.jvz-pdp-lightbox {
	position: fixed;
	inset: 0;
	z-index: 999999; /* above .site-header (99991) and #wpadminbar (99999) */
	background: rgba(0, 21, 57, .92);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 24px;
	cursor: zoom-out;
	animation: jvz-lightbox-fade .2s ease-out;
}

/* When the WP admin bar is visible (logged-in admins), shift the lightbox
   top by the admin-bar height so the image+caption centers in the VISIBLE
   area, not behind the bar. WP admin-bar = 32px desktop, 46px ≤782px. */
body.admin-bar .jvz-pdp-lightbox {
	top: 32px;
}
@media screen and (max-width: 782px) {
	body.admin-bar .jvz-pdp-lightbox {
		top: 46px;
	}
}

.jvz-pdp-lightbox[hidden] {
	display: none !important;
}

@keyframes jvz-lightbox-fade {
	from { opacity: 0; }
	to   { opacity: 1; }
}

.jvz-pdp-lightbox__figure {
	width: 100%;
	height: 100%;
	max-width: min(95vw, 1600px);
	margin: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 12px;
	cursor: default;
	min-height: 0;
}

.jvz-pdp-lightbox__img {
	width: auto;
	height: auto;
	max-width: 100%;
	max-height: 100%;
	min-height: 0;
	flex: 0 0 auto; /* never grow, never shrink past intrinsic */
	object-fit: scale-down; /* contain when too big, native size when smaller — never upscales */
	border-radius: 12px;
	box-shadow: 0 30px 60px rgba(0, 0, 0, .4);
	display: block;
	cursor: default;
	background: #fff;
}

.jvz-pdp-lightbox__caption {
	color: #fff;
	font: var(--jvz-fw-medium) 13px/1.4 var(--jvz-font-display);
	text-align: center;
	max-width: 80vw;
	flex: 0 0 auto;
}

.jvz-pdp-lightbox__caption:empty {
	display: none;
}

.jvz-pdp-lightbox__close {
	position: absolute;
	top: 16px;
	right: 16px;
	width: 44px;
	height: 44px;
	padding: 0 !important;
	margin: 0 !important;
	border: 0 !important;
	border-radius: var(--jvz-r-pill);
	background: rgba(255, 255, 255, .15) !important;
	color: #fff !important;
	cursor: pointer;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	box-shadow: none !important;
	transition: background .15s;
}

.jvz-pdp-lightbox__close:hover {
	background: rgba(255, 255, 255, .25) !important;
}

.jvz-pdp-lightbox__nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 48px;
	height: 48px;
	padding: 0 !important;
	margin: 0 !important;
	border: 0 !important;
	border-radius: var(--jvz-r-pill);
	background: rgba(255, 255, 255, .15) !important;
	color: #fff !important;
	cursor: pointer;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	box-shadow: none !important;
	transition: background .15s;
}

.jvz-pdp-lightbox__nav:hover {
	background: rgba(255, 255, 255, .25) !important;
}

.jvz-pdp-lightbox__nav svg {
	width: 22px !important;
	height: 22px !important;
}

.jvz-pdp-lightbox__nav--prev { left: 24px; }
.jvz-pdp-lightbox__nav--next { right: 24px; }

@media (max-width: 700px) {
	.jvz-pdp-lightbox {
		padding: 12px;
	}
	.jvz-pdp-lightbox__nav--prev { left: 8px; width: 40px; height: 40px; }
	.jvz-pdp-lightbox__nav--next { right: 8px; width: 40px; height: 40px; }
}

/* Bottom-left color + view chip — visible only when a variation swatch is
   active and the gallery is showing that variation's image. */
.jvz-pdp-gallery__chip {
	position: absolute;
	bottom: 16px;
	left: 16px;
	z-index: 4;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: rgba(255, 255, 255, .95);
	padding: 8px 14px;
	border-radius: var(--jvz-r-pill);
	font: var(--jvz-fw-bold) 12px/1 var(--jvz-font-display);
	color: var(--jvz-navy);
	box-shadow: var(--jvz-shadow-sm);
	max-width: calc(100% - 96px); /* leaves room for dots bottom-right */
}

.jvz-pdp-gallery__chip[hidden] {
	display: none !important;
}

.jvz-pdp-gallery__chip-dot {
	flex: 0 0 auto;
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background: var(--jvz-cream-2);
	box-shadow: 0 0 0 1px rgba(0, 0, 0, .08);
}

.jvz-pdp-gallery__chip-view {
	font-weight: var(--jvz-fw-medium);
	color: var(--jvz-fg-3);
}

.jvz-pdp-gallery__chip-view:not(:empty)::before {
	content: '· ';
	margin-right: 2px;
}

/* Mobile-only counter chip (rendered always, hidden on desktop). */
.jvz-pdp-gallery__counter {
	display: none;
	position: absolute;
	bottom: 12px;
	right: 12px;
	z-index: 4;
	background: rgba(0, 0, 0, .55);
	color: #fff;
	font: var(--jvz-fw-bold) 11px/1 var(--jvz-font-display);
	padding: 4px 8px;
	border-radius: var(--jvz-r-pill);
}

/* Mobile-only color-bar row below gallery (rendered always, hidden on desktop). */
.jvz-pdp-gallery__color-bar {
	display: none;
}

@media (max-width: 900px) {
	.jvz-pdp-gallery--v2 {
		grid-template-columns: 1fr;
		gap: 0;
	}
	.jvz-pdp-gallery__thumbs-wrap {
		display: none;
	}
	.jvz-pdp-gallery__main {
		aspect-ratio: 1 / 1;
		border: 0;
		border-radius: 0;
		box-shadow: none;
		background: var(--jvz-cream-2);
	}
	.jvz-pdp-gallery__dots {
		left: 0;
		right: 0;
		bottom: 12px;
		justify-content: center;
	}
	.jvz-pdp-gallery__dot {
		background: rgba(255, 255, 255, .55);
	}
	.jvz-pdp-gallery__dot.is-active {
		background: #fff;
	}
	.jvz-pdp-gallery__counter {
		display: inline-flex;
	}
	.jvz-pdp-gallery__chip {
		display: none !important;
	}
	.jvz-pdp-gallery__nav {
		display: none;
	}

	.jvz-pdp-gallery__color-bar {
		display: flex;
		align-items: center;
		gap: 8px;
		padding: 8px 16px;
		background: var(--jvz-cream);
		border-bottom: 1px solid color-mix(in srgb, var(--jvz-line) 70%, transparent);
		font: var(--jvz-fw-bold) 11px/1.2 var(--jvz-font-display);
		color: var(--jvz-navy);
	}
	.jvz-pdp-gallery__color-bar[hidden] {
		display: none !important;
	}
	.jvz-pdp-gallery__color-bar-dot {
		flex: 0 0 auto;
		width: 12px;
		height: 12px;
		border-radius: 50%;
		background: var(--jvz-cream-2);
		box-shadow: 0 0 0 1px rgba(0, 0, 0, .08);
	}
	.jvz-pdp-gallery__color-bar-view {
		font-weight: var(--jvz-fw-medium);
		color: var(--jvz-fg-3);
	}
	.jvz-pdp-gallery__color-bar-view:not(:empty)::before {
		content: '· ';
		margin-right: 2px;
	}
}

/* ---------- 5. Trust strip ------------------------------------ */
.jvz-pdp-trust {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 8px;
	margin-top: 20px;
}

/* Narrow desktop where the left col can't comfortably fit 4 cards next to
   the 440px sticky koopblok — fall back to 2×2 so items don't bleed into
   the right column. */
@media (min-width: 901px) and (max-width: 1199px) {
	.jvz-pdp-trust {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

.jvz-pdp-trust__item {
	display: flex;
	align-items: center;
	gap: 10px;
	background: #fff;
	border: 1px solid var(--jvz-line);
	border-radius: var(--jvz-r-md);
	padding: 12px;
	min-width: 0; /* allow grid cell to shrink the flex content */
}

.jvz-pdp-trust__text {
	min-width: 0;
}

.jvz-pdp-trust__label,
.jvz-pdp-trust__sub {
	overflow: hidden;
	text-overflow: ellipsis;
}

.jvz-pdp-trust__icon {
	flex: 0 0 auto;
	height: 36px;
	width: 36px;
	border-radius: var(--jvz-r-pill);
	background: var(--jvz-cream);
	color: var(--jvz-orange);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.jvz-pdp-trust__label {
	font: var(--jvz-fw-bold) 12px/1.3 var(--jvz-font-display);
	color: var(--jvz-navy);
}

.jvz-pdp-trust__sub {
	font-size: 11px;
	color: var(--jvz-fg-3);
}

@media (max-width: 900px) {
	.jvz-pdp-trust {
		display: flex;
		flex-wrap: nowrap;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
		padding-bottom: 4px;
		gap: 8px;
		min-width: 0;
		/* Bleed right edge of the carousel to the viewport — partial card peek
		   indicates "more on the right". Negates inner's 16px right-padding. */
		margin-right: -16px;
		padding-right: 16px;
	}
	.jvz-pdp-trust::-webkit-scrollbar { display: none; }
	.jvz-pdp-trust__item {
		flex: 0 0 auto;
		min-width: 160px;
	}
}

/* ---------- 6. Koopblok (right column) ------------------------ */
.jvz-pdp-buy {
	display: block;
}

.jvz-pdp-buy > * + * {
	/* default fallback gap when no explicit margin set */
}

.jvz-pdp-buy__eyebrow {
	font: var(--jvz-fw-bold) 12px/1 var(--jvz-font-display);
	color: var(--jvz-orange);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	margin-bottom: 0;
}

.jvz-pdp-buy__title {
	font: var(--jvz-fw-bold) 34px/1.15 var(--jvz-font-display);
	color: var(--jvz-navy);
	letter-spacing: -0.005em;
	margin: 8px 0 0;
}

.jvz-pdp-buy__positioning {
	font-size: 15px;
	line-height: 1.55;
	color: var(--jvz-fg-2);
	margin: 12px 0 0;
}

.jvz-pdp-buy__positioning p {
	margin: 0;
}

.jvz-pdp-buy__positioning p + p {
	margin-top: 8px;
}

/* Tag chips */
.jvz-pdp-buy__tags {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 12px;
}

.jvz-pdp-buy__tag {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font: var(--jvz-fw-bold) 12px/1 var(--jvz-font-display);
	background: color-mix(in srgb, var(--jvz-navy) 5%, transparent);
	color: var(--jvz-navy);
	padding: 6px 10px;
	border-radius: var(--jvz-r-pill);
}

.jvz-pdp-buy__tag--ok {
	background: color-mix(in srgb, var(--jvz-green) 10%, transparent);
	color: var(--jvz-green-700);
}

/* Price card */
.jvz-pdp-buy__price-card {
	background: #fff;
	border: 1px solid var(--jvz-line);
	border-radius: var(--jvz-r-lg);
	padding: 20px;
	margin-top: 24px;
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.jvz-pdp-buy__price-row {
	display: flex;
	align-items: baseline;
	gap: 12px;
	flex-wrap: wrap;
}

.jvz-pdp-buy__price {
	font: var(--jvz-fw-bold) 40px/1 var(--jvz-font-display);
	color: var(--jvz-navy);
	letter-spacing: -0.005em;
}

.jvz-pdp-buy__price-unit {
	color: var(--jvz-fg-3);
	font-size: 14px;
}

.jvz-pdp-buy__price-old {
	color: var(--jvz-fg-4);
	font-size: 14px;
	text-decoration: line-through;
}

.jvz-pdp-buy__discount {
	margin-left: auto;
	background: var(--jvz-orange);
	color: #fff;
	font: var(--jvz-fw-bold) 12px/1 var(--jvz-font-display);
	padding: 4px 10px;
	border-radius: var(--jvz-r-pill);
}

.jvz-pdp-buy__price-sub {
	font-size: 13px;
	color: var(--jvz-fg-3);
	margin-top: -8px;
}

/* Slot placeholders — invisible until wired in next steps */
.jvz-pdp-buy__calc-slot:empty,
.jvz-pdp__bundle-slot:empty,
.jvz-pdp__suit-slot:empty,
.jvz-pdp__desc-slot:empty {
	display: none;
}

/* ---------- 8. WC variation form / swatches inside koopblok --- */
.jvz-pdp-buy__swatches {
	margin-top: 4px;
}

/* WC native cart-form bits we don't want visually — covers BOTH simple
 * products (where .quantity / .single_add_to_cart_button live directly in
 * form.cart) AND variable products (where they live inside .single_variation_wrap).
 * The Design 2.0 .jvz-pdp-buy__cta-primary button is the only visible CTA; the
 * legacy form stays in the DOM so the cart-drawer JS can submit it via AJAX. */
.jvz-pdp-buy__swatches form.cart > .quantity,
.jvz-pdp-buy__swatches form.cart > .single_add_to_cart_button,
.jvz-pdp-buy__swatches .variations_form .reset_variations,
.jvz-pdp-buy__swatches .single_variation_wrap .quantity,
.jvz-pdp-buy__swatches .single_variation_wrap .single_add_to_cart_button,
.jvz-pdp-buy__swatches .single_variation_wrap .woocommerce-variation-add-to-cart {
	display: none !important;
}

/* Hide WC's auto-injected "Bekijk winkelwagen" link. WooCommerce drops a
 * <a class="added_to_cart wc-forward"> next to the legacy add-to-cart button
 * after a successful AJAX add. We have our own slide-in cart drawer, so this
 * link is duplicate and visually ugly inside the swatches block. */
.jvz-pdp-buy__swatches a.added_to_cart,
.jvz-pdp-buy__swatches .added_to_cart.wc-forward {
	display: none !important;
}

/* Variations table — strip default table chrome */
.jvz-pdp-buy__swatches table.variations,
.jvz-pdp-buy__swatches table.variations tbody,
.jvz-pdp-buy__swatches table.variations tr,
.jvz-pdp-buy__swatches table.variations td {
	display: block;
	border: 0;
	padding: 0;
	margin: 0;
	width: 100%;
}

.jvz-pdp-buy__swatches table.variations td.label {
	margin-bottom: 8px;
}

.jvz-pdp-buy__swatches table.variations td.label label {
	font: var(--jvz-fw-bold) 14px/1 var(--jvz-font-display);
	color: var(--jvz-navy);
}

/* Hide the underlying <select> (still in DOM for variation matching) */
.jvz-pdp-buy__swatches .original-options,
.jvz-pdp-buy__swatches td.value select {
	display: none !important;
}

/* WP Armour honeypot debug box only shows to admins — hide on PDP. */
.jvz-pdp-buy__swatches .wpa_hidden_field,
.jvz-pdp-buy__swatches .wpa-test-msg {
	display: none !important;
}

/* Swatches grid — re-theme the legacy .product-variations markup */
.jvz-pdp-buy__swatches .product-variations {
	margin-top: 0;
}

/* Hide legacy "Kleur." label inside variation form — we render our own
   "Kleur: <name>" header above. */
.jvz-pdp-buy__swatches .product-variations .heading3 {
	display: none !important;
}

.jvz-pdp-buy__swatches .swatches-wrapper {
	display: grid;
	grid-template-columns: repeat(6, minmax(0, 1fr));
	gap: 12px;
	width: 100%;
}

/* Each swatch is wrapped in a `__cell` so we can stack the wood-grain tile
   above its name label without touching the box's existing background-image
   trick. The label is always rendered (matches PDP mockup desktop + mobile). */
.jvz-pdp-buy__swatches .vloerplus-swatch-cell {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 6px;
	min-width: 0;
}
.jvz-pdp-buy__swatches .vloerplus-swatch-name {
	font: var(--jvz-fw-medium) 11px/1.25 var(--jvz-font-display);
	color: var(--jvz-navy);
	text-align: left;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.jvz-pdp-buy__swatches .vloerplus-swatch-cell:has(.vloerplus-swatch-box.selected) .vloerplus-swatch-name {
	font-weight: var(--jvz-fw-bold);
}

.jvz-pdp-buy__swatches .vloerplus-swatch-box {
	position: relative;
	width: 100%;
	height: 78px;
	border-radius: var(--jvz-r-md);
	overflow: hidden;
	border: 1px solid var(--jvz-line);
	cursor: pointer;
	background-size: cover;
	background-position: center;
	transition: border-color .15s, box-shadow .15s;
	min-width: 0;
}

.jvz-pdp-buy__swatches .vloerplus-swatch-box:hover {
	border-color: var(--jvz-navy);
}

.jvz-pdp-buy__swatches .vloerplus-swatch-box.selected {
	border-color: var(--jvz-navy);
	box-shadow: 0 0 0 2px var(--jvz-blue), 0 0 0 4px #fff;
}

.jvz-pdp-buy__swatches .vloerplus-swatch-box .swatch-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.jvz-pdp-buy__swatches .vloerplus-swatch-box .swatch-name-fallback {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font: var(--jvz-fw-bold) 11px/1.2 var(--jvz-font-display);
	color: var(--jvz-navy);
	text-align: center;
	padding: 4px 6px;
}

@media (max-width: 600px) {
	.jvz-pdp-buy__swatches .swatches-wrapper {
		grid-template-columns: repeat(3, 1fr);
	}
}

/* ---------- 9. Live calculator (mockup-style) ---------------- */
.jvz-pdp-calc {
	background: color-mix(in srgb, var(--jvz-cream) 70%, transparent);
	border: 1px solid var(--jvz-line);
	border-radius: var(--jvz-r-lg);
	padding: 20px;
}

.jvz-pdp-calc__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 12px;
}

.jvz-pdp-calc__title {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font: var(--jvz-fw-bold) 15px/1 var(--jvz-font-display);
	color: var(--jvz-navy);
	margin: 0;
}

.jvz-pdp-calc__mode {
	display: inline-flex;
	background: #fff;
	border: 1px solid var(--jvz-line);
	border-radius: var(--jvz-r-pill);
	padding: 2px;
}

.jvz-pdp-calc__mode button {
	border: 0;
	background: transparent;
	color: var(--jvz-fg-2);
	font: var(--jvz-fw-bold) 12px/1 var(--jvz-font-display);
	padding: 6px 12px;
	border-radius: var(--jvz-r-pill);
	cursor: pointer;
	transition: background .15s, color .15s;
	/* Keep "L × B" / "m²" on a single line — narrow phones (≤320px) would
	 * otherwise wrap "L × B" between the L and × and double the toggle's
	 * height, which mangles the row above the input. */
	white-space: nowrap;
}

.jvz-pdp-calc__mode button.is-active {
	background: var(--jvz-navy);
	color: #fff;
}

.jvz-pdp-calc__field {
	display: block;
}

.jvz-pdp-calc__label {
	font: var(--jvz-fw-bold) 12px/1 var(--jvz-font-display);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--jvz-fg-2);
	display: block;
	margin-bottom: 6px;
}

.jvz-pdp-calc__input-wrap {
	display: flex;
	align-items: center;
	background: #fff;
	border: 1px solid var(--jvz-line);
	border-radius: var(--jvz-r-sm);
	transition: border-color .15s;
}

.jvz-pdp-calc__input-wrap:focus-within {
	border-color: var(--jvz-navy);
}

.jvz-pdp-calc__input-wrap input[type="number"] {
	flex: 1 1 auto;
	min-width: 0;
	width: 100%;
	padding: 12px 16px;
	border: 0;
	background: transparent;
	font: var(--jvz-fw-bold) 18px/1 var(--jvz-font-display);
	color: var(--jvz-navy);
	outline: 0;
}

.jvz-pdp-calc__input-wrap input[type="number"]::-webkit-outer-spin-button,
.jvz-pdp-calc__input-wrap input[type="number"]::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

.jvz-pdp-calc__input-wrap input[type="number"] {
	-moz-appearance: textfield;
}

.jvz-pdp-calc__suffix {
	flex: 0 0 auto;
	padding: 0 16px;
	color: var(--jvz-fg-3);
	font: var(--jvz-fw-bold) 14px/1 var(--jvz-font-display);
}

.jvz-pdp-calc__row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px;
}

.jvz-pdp-calc__toggles {
	display: flex;
	flex-wrap: wrap;
	gap: 6px 20px;
	margin-top: 12px;
}

.jvz-pdp-calc__toggle {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 13px;
	color: var(--jvz-fg-2);
	cursor: pointer;
}

.jvz-pdp-calc__toggle input[type="checkbox"] {
	width: 16px;
	height: 16px;
	accent-color: var(--jvz-blue);
	cursor: pointer;
}

.jvz-pdp-calc__hint {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 12px;
	color: var(--jvz-fg-3);
	margin-top: 4px;
}

.jvz-pdp-calc__result {
	margin-top: 16px;
	background: #fff;
	border: 1px solid var(--jvz-line);
	border-radius: var(--jvz-r-md);
	padding: 14px 16px;
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 16px;
}

.jvz-pdp-calc__result-label {
	font: var(--jvz-fw-bold) 11px/1 var(--jvz-font-display);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--jvz-fg-3);
	margin-bottom: 6px;
}

.jvz-pdp-calc__stepper {
	display: inline-flex;
	align-items: center;
	background: var(--jvz-cream);
	border: 1px solid var(--jvz-line);
	border-radius: var(--jvz-r-pill);
}

.jvz-pdp-calc__stepper button {
	width: 36px !important;
	height: 36px !important;
	min-width: 36px;
	padding: 0 !important;
	margin: 0 !important;
	border: 0 !important;
	background: transparent !important;
	color: var(--jvz-navy);
	cursor: pointer;
	border-radius: var(--jvz-r-pill);
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	line-height: 1 !important;
	box-shadow: none !important;
	transition: background .15s;
}

.jvz-pdp-calc__stepper button:hover {
	background: var(--jvz-cream-2);
}

.jvz-pdp-calc__stepper > span {
	min-width: 36px;
	text-align: center;
	font: var(--jvz-fw-bold) 18px/1 var(--jvz-font-display);
	color: var(--jvz-navy);
	padding: 0 4px;
}

.jvz-pdp-calc__reset {
	display: inline-block;
	margin-top: 4px;
	font: var(--jvz-fw-bold) 11px/1 var(--jvz-font-display);
	color: var(--jvz-blue);
	text-decoration: none;
}

.jvz-pdp-calc__reset:hover {
	text-decoration: underline;
}

.jvz-pdp-calc__result-right {
	text-align: right;
}

.jvz-pdp-calc__delivered {
	font: var(--jvz-fw-bold) 18px/1 var(--jvz-font-display);
	color: var(--jvz-navy);
}

.jvz-pdp-calc__asked {
	font-size: 12px;
	color: var(--jvz-fg-3);
	margin-top: 2px;
}

/* ---------- 9b. Total summary panel -------------------------- */
.jvz-pdp-buy__total {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 12px;
	padding-top: 16px;
	border-top: 1px solid var(--jvz-line-soft);
}

.jvz-pdp-buy__total-line {
	font-size: 13px;
	color: var(--jvz-fg-2);
}

.jvz-pdp-buy__total-savings {
	font: var(--jvz-fw-bold) 12px/1 var(--jvz-font-display);
	color: var(--jvz-green-700);
	margin-top: 4px;
}

.jvz-pdp-buy__total-right {
	text-align: right;
}

.jvz-pdp-buy__total-amount {
	font: var(--jvz-fw-bold) 28px/1 var(--jvz-font-display);
	color: var(--jvz-navy);
	letter-spacing: -0.005em;
}

.jvz-pdp-buy__total-old {
	font-size: 12px;
	color: var(--jvz-fg-4);
	text-decoration: line-through;
	margin-top: 2px;
}

/* ---------- 9c. Primary CTA --------------------------------- */
/* Wrapper sits between calc summary and the CTA so the toast can position
 * itself above the button without disrupting flow. */
.jvz-pdp-buy__cta-wrap {
	position: relative;
}

/* "Kies eerst een kleur" toast — fades+slides in when the user tries to
 * add a variable product without picking a color. Tinted orange (warning)
 * but soft so it doesn't read as an error.
 *
 * Inline above the CTA on desktop, but `position: fixed` above the mobile
 * sticky bar so the user always sees it — the in-page CTA is usually below
 * the fold on mobile, so an inline toast would be invisible. */
.jvz-pdp-buy__pick-toast {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 8px;
	padding: 10px 14px;
	background: color-mix(in srgb, var(--jvz-orange) 12%, #fff);
	border: 1px solid color-mix(in srgb, var(--jvz-orange) 35%, transparent);
	border-radius: var(--jvz-r-md);
	color: var(--jvz-fg-1);
	font: var(--jvz-fw-bold) 13px/1.3 var(--jvz-font-display);
	opacity: 0;
	transform: translateY(4px);
	transition: opacity .18s ease, transform .18s ease;
	pointer-events: none;
	box-shadow: 0 8px 24px rgba(0, 0, 0, .12);
}
/* `display: flex` above wins from the browser-default `[hidden] { display: none }`
 * — without this override the toast keeps its full height + margin even when
 * collapsed, leaving a gap above the CTA on every PDP. */
.jvz-pdp-buy__pick-toast[hidden] {
	display: none !important;
}
.jvz-pdp-buy__pick-toast.is-visible {
	opacity: 1;
	transform: translateY(0);
}
.jvz-pdp-buy__pick-toast svg {
	flex: 0 0 auto;
	color: var(--jvz-orange);
}

@media (max-width: 900px) {
	.jvz-pdp-buy__pick-toast {
		position: fixed;
		left: 12px;
		right: 12px;
		/* Sticky bar is ~64px tall + safe-area-inset → ~80px clearance */
		bottom: calc(80px + env(safe-area-inset-bottom, 0px));
		margin: 0;
		z-index: 9000; /* above sticky bar (which sits at z-index lower) */
	}
}

.jvz-pdp-buy__cta-primary {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
	min-height: 60px;
	padding: 0 24px;
	background: var(--jvz-blue);
	color: #fff;
	border: 0;
	border-radius: var(--jvz-r-pill);
	font: var(--jvz-fw-bold) 16px/1 var(--jvz-font-display);
	cursor: pointer;
	box-shadow: var(--jvz-shadow-cta);
	transition: background .15s, opacity .15s;
}

.jvz-pdp-buy__cta-primary:hover:not(:disabled):not(.is-disabled) {
	background: var(--jvz-blue-hover);
}

.jvz-pdp-buy__cta-primary:disabled,
.jvz-pdp-buy__cta-primary.is-disabled {
	opacity: .55;
	box-shadow: none;
	/* Note: NOT `cursor: not-allowed` and NOT `pointer-events: none` —
	 * we want clicks to reach the JS handler so it can show validation
	 * feedback ("Kies eerst een kleur" / focus the m² input) instead
	 * of the tap silently doing nothing. */
}

.jvz-pdp-buy__cta-text {
	display: inline-flex;
	gap: 4px;
}

/* ---------- 10. Secondary CTA (sample) ----------------------- */
.jvz-pdp-buy__sample-host {
	margin-top: 4px;
}

/* Re-skin the vloerplus-samples plugin's button (.vps-sample-btn) to match the
   koopblok's secondary CTA style. The plugin emits its own #vps-sample-btn and
   handles the click via its bundled JS — we only style. */
.jvz-pdp-buy__sample-host .vps-sample-section {
	padding-top: 0 !important;
	border-top: 0 !important;
	margin-top: 0;
}

.jvz-pdp-buy__sample-host .vps-sample-btn {
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 10px !important;
	width: 100% !important;
	min-height: 60px !important;
	padding: 0 24px !important;
	background: #fff !important;
	border: 1.5px solid var(--jvz-blue) !important;
	border-radius: var(--jvz-r-pill) !important;
	color: var(--jvz-blue) !important;
	font: var(--jvz-fw-bold) 15px/1 var(--jvz-font-display) !important;
	cursor: pointer;
	transition: background .15s, color .15s;
}

.jvz-pdp-buy__sample-host .vps-sample-btn:hover,
.jvz-pdp-buy__sample-host .vps-sample-btn:focus-visible {
	background: var(--jvz-blue) !important;
	color: #fff !important;
}

.jvz-pdp-buy__sample-host .vps-sample-btn__icon svg {
	width: 18px !important;
	height: 18px !important;
	stroke: currentColor !important;
}

.jvz-pdp-buy__sample-host .vps-sample-btn__price {
	background: color-mix(in srgb, var(--jvz-blue) 12%, #fff);
	color: var(--jvz-navy);
	padding: 4px 10px;
	border-radius: var(--jvz-r-pill);
	font-size: 12px;
	font-weight: var(--jvz-fw-bold);
}

.jvz-pdp-buy__sample-host .vps-sample-btn:hover .vps-sample-btn__price {
	background: rgba(255, 255, 255, .25);
	color: #fff;
}

.jvz-pdp-buy__swatches-sample {
	border: 0;
	background: transparent;
	padding: 0;
	cursor: pointer;
}

/* ---------- Swatches block (label + grid) -------------------- */
.jvz-pdp-buy__swatches-block {
	margin-top: 24px;
}

.jvz-pdp-buy__swatches-head {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 12px;
	transition: transform .15s;
}

.jvz-pdp-buy__swatches-head--shake {
	animation: jvz-pdp-shake .5s;
}

@keyframes jvz-pdp-shake {
	10%, 90% { transform: translateX(-2px); }
	20%, 80% { transform: translateX(3px); }
	30%, 50%, 70% { transform: translateX(-5px); }
	40%, 60% { transform: translateX(5px); }
}

.jvz-pdp-buy__swatches-label {
	font: var(--jvz-fw-bold) 14px/1 var(--jvz-font-display);
	color: var(--jvz-navy);
}

.jvz-pdp-buy__swatches-label strong {
	font-weight: var(--jvz-fw-medium);
	color: var(--jvz-fg-2);
}

.jvz-pdp-buy__swatches-sample {
	font: var(--jvz-fw-bold) 13px/1 var(--jvz-font-display);
	color: var(--jvz-blue);
	text-decoration: none;
}

.jvz-pdp-buy__swatches-sample:hover {
	text-decoration: underline;
}

/* ACF placeholder hints — only visible to logged-in editors. */
.jvz-acf-hint {
	background: color-mix(in srgb, var(--jvz-amber) 14%, transparent);
	color: var(--jvz-fg-2);
	border: 1px dashed var(--jvz-amber);
	border-radius: var(--jvz-r-sm);
	padding: 8px 12px;
	font-size: 13px;
	font-style: italic;
}

/* ---------- 11. Delivery / pickup options -------------------- */
.jvz-pdp-buy__delivery {
	display: flex;
	flex-direction: column;
	gap: 8px;
	background: var(--jvz-cream);
	border: 1px solid var(--jvz-line);
	border-radius: var(--jvz-r-md);
	padding: 12px 16px;
	margin-top: 16px;
}

.jvz-pdp-buy__delivery-row {
	display: flex;
	align-items: center;
	gap: 12px;
}

.jvz-pdp-buy__delivery-row + .jvz-pdp-buy__delivery-row {
	border-top: 1px solid var(--jvz-line);
	padding-top: 8px;
}

.jvz-pdp-buy__delivery-icon {
	flex: 0 0 auto;
	height: 36px;
	width: 36px;
	border-radius: var(--jvz-r-pill);
	background: #fff;
	border: 1px solid var(--jvz-line);
	color: var(--jvz-green-700);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.jvz-pdp-buy__delivery-text {
	flex: 1 1 auto;
	display: flex;
	align-items: baseline;
	flex-wrap: wrap;
	gap: 4px 10px;
	font-size: 13px;
	line-height: 1.4;
}

.jvz-pdp-buy__delivery-title {
	font-family: var(--jvz-font-display);
	font-weight: var(--jvz-fw-bold);
	color: var(--jvz-fg-1);
}

.jvz-pdp-buy__delivery-cost {
	font-size: 12px;
	color: var(--jvz-fg-3);
	font-variant-numeric: tabular-nums;
}

/* ---------- 12. Payments row --------------------------------- */
/* Single horizontal row: "Veilig betalen: [logo] [logo] [logo]…" — wraps
 * to a new line only when there's truly no space. Selectors use the parent
 * scope so they outrank WooCommerce's global `.woocommerce img` rule
 * (specificity 0,1,1) which would otherwise force `height: auto` and let
 * the SVG's intrinsic 300×114 dimensions blow the icon up to ~480px wide. */
.jvz-pdp-buy__payments {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 6px 10px;
	margin-top: 4px;
	min-width: 0;
	max-width: 100%;
}

.jvz-pdp-buy__payments .jvz-pdp-buy__payments-label {
	font: var(--jvz-fw-bold) 11px/1 var(--jvz-font-display);
	color: var(--jvz-fg-3);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	flex: 0 0 auto;
}

.jvz-pdp-buy__payments .jvz-pdp-buy__payments-icons {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px 10px;
	min-width: 0;
}

/* Text-chip variant (fallback when a gateway has no logo URL). */
.jvz-pdp-buy__payments .jvz-pdp-buy__payment {
	flex: 0 0 auto;
	background: var(--jvz-cream);
	border: 1px solid var(--jvz-line);
	color: var(--jvz-navy);
	padding: 4px 8px;
	border-radius: 4px;
	font-size: 10px;
}

/* Icon variant — fixed height, auto width, hard-capped max-width so wide
 * marks (iDEAL Wero) don't blow out the row. Parent-scoped selector wins
 * over WooCommerce's `.woocommerce img { height: auto }`. */
.jvz-pdp-buy__payments .jvz-pdp-buy__payment--icon {
	background: transparent;
	border: 0;
	padding: 0;
	border-radius: 0;
	height: 24px;
	width: auto;
	max-width: 80px;
	object-fit: contain;
	display: inline-block;
	flex: 0 0 auto;
}

/* ---------- 13. Help block ----------------------------------- */
.jvz-pdp-buy__help {
	display: flex;
	align-items: center;
	gap: 12px;
	background: color-mix(in srgb, var(--jvz-blue) 5%, #fff);
	border: 1.5px solid color-mix(in srgb, var(--jvz-blue) 30%, transparent);
	border-radius: var(--jvz-r-md);
	padding: 14px 16px;
	margin-top: 16px;
	text-decoration: none;
	transition: background .15s, border-color .15s;
}

.jvz-pdp-buy__help:hover {
	background: color-mix(in srgb, var(--jvz-blue) 10%, #fff);
	border-color: var(--jvz-blue);
}

.jvz-pdp-buy__help-icon {
	flex: 0 0 auto;
	height: 40px;
	width: 40px;
	border-radius: var(--jvz-r-pill);
	background: #fff;
	color: var(--jvz-blue);
	border: 1px solid color-mix(in srgb, var(--jvz-blue) 20%, transparent);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.jvz-pdp-buy__help-title {
	font: var(--jvz-fw-bold) 14px/1.3 var(--jvz-font-display);
	color: var(--jvz-blue);
}

.jvz-pdp-buy__help-sub {
	font-size: 12px;
	color: var(--jvz-fg-2);
	margin-top: 2px;
}

.jvz-pdp-buy__help-sub strong {
	color: var(--jvz-navy);
}

/* ---------- 14. Productomschrijving collapsible -------------- */
.jvz-pdp-desc {
	background: #fff;
	border: 1px solid var(--jvz-line);
	border-radius: var(--jvz-r-lg);
	overflow: hidden;
	margin-top: 24px;
}

.jvz-pdp-desc__toggle {
	width: 100%;
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 16px 24px;
	background: transparent;
	border: 0;
	cursor: pointer;
	text-align: left;
	transition: background .15s;
}

.jvz-pdp-desc__toggle:hover {
	background: color-mix(in srgb, var(--jvz-cream) 40%, transparent);
}

.jvz-pdp-desc__toggle-icon {
	flex: 0 0 auto;
	height: 40px;
	width: 40px;
	border-radius: var(--jvz-r-pill);
	background: var(--jvz-cream);
	color: var(--jvz-navy);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.jvz-pdp-desc__toggle-text {
	flex: 1 1 auto;
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.jvz-pdp-desc__toggle-eyebrow {
	font: var(--jvz-fw-bold) 11px/1 var(--jvz-font-display);
	color: var(--jvz-orange);
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

.jvz-pdp-desc__toggle-title {
	font: var(--jvz-fw-bold) 16px/1.3 var(--jvz-font-display);
	color: var(--jvz-navy);
}

.jvz-pdp-desc__toggle-chev {
	flex: 0 0 auto;
	height: 40px;
	width: 40px;
	border-radius: var(--jvz-r-pill);
	border: 1px solid var(--jvz-line);
	color: var(--jvz-navy);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: transform .25s;
}

.jvz-pdp-desc__toggle[aria-expanded="true"] .jvz-pdp-desc__toggle-chev {
	transform: rotate(180deg);
}

.jvz-pdp-desc__body {
	padding: 8px 28px 28px;
	border-top: 1px solid var(--jvz-line);
}

.jvz-pdp-desc__body[hidden] {
	display: none;
}

.jvz-pdp-desc__extra,
.jvz-pdp-desc__long {
	font-size: 15px;
	line-height: 1.65;
	color: var(--jvz-fg-2);
	margin-top: 16px;
}

.jvz-pdp-desc__extra h2,
.jvz-pdp-desc__extra h3,
.jvz-pdp-desc__long h2,
.jvz-pdp-desc__long h3 {
	color: var(--jvz-navy);
	margin-top: 20px;
	margin-bottom: 8px;
}

.jvz-pdp-desc__extra p + p,
.jvz-pdp-desc__long p + p {
	margin-top: 12px;
}

.jvz-pdp-desc__specs {
	margin-top: 24px;
	background: var(--jvz-cream);
	border-radius: var(--jvz-r-md);
	padding: 20px;
}

.jvz-pdp-desc__specs-title {
	font: var(--jvz-fw-bold) 14px/1 var(--jvz-font-display);
	color: var(--jvz-navy);
	margin-bottom: 12px;
}

.jvz-pdp-desc__specs-list {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 4px 24px;
	margin: 0;
}

.jvz-pdp-desc__spec {
	display: flex;
	justify-content: space-between;
	gap: 12px;
	padding: 6px 0;
	border-bottom: 1px solid var(--jvz-cream-2);
	font-size: 13px;
}

.jvz-pdp-desc__spec dt {
	color: var(--jvz-fg-3);
	margin: 0;
}

.jvz-pdp-desc__spec dd {
	color: var(--jvz-navy);
	font: var(--jvz-fw-bold) 13px/1.4 var(--jvz-font-display);
	text-align: right;
	margin: 0;
}

@media (max-width: 600px) {
	.jvz-pdp-desc__specs-list {
		grid-template-columns: 1fr;
	}
}

/* ---------- 15. Suitability row ------------------------------ */
.jvz-pdp-suit {
	background: #fff;
	border: 1px solid var(--jvz-line);
	border-radius: var(--jvz-r-lg);
	padding: 24px;
	margin-top: 48px;
}

.jvz-pdp-suit__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 20px;
}

.jvz-pdp-suit__eyebrow {
	font: var(--jvz-fw-bold) 12px/1 var(--jvz-font-display);
	color: var(--jvz-orange);
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

.jvz-pdp-suit__title {
	font: var(--jvz-fw-bold) 22px/1.25 var(--jvz-font-display);
	color: var(--jvz-navy);
	margin: 4px 0 0;
}

.jvz-pdp-suit__grid {
	display: grid;
	/* `minmax(0, 1fr)` instead of plain `1fr` — without it the columns get
	 * pushed wider than the container's available space whenever an item's
	 * intrinsic content is wider than the equal share, and the right-most
	 * cells overflow the grid box. */
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 12px;
}

.jvz-pdp-suit__item {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 12px 16px;
	border: 1px solid var(--jvz-line);
	border-radius: var(--jvz-r-md);
	background: color-mix(in srgb, var(--jvz-cream) 40%, transparent);
	min-width: 0; /* let label text shrink/wrap inside its column */
}

.jvz-pdp-suit__item-text {
	min-width: 0;
}
.jvz-pdp-suit__label {
	overflow-wrap: anywhere;
}

.jvz-pdp-suit__item.is-no {
	background: #fff;
	opacity: .7;
}

.jvz-pdp-suit__icon {
	flex: 0 0 auto;
	height: 36px;
	width: 36px;
	border-radius: var(--jvz-r-pill);
	background: color-mix(in srgb, var(--jvz-green) 12%, transparent);
	color: var(--jvz-green-700);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.jvz-pdp-suit__item.is-no .jvz-pdp-suit__icon {
	background: var(--jvz-cream-2);
	color: var(--jvz-fg-3);
}

.jvz-pdp-suit__label {
	font: var(--jvz-fw-bold) 14px/1.2 var(--jvz-font-display);
	color: var(--jvz-navy);
}

.jvz-pdp-suit__note {
	font: var(--jvz-fw-bold) 11px/1.2 var(--jvz-font-display);
	color: var(--jvz-green-700);
	margin-top: 2px;
}

.jvz-pdp-suit__item.is-no .jvz-pdp-suit__note {
	color: var(--jvz-fg-3);
}

@media (max-width: 1100px) {
	.jvz-pdp-suit__grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 600px) {
	.jvz-pdp-suit__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

/* ---------- 15b. Bundle block (mockup-fidelity) -------------- */
.jvz-pdp-bundle {
	background: #fff;
	border: 1px solid var(--jvz-line);
	border-radius: var(--jvz-r-lg);
	margin-top: 48px;
	overflow: hidden;
	box-shadow: var(--jvz-shadow-md);
}

.jvz-pdp-bundle__head {
	background: var(--jvz-navy);
	color: #fff;
	padding: 20px 24px;
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 24px;
}

.jvz-pdp-bundle__head-left {
	flex: 1 1 auto;
}

.jvz-pdp-bundle__eyebrow {
	font: var(--jvz-fw-bold) 12px/1 var(--jvz-font-display);
	color: var(--jvz-orange);
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

.jvz-pdp-bundle__title {
	font: var(--jvz-fw-bold) 24px/1.2 var(--jvz-font-display);
	color: #fff;
	margin: 4px 0 4px;
}

.jvz-pdp-bundle__sub {
	font-size: 13px;
	color: rgba(255, 255, 255, .7);
	margin: 0;
}

.jvz-pdp-bundle__head-right {
	flex: 0 0 auto;
	text-align: right;
}

.jvz-pdp-bundle__savings-label {
	font: var(--jvz-fw-bold) 11px/1 var(--jvz-font-display);
	color: rgba(255, 255, 255, .6);
	text-transform: uppercase;
	letter-spacing: 0.06em;
}

.jvz-pdp-bundle__savings-amount {
	font: var(--jvz-fw-bold) 28px/1 var(--jvz-font-display);
	color: var(--jvz-orange);
	margin-top: 6px;
}

.jvz-pdp-bundle__savings-meta {
	font-size: 11px;
	color: rgba(255, 255, 255, .6);
	margin-top: 4px;
}

.jvz-pdp-bundle__body {
	padding: 20px 24px;
}

.jvz-pdp-bundle__grid {
	display: grid;
	/* Universal layout: cards auto-pack into rows of ≥180px columns; anchor card
	   spans 2 columns (it's the anchor "Jouw vloer" tile). Wraps gracefully
	   when there are many addons. */
	grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
	gap: 16px;
	grid-auto-rows: minmax(0, auto);
}

.jvz-pdp-bundle__card--anchor {
	grid-column: span 2;
}

.jvz-pdp-bundle__card {
	position: relative;
	background: #fff;
	border: 1px solid var(--jvz-line);
	border-radius: var(--jvz-r-md);
	padding: 14px;
	display: flex;
	flex-direction: column;
	gap: 8px;
	transition: opacity .15s, border-color .15s;
}

.jvz-pdp-bundle__card--anchor {
	background: color-mix(in srgb, var(--jvz-cream) 60%, transparent);
}

.jvz-pdp-bundle__card--addon.is-on {
	border-color: var(--jvz-navy);
}

.jvz-pdp-bundle__card-tags {
	display: flex;
	align-items: center;
	gap: 6px;
}

.jvz-pdp-bundle__pill {
	font: var(--jvz-fw-bold) 10px/1 var(--jvz-font-display);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	padding: 4px 8px;
	border-radius: var(--jvz-r-pill);
}

.jvz-pdp-bundle__pill--anchor {
	background: var(--jvz-navy);
	color: #fff;
}

.jvz-pdp-bundle__pill--rec {
	align-self: flex-start;
	background: color-mix(in srgb, var(--jvz-green) 14%, transparent);
	color: var(--jvz-green-700);
}

.jvz-pdp-bundle__lock {
	font-size: 11px;
	color: var(--jvz-fg-3);
}

.jvz-pdp-bundle__check {
	position: absolute;
	top: 10px;
	right: 10px;
	height: 24px;
	width: 24px;
	padding: 0;
	border-radius: 6px;
	border: 1.5px solid var(--jvz-line);
	background: #fff;
	color: transparent;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: background .15s, border-color .15s, color .15s;
	z-index: 2;
}

.jvz-pdp-bundle__check svg {
	width: 14px !important;
	height: 14px !important;
	display: block;
	flex: 0 0 auto;
	max-width: none;
}

/* Generic PDP icon-button override — neutralises a global rule elsewhere in
   the theme that collapses inline <svg> width to 0. Honours the SVG's own
   width/height attributes so each icon renders at its declared size. */
.jvz-pdp svg[width][height] {
	width: attr(width px);
	height: attr(height px);
}

.jvz-pdp-calc__stepper button svg,
.jvz-pdp-calc__hint svg,
.jvz-pdp-calc__title svg,
.jvz-pdp-bundle__qty button svg,
.jvz-pdp-sticky__stepper button svg,
.jvz-pdp-sticky__cta svg,
.jvz-pdp-sticky__meta svg,
.jvz-pdp-buy__cta-primary svg,
.jvz-pdp-buy__delivery-icon svg,
.jvz-pdp-buy__help-icon svg,
.jvz-pdp-bundle__cta svg,
.jvz-pdp-trust__icon svg,
.jvz-pdp-suit__icon svg,
.jvz-pdp-desc__toggle-icon svg,
.jvz-pdp-desc__toggle-chev svg,
.jvz-pdp-uspbar__icon svg,
.jvz-uspbar__icon svg,
.jvz-pdp-gallery__util-btn svg,
.jvz-pdp-gallery__nav svg,
.jvz-pdp-gallery__thumb-nav svg,
.jvz-pdp-buy__tag svg {
	display: block;
	flex: 0 0 auto;
	max-width: none;
}

.jvz-pdp-calc__stepper button svg,
.jvz-pdp-bundle__qty button svg {
	width: 14px !important;
	height: 14px !important;
}

.jvz-pdp-calc__title svg,
.jvz-pdp-calc__hint svg {
	width: 16px !important;
	height: 16px !important;
}

.jvz-pdp-sticky__stepper button svg {
	width: 14px !important;
	height: 14px !important;
}

.jvz-pdp-sticky__cta svg,
.jvz-pdp-buy__cta-primary svg,
.jvz-pdp-bundle__cta svg {
	width: 18px !important;
	height: 18px !important;
}

.jvz-pdp-buy__delivery-icon svg,
.jvz-pdp-buy__help-icon svg {
	width: 20px !important;
	height: 20px !important;
}

.jvz-pdp-trust__icon svg,
.jvz-pdp-suit__icon svg,
.jvz-pdp-desc__toggle-icon svg {
	width: 18px !important;
	height: 18px !important;
}

.jvz-pdp-desc__toggle-chev svg {
	width: 18px !important;
	height: 18px !important;
}

.jvz-pdp-gallery__util-btn svg,
.jvz-pdp-gallery__nav svg {
	width: 18px !important;
	height: 18px !important;
}

.jvz-pdp-gallery__thumb-nav svg {
	width: 14px !important;
	height: 14px !important;
}

.jvz-pdp-buy__tag svg {
	width: 12px !important;
	height: 12px !important;
}

.jvz-pdp-sticky__meta svg {
	width: 11px !important;
	height: 11px !important;
}

/* Card-driven state — JS toggles `is-on` on the card; the checkbox style keys
   off the card class so the two stay in sync. */
.jvz-pdp-bundle__card--addon.is-on .jvz-pdp-bundle__check {
	background: var(--jvz-blue);
	border-color: var(--jvz-blue);
	color: #fff;
}

.jvz-pdp-bundle__card--addon:not(.is-on) .jvz-pdp-bundle__check {
	background: #fff;
	border-color: var(--jvz-line);
	color: transparent;
}

/* Unchecked card: dim the chrome but keep the checkbox at full strength so it
   reads as a real toggle target. */
.jvz-pdp-bundle__card--addon:not(.is-on) {
	background: color-mix(in srgb, var(--jvz-cream) 30%, #fff);
	border-color: var(--jvz-line);
	opacity: 1;
}

.jvz-pdp-bundle__card--addon:not(.is-on) > *:not(.jvz-pdp-bundle__check) {
	opacity: .55;
}

.jvz-pdp-bundle__card-img {
	display: block;
	height: 100px;
	border-radius: 10px;
	border: 1px solid var(--jvz-line);
	background-color: var(--jvz-cream-2);
	background-size: cover;
	background-position: center;
}

a.jvz-pdp-bundle__card-img {
	transition: transform .15s ease, box-shadow .15s ease;
}

a.jvz-pdp-bundle__card-img:hover {
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

a.jvz-pdp-bundle__card-sub {
	display: block;
	color: var(--jvz-fg-3);
	text-decoration: none;
}

a.jvz-pdp-bundle__card-sub:hover {
	text-decoration: underline;
}

.jvz-pdp-bundle__card--anchor .jvz-pdp-bundle__card-img {
	height: 110px;
}

.jvz-pdp-bundle__card--addon .jvz-pdp-bundle__card-img {
	height: 80px;
}

.jvz-pdp-bundle__card-name {
	font: var(--jvz-fw-bold) 13px/1.3 var(--jvz-font-display);
	color: var(--jvz-navy);
	text-decoration: none;
	display: block;
}

a.jvz-pdp-bundle__card-name:hover {
	text-decoration: underline;
}

.jvz-pdp-bundle__card-sub {
	font-size: 11px;
	color: var(--jvz-fg-3);
	line-height: 1.4;
}

.jvz-pdp-bundle__qty {
	display: inline-flex;
	align-items: center;
	align-self: flex-start;
	background: var(--jvz-cream);
	border: 1px solid var(--jvz-line);
	border-radius: var(--jvz-r-pill);
}

.jvz-pdp-bundle__qty button {
	width: 28px !important;
	height: 28px !important;
	min-width: 28px;
	padding: 0 !important;
	margin: 0 !important;
	border: 0 !important;
	background: transparent !important;
	color: var(--jvz-navy);
	cursor: pointer;
	border-radius: var(--jvz-r-pill);
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	line-height: 1 !important;
	box-shadow: none !important;
}

.jvz-pdp-bundle__qty span {
	min-width: 24px;
	text-align: center;
	font: var(--jvz-fw-bold) 12px/1 var(--jvz-font-display);
	color: var(--jvz-navy);
}

.jvz-pdp-bundle__card-foot {
	margin-top: auto;
	padding-top: 8px;
	display: flex;
	align-items: baseline;
	justify-content: flex-end;
	gap: 8px;
}

.jvz-pdp-bundle__sub-label {
	font: var(--jvz-fw-bold) 10px/1 var(--jvz-font-display);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--jvz-fg-3);
	margin-right: auto;
}

.jvz-pdp-bundle__sub-amount,
.jvz-pdp-bundle__price {
	font: var(--jvz-fw-bold) 15px/1 var(--jvz-font-display);
	color: var(--jvz-navy);
}

.jvz-pdp-bundle__price-old {
	font-size: 11px;
	color: var(--jvz-fg-4);
	text-decoration: line-through;
}

.jvz-pdp-bundle__foot {
	background: var(--jvz-cream);
	border-top: 1px solid var(--jvz-line);
	padding: 18px 24px;
	display: flex;
	align-items: center;
	gap: 24px;
}

.jvz-pdp-bundle__foot-left {
	flex: 1 1 auto;
}

.jvz-pdp-bundle__foot-label {
	font: var(--jvz-fw-bold) 12px/1 var(--jvz-font-display);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--jvz-fg-2);
	display: flex;
	align-items: center;
	gap: 8px;
}

.jvz-pdp-bundle__foot-pct {
	background: var(--jvz-orange);
	color: #fff;
	padding: 3px 8px;
	border-radius: var(--jvz-r-pill);
	font-size: 11px;
	letter-spacing: 0;
}

.jvz-pdp-bundle__foot-row {
	display: flex;
	align-items: baseline;
	gap: 12px;
	margin-top: 6px;
}

.jvz-pdp-bundle__foot-total {
	font: var(--jvz-fw-bold) 32px/1 var(--jvz-font-display);
	color: var(--jvz-navy);
	letter-spacing: -0.005em;
}

.jvz-pdp-bundle__foot-old {
	font-size: 14px;
	color: var(--jvz-fg-4);
	text-decoration: line-through;
}

.jvz-pdp-bundle__foot-savings {
	font: var(--jvz-fw-bold) 12px/1 var(--jvz-font-display);
	color: var(--jvz-green-700);
}

.jvz-pdp-bundle__foot-meta {
	font-size: 11px;
	color: var(--jvz-fg-3);
	margin-top: 4px;
}

.jvz-pdp-bundle__cta {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	min-height: 58px;
	padding: 0 28px;
	background: var(--jvz-blue);
	color: #fff;
	border: 0;
	border-radius: var(--jvz-r-pill);
	font: var(--jvz-fw-bold) 15px/1 var(--jvz-font-display);
	cursor: pointer;
	box-shadow: var(--jvz-shadow-cta);
	white-space: nowrap;
	transition: background .15s;
}

.jvz-pdp-bundle__cta:hover {
	background: var(--jvz-blue-hover);
}

@media (max-width: 700px) {
	.jvz-pdp-bundle__head,
	.jvz-pdp-bundle__foot {
		flex-direction: column;
		align-items: flex-start;
		gap: 12px;
	}
	.jvz-pdp-bundle__head-right,
	.jvz-pdp-bundle__cta {
		text-align: left;
		align-self: stretch;
	}
	.jvz-pdp-bundle__cta {
		width: 100%;
		justify-content: center;
	}
	.jvz-pdp-bundle__grid {
		grid-template-columns: 1fr 1fr;
	}
	.jvz-pdp-bundle__card--anchor {
		grid-column: span 2;
	}
}

/* ---------- 15c. Strip duplicate legacy below-fold ----------- */
.product-info-tabs-container,
#vaak-samen-gekocht.vaak-samen-gekocht-section {
	display: none !important;
}

/* ---------- 16. Mobile sticky bottom CTA --------------------- */
.jvz-pdp-sticky {
	display: none;
}

@media (max-width: 900px) {
	.jvz-pdp-sticky {
		display: block;
		position: fixed;
		left: 0;
		right: 0;
		bottom: 0;
		z-index: 80;
		background: #fff;
		border-top: 1px solid var(--jvz-line);
		box-shadow: 0 -6px 18px rgba(0,0,0,.10);
		padding: 10px 12px calc(env(safe-area-inset-bottom, 0) + 12px);
	}

	.jvz-pdp-sticky__inner {
		display: flex;
		align-items: center;
		gap: 10px;
	}

	.jvz-pdp-sticky__stepper {
		flex: 0 0 auto;
		display: inline-flex;
		align-items: center;
		background: var(--jvz-cream);
		border: 1px solid var(--jvz-line);
		border-radius: var(--jvz-r-pill);
	}

	.jvz-pdp-sticky__stepper button {
		width: 36px !important;
		height: 44px !important;
		min-width: 36px;
		padding: 0 !important;
		margin: 0 !important;
		border: 0 !important;
		background: transparent !important;
		color: var(--jvz-navy);
		cursor: pointer;
		border-radius: var(--jvz-r-pill);
		display: inline-flex !important;
		align-items: center !important;
		justify-content: center !important;
		line-height: 1 !important;
		box-shadow: none !important;
	}

	.jvz-pdp-sticky__stepper > span {
		min-width: 28px;
		text-align: center;
		font: var(--jvz-fw-bold) 14px/1 var(--jvz-font-display);
		color: var(--jvz-navy);
	}

	.jvz-pdp-sticky__cta {
		flex: 1 1 auto;
		min-width: 0; /* allow children to shrink/ellipsize within the bar */
		min-height: 48px;
		padding: 0 14px;
		background: var(--jvz-blue);
		color: #fff;
		border: 0;
		border-radius: var(--jvz-r-pill);
		font: var(--jvz-fw-bold) 13px/1 var(--jvz-font-display);
		display: inline-flex;
		align-items: center;
		justify-content: center;
		gap: 6px;
		cursor: pointer;
		box-shadow: var(--jvz-shadow-cta);
		transition: background .15s;
	}

	.jvz-pdp-sticky__cta-label,
	.jvz-pdp-sticky__cta-price {
		/* Both must stay on a single line — phones ≤340px would otherwise
		 * wrap "In winkelwagen" between "In" and "winkelwagen" and stack
		 * "€ 29,95" above "/m²", doubling the bar height. */
		white-space: nowrap;
	}

	.jvz-pdp-sticky__cta-price {
		background: rgba(255, 255, 255, .2);
		padding: 4px 8px;
		border-radius: var(--jvz-r-pill);
		font-size: 12px;
	}

	/* Very narrow phones (iPhone SE etc): the label + price together don't
	 * fit. Drop the label — the cart icon is universally readable, and the
	 * price tag is what the user actually wants to see. */
	@media (max-width: 360px) {
		.jvz-pdp-sticky__cta-label {
			display: none;
		}
		.jvz-pdp-sticky__cta {
			padding: 0 12px;
			gap: 8px;
		}
		.jvz-pdp-sticky__stepper {
			padding: 2px;
		}
		.jvz-pdp-sticky {
			padding: 8px 10px calc(env(safe-area-inset-bottom, 0) + 8px) !important;
		}
	}

	.jvz-pdp-sticky__meta {
		display: flex;
		justify-content: space-between;
		font-size: 10px;
		color: var(--jvz-fg-3);
		margin-top: 6px;
	}

	.jvz-pdp-sticky__meta span {
		display: inline-flex;
		align-items: center;
		gap: 4px;
	}

	.jvz-pdp-sticky__stock {
		color: var(--jvz-green-700);
		font: var(--jvz-fw-bold) 10px/1 var(--jvz-font-display);
	}

	/* Sticky-bar overlap-avoidance is handled at body level (above), so no
	   inner padding needed here — keeps section-to-section flow tight. */

	/* Suppress legacy breadcrumb that lives outside our PDP — only ours stays. */
	body.single-product .breadcrumbs:not(.jvz-pdp-breadcrumb),
	body.single-product nav.woocommerce-breadcrumb:not(.jvz-pdp-breadcrumb) {
		display: none !important;
	}
}

/* Hide duplicate breadcrumbs at any viewport. */
body.single-product .site-content > .breadcrumbs,
body.single-product .site-main > nav.woocommerce-breadcrumb,
body.single-product .header-breadcrumbs {
	display: none !important;
}

/* ---------- 7. Mobile tweaks ---------------------------------- */
@media (max-width: 900px) {
	.jvz-pdp-buy__title {
		font-size: 24px;
	}

	.jvz-pdp-buy__price {
		font-size: 32px;
	}

	.jvz-pdp-uspbar__inner {
		padding: 8px 16px;
		overflow-x: auto;
	}

	.jvz-pdp-uspbar__item {
		flex-shrink: 0;
	}
}

/* Addon-only product notice — replaces "In winkelwagen" CTA on bijproduct PDPs
   (lijm, lijmkam, ondervloer, …). Server-side gate is `vloerplus_pdp_is_addon`. */
.jvz-pdp-buy__addon-notice {
	display: flex;
	gap: 14px;
	align-items: flex-start;
	margin-top: 16px;
	padding: 18px 20px;
	background: #FFF7EC;
	border: 1px solid #F2D8A1;
	border-radius: 14px;
	color: #5A4421;
}

.jvz-pdp-buy__addon-notice-icon {
	flex: 0 0 auto;
	width: 36px;
	height: 36px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #FBE7BE;
	color: #8A5A12;
	border-radius: 999px;
}

.jvz-pdp-buy__addon-notice-body {
	flex: 1 1 auto;
	min-width: 0;
}

.jvz-pdp-buy__addon-notice-title {
	display: block;
	font-size: 15px;
	font-weight: 700;
	color: #3D2D10;
	margin-bottom: 4px;
}

.jvz-pdp-buy__addon-notice-text {
	font-size: 14px;
	line-height: 1.5;
	margin: 0 0 10px;
}

.jvz-pdp-buy__addon-notice-cta {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: 14px;
	font-weight: 600;
	color: #1F4A2E;
	text-decoration: none;
	border-bottom: 1px solid currentColor;
	padding-bottom: 1px;
}

.jvz-pdp-buy__addon-notice-cta:hover {
	color: #163A22;
}
