/* ============================================================
 *  Pluffie productpagina (PDP)
 *  Gallery + samenvatting, picker, accordions, verhaal, waarom,
 *  reviews en sticky koopbalk. Dier-kleur via data-pluffie-dier
 *  (--pluffie-current), met accent als fallback.
 * ============================================================ */

.pluffie-pdp {
	--pdp-accent: var(--pluffie-current, var(--pluffie-accent));
	padding: 0 0 var(--pluffie-space-3xl);
}

.pluffie-pdp > .pluffie-container > .woocommerce-breadcrumb { margin-top: 0; }

/* === Top: gallery + samenvatting === */
.pluffie-pdp__top {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: clamp(1.5rem, 4vw, 3.5rem);
	align-items: start;
}

/* Gallery */
.pluffie-pdp__gallery {
	position: relative;
}

/* WooCommerce-gallery vult de VOLLE kolombreedte (geen padding eromheen). */
.pluffie-pdp__gallery .woocommerce-product-gallery {
	width: 100% !important;
	float: none !important;
	margin: 0 !important;
}

.pluffie-pdp__gallery .woocommerce-product-gallery__wrapper,
.pluffie-pdp__gallery .woocommerce-product-gallery__image {
	width: 100%;
	margin: 0;
}

.pluffie-pdp__gallery .woocommerce-product-gallery__image img,
.pluffie-pdp__gallery .woocommerce-product-gallery img {
	width: 100%;
	height: auto;
	border-radius: var(--pluffie-radius-xl);
	background: color-mix(in srgb, var(--pdp-accent) 12%, var(--pluffie-bg-card));
}

.pluffie-pdp__gallery .flex-control-thumbs {
	display: flex;
	flex-wrap: wrap;
	gap: var(--pluffie-space-2xs);
	list-style: none;
	margin: var(--pluffie-space-sm) 0 0;
	padding: 0;
}

.pluffie-pdp__gallery .flex-control-thumbs li {
	width: 64px;
	margin: 0;
}

.pluffie-pdp__gallery .flex-control-thumbs img {
	border-radius: var(--pluffie-radius-md);
	cursor: pointer;
	opacity: 0.7;
	transition: opacity var(--pluffie-transition-base);
}

.pluffie-pdp__gallery .flex-control-thumbs img.flex-active,
.pluffie-pdp__gallery .flex-control-thumbs img:hover {
	opacity: 1;
}

.pluffie-pdp .onsale,
.pluffie-pdp__gallery .onsale {
	position: absolute;
	z-index: 2;
	top: var(--pluffie-space-sm);
	left: var(--pluffie-space-sm);
	background: var(--pluffie-accent);
	color: var(--pluffie-bg-card);
	font-family: var(--pluffie-font-display);
	font-weight: var(--pluffie-fw-bold);
	font-size: var(--pluffie-fs-3xs);
	padding: 0.35rem 0.8rem;
	border-radius: var(--pluffie-radius-pill);
	margin: 0;
}

/* === Samenvatting === */
.pluffie-pdp__summary {
	display: flex;
	flex-direction: column;
}

.pluffie-pdp__rating {
	display: inline-flex;
	align-items: center;
	gap: var(--pluffie-space-2xs);
	text-decoration: none;
	color: var(--pluffie-fg-muted);
	font-size: var(--pluffie-fs-2xs);
	margin-bottom: var(--pluffie-space-2xs);
}

.pluffie-pdp__rating .star-rating { color: var(--pluffie-warning, #E0A23F); }

.pluffie-pdp__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	align-self: flex-start;
	background: color-mix(in srgb, var(--pdp-accent) 26%, var(--pluffie-bg-card));
	color: var(--pluffie-fg);
	font-family: var(--pluffie-font-display);
	font-weight: var(--pluffie-fw-bold);
	font-size: var(--pluffie-fs-3xs);
	padding: 0.35rem 0.85rem;
	border-radius: var(--pluffie-radius-pill);
	margin-bottom: var(--pluffie-space-xs);
}

.pluffie-pdp__eyebrow .pluffie-heart { color: var(--pluffie-accent); }

.pluffie-pdp__eyebrow--limited {
	background: var(--pluffie-accent-dark);
	color: var(--pluffie-bg-card);
	letter-spacing: 0.05em;
	text-transform: uppercase;
}

.pluffie-pdp__eyebrow--limited svg { color: var(--pluffie-bg-card); }

.pluffie-pdp__title {
	font-family: var(--pluffie-font-display);
	font-size: clamp(1.9rem, 3.5vw, 2.75rem);
	font-weight: var(--pluffie-fw-extra);
	line-height: var(--pluffie-lh-tight);
	color: var(--pluffie-fg);
	margin: 0 0 var(--pluffie-space-xs);
}

.pluffie-pdp__oneliner {
	font-size: var(--pluffie-fs-md);
	color: var(--pluffie-fg-muted);
	margin: 0 0 var(--pluffie-space-md);
}

.pluffie-pdp__price {
	font-family: var(--pluffie-font-display);
	font-weight: var(--pluffie-fw-bold);
	font-size: var(--pluffie-fs-xl);
	color: var(--pluffie-accent-dark);
	margin-bottom: var(--pluffie-space-md);
}

.pluffie-pdp__price del {
	color: var(--pluffie-fg-muted);
	font-weight: var(--pluffie-fw-semibold);
	font-size: 0.7em;
	margin-right: 0.4em;
}

.pluffie-pdp__price ins { text-decoration: none; }

.pluffie-pdp__price:has(+ .pluffie-pdp__scarcity) {
	margin-bottom: var(--pluffie-space-xs);
}

.pluffie-pdp__scarcity {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	align-self: flex-start;
	max-width: 100%;
	margin: 0 0 var(--pluffie-space-md);
	padding: 0.38rem 0.8rem;
	background: color-mix(in srgb, var(--pluffie-accent) 15%, var(--pluffie-bg-card));
	border: 1.5px solid color-mix(in srgb, var(--pluffie-accent) 45%, transparent);
	border-radius: var(--pluffie-radius-pill);
	color: var(--pluffie-fg);
	font-size: 0.9rem;
	font-weight: var(--pluffie-fw-semibold);
	line-height: 1.3;
}

.pluffie-pdp__scarcity svg {
	flex-shrink: 0;
	color: var(--pluffie-accent);
}

.pluffie-pdp__scarcity strong {
	font-weight: var(--pluffie-fw-extra);
	color: var(--pluffie-accent-dark);
}

.pluffie-pdp__usps,
.pluffie-pdp__trust {
	list-style: none;
	margin: 0 0 var(--pluffie-space-md);
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--pluffie-space-2xs);
}

.pluffie-pdp__usps li,
.pluffie-pdp__trust li {
	display: flex;
	align-items: center;
	gap: var(--pluffie-space-2xs);
	font-size: var(--pluffie-fs-2xs);
	color: var(--pluffie-fg);
	margin: 0;
}

.pluffie-pdp__usps .pluffie-icon { color: var(--pdp-accent); flex-shrink: 0; }
.pluffie-pdp__trust { padding-top: var(--pluffie-space-sm); border-top: 1px solid var(--pluffie-border-soft); }
.pluffie-pdp__trust li { color: var(--pluffie-fg-muted); }
.pluffie-pdp__trust .pluffie-icon { color: var(--pluffie-fg-muted); flex-shrink: 0; }

/* === Picker "Kies jouw Pluffie" === */
.pluffie-pdp-picker {
	margin: 0 0 var(--pluffie-space-md);
}

.pluffie-pdp-picker__label {
	display: block;
	font-family: var(--pluffie-font-display);
	font-weight: var(--pluffie-fw-bold);
	font-size: var(--pluffie-fs-2xs);
	color: var(--pluffie-fg);
	margin-bottom: var(--pluffie-space-2xs);
}

.pluffie-pdp-picker__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(92px, 1fr));
	gap: var(--pluffie-space-2xs);
}

.pluffie-pdp-picker__item {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 4px;
	padding: 6px 4px;
	border: 2px solid var(--pluffie-border-soft);
	border-radius: var(--pluffie-radius-md);
	background: var(--pluffie-bg-card);
	text-decoration: none;
	transition: border-color var(--pluffie-transition-base), transform var(--pluffie-transition-fast);
}

.pluffie-pdp-picker__item:hover { transform: translateY(-2px); border-color: var(--pdp-accent); }

.pluffie-pdp-picker__item.is-active {
	border-color: var(--pdp-accent);
	background: color-mix(in srgb, var(--pdp-accent) 16%, var(--pluffie-bg-card));
}

.pluffie-pdp-picker__media {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	aspect-ratio: 1 / 1;
	overflow: hidden;
	border-radius: var(--pluffie-radius-sm);
}

.pluffie-pdp-picker__media img { width: 100%; height: 100%; object-fit: cover; }
.pluffie-pdp-picker__emoji { font-size: 1.8rem; line-height: 1; }

/* Uitverkocht: niet aanklikbaar, gedimd, met badge. */
.pluffie-pdp-picker__item--soldout {
	pointer-events: none;
	cursor: default;
	opacity: 0.6;
}
.pluffie-pdp-picker__item--soldout .pluffie-pdp-picker__media img,
.pluffie-pdp-picker__item--soldout .pluffie-pdp-picker__emoji { filter: grayscale(0.7); }
.pluffie-pdp-picker__item--soldout:hover { transform: none; border-color: var(--pluffie-border); }
.pluffie-pdp-picker__soldout {
	position: absolute;
	top: 6px;
	left: 6px;
	background: var(--pluffie-fg);
	color: #fff;
	font-size: 0.62rem;
	font-weight: var(--pluffie-fw-bold);
	letter-spacing: 0.05em;
	text-transform: uppercase;
	padding: 2px 7px;
	border-radius: var(--pluffie-radius-pill);
}

.pluffie-pdp-picker__foot {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 5px;
	width: 100%;
}

.pluffie-pdp-picker__radio {
	width: 14px;
	height: 14px;
	border: 2px solid var(--pluffie-border);
	border-radius: 50%;
	flex-shrink: 0;
	position: relative;
}

.pluffie-pdp-picker__item.is-active .pluffie-pdp-picker__radio { border-color: var(--pdp-accent); }
.pluffie-pdp-picker__item.is-active .pluffie-pdp-picker__radio::after {
	content: "";
	position: absolute;
	inset: 2px;
	border-radius: 50%;
	background: var(--pdp-accent);
}

.pluffie-pdp-picker__naam {
	font-size: 0.72rem;
	font-weight: var(--pluffie-fw-semibold);
	color: var(--pluffie-fg-muted);
	min-width: 0;
	line-height: 1.2;
	text-align: center;
}

.pluffie-pdp-picker__item.is-active .pluffie-pdp-picker__naam { color: var(--pluffie-fg); }

/* === Koopknop (WooCommerce form) === */
.pluffie-pdp__buy {
	margin-bottom: var(--pluffie-space-md);
}

.pluffie-pdp__buy form.cart {
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	gap: var(--pluffie-space-2xs);
	margin: 0;
}

.pluffie-pdp__buy .quantity input.qty {
	width: 64px;
	height: 100%;
	min-height: 52px;
	padding: 0 0.5rem;
	border: 2px solid var(--pluffie-border);
	border-radius: var(--pluffie-radius-pill);
	background: var(--pluffie-bg-card);
	font-family: var(--pluffie-font-display);
	font-weight: var(--pluffie-fw-bold);
	color: var(--pluffie-fg);
	text-align: center;
}

/* WooCommerce kleurt .button.alt standaard paars (#a46497); wij forceren het
   Pluffie-accent, ook op de variabele (cadeaubon) add-to-cart knop. */
.pluffie-pdp__buy .single_add_to_cart_button,
.pluffie-pdp__buy button.button,
.pluffie-pdp__buy .button.alt {
	flex: 1 1 auto;
	min-height: 52px;
	padding: 0 var(--pluffie-space-lg);
	background: var(--pluffie-accent) !important;
	color: #fff !important;
	border: 0;
	border-radius: var(--pluffie-radius-pill);
	font-family: var(--pluffie-font-display);
	font-weight: var(--pluffie-fw-bold);
	font-size: var(--pluffie-fs-sm);
	cursor: pointer;
	transition: background var(--pluffie-transition-base), transform var(--pluffie-transition-fast);
}

.pluffie-pdp__buy .single_add_to_cart_button:hover,
.pluffie-pdp__buy .button.alt:hover {
	background: var(--pluffie-accent-dark) !important;
	transform: translateY(-2px);
}
.pluffie-pdp__buy .single_add_to_cart_button.disabled,
.pluffie-pdp__buy .single_add_to_cart_button:disabled { opacity: 0.5; cursor: not-allowed; transform: none; }

/* === Accordions === */
.pluffie-pdp__accordions {
	border-top: 1px solid var(--pluffie-border-soft);
}

.pluffie-pdp__acc {
	border-bottom: 1px solid var(--pluffie-border-soft);
}

.pluffie-pdp__acc-head {
	cursor: pointer;
	list-style: none;
	padding: var(--pluffie-space-sm) 0;
	font-family: var(--pluffie-font-display);
	font-weight: var(--pluffie-fw-bold);
	color: var(--pluffie-fg);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--pluffie-space-sm);
}

.pluffie-pdp__acc-head::-webkit-details-marker { display: none; }

.pluffie-pdp__acc-head::after {
	content: "+";
	font-size: 1.4em;
	line-height: 1;
	color: var(--pdp-accent);
	transition: transform var(--pluffie-transition-base);
}

.pluffie-pdp__acc[open] .pluffie-pdp__acc-head::after { transform: rotate(45deg); }

.pluffie-pdp__acc-body {
	padding: 0 0 var(--pluffie-space-md);
}

.pluffie-pdp__specs {
	list-style: none;
	margin: var(--pluffie-space-xs) 0 0;
	padding: 0;
}

.pluffie-pdp__specs li {
	padding: 0.35rem 0;
	border-bottom: 1px dashed var(--pluffie-border-soft);
	font-size: var(--pluffie-fs-2xs);
	color: var(--pluffie-fg-muted);
}

.pluffie-pdp__specs strong { color: var(--pluffie-fg); }

/* === Verhaal-sectie === */
.pluffie-pdp-story {
	margin-top: var(--pluffie-space-2xl);
	background: var(--pluffie-bg-warm);
	border-radius: var(--pluffie-radius-xl);
	padding: clamp(2rem, 5vw, 3.5rem) 0;
}

.pluffie-pdp-story .pluffie-container { max-width: 820px; }

.pluffie-pdp-story__title {
	font-family: var(--pluffie-font-display);
	font-size: var(--pluffie-fs-xl);
	font-weight: var(--pluffie-fw-extra);
	color: var(--pluffie-fg);
	margin: 0 0 var(--pluffie-space-sm);
	text-align: center;
}

.pluffie-pdp-story__tekst,
.pluffie-pdp-story__tekst p { text-align: center; }
/* Lees-kolom zelf centreren: anders pint de globale p{max-width:65ch} het blok links vast. */
.pluffie-pdp-story__tekst {
	max-width: 60ch;
	margin-left: auto;
	margin-right: auto;
}
.pluffie-pdp-story__tekst p {
	max-width: none;
	margin-left: auto;
	margin-right: auto;
}
.pluffie-pdp-story .pluffie-pdp-traits { justify-content: center; }

.pluffie-pdp-traits {
	list-style: none;
	margin: var(--pluffie-space-md) 0 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: var(--pluffie-space-2xs);
	justify-content: center;
}

.pluffie-pdp-trait {
	background: var(--pluffie-bg-card);
	border: 1px solid var(--pluffie-border-soft);
	border-radius: var(--pluffie-radius-pill);
	padding: 0.4rem 0.9rem;
	font-size: var(--pluffie-fs-2xs);
	font-weight: var(--pluffie-fw-semibold);
	color: var(--pluffie-fg);
}

/* === Wat is een Pluffie? (intro voor bezoekers die via ads binnenkomen) === */
.pluffie-pdp-wat {
	margin-top: var(--pluffie-space-2xl);
	background: var(--pluffie-accent-light);
	border-radius: var(--pluffie-radius-xl);
	padding: clamp(2rem, 5vw, 3.5rem) 0;
}
.pluffie-pdp-wat__inner {
	max-width: 640px;
	margin-left: auto;
	margin-right: auto;
	padding: 0 var(--pluffie-space-md);
	text-align: center;
}
.pluffie-pdp-wat__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	color: var(--pluffie-accent-dark);
	font-family: var(--pluffie-font-display);
	font-weight: var(--pluffie-fw-bold);
	font-size: var(--pluffie-fs-2xs);
	text-transform: uppercase;
	letter-spacing: var(--pluffie-tracking-wide);
	margin-bottom: var(--pluffie-space-2xs);
}
.pluffie-pdp-wat__title {
	font-family: var(--pluffie-font-display);
	font-size: var(--pluffie-fs-xl);
	font-weight: var(--pluffie-fw-extra);
	color: var(--pluffie-fg);
	margin: 0 0 var(--pluffie-space-sm);
}
.pluffie-pdp-wat__lead {
	max-width: 56ch;
	margin: 0 auto var(--pluffie-space-lg);
	color: var(--pluffie-fg);
	opacity: 0.85;
	font-size: var(--pluffie-fs-md);
	line-height: 1.65;
}
.pluffie-pdp-wat__points {
	list-style: none;
	margin: 0 0 var(--pluffie-space-lg);
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--pluffie-space-sm) var(--pluffie-space-lg);
}
.pluffie-pdp-wat__points li {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-weight: var(--pluffie-fw-semibold);
	color: var(--pluffie-fg);
	font-size: var(--pluffie-fs-sm);
}
.pluffie-pdp-wat__points svg { color: var(--pluffie-accent); flex: 0 0 auto; }

/* === Waarom een Pluffie === */
.pluffie-pdp-waarom {
	padding: clamp(2.5rem, 6vw, 4rem) 0;
}

.pluffie-pdp-waarom__title {
	font-family: var(--pluffie-font-display);
	font-size: var(--pluffie-fs-xl);
	font-weight: var(--pluffie-fw-extra);
	color: var(--pluffie-fg);
	text-align: center;
	margin: 0 0 var(--pluffie-space-lg);
}

.pluffie-pdp-waarom__grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: var(--pluffie-space-lg);
}

.pluffie-pdp-waarom__item {
	text-align: center;
	background: var(--pluffie-bg-card);
	border: 1px solid var(--pluffie-border-soft);
	border-radius: var(--pluffie-radius-lg);
	padding: var(--pluffie-space-lg);
}

.pluffie-pdp-waarom__icon {
	display: inline-flex;
	color: var(--pluffie-accent);
	margin-bottom: var(--pluffie-space-2xs);
}

.pluffie-pdp-waarom__naam {
	font-family: var(--pluffie-font-display);
	font-size: var(--pluffie-fs-md);
	font-weight: var(--pluffie-fw-bold);
	color: var(--pluffie-fg);
	margin: 0 0 var(--pluffie-space-3xs);
}

.pluffie-pdp-waarom__tekst {
	color: var(--pluffie-fg-muted);
	font-size: var(--pluffie-fs-2xs);
	margin: 0;
}

/* === Reviews (WooCommerce) === */
.pluffie-pdp-reviews {
	padding: clamp(2rem, 5vw, 3.5rem) 0;
	border-top: 1px solid var(--pluffie-border-soft);
}

.pluffie-pdp-reviews .pluffie-container { max-width: 860px; }

.pluffie-pdp-reviews #reviews h2,
.pluffie-pdp-reviews .woocommerce-Reviews-title {
	font-family: var(--pluffie-font-display);
	font-size: var(--pluffie-fs-lg);
	font-weight: var(--pluffie-fw-bold);
	color: var(--pluffie-fg);
}

.pluffie-pdp-reviews ol.commentlist {
	list-style: none;
	margin: var(--pluffie-space-md) 0;
	padding: 0;
}

.pluffie-pdp-reviews ol.commentlist li.review {
	background: var(--pluffie-bg-card);
	border: 1px solid var(--pluffie-border-soft);
	border-radius: var(--pluffie-radius-lg);
	padding: var(--pluffie-space-md);
	margin-bottom: var(--pluffie-space-sm);
}

.pluffie-pdp-reviews .comment-form input[type="text"],
.pluffie-pdp-reviews .comment-form input[type="email"],
.pluffie-pdp-reviews .comment-form textarea {
	width: 100%;
	padding: 0.7rem 0.9rem;
	border: 2px solid var(--pluffie-border);
	border-radius: var(--pluffie-radius-md);
	background: var(--pluffie-bg-card);
	font-family: var(--pluffie-font-body);
}

.pluffie-pdp-reviews .comment-form .submit,
.pluffie-pdp-reviews #respond .form-submit input {
	background: var(--pluffie-accent);
	color: var(--pluffie-bg-card);
	border: 0;
	border-radius: var(--pluffie-radius-pill);
	padding: 0.7rem 1.4rem;
	font-family: var(--pluffie-font-display);
	font-weight: var(--pluffie-fw-bold);
	cursor: pointer;
}

/* === Sticky koopbalk === */
.pluffie-pdp-sticky {
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: var(--pluffie-z-sticky);
	background: var(--pluffie-bg-card);
	border-top: 1px solid var(--pluffie-border);
	box-shadow: 0 -8px 24px rgba(59, 46, 36, 0.10);
	padding: 0.6rem 0;
	animation: pluffie-sticky-in var(--pluffie-transition-base) ease;
}

.pluffie-pdp-sticky[hidden] { display: none; }

@keyframes pluffie-sticky-in {
	from { transform: translateY(100%); }
	to { transform: translateY(0); }
}

.pluffie-pdp-sticky__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--pluffie-space-sm);
}

.pluffie-pdp-sticky__info {
	display: flex;
	align-items: center;
	gap: var(--pluffie-space-2xs);
	min-width: 0;
}

.pluffie-pdp-sticky__media img {
	width: 44px;
	height: 44px;
	object-fit: cover;
	border-radius: var(--pluffie-radius-md);
}

.pluffie-pdp-sticky__naam {
	font-family: var(--pluffie-font-display);
	font-weight: var(--pluffie-fw-bold);
	color: var(--pluffie-fg);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.pluffie-pdp-sticky__buy {
	display: flex;
	align-items: center;
	gap: var(--pluffie-space-sm);
	flex-shrink: 0;
}

.pluffie-pdp-sticky__price {
	font-family: var(--pluffie-font-display);
	font-weight: var(--pluffie-fw-bold);
	color: var(--pluffie-accent-dark);
}

/* === Responsive === */
@media (min-width: 981px) {
	.pluffie-pdp__gallery {
		position: sticky;
		top: calc(var(--pluffie-header-height) + 1rem);
	}
}

@media (max-width: 980px) {
	.pluffie-pdp__top { grid-template-columns: 1fr; }
}

@media (max-width: 600px) {
	.pluffie-pdp-sticky__naam { max-width: 40vw; }
}

/* === USP-boxen (boven picker en onder de betaaliconen) === */
.pluffie-pdp-uspbox {
	list-style: none;
	margin: 0 0 var(--pluffie-space-md);
	padding: 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--pluffie-space-2xs);
}

.pluffie-pdp-uspbox__item {
	display: flex;
	flex-direction: column;
	gap: clamp(4px, 1.5vw, 8px);
	padding: clamp(0.65rem, 2.6vw, 1.1rem);
	background: var(--pluffie-bg-warm);
	border-radius: var(--pluffie-radius-md);
	min-width: 0;
}

.pluffie-pdp-uspbox--product .pluffie-pdp-uspbox__item {
	background: color-mix(in srgb, var(--pdp-accent) 15%, var(--pluffie-bg-card));
}

.pluffie-pdp-uspbox__icon { color: var(--pluffie-accent-dark); display: inline-flex; }
.pluffie-pdp-uspbox__icon svg { width: clamp(24px, 7vw, 30px); height: auto; }
.pluffie-pdp-uspbox--product .pluffie-pdp-uspbox__icon { color: var(--pdp-accent); }

.pluffie-pdp-uspbox__text { display: flex; flex-direction: column; }
.pluffie-pdp-uspbox__text strong {
	font-family: var(--pluffie-font-display);
	font-size: clamp(0.82rem, 3.2vw, 0.95rem);
	color: var(--pluffie-fg);
	line-height: 1.2;
}
.pluffie-pdp-uspbox__text span {
	font-size: clamp(0.72rem, 2.7vw, 0.8rem);
	color: var(--pluffie-fg-muted);
	line-height: 1.3;
}

/* === Betaalmethoden === */
.pluffie-pay {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin: 0 0 var(--pluffie-space-md);
}

.pluffie-pay__item {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 46px;
	height: 30px;
	padding: 0 8px;
	background: var(--pluffie-bg-card);
	border: 1px solid var(--pluffie-border-soft);
	border-radius: 8px;
	font-family: var(--pluffie-font-display);
	font-weight: var(--pluffie-fw-bold);
	font-size: 0.72rem;
	line-height: 1;
}

.pluffie-pay__item--ideal { color: #cc0066; }
.pluffie-pay__item--visa { color: #1a1f71; letter-spacing: 0.5px; }
.pluffie-pay__item--paypal { color: #003087; }
.pluffie-pay__item--klarna { background: #ffb3c7; color: #17120f; border-color: #ffb3c7; }
.pluffie-pay__item--applepay { color: #111; }
.pluffie-pay__item--bancontact { color: #005498; font-size: 0.6rem; }
.pluffie-pay__item--mc { padding: 0 6px; }
.pluffie-pay__item--mc svg { display: block; }

/* === Reviews (eigen design) === */
.pluffie-pdp-reviews__title {
	font-family: var(--pluffie-font-display);
	font-size: var(--pluffie-fs-xl);
	font-weight: var(--pluffie-fw-extra);
	color: var(--pluffie-fg);
	margin: 0 0 var(--pluffie-space-lg);
	text-align: center;
}

.pluffie-pdp-reviews__summary {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: clamp(1.5rem, 5vw, 3rem);
	align-items: center;
	background: var(--pluffie-bg-card);
	border: 1px solid var(--pluffie-border-soft);
	border-radius: var(--pluffie-radius-lg);
	padding: var(--pluffie-space-lg);
	margin-bottom: var(--pluffie-space-lg);
}

.pluffie-pdp-reviews__score { text-align: center; }
.pluffie-pdp-reviews__avg {
	display: block;
	font-family: var(--pluffie-font-display);
	font-weight: var(--pluffie-fw-extra);
	font-size: 3rem;
	line-height: 1;
	color: var(--pluffie-fg);
}
.pluffie-pdp-reviews__count { display: block; margin-top: 4px; font-size: var(--pluffie-fs-2xs); color: var(--pluffie-fg-muted); }

.pluffie-pdp-reviews__bars { display: flex; flex-direction: column; gap: 5px; }
.pluffie-pdp-reviews__bar { display: grid; grid-template-columns: 36px 1fr 26px; align-items: center; gap: 8px; font-size: var(--pluffie-fs-3xs); color: var(--pluffie-fg-muted); }
.pluffie-pdp-reviews__track { height: 8px; background: var(--pluffie-bg-warm); border-radius: var(--pluffie-radius-pill); overflow: hidden; }
.pluffie-pdp-reviews__track > span { display: block; height: 100%; background: var(--pluffie-warning, #E0A23F); border-radius: var(--pluffie-radius-pill); }

.pluffie-pdp-reviews__list {
	list-style: none;
	margin: 0 0 var(--pluffie-space-lg);
	padding: 0;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: var(--pluffie-space-md);
}

.pluffie-pdp-review {
	background: var(--pluffie-bg-card);
	border: 1px solid var(--pluffie-border-soft);
	border-radius: var(--pluffie-radius-lg);
	padding: var(--pluffie-space-md);
}

.pluffie-pdp-review__head { display: flex; align-items: center; gap: var(--pluffie-space-2xs); margin-bottom: var(--pluffie-space-2xs); }
.pluffie-pdp-review__avatar {
	display: inline-flex; align-items: center; justify-content: center;
	width: 38px; height: 38px; border-radius: 50%;
	background: var(--pluffie-accent-light); color: var(--pluffie-accent-dark);
	font-family: var(--pluffie-font-display); font-weight: var(--pluffie-fw-bold);
	flex-shrink: 0;
}
.pluffie-pdp-review__meta { display: flex; flex-direction: column; }
.pluffie-pdp-review__naam { font-family: var(--pluffie-font-display); font-weight: var(--pluffie-fw-bold); color: var(--pluffie-fg); }
.pluffie-pdp-review__verified {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: var(--pluffie-fs-3xs);
	font-weight: var(--pluffie-fw-semibold);
	color: var(--pluffie-saliegroen, #6E9A4E);
}
.pluffie-pdp-review__verified svg { flex: 0 0 auto; }
.pluffie-pdp-review__tekst { color: var(--pluffie-fg); font-size: var(--pluffie-fs-2xs); margin: var(--pluffie-space-2xs) 0; }
.pluffie-pdp-review__datum { font-size: var(--pluffie-fs-3xs); color: var(--pluffie-fg-muted); }

.pluffie-pdp-reviews__empty { text-align: center; color: var(--pluffie-fg-muted); max-width: none; margin: 0 auto var(--pluffie-space-lg); }

/* Review-formulier */
.pluffie-reviewform {
	max-width: 620px;
	margin: 0 auto;
	background: var(--pluffie-bg-warm);
	border-radius: var(--pluffie-radius-lg);
	padding: var(--pluffie-space-lg);
}
.pluffie-reviewform .comment-reply-title {
	font-family: var(--pluffie-font-display);
	font-weight: var(--pluffie-fw-bold);
	color: var(--pluffie-fg);
	margin-top: 0;
	text-align: center;
}
/* Inleidende tekst en "aangemeld als"-regel gecentreerd, net als de rest. */
.pluffie-reviewform .comment-notes,
.pluffie-reviewform .logged-in-as {
	text-align: center;
	color: var(--pluffie-fg-muted);
	font-size: var(--pluffie-fs-2xs);
	margin-bottom: var(--pluffie-space-sm);
}
.pluffie-reviewform .form-submit { text-align: center; margin-bottom: 0; }
.pluffie-reviewform label { display: block; font-size: var(--pluffie-fs-2xs); font-weight: var(--pluffie-fw-semibold); margin-bottom: 4px; color: var(--pluffie-fg); }
.pluffie-reviewform input[type="text"],
.pluffie-reviewform input[type="email"],
.pluffie-reviewform select,
.pluffie-reviewform textarea {
	width: 100%;
	padding: 0.6rem 0.8rem;
	border: 2px solid var(--pluffie-border);
	border-radius: var(--pluffie-radius-md);
	background: var(--pluffie-bg-card);
	font-family: var(--pluffie-font-body);
	margin-bottom: var(--pluffie-space-sm);
}
.pluffie-reviewform .submit,
.pluffie-reviewform input[type="submit"] {
	background: var(--pluffie-accent);
	color: var(--pluffie-bg-card);
	border: 0;
	border-radius: var(--pluffie-radius-pill);
	padding: 0.7rem 1.6rem;
	font-family: var(--pluffie-font-display);
	font-weight: var(--pluffie-fw-bold);
	cursor: pointer;
}
.pluffie-reviewform .submit:hover,
.pluffie-reviewform input[type="submit"]:hover { background: var(--pluffie-accent-dark); }

@media (max-width: 600px) {
	/* USP-boxen blijven ALTIJD 3 kolommen; de inhoud schaalt mee via clamp(). */
	.pluffie-pdp-reviews__summary { grid-template-columns: 1fr; text-align: center; }
}

/* === Bundel-selector (upsell: 2e Pluffie korting) === */
.pluffie-pdp-bundle {
	display: flex;
	flex-direction: column;
	gap: var(--pluffie-space-2xs);
	margin: 0 0 var(--pluffie-space-md);
}

.pluffie-pdp-bundle__opt {
	position: relative;
	display: flex;
	align-items: center;
	gap: var(--pluffie-space-2xs);
	padding: var(--pluffie-space-sm) var(--pluffie-space-md);
	border: 2px solid var(--pluffie-border-soft);
	border-radius: var(--pluffie-radius-md);
	background: var(--pluffie-bg-card);
	cursor: pointer;
	transition: border-color var(--pluffie-transition-base), background var(--pluffie-transition-base);
}

.pluffie-pdp-bundle__opt:hover { border-color: var(--pdp-accent); }

.pluffie-pdp-bundle__opt.is-active {
	border-color: var(--pdp-accent);
	background: color-mix(in srgb, var(--pdp-accent) 12%, var(--pluffie-bg-card));
}

.pluffie-pdp-bundle__opt input {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.pluffie-pdp-bundle__radio {
	width: 20px;
	height: 20px;
	border-radius: 50%;
	border: 2px solid var(--pluffie-border);
	flex-shrink: 0;
	position: relative;
}

.pluffie-pdp-bundle__opt.is-active .pluffie-pdp-bundle__radio { border-color: var(--pdp-accent); }
.pluffie-pdp-bundle__opt.is-active .pluffie-pdp-bundle__radio::after {
	content: "";
	position: absolute;
	inset: 3px;
	border-radius: 50%;
	background: var(--pdp-accent);
}

.pluffie-pdp-bundle__label {
	flex: 1 1 auto;
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--pluffie-space-2xs);
	font-family: var(--pluffie-font-display);
	font-weight: var(--pluffie-fw-bold);
	color: var(--pluffie-fg);
}

.pluffie-pdp-bundle__naam { white-space: nowrap; }

/* Verhaal / reviews / waarom: altijd een gecentreerde leeskolom */
.pluffie-pdp-story > .pluffie-container,
.pluffie-pdp-reviews > .pluffie-container,
.pluffie-pdp-waarom > .pluffie-container {
	margin-left: auto !important;
	margin-right: auto !important;
}
.pluffie-pdp-story > .pluffie-container { max-width: 820px; }
.pluffie-pdp-reviews > .pluffie-container { max-width: 860px; }

.pluffie-pdp-bundle__badge {
	background: var(--pluffie-accent);
	color: var(--pluffie-bg-card);
	font-size: var(--pluffie-fs-3xs);
	font-weight: var(--pluffie-fw-bold);
	padding: 0.2rem 0.55rem;
	border-radius: var(--pluffie-radius-pill);
}

.pluffie-pdp-bundle__price {
	font-family: var(--pluffie-font-display);
	font-weight: var(--pluffie-fw-bold);
	color: var(--pluffie-accent-dark);
	white-space: nowrap;
}

.pluffie-pdp-bundle__price del {
	color: var(--pluffie-fg-muted);
	font-weight: var(--pluffie-fw-semibold);
	font-size: 0.8em;
	margin-left: 4px;
}

/* Uitklap: tweede dier kiezen */
.pluffie-pdp-bundle__expand {
	margin-top: var(--pluffie-space-2xs);
	padding: var(--pluffie-space-sm);
	background: color-mix(in srgb, var(--pdp-accent) 9%, var(--pluffie-bg-card));
	border-radius: var(--pluffie-radius-md);
}
.pluffie-pdp-bundle__expand[hidden] { display: none; }
.pluffie-pdp-bundle__expand-help { font-size: var(--pluffie-fs-3xs); color: var(--pluffie-fg-muted); margin: 0 0 var(--pluffie-space-2xs); }
.pluffie-pdp-bundle__second { display: grid; grid-template-columns: 48px 1fr auto; gap: var(--pluffie-space-2xs); align-items: center; }
.pluffie-pdp-bundle__second-media img { width: 48px; height: 48px; object-fit: cover; border-radius: var(--pluffie-radius-sm); display: block; }
.pluffie-pdp-bundle__select { width: 100%; padding: 0.5rem 0.6rem; border: 2px solid var(--pluffie-border); border-radius: var(--pluffie-radius-sm); background: var(--pluffie-bg-card); font-family: var(--pluffie-font-body); color: var(--pluffie-fg); }
.pluffie-pdp-bundle__second-price { font-family: var(--pluffie-font-display); font-weight: var(--pluffie-fw-bold); color: var(--pluffie-accent-dark); white-space: nowrap; font-size: var(--pluffie-fs-3xs); }
.pluffie-pdp-bundle__second-price del { color: var(--pluffie-fg-muted); font-weight: normal; margin-left: 3px; }
