/* ============================================================
   Pluffie e-mail pop-up (2 stappen, instelbaar via Site-inhoud > Pop-up)
   ============================================================ */
.pluffie-popup {
	position: fixed;
	inset: 0;
	z-index: 99990;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 20px;
	opacity: 0;
	transition: opacity 0.28s ease;
}
.pluffie-popup[hidden] { display: none; }
.pluffie-popup.is-open { opacity: 1; }

.pluffie-popup__overlay {
	position: absolute;
	inset: 0;
	background: rgba(30, 26, 48, 0.55);
	backdrop-filter: blur(2px);
}

.pluffie-popup__modal {
	position: relative;
	z-index: 1;
	width: 100%;
	max-width: 540px;
	background: #FBF6EE;
	border-radius: 30px;
	padding: clamp(32px, 5vw, 48px) clamp(26px, 5vw, 46px) clamp(28px, 4vw, 38px);
	box-shadow: 0 40px 80px -32px rgba(30, 26, 48, 0.6);
	overflow: hidden;
	text-align: center;
	transform: translateY(14px) scale(0.97);
	transition: transform 0.32s cubic-bezier(0.2, 0.7, 0.3, 1);
	max-height: calc(100vh - 40px);
	overflow-y: auto;
}
.pluffie-popup.is-open .pluffie-popup__modal { transform: none; }

/* Decoratief poot/sparkle-patroon op de achtergrond */
.pluffie-popup__deco { position: absolute; inset: 0; pointer-events: none; z-index: 0; color: var(--pluffie-accent-dark, #C9744A); }
.pluffie-popup__deco-item { position: absolute; line-height: 1; opacity: 0.1; }
.pluffie-popup__deco-item .pluffie-popup__paw { display: block; height: auto; }

.pluffie-popup__modal > *:not(.pluffie-popup__deco) { position: relative; z-index: 1; }

.pluffie-popup__close {
	position: absolute;
	top: 16px;
	right: 16px;
	z-index: 2;
	width: 38px;
	height: 38px;
	border-radius: 50%;
	border: none;
	background: rgba(255, 255, 255, 0.7);
	color: #6E665C;
	font-size: 26px;
	line-height: 1;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background 0.18s ease, transform 0.18s ease;
}
.pluffie-popup__close:hover { background: #fff; transform: rotate(90deg); }

.pluffie-popup__head { margin-bottom: 22px; }
.pluffie-popup__korting {
	display: block;
	font-family: var(--pluffie-font-display);
	font-weight: 600;
	font-size: clamp(2.4rem, 8vw, 3.4rem);
	line-height: 1;
	letter-spacing: -0.01em;
	color: var(--pluffie-accent-dark, #C9744A);
	text-transform: uppercase;
}
.pluffie-popup__korting-sub {
	display: block;
	font-family: var(--pluffie-font-display);
	font-weight: 600;
	font-size: clamp(1rem, 3.5vw, 1.35rem);
	color: var(--pluffie-accent, #E08A5F);
	margin-top: 4px;
}

.pluffie-popup__vraag {
	font-family: var(--pluffie-font-display);
	font-weight: 600;
	font-size: clamp(18px, 4vw, 23px);
	color: #34302A;
	margin: 0 0 22px;
}

.pluffie-popup__opties { display: flex; flex-direction: column; gap: 12px; }
.pluffie-popup__optie {
	display: block;
	width: 100%;
	padding: 16px 18px;
	border: none;
	border-radius: 16px;
	background: var(--pluffie-accent-dark, #C9744A);
	color: #fff;
	font-family: var(--pluffie-font-display);
	font-weight: 600;
	font-size: 16px;
	cursor: pointer;
	box-shadow: 0 12px 24px -16px rgba(201, 116, 74, 0.9);
	transition: transform 0.16s ease, filter 0.16s ease;
}
.pluffie-popup__optie:hover { transform: translateY(-2px); filter: brightness(1.04); }
.pluffie-popup__optie:active { transform: scale(0.99); }

.pluffie-popup__skip {
	display: inline-block;
	margin-top: 20px;
	background: none;
	border: none;
	font-family: var(--pluffie-font-display);
	font-weight: 600;
	font-size: 15px;
	color: #2E2A24;
	cursor: pointer;
	text-decoration: underline;
	text-underline-offset: 3px;
}
.pluffie-popup__skip:hover { color: var(--pluffie-accent-dark, #C9744A); }

/* Stap 2 — e-mail */
.pluffie-popup__form { display: flex; flex-direction: column; gap: 14px; }
.pluffie-popup__email {
	width: 100%;
	padding: 17px 22px;
	border: 1.5px solid #E2D6C4;
	border-radius: 14px;
	background: #fff;
	font-family: var(--pluffie-font-body);
	font-size: 16px;
	color: #34302A;
}
.pluffie-popup__email:focus { outline: none; border-color: var(--pluffie-accent-dark, #C9744A); box-shadow: 0 0 0 3px rgba(201, 116, 74, 0.15); }
.pluffie-popup__claim { width: 100%; }
.pluffie-popup__error { margin: 4px 0 0; font-size: 13.5px; font-weight: 700; color: #C0392B; }

/* Stap 3 — succes */
.pluffie-popup__step--succes { padding: 6px 0; }
.pluffie-popup__check {
	display: inline-flex;
	width: 64px;
	height: 64px;
	border-radius: 50%;
	background: #EAF0E7;
	color: #5C7A60;
	align-items: center;
	justify-content: center;
	margin-bottom: 14px;
}
.pluffie-popup__succes-titel { font-family: var(--pluffie-font-display); font-weight: 600; font-size: clamp(24px, 5vw, 30px); color: #2E2A24; margin: 0 0 8px; }
.pluffie-popup__succes-tekst { font-size: 15px; line-height: 1.55; color: #6E665C; max-width: 38ch; margin: 0 auto 18px; }
.pluffie-popup__code {
	display: inline-block;
	margin: 0 auto 22px;
	padding: 12px 26px;
	border: 2px dashed var(--pluffie-accent-dark, #C9744A);
	border-radius: 12px;
	background: #fff;
	color: var(--pluffie-accent-dark, #C9744A);
	font-family: var(--pluffie-font-display);
	font-weight: 600;
	font-size: 22px;
	letter-spacing: 0.08em;
	cursor: pointer;
}
.pluffie-popup__code.is-copied { color: #5C7A60; border-color: #5C7A60; }

@media (max-width: 520px) {
	.pluffie-popup { padding: 16px; align-items: center; }
	.pluffie-popup__modal { border-radius: 26px; max-height: calc(100vh - 32px); }
	.pluffie-popup__optie { padding: 15px 16px; font-size: 15.5px; }
}
@media (prefers-reduced-motion: reduce) {
	.pluffie-popup, .pluffie-popup__modal { transition: none; }
}

.pluffie-popup__mail-note { font-size: 13.5px; font-weight: 700; color: #5C7A60; margin: -8px 0 16px; }
