/* ==========================================================================
   PGP Deurne — Hoofdstylesheet
   Gebaseerd op de officiële huisstijl (Branding Sheet v1.0 / 2025)
   ========================================================================== */

/* ---------------------------------------------------------------- Tokens */
:root {
	/* Hoofdkleuren */
	--pgp-rood: #E31E24;
	--pgp-roze: #D6237E;
	--pgp-groen: #6ABE4A;
	--pgp-oranje: #F15B2A;

	/* Steunkleuren */
	--pgp-donker: #2C2C2C;
	--pgp-licht: #F8F8F8;
	--pgp-wit: #FFFFFF;
	--pgp-grijs-100: #F1F1F1;
	--pgp-grijs-200: #E5E5E5;
	--pgp-grijs-400: #B5B5B5;
	--pgp-grijs-600: #6C6C6C;
	--pgp-grijs-800: #3A3A3A;

	/* Gradients */
	--pgp-gradient-primair: linear-gradient(135deg, #E31E24 0%, #D6237E 50%, #F15B2A 100%);
	--pgp-gradient-secundair: linear-gradient(135deg, #6ABE4A 0%, #F15B2A 100%);
	--pgp-gradient-zacht: linear-gradient(135deg, rgba(227,30,36,.08) 0%, rgba(214,35,126,.08) 50%, rgba(241,91,42,.08) 100%);

	/* Typografie */
	--pgp-font: "Inter", "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
	--pgp-fs-h1: 2.5rem;	/* 40px */
	--pgp-fs-h2: 2rem;		/* 32px */
	--pgp-fs-h3: 1.3rem;	/* 20.8px */
	--pgp-fs-body: 1rem;	/* 16px */
	--pgp-fs-small: 0.9rem;	/* 14.4px */
	--pgp-lh-tight: 1.2;
	--pgp-lh-base: 1.65;

	/* Schaduwen */
	--pgp-shadow-sm: 0 2px 8px rgba(0,0,0,.08);
	--pgp-shadow-md: 0 4px 15px rgba(0,0,0,.10);
	--pgp-shadow-lg: 0 6px 20px rgba(0,0,0,.15);
	--pgp-shadow-xl: 0 12px 36px rgba(0,0,0,.18);

	/* Hoeken — afgestemd met de plugin */
	--pgp-radius-sm: 4px;
	--pgp-radius-md: 8px;
	--pgp-radius-lg: 16px;
	--pgp-radius-xl: 24px;
	--pgp-radius-pill: 999px;

	/* Layout */
	--pgp-container: 1200px;
	--pgp-container-narrow: 760px;
	--pgp-gutter: clamp(1rem, 4vw, 2.5rem);
	--pgp-section-y: clamp(3rem, 8vw, 6rem);

	/* Transities */
	--pgp-ease: cubic-bezier(.22, .61, .36, 1);
	--pgp-trans: 220ms var(--pgp-ease);
}

/* ---------------------------------------------------------------- Reset */
*, *::before, *::after { box-sizing: border-box; }

html {
	scroll-behavior: smooth;
	-webkit-text-size-adjust: 100%;
}

body {
	margin: 0;
	font-family: var(--pgp-font);
	font-size: var(--pgp-fs-body);
	line-height: var(--pgp-lh-base);
	color: var(--pgp-donker);
	background: var(--pgp-wit);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

img, svg, video { max-width: 100%; height: auto; display: block; }

a {
	color: var(--pgp-rood);
	text-decoration: none;
	transition: color var(--pgp-trans);
}
a:hover, a:focus-visible { color: var(--pgp-roze); }

p { margin: 0 0 1.25rem; }

ul, ol { padding-left: 1.5rem; }

/* Selection */
::selection { background: var(--pgp-roze); color: var(--pgp-wit); }

/* ---------------------------------------------------------------- Typografie */
h1, h2, h3, h4, h5, h6 {
	font-family: var(--pgp-font);
	font-weight: 700;
	line-height: var(--pgp-lh-tight);
	margin: 0 0 .75em;
	color: var(--pgp-donker);
}

h1 { font-size: var(--pgp-fs-h1); letter-spacing: -.01em; }
h2 { font-size: var(--pgp-fs-h2); letter-spacing: -.005em; }
h3 { font-size: var(--pgp-fs-h3); }
h4 { font-size: 1.125rem; font-weight: 600; }

.pgp-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	font-size: var(--pgp-fs-small);
	font-weight: 700;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--pgp-rood); /* fallback voor browsers zonder background-clip:text */
	background: var(--pgp-gradient-primair);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	margin-bottom: .85rem;
}
@supports not (background-clip: text) {
	.pgp-eyebrow { -webkit-text-fill-color: currentColor; }
}
.pgp-eyebrow::before {
	content: "";
	width: 24px; height: 2px;
	background: var(--pgp-gradient-primair);
	border-radius: 999px;
	display: inline-block;
}

.pgp-lead {
	font-size: 1.2rem;
	font-weight: 300;
	color: var(--pgp-grijs-800);
	max-width: 60ch;
}

blockquote {
	margin: 2rem 0;
	padding: 1.5rem 1.75rem;
	border-left: 4px solid var(--pgp-roze);
	background: var(--pgp-licht);
	border-radius: 0 var(--pgp-radius-md) var(--pgp-radius-md) 0;
	font-style: italic;
	color: var(--pgp-grijs-800);
}

code, pre, kbd {
	font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
	font-size: .92em;
}
code {
	background: var(--pgp-grijs-100);
	padding: .15em .4em;
	border-radius: var(--pgp-radius-sm);
}
pre {
	background: var(--pgp-donker);
	color: var(--pgp-licht);
	padding: 1rem 1.25rem;
	border-radius: var(--pgp-radius-md);
	overflow-x: auto;
}

/* ---------------------------------------------------------------- Layout helpers */
.pgp-container {
	width: 100%;
	max-width: var(--pgp-container);
	margin-inline: auto;
	padding-inline: var(--pgp-gutter);
}
.pgp-container--narrow { max-width: var(--pgp-container-narrow); }

.pgp-section { padding-block: var(--pgp-section-y); }
.pgp-section--tinted { background: var(--pgp-licht); }
.pgp-section--gradient {
	background: var(--pgp-gradient-zacht);
}

.pgp-grid { display: grid; gap: clamp(1.25rem, 3vw, 2rem); }
.pgp-grid--2 { grid-template-columns: repeat(auto-fit, minmax(min(100%, 320px), 1fr)); }
.pgp-grid--3 { grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr)); }
.pgp-grid--4 { grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 1fr)); }

/* Skip link */
.skip-link {
	position: absolute;
	left: -9999px;
	top: auto;
	width: 1px;
	height: 1px;
	overflow: hidden;
	z-index: 9999;
}
.skip-link:focus {
	left: 1rem;
	top: 1rem;
	width: auto;
	height: auto;
	padding: .75rem 1.25rem;
	background: var(--pgp-donker);
	color: var(--pgp-wit) !important;
	border-radius: var(--pgp-radius-md);
	box-shadow: var(--pgp-shadow-md);
}

/* Screen-reader-only */
.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px; width: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute !important;
	word-wrap: normal !important;
}

/* Focus ring (accessibility-ready) */
:focus-visible {
	outline: 3px solid var(--pgp-roze);
	outline-offset: 2px;
	border-radius: var(--pgp-radius-sm);
}

/* ---------------------------------------------------------------- Knoppen */
.pgp-btn,
button.pgp-btn,
a.pgp-btn,
input[type="submit"].pgp-btn {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: .6rem;
	font-family: var(--pgp-font);
	font-size: 1rem;
	font-weight: 700;
	line-height: 1;
	padding: 1.1rem 2.5rem;
	border: 0;
	border-radius: var(--pgp-radius-pill);
	background: var(--pgp-gradient-secundair);
	color: var(--pgp-wit);
	cursor: pointer;
	box-shadow: 0 6px 18px rgba(241,91,42,.35);
	text-decoration: none;
	transition: transform var(--pgp-trans), box-shadow var(--pgp-trans), filter var(--pgp-trans);
	will-change: transform;
	overflow: hidden;
}
.pgp-btn::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(255,255,255,.25), transparent 60%);
	opacity: 0;
	transition: opacity var(--pgp-trans);
}
.pgp-btn:hover,
.pgp-btn:focus-visible {
	color: var(--pgp-wit);
	transform: translateY(-3px);
	box-shadow: 0 14px 32px rgba(241,91,42,.45);
	filter: saturate(1.1);
}
.pgp-btn:hover::after { opacity: 1; }
.pgp-btn:active { transform: translateY(0); box-shadow: var(--pgp-shadow-sm); }
.pgp-btn--primair { background: var(--pgp-gradient-primair); box-shadow: 0 6px 18px rgba(214,35,126,.35); }
.pgp-btn--primair:hover { box-shadow: 0 14px 32px rgba(214,35,126,.45); }

.pgp-btn--outline {
	background: transparent;
	color: var(--pgp-rood);
	border: 2px solid currentColor;
	box-shadow: none;
	padding: calc(1rem - 2px) calc(3rem - 2px);
}
.pgp-btn--outline:hover { color: var(--pgp-roze); }

.pgp-btn--ghost {
	background: var(--pgp-wit);
	color: var(--pgp-donker);
	box-shadow: var(--pgp-shadow-sm);
}
.pgp-btn--ghost:hover { color: var(--pgp-rood); }

.pgp-btn--small { padding: .65rem 1.5rem; font-size: .9rem; }

/* WP block-knoppen krijgen exact dezelfde behandeling als .pgp-btn */
.wp-block-button__link,
.wp-element-button {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: .6rem;
	border: 0;
	border-radius: var(--pgp-radius-pill);
	background: var(--pgp-gradient-secundair);
	padding: 1.1rem 2.5rem;
	font-weight: 700;
	color: var(--pgp-wit);
	box-shadow: 0 6px 18px rgba(241,91,42,.35);
	transition: transform var(--pgp-trans), box-shadow var(--pgp-trans), filter var(--pgp-trans);
	overflow: hidden;
}
.wp-block-button__link:hover,
.wp-element-button:hover {
	transform: translateY(-3px);
	box-shadow: 0 14px 32px rgba(241,91,42,.45);
	filter: saturate(1.1);
	color: var(--pgp-wit);
}

/* ---------------------------------------------------------------- Header */
.pgp-site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background: rgba(255,255,255,.92);
	backdrop-filter: saturate(160%) blur(10px);
	-webkit-backdrop-filter: saturate(160%) blur(10px);
	border-bottom: 1px solid var(--pgp-grijs-200);
}
.pgp-site-header::after {
	content: "";
	display: block;
	height: 4px;
	background: var(--pgp-gradient-primair);
}

.pgp-header-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1.5rem;
	min-height: 84px;
}

.pgp-branding { display: flex; align-items: center; gap: 1rem; }
.pgp-branding a { color: var(--pgp-donker); display: inline-flex; align-items: center; gap: .85rem; }

.pgp-logo {
	display: inline-flex;
	align-items: center;
	gap: .75rem;
	font-weight: 700;
	font-size: 1.35rem;
	line-height: 1;
}
.pgp-logo__mark {
	width: 44px; height: 44px;
	border-radius: var(--pgp-radius-md);
	background: var(--pgp-gradient-primair);
	box-shadow: var(--pgp-shadow-md);
	display: grid; place-items: center;
	color: var(--pgp-wit);
	font-weight: 700;
	letter-spacing: -.02em;
}
.pgp-logo__text { display: flex; flex-direction: column; line-height: 1.05; }
.pgp-logo__text small {
	font-size: .7rem;
	font-weight: 400;
	color: var(--pgp-grijs-600);
	letter-spacing: .05em;
}
.custom-logo { max-height: 56px; width: auto; }

/* Navigatie */
.pgp-nav { display: flex; align-items: center; gap: 1.25rem; }
.pgp-nav-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: .25rem;
	flex-wrap: wrap;
}
.pgp-nav-list a {
	display: inline-block;
	padding: .6rem 1rem;
	color: var(--pgp-donker);
	font-weight: 600;
	border-radius: var(--pgp-radius-pill);
	position: relative;
	transition: background-color var(--pgp-trans), color var(--pgp-trans);
}
.pgp-nav-list a:hover,
.pgp-nav-list a:focus-visible,
.pgp-nav-list .current-menu-item > a,
.pgp-nav-list .current_page_item > a {
	color: var(--pgp-wit);
	background: var(--pgp-gradient-primair);
}

/* Submenu */
.pgp-nav-list li { position: relative; }
.pgp-nav-list .sub-menu {
	position: absolute;
	top: calc(100% + .5rem);
	left: 0;
	min-width: 220px;
	list-style: none;
	margin: 0;
	padding: .5rem;
	background: var(--pgp-wit);
	border-radius: var(--pgp-radius-md);
	box-shadow: var(--pgp-shadow-lg);
	opacity: 0;
	visibility: hidden;
	transform: translateY(-6px);
	transition: opacity var(--pgp-trans), transform var(--pgp-trans), visibility var(--pgp-trans);
	z-index: 10;
}
.pgp-nav-list li:hover > .sub-menu,
.pgp-nav-list li:focus-within > .sub-menu {
	opacity: 1; visibility: visible; transform: translateY(0);
}
.pgp-nav-list .sub-menu a { display: block; padding: .55rem .85rem; border-radius: var(--pgp-radius-sm); }

/* Mobiele menutoggle */
.pgp-menu-toggle {
	display: none;
	background: transparent;
	border: 0;
	width: 44px; height: 44px;
	border-radius: var(--pgp-radius-md);
	cursor: pointer;
	color: var(--pgp-donker);
	align-items: center; justify-content: center;
}
.pgp-menu-toggle:hover { background: var(--pgp-grijs-100); }
.pgp-menu-toggle svg { width: 24px; height: 24px; }

@media (max-width: 900px) {
	.pgp-menu-toggle { display: inline-flex; }
	.pgp-nav {
		position: fixed;
		inset: 84px 0 auto 0;
		background: var(--pgp-wit);
		border-bottom: 1px solid var(--pgp-grijs-200);
		box-shadow: var(--pgp-shadow-md);
		padding: 1rem var(--pgp-gutter) 1.5rem;
		transform: translateY(-110%);
		transition: transform var(--pgp-trans);
	}
	.pgp-nav[data-open="true"] { transform: translateY(0); }
	.pgp-nav-list {
		flex-direction: column;
		align-items: stretch;
		gap: .25rem;
	}
	.pgp-nav-list a { width: 100%; }
	.pgp-nav-list .sub-menu {
		position: static;
		opacity: 1; visibility: visible; transform: none;
		box-shadow: none;
		padding-left: 1rem;
	}
}

/* ---------------------------------------------------------------- Hero */
.pgp-hero {
	position: relative;
	overflow: hidden;
	color: var(--pgp-wit);
	background: var(--pgp-gradient-primair);
	padding-block: clamp(4.5rem, 11vw, 9rem);
}
.pgp-hero::before,
.pgp-hero::after {
	content: "";
	position: absolute;
	border-radius: 50%;
	filter: blur(80px);
	opacity: .6;
	pointer-events: none;
}
.pgp-hero::before {
	width: 480px; height: 480px;
	top: -160px; right: -140px;
	background: var(--pgp-oranje);
}
.pgp-hero::after {
	width: 420px; height: 420px;
	bottom: -160px; left: -120px;
	background: var(--pgp-groen);
	opacity: .4;
}
/* Subtiele grain-overlay tegen het 'platte gradient'-gevoel */
.pgp-hero {
	background-image:
		url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 .35 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/></svg>"),
		var(--pgp-gradient-primair);
	background-size: 220px 220px, cover;
}

/* Decoratieve kleurschijfjes — zacht, geen storend */
.pgp-hero__inner::after {
	content: "";
	position: absolute;
	right: -15%; top: 5%;
	width: 320px; height: 320px;
	border-radius: 50%;
	border: 2px dashed rgba(255,255,255,.22);
	z-index: 0;
	pointer-events: none;
}

.pgp-hero__inner {
	position: relative;
	z-index: 1;
	max-width: 760px;
}
.pgp-hero__inner > * { position: relative; z-index: 1; }
.pgp-hero h1 {
	color: var(--pgp-wit);
	font-size: clamp(2.5rem, 5.5vw, 4.25rem);
	font-weight: 800;
	letter-spacing: -.02em;
	line-height: 1.05;
	margin-bottom: 1.25rem;
	text-wrap: balance;
}
.pgp-hero p {
	font-size: clamp(1.1rem, 1.8vw, 1.35rem);
	font-weight: 300;
	max-width: 60ch;
	margin-bottom: 2.25rem;
	color: rgba(255,255,255,.96);
	line-height: 1.55;
}
.pgp-hero .pgp-eyebrow {
	background: rgba(255,255,255,.22);
	-webkit-background-clip: initial;
	background-clip: initial;
	color: var(--pgp-wit);
	-webkit-text-fill-color: currentColor;
	padding: .45rem 1rem;
	border-radius: var(--pgp-radius-pill);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	font-weight: 700;
}
.pgp-hero .pgp-eyebrow::before {
	background: rgba(255,255,255,.7);
}
.pgp-hero__actions { display: flex; flex-wrap: wrap; gap: 1rem; }
.pgp-hero .pgp-btn--ghost {
	color: var(--pgp-rood);
	background: var(--pgp-wit);
}
.pgp-hero .pgp-btn--ghost:hover { color: var(--pgp-roze); }

/* Kleinere page-header voor archief/single */
.pgp-page-header {
	position: relative;
	overflow: hidden;
	background: var(--pgp-gradient-zacht);
	padding-block: clamp(2.5rem, 6vw, 4.5rem);
	border-bottom: 1px solid var(--pgp-grijs-200);
}
.pgp-page-header::before {
	content: "";
	position: absolute;
	width: 360px; height: 360px;
	border-radius: 50%;
	right: -120px; top: -120px;
	background: radial-gradient(circle at 30% 30%, rgba(241,91,42,.18), transparent 70%);
	pointer-events: none;
	z-index: 0;
}
.pgp-page-header::after {
	content: "";
	position: absolute;
	width: 280px; height: 280px;
	border-radius: 50%;
	left: -100px; bottom: -120px;
	background: radial-gradient(circle at 70% 30%, rgba(106,190,74,.18), transparent 70%);
	pointer-events: none;
	z-index: 0;
}
.pgp-page-header > * { position: relative; z-index: 1; }
.pgp-page-header h1 {
	margin: 0 0 .35rem;
	font-size: clamp(1.85rem, 3.5vw, 2.75rem);
	letter-spacing: -.015em;
}
.pgp-page-header__meta { color: var(--pgp-grijs-600); font-size: 1.05rem; }
.pgp-page-header .pgp-pill {
	margin-bottom: 1rem;
}

/* ---------------------------------------------------------------- Cards */
.pgp-card {
	position: relative;
	display: flex;
	flex-direction: column;
	background: var(--pgp-wit);
	border-radius: var(--pgp-radius-lg);
	overflow: hidden;
	box-shadow: var(--pgp-shadow-sm);
	transition: transform var(--pgp-trans), box-shadow var(--pgp-trans);
	height: 100%;
	isolation: isolate;
}
.pgp-card::before {
	content: "";
	position: absolute;
	inset: 0 0 auto 0;
	height: 5px;
	background: var(--pgp-gradient-primair);
	z-index: 2;
	pointer-events: none;
	transition: height var(--pgp-trans);
}
.pgp-card:nth-child(4n+2)::before { background: linear-gradient(90deg, var(--pgp-roze), var(--pgp-oranje)); }
.pgp-card:nth-child(4n+3)::before { background: linear-gradient(90deg, var(--pgp-groen), var(--pgp-oranje)); }
.pgp-card:nth-child(4n+4)::before { background: linear-gradient(90deg, var(--pgp-oranje), var(--pgp-rood)); }

.pgp-card:hover {
	transform: translateY(-6px);
	box-shadow: 0 18px 48px rgba(44,44,44,.16);
}
.pgp-card:hover::before { height: 7px; }

.pgp-card__media {
	position: relative;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: var(--pgp-gradient-zacht);
}
.pgp-card__media img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform 700ms var(--pgp-ease);
}
.pgp-card:hover .pgp-card__media img { transform: scale(1.06); }

.pgp-card__media--placeholder {
	position: relative;
	display: grid;
	place-items: center;
	background: var(--pgp-gradient-primair);
	color: var(--pgp-wit);
	font-size: clamp(2rem, 4vw, 3rem);
}
.pgp-card__media--placeholder::before {
	content: "";
	position: absolute;
	width: 200px; height: 200px;
	border-radius: 50%;
	background: rgba(255,255,255,.15);
	filter: blur(40px);
	right: -40px; top: -40px;
	pointer-events: none;
}

.pgp-card__body {
	padding: 1.5rem 1.5rem 1.75rem;
	display: flex;
	flex-direction: column;
	gap: .65rem;
	flex: 1;
}

.pgp-card__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: .5rem .85rem;
	font-size: var(--pgp-fs-small);
	color: var(--pgp-grijs-600);
	font-weight: 500;
	margin-bottom: .15rem;
}
.pgp-card__meta .posted-on {
	display: inline-flex;
	align-items: center;
	gap: .4rem;
}
.pgp-card__meta .posted-on::before {
	content: "";
	width: 6px; height: 6px;
	border-radius: 999px;
	background: var(--pgp-rood);
}
.pgp-card:nth-child(4n+2) .pgp-card__meta .posted-on::before { background: var(--pgp-roze); }
.pgp-card:nth-child(4n+3) .pgp-card__meta .posted-on::before { background: var(--pgp-groen); }
.pgp-card:nth-child(4n+4) .pgp-card__meta .posted-on::before { background: var(--pgp-oranje); }

.pgp-card__title {
	font-size: clamp(1.15rem, 1.5vw, 1.4rem);
	font-weight: 800;
	letter-spacing: -.01em;
	line-height: 1.25;
	margin: 0;
}
.pgp-card__title a {
	color: var(--pgp-donker);
	background-image: linear-gradient(currentColor, currentColor);
	background-size: 0 2px;
	background-repeat: no-repeat;
	background-position: 0 100%;
	transition: background-size var(--pgp-trans), color var(--pgp-trans);
}
.pgp-card__title a:hover {
	color: var(--pgp-rood);
	background-size: 100% 2px;
}

.pgp-card__excerpt {
	color: var(--pgp-grijs-800);
	font-size: .98rem;
	line-height: 1.55;
	margin: 0;
}
.pgp-card__excerpt p { margin: 0; }
.pgp-card__excerpt p:last-child { margin-bottom: 0; }

.pgp-card__terms {
	display: flex; flex-wrap: wrap; gap: .35rem;
	margin-top: .25rem;
}

.pgp-card__more {
	margin-top: auto;
	padding-top: .5rem;
	font-weight: 700;
	font-size: .92rem;
	color: var(--pgp-rood);
	display: inline-flex;
	align-items: center;
	gap: .45rem;
	align-self: flex-start;
	transition: color var(--pgp-trans), gap var(--pgp-trans);
}
.pgp-card__more::after {
	content: "→";
	display: inline-flex;
	width: 24px; height: 24px;
	align-items: center; justify-content: center;
	border-radius: 999px;
	background: var(--pgp-gradient-secundair);
	color: var(--pgp-wit);
	font-size: .85rem;
	transition: transform var(--pgp-trans), filter var(--pgp-trans);
	box-shadow: var(--pgp-shadow-sm);
}
.pgp-card__more:hover {
	color: var(--pgp-roze);
	gap: .65rem;
}
.pgp-card__more:hover::after {
	transform: translateX(2px) rotate(-3deg);
	filter: saturate(1.2);
}

/* Categorie-pill */
.pgp-pill {
	display: inline-flex;
	align-items: center;
	gap: .35rem;
	padding: .25rem .7rem;
	border-radius: var(--pgp-radius-pill);
	font-size: .78rem;
	font-weight: 600;
	letter-spacing: .03em;
	text-transform: uppercase;
	background: var(--pgp-licht);
	color: var(--pgp-grijs-800);
	text-decoration: none;
	border: 1px solid var(--pgp-grijs-200);
	transition: background-color var(--pgp-trans), color var(--pgp-trans);
}
.pgp-pill:hover { background: var(--pgp-gradient-primair); color: var(--pgp-wit); border-color: transparent; }
/* Brand-pills — donkere variant van groen/oranje voor WCAG AA contrast tegen wit */
.pgp-pill--rood    { background: var(--pgp-rood);   color: var(--pgp-wit); border-color: transparent; }
.pgp-pill--roze    { background: var(--pgp-roze);   color: var(--pgp-wit); border-color: transparent; }
.pgp-pill--groen   { background: #3F8E2A;           color: var(--pgp-wit); border-color: transparent; }
.pgp-pill--oranje  { background: #C84218;           color: var(--pgp-wit); border-color: transparent; }

/* ---------------------------------------------------------------- Featured highlight blok */
.pgp-feature-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 240px), 1fr));
	gap: clamp(1rem, 2vw, 1.75rem);
}
.pgp-feature {
	position: relative;
	padding: 2rem 1.75rem;
	border-radius: var(--pgp-radius-lg);
	background: var(--pgp-wit);
	box-shadow: var(--pgp-shadow-sm);
	transition: transform var(--pgp-trans), box-shadow var(--pgp-trans);
	overflow: hidden;
	isolation: isolate;
}
.pgp-feature::before {
	content: "";
	position: absolute;
	inset: 0 0 auto 0;
	height: 5px;
	background: var(--pgp-rood);
	z-index: 2;
	pointer-events: none;
	transition: height var(--pgp-trans);
}
.pgp-feature:nth-child(4n+2)::before { background: var(--pgp-roze); }
.pgp-feature:nth-child(4n+3)::before { background: var(--pgp-groen); }
.pgp-feature:nth-child(4n+4)::before { background: var(--pgp-oranje); }
.pgp-feature::after {
	content: "";
	position: absolute;
	width: 180px; height: 180px;
	border-radius: 50%;
	right: -60px; bottom: -60px;
	background: radial-gradient(circle, rgba(227,30,36,.06), transparent 70%);
	z-index: 0;
	pointer-events: none;
}
.pgp-feature:nth-child(4n+2)::after { background: radial-gradient(circle, rgba(214,35,126,.06), transparent 70%); }
.pgp-feature:nth-child(4n+3)::after { background: radial-gradient(circle, rgba(106,190,74,.06), transparent 70%); }
.pgp-feature:nth-child(4n+4)::after { background: radial-gradient(circle, rgba(241,91,42,.06), transparent 70%); }
.pgp-feature > * { position: relative; z-index: 1; }
.pgp-feature:hover {
	transform: translateY(-6px);
	box-shadow: 0 18px 48px rgba(44,44,44,.16);
}
.pgp-feature:hover::before { height: 6px; }

.pgp-feature__icon {
	display: inline-flex;
	width: 56px; height: 56px;
	font-size: 1.65rem;
	align-items: center; justify-content: center;
	border-radius: var(--pgp-radius-md);
	background: var(--pgp-gradient-zacht);
	margin-bottom: 1rem;
	transition: transform var(--pgp-trans);
}
.pgp-feature:hover .pgp-feature__icon { transform: scale(1.06) rotate(-3deg); }
.pgp-feature h3 {
	margin: 0 0 .45rem;
	font-size: 1.2rem;
	font-weight: 800;
	letter-spacing: -.01em;
}
.pgp-feature p {
	margin: 0;
	color: var(--pgp-grijs-800);
	font-size: 1rem;
	line-height: 1.55;
}

/* ---------------------------------------------------------------- Section heads */
.pgp-section__head {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 1.25rem;
	margin-bottom: 2.5rem;
	padding-bottom: 1.25rem;
	border-bottom: 1px solid var(--pgp-grijs-200);
	position: relative;
}
.pgp-section__head::after {
	content: "";
	position: absolute;
	left: 0; bottom: -1px;
	width: 64px; height: 3px;
	background: var(--pgp-gradient-primair);
	border-radius: 999px;
}
.pgp-section__head h2 {
	margin: 0;
	font-size: clamp(1.6rem, 2.4vw, 2.25rem);
	letter-spacing: -.015em;
}

/* ---------------------------------------------------------------- Single article */
.pgp-article {
	max-width: var(--pgp-container-narrow);
	margin: 0 auto;
}
.pgp-article header { margin-bottom: 2rem; }
.pgp-article__meta {
	display: flex;
	flex-wrap: wrap;
	gap: .5rem 1rem;
	color: var(--pgp-grijs-600);
	font-size: var(--pgp-fs-small);
	margin-bottom: 1rem;
}
.pgp-article__featured {
	margin: 0 0 2rem;
	border-radius: var(--pgp-radius-lg);
	overflow: hidden;
	box-shadow: var(--pgp-shadow-md);
}
.pgp-article__content > *:first-child { margin-top: 0; }
.pgp-article__content h2 { margin-top: 2.5rem; }
.pgp-article__content h3 { margin-top: 2rem; }
.pgp-article__content img { border-radius: var(--pgp-radius-md); }
.pgp-article__content figure { margin: 2rem 0; }
.pgp-article__content figcaption {
	font-size: var(--pgp-fs-small);
	color: var(--pgp-grijs-600);
	margin-top: .5rem;
	text-align: center;
}

/* Lijst met categorie/tag-pills onder artikel */
.pgp-article__taxonomy {
	display: flex;
	flex-wrap: wrap;
	gap: .5rem;
	margin: 2.5rem 0 0;
	padding-top: 1.5rem;
	border-top: 1px solid var(--pgp-grijs-200);
}

/* ---------------------------------------------------------------- Forms */
input[type="text"], input[type="email"], input[type="search"], input[type="url"],
input[type="tel"], input[type="number"], input[type="password"], textarea, select {
	width: 100%;
	font-family: inherit;
	font-size: 1rem;
	padding: .75rem 1rem;
	border: 1.5px solid var(--pgp-grijs-200);
	border-radius: var(--pgp-radius-md);
	background: var(--pgp-wit);
	color: var(--pgp-donker);
	transition: border-color var(--pgp-trans), box-shadow var(--pgp-trans);
}
input:focus, textarea:focus, select:focus {
	outline: 0;
	border-color: var(--pgp-roze);
	box-shadow: 0 0 0 3px rgba(214,35,126,.18);
}

label { font-weight: 600; display: inline-block; margin-bottom: .35rem; }

.pgp-search-form {
	display: flex;
	gap: .5rem;
	max-width: 540px;
}
.pgp-search-form input[type="search"] { flex: 1; border-radius: var(--pgp-radius-pill); padding-left: 1.25rem; }
.pgp-search-form button { border-radius: var(--pgp-radius-pill); padding: .75rem 1.5rem; }

/* ---------------------------------------------------------------- Pagination */
.pgp-pagination {
	display: flex;
	flex-wrap: wrap;
	gap: .5rem;
	justify-content: center;
	margin-top: 3rem;
}
.pgp-pagination a, .pgp-pagination span {
	display: inline-flex;
	align-items: center; justify-content: center;
	min-width: 44px; height: 44px;
	padding: 0 .9rem;
	border-radius: var(--pgp-radius-pill);
	background: var(--pgp-licht);
	color: var(--pgp-donker);
	font-weight: 600;
	border: 1px solid var(--pgp-grijs-200);
	text-decoration: none;
}
.pgp-pagination a:hover, .pgp-pagination .current {
	background: var(--pgp-gradient-primair);
	color: var(--pgp-wit);
	border-color: transparent;
}

/* ---------------------------------------------------------------- Comments */
.pgp-comments { margin-top: 3rem; }
.pgp-comments h2 { margin-bottom: 1.5rem; }
.pgp-comments .comment-list {
	list-style: none;
	padding: 0;
	display: grid;
	gap: 1.25rem;
}
.pgp-comments .comment-body {
	background: var(--pgp-licht);
	padding: 1.25rem 1.5rem;
	border-radius: var(--pgp-radius-md);
	box-shadow: var(--pgp-shadow-sm);
}
.pgp-comments .comment-author { font-weight: 700; }
.pgp-comments .comment-meta { font-size: var(--pgp-fs-small); color: var(--pgp-grijs-600); margin-bottom: .5rem; }
.pgp-comments .reply { margin-top: .5rem; }
.pgp-comments .children { list-style: none; padding-left: 1.5rem; margin-top: 1rem; }

/* ---------------------------------------------------------------- Footer */
.pgp-site-footer {
	margin-top: var(--pgp-section-y);
	background: var(--pgp-donker);
	color: rgba(255,255,255,.85);
	position: relative;
}
.pgp-site-footer::before {
	content: "";
	display: block;
	height: 6px;
	background: var(--pgp-gradient-primair);
}
.pgp-footer-grid {
	display: grid;
	gap: 2rem;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 240px), 1fr));
	padding-block: 3rem;
}
.pgp-site-footer h3 { color: var(--pgp-wit); font-size: 1.05rem; margin-bottom: 1rem; }
.pgp-site-footer a { color: rgba(255,255,255,.85); }
.pgp-site-footer a:hover { color: var(--pgp-wit); }
.pgp-site-footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: .35rem; }
.pgp-footer-base {
	border-top: 1px solid rgba(255,255,255,.1);
	padding: 1.5rem 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	gap: 1rem;
	font-size: var(--pgp-fs-small);
}

/* Sociaal */
.pgp-social { display: flex; gap: .5rem; flex-wrap: wrap; }
.pgp-social a {
	width: 40px; height: 40px;
	display: inline-flex;
	align-items: center; justify-content: center;
	border-radius: var(--pgp-radius-pill);
	background: rgba(255,255,255,.08);
	transition: background-color var(--pgp-trans), transform var(--pgp-trans);
}
.pgp-social a:hover { background: var(--pgp-gradient-primair); transform: translateY(-2px); }
.pgp-social svg { width: 18px; height: 18px; fill: currentColor; }

/* ---------------------------------------------------------------- 404 */
.pgp-404 { text-align: center; padding-block: clamp(4rem, 10vw, 7rem); }
.pgp-404 h1 {
	font-size: clamp(4rem, 18vw, 9rem);
	background: var(--pgp-gradient-primair);
	-webkit-background-clip: text; background-clip: text;
	color: transparent;
	margin: 0;
}
.pgp-404 p { max-width: 50ch; margin-inline: auto; }

/* ---------------------------------------------------------------- Reductie van animaties */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation-duration: .01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: .01ms !important;
		scroll-behavior: auto !important;
	}
}

/* ---------------------------------------------------------------- Print */
@media print {
	.pgp-site-header, .pgp-site-footer, .pgp-nav, .pgp-menu-toggle { display: none !important; }
	body { color: #000; background: #fff; }
	a { color: #000; text-decoration: underline; }
}
