/* =========================================================
   Home etc. Porselein - main.css
   Porselein, Delfts blauw + koper
   Syne (display) + Figtree (body)
   ========================================================= */

:root {
	--fond: #f3f5f4;
	--vlak: #ffffff;
	--inkt: #19231f;
	--inkt-zacht: #5b6661;
	--blauw: #2b4acf;
	--blauw-donker: #1e36a3;
	--koper: #b97a2a;
	--steen: #e7ecea;
	--lijn: #d9e0dd;
	--lijn-zacht: #e7ecea;
	--schaduw: 0 1px 2px rgba(20, 30, 27, 0.06), 0 6px 18px rgba(20, 30, 27, 0.05);
	--radius: 10px;
	--font-display: "Syne", system-ui, sans-serif;
	--font-body: "Figtree", system-ui, sans-serif;
	--maat: 1140px;
	--maat-smal: 720px;
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
	html { scroll-behavior: auto; }
	*, *::before, *::after { animation: none !important; transition: none !important; }
}

body.he-porselein {
	font-family: var(--font-body);
	background: var(--fond);
	color: var(--inkt);
	line-height: 1.65;
	font-size: 17px;
	-webkit-font-smoothing: antialiased;
	position: relative;
}


img { max-width: 100%; height: auto; display: block; }
a { color: inherit; }

h1, h2, h3, h4 {
	font-family: var(--font-display);
	font-weight: 700;
	line-height: 1.1;
	letter-spacing: -0.01em;
}
h1 em, h2 em, h3 em, .he-hero-titel em {
	font-style: normal;
	color: var(--blauw);
	background: linear-gradient(transparent 68%, rgba(43, 74, 207, 0.16) 68%);
	padding: 0 1px;
}

.he-wrap { max-width: var(--maat); margin: 0 auto; padding: 0 24px; position: relative; z-index: 2; }
.he-main { position: relative; z-index: 2; }

.screen-reader-text {
	position: absolute !important;
	width: 1px; height: 1px;
	clip-path: inset(50%);
	overflow: hidden;
	white-space: nowrap;
}

:focus-visible { outline: 2px solid var(--blauw); outline-offset: 3px; border-radius: 2px; }

/* ---------- Header ---------- */
.he-header {
	position: sticky;
	top: 0;
	z-index: 50;
	background: rgba(243, 245, 244, 0.92);
	backdrop-filter: blur(12px);
	border-bottom: 1px solid var(--lijn);
}
.he-header-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	padding-top: 16px;
	padding-bottom: 16px;
}
.he-brand {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: 22px;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 9px;
	letter-spacing: -0.01em;
}
.he-brand-dot {
	width: 10px; height: 10px;
	border-radius: 50%;
	background: var(--blauw);
	flex: none;
}
.he-brand-amp { color: var(--blauw); font-weight: 800; }

.he-nav-lijst { display: flex; gap: 28px; list-style: none; }
.he-nav-lijst a {
	text-decoration: none;
	font-size: 14.5px;
	font-weight: 500;
	color: var(--inkt);
	padding-bottom: 3px;
	border-bottom: 2px solid transparent;
	transition: border-color 0.15s;
}
.he-nav-lijst a:hover,
.he-nav-lijst .current-menu-item > a { border-color: var(--blauw); }

.he-header-acties { display: flex; align-items: center; gap: 14px; }
.he-bewaard-link {
	position: relative;
	display: inline-flex;
	padding: 8px;
	color: var(--inkt);
	border-radius: 50%;
}
.he-bewaard-link:hover { color: var(--blauw); }
.he-bewaard-teller {
	position: absolute;
	top: 0; right: -2px;
	background: var(--blauw);
	color: #fff;
	font-size: 10.5px;
	font-weight: 700;
	min-width: 17px; height: 17px;
	border-radius: 9px;
	display: flex; align-items: center; justify-content: center;
	padding: 0 4px;
}

.he-menu-knop {
	display: none;
	background: none; border: 0; cursor: pointer;
	width: 38px; height: 38px;
	position: relative;
}
.he-menu-streep, .he-menu-streep::before, .he-menu-streep::after {
	content: ""; position: absolute; left: 8px; right: 8px;
	height: 2px; background: var(--inkt); transition: transform 0.2s, top 0.2s;
}
.he-menu-streep { top: 18px; }
.he-menu-streep::before { top: -7px; left: 0; right: 0; }
.he-menu-streep::after { top: 7px; left: 0; right: 0; }
.he-menu-knop[aria-expanded="true"] .he-menu-streep { background: transparent; }
.he-menu-knop[aria-expanded="true"] .he-menu-streep::before { top: 0; transform: rotate(45deg); }
.he-menu-knop[aria-expanded="true"] .he-menu-streep::after { top: 0; transform: rotate(-45deg); }

.he-mobiel-menu { border-top: 1px solid var(--lijn); background: var(--vlak); }
.he-mobiel-lijst { list-style: none; padding: 12px 24px 20px; }
.he-mobiel-lijst a {
	display: block; padding: 11px 0;
	text-decoration: none; font-weight: 500; font-size: 17px;
	border-bottom: 1px solid var(--lijn-zacht);
}

/* ---------- Hero ---------- */
.he-hero { padding: 72px 0 40px; }
.he-hero-grid {
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: 56px;
	align-items: end;
}
.he-eyebrow {
	font-size: 12.5px;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--koper);
	margin-bottom: 16px;
}
.he-hero-titel { font-size: clamp(40px, 6vw, 68px); }
.he-hero-zij p { color: var(--inkt-zacht); font-size: 16.5px; }
.he-auteur-regel {
	display: flex; align-items: center; gap: 12px;
	margin-top: 22px;
	font-size: 14px; line-height: 1.4;
}
.he-auteur-regel span { color: var(--inkt-zacht); }
.he-auteur-regel a { text-decoration: none; }
.he-auteur-regel a:hover { color: var(--blauw); }

.he-avatar { border-radius: 50%; object-fit: cover; flex: none; }
.he-avatar-initiaal {
	display: inline-flex; align-items: center; justify-content: center;
	background: var(--koper); color: #fff;
	font-family: var(--font-display); font-weight: 700;
}

/* ---------- Statsstrip ---------- */
.he-strip {
	display: flex; flex-wrap: wrap; gap: 10px 32px;
	border-top: 1px solid var(--inkt);
	border-bottom: 1px solid var(--inkt);
	padding: 13px 0;
	font-size: 14px;
	color: var(--inkt-zacht);
}
.he-strip strong { color: var(--inkt); font-weight: 700; }
.he-strip-rechts { margin-left: auto; }

/* ---------- Sectiekoppen ---------- */
.he-sectie-kop { margin: 0 0 32px; max-width: 640px; }
.he-sectie-kop h2 { font-size: clamp(28px, 4vw, 40px); margin-bottom: 10px; }
.he-sectie-kop p { color: var(--inkt-zacht); }

/* ---------- Uitgelicht ---------- */
.he-featured {
	display: grid;
	grid-template-columns: 1.25fr 1fr;
	gap: 44px;
	align-items: center;
	padding-top: 64px;
}
.he-featured-beeld {
	display: block;
	border-radius: var(--radius);
	overflow: hidden;
	box-shadow: var(--schaduw);
}
.he-featured-beeld img { aspect-ratio: 5 / 3.4; object-fit: cover; width: 100%; }
.he-cat-tag {
	display: inline-block;
	font-size: 12px; font-weight: 700;
	letter-spacing: 0.1em; text-transform: uppercase;
	color: var(--blauw);
	background: rgba(43, 74, 207, 0.09);
	padding: 5px 11px;
	border-radius: 99px;
	margin-bottom: 14px;
}
.he-featured-meta h2 { font-size: clamp(26px, 3.4vw, 38px); margin-bottom: 14px; }
.he-featured-meta h2 a { text-decoration: none; }
.he-featured-meta h2 a:hover em, .he-featured-meta h2 a:hover { color: var(--blauw-donker); }
.he-featured-meta p { color: var(--inkt-zacht); margin-bottom: 14px; }

/* ---------- Kaarten ---------- */
.he-recent { padding: 72px 24px; }
.he-kaarten-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 36px 28px;
}
.he-kaart { position: relative; }
.he-kaart-link { text-decoration: none; display: block; }
.he-kaart-beeld {
	border-radius: var(--radius);
	overflow: hidden;
	background: var(--steen);
	margin-bottom: 16px;
	box-shadow: var(--schaduw);
}
.he-kaart-beeld img, .he-kaart-leeg {
	aspect-ratio: 3 / 2; width: 100%; object-fit: cover; display: block;
	transition: transform 0.35s ease;
}
.he-kaart-link:hover .he-kaart-beeld img { transform: scale(1.025); }
.he-kaart-leeg {
	background: linear-gradient(135deg, var(--steen), var(--lijn-zacht));
}
.he-kaart h3 { font-size: 20px; margin: 8px 0 8px; }
.he-kaart-link:hover h3 { color: var(--blauw-donker); }
.he-kaart-excerpt { font-size: 15px; color: var(--inkt-zacht); margin-bottom: 10px; }
.he-kaart-meta { font-size: 13px; color: var(--inkt-zacht); }

/* ---------- Bewaarknop ---------- */
.he-bewaar {
	display: inline-flex; align-items: center; gap: 7px;
	font-family: var(--font-body);
	font-size: 13.5px; font-weight: 600;
	color: var(--inkt);
	background: var(--vlak);
	border: 1px solid var(--lijn);
	border-radius: 99px;
	padding: 8px 15px;
	cursor: pointer;
	margin-top: 16px;
	transition: border-color 0.15s, color 0.15s;
}
.he-bewaar:hover { border-color: var(--blauw); color: var(--blauw); }
.he-bewaar[aria-pressed="true"] { color: var(--blauw); border-color: var(--blauw); }
.he-bewaar[aria-pressed="true"] .he-bewaar-pad { fill: currentColor; }
.he-bewaar-compact {
	position: absolute; top: 10px; right: 10px;
	margin: 0; padding: 8px;
	background: rgba(255, 255, 255, 0.94);
}
.he-bewaar-compact .he-bewaar-label { display: none; }

/* ---------- Woonstijlen-sectie ---------- */
.he-stijlen-sectie {
	background: var(--steen);
	border-top: 1px solid var(--lijn);
	border-bottom: 1px solid var(--lijn);
	padding: 72px 0;
	margin-top: 72px;
	position: relative;
	z-index: 2;
}
.he-stijlen-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
	gap: 24px;
}
.he-stijl-kaart {
	background: var(--vlak);
	border: 1px solid var(--lijn);
	border-radius: var(--radius);
	padding: 18px;
	text-decoration: none;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
	display: block;
}
.he-stijl-kaart:hover { transform: translateY(-3px); box-shadow: 0 8px 22px rgba(20, 30, 27, 0.09); }
.he-stijl-beeld {
	border-radius: 4px; overflow: hidden;
	background: var(--lijn-zacht);
	margin-bottom: 14px;
	position: relative;
	aspect-ratio: 16 / 10;
}
.he-stijl-beeld img { width: 100%; height: 100%; object-fit: cover; }
.he-stijl-stalen {
	position: absolute; left: 10px; bottom: 10px;
	display: flex; gap: 5px;
}
.he-stijl-stalen span {
	width: 20px; height: 20px;
	border-radius: 4px;
	border: 2px solid var(--vlak);
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
}
.he-stijl-kaart h3 { font-size: 19px; }
.he-stijl-sfeer { font-size: 13.5px; color: var(--inkt-zacht); margin-top: 3px; }
.he-stijl-aantal { font-size: 12.5px; color: var(--koper); font-weight: 600; display: inline-block; margin-top: 8px; }

.he-stijlen-cta {
	margin-top: 36px;
	display: flex; align-items: center; gap: 18px; flex-wrap: wrap;
	border-top: 1px dashed var(--lijn);
	padding-top: 28px;
}
.he-stijlen-cta p { font-family: var(--font-display); font-weight: 600; font-size: 19px; }

.he-knop {
	display: inline-block;
	background: var(--blauw);
	color: #fff;
	font-weight: 700;
	font-size: 15px;
	text-decoration: none;
	padding: 12px 24px;
	border-radius: 99px;
	border: 0;
	cursor: pointer;
	font-family: var(--font-body);
	transition: background 0.15s;
}
.he-knop:hover { background: var(--blauw-donker); }

.he-tekstlink {
	color: var(--blauw);
	font-weight: 600;
	text-decoration: none;
	border-bottom: 1.5px solid currentColor;
	padding-bottom: 1px;
	background: none; border-top: 0; border-left: 0; border-right: 0;
	cursor: pointer;
	font-size: 15px;
	font-family: var(--font-body);
}
.he-tekstlink:hover { color: var(--blauw-donker); }

/* ---------- Achterklep ---------- */
.he-achterklep { padding: 64px 0; border-top: 1px solid var(--lijn); }
.he-achterklep-titel { font-size: clamp(26px, 3.4vw, 36px); color: var(--koper); margin-bottom: 24px; }
.he-achterklep-lijst { list-style: none; max-width: var(--maat-smal); }
.he-achterklep-lijst a {
	display: flex; gap: 22px; align-items: baseline;
	padding: 15px 0;
	border-bottom: 1px solid var(--lijn-zacht);
	text-decoration: none;
}
.he-achterklep-lijst a:hover .he-achterklep-kop { color: var(--blauw); }
.he-achterklep-datum { font-size: 13px; color: var(--inkt-zacht); flex: none; width: 52px; }
.he-achterklep-kop { font-family: var(--font-display); font-weight: 600; font-size: 19px; }

/* ---------- Auteurkaart ---------- */
.he-auteurkaart { padding: 72px 24px 88px; }
.he-auteurkaart-inner {
	display: flex; gap: 24px; align-items: flex-start;
	background: var(--vlak);
	border: 1px solid var(--lijn);
	border-radius: var(--radius);
	padding: 32px;
	max-width: 760px;
}
.he-auteurkaart h2 { font-size: 24px; }
.he-auteur-functie { display: block; font-size: 13px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--koper); margin: 4px 0 10px; }
.he-auteurkaart p { color: var(--inkt-zacht); margin-bottom: 12px; }

/* ---------- Archief ---------- */
.he-archief { padding: 56px 24px 88px; }
.he-archief-kop { margin-bottom: 40px; max-width: 680px; }
.he-archief-kop h1 { font-size: clamp(32px, 5vw, 52px); }
.he-archief-intro { color: var(--inkt-zacht); margin-top: 12px; }

.he-paginering { margin-top: 48px; }
.he-paginering .nav-links { display: flex; gap: 8px; flex-wrap: wrap; }
.he-paginering .page-numbers {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 40px; height: 40px; padding: 0 12px;
	border: 1px solid var(--lijn);
	border-radius: 99px;
	text-decoration: none;
	font-weight: 600; font-size: 14.5px;
	background: var(--vlak);
}
.he-paginering .page-numbers.current { background: var(--inkt); color: var(--vlak); border-color: var(--inkt); }
.he-paginering .page-numbers:hover:not(.current) { border-color: var(--blauw); color: var(--blauw); }

/* ---------- Artikel ---------- */
.he-artikel-kop { padding-top: 56px; max-width: 820px; }
.he-kruimels { font-size: 13.5px; color: var(--inkt-zacht); display: flex; gap: 10px; margin-bottom: 22px; }
.he-kruimels a { text-decoration: none; }
.he-kruimels a:hover { color: var(--blauw); }
.he-artikel-titel { font-size: clamp(32px, 5vw, 54px); margin-bottom: 24px; }
.he-artikel-meta {
	display: flex; align-items: center; justify-content: space-between;
	gap: 20px; flex-wrap: wrap;
	font-size: 14px;
	padding-bottom: 28px;
}
.he-artikel-meta .he-bewaar { margin-top: 0; }
.he-artikel-hero { max-width: 980px; margin-bottom: 16px; }
.he-artikel-hero img { border-radius: var(--radius); box-shadow: var(--schaduw); }

.he-artikel-body { max-width: 760px; padding-top: 28px; padding-bottom: 24px; }
.entry-content > * + * { margin-top: 1.25em; }
.entry-content h2 { font-size: clamp(24px, 3vw, 32px); margin-top: 1.8em; scroll-margin-top: 90px; }
.entry-content h3 { font-size: 21px; margin-top: 1.5em; }
.entry-content a { color: var(--blauw); text-decoration-thickness: 1.5px; text-underline-offset: 2px; }
.entry-content a:hover { color: var(--blauw-donker); }
.entry-content img { border-radius: var(--radius); }
.entry-content ul, .entry-content ol { padding-left: 1.3em; }
.entry-content blockquote {
	border-left: 3px solid var(--blauw);
	padding: 6px 0 6px 22px;
	font-family: var(--font-display);
	font-weight: 700;
	font-size: 20px;
	color: var(--inkt);
}
.entry-content figcaption { font-size: 13.5px; color: var(--inkt-zacht); margin-top: 8px; }

.he-artikel-stijlen {
	max-width: 760px;
	display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
	padding-bottom: 32px;
	font-size: 14px; color: var(--inkt-zacht);
}
.he-stijl-pill {
	display: inline-block;
	background: var(--steen);
	color: var(--koper);
	font-weight: 700; font-size: 13.5px;
	text-decoration: none;
	padding: 7px 15px;
	border-radius: 99px;
	border: 1px solid transparent;
}
.he-stijl-pill:hover { border-color: var(--koper); }
.he-stijl-pills { display: flex; gap: 10px; flex-wrap: wrap; }

.he-auteurbox {
	display: flex; gap: 20px;
	background: var(--vlak);
	border: 1px solid var(--lijn);
	border-radius: var(--radius);
	padding: 26px;
	max-width: 760px;
	margin-bottom: 24px;
}
.he-auteurbox p { font-size: 15px; color: var(--inkt-zacht); margin: 6px 0 10px; }

.he-gerelateerd { padding: 48px 24px 88px; }
.he-gerelateerd h2 { font-size: clamp(26px, 3.4vw, 36px); margin-bottom: 28px; }

/* ---------- Woonstijl-hub ---------- */
.he-hub-kop { padding: 64px 0 56px; }
.he-hub-kop-grid {
	display: grid; grid-template-columns: 1fr 1fr;
	gap: 48px; align-items: center;
}
.he-hub-kop h1 { font-size: clamp(38px, 6vw, 64px); }
.he-hub-sfeer { font-family: var(--font-display); font-weight: 700; color: var(--koper); font-size: 17px; letter-spacing: 0.01em; margin-top: 10px; }
.he-hub-intro { color: var(--inkt-zacht); margin-top: 16px; max-width: 480px; }
.he-hub-beeld img {
	border-radius: var(--radius);
	box-shadow: var(--schaduw);
	aspect-ratio: 4 / 3;
	object-fit: cover;
	width: 100%;
}
.he-hub-sectie { padding: 44px 0; border-top: 1px solid var(--lijn); }
.he-hub-sectie h2 { font-size: clamp(24px, 3.2vw, 34px); margin-bottom: 18px; }
.he-hub-hint { font-size: 14px; color: var(--inkt-zacht); margin: -8px 0 20px; }
.he-hub-twee { display: grid; grid-template-columns: 1fr 1fr; gap: 44px; }
.he-hub-andere { padding-bottom: 88px; }

/* Paletten en stofstalen */
.he-palet { display: flex; flex-wrap: wrap; gap: 14px; }
.he-staal {
	background: var(--vlak);
	border: 1px solid var(--lijn);
	border-radius: var(--radius);
	padding: 10px;
	cursor: pointer;
	text-align: left;
	font-family: var(--font-body);
	transition: transform 0.15s ease, box-shadow 0.15s ease;
	position: relative;
}
.he-staal:hover { transform: translateY(-2px); box-shadow: 0 6px 16px rgba(20, 30, 27, 0.1); }
.he-staal-kleur {
	display: block;
	width: 100%;
	border-radius: 4px;
	margin-bottom: 8px;
	border: 1px solid rgba(20, 30, 27, 0.08);
}
.he-palet-groot .he-staal { width: 138px; }
.he-palet-groot .he-staal-kleur { height: 86px; }
.he-palet-normaal .he-staal { width: 112px; }
.he-palet-normaal .he-staal-kleur { height: 64px; }
.he-palet-mini { gap: 6px; }
.he-palet-mini .he-staal { width: 38px; padding: 4px; }
.he-palet-mini .he-staal-kleur { height: 28px; margin-bottom: 0; }
.he-palet-mini .he-staal-naam, .he-palet-mini .he-staal-hex { display: none; }
.he-staal-naam { display: block; font-weight: 700; font-size: 13.5px; }
.he-staal-hex { display: block; font-size: 12px; color: var(--inkt-zacht); }
.he-staal.is-gekopieerd::after {
	content: "Gekopieerd";
	position: absolute;
	top: -30px; left: 50%;
	transform: translateX(-50%);
	background: var(--inkt);
	color: var(--vlak);
	font-size: 11.5px; font-weight: 600;
	padding: 4px 10px;
	border-radius: 99px;
	white-space: nowrap;
}

/* Vink- en materiaallijsten */
.he-vinklijst { list-style: none; }
.he-vinklijst li {
	padding: 11px 0 11px 32px;
	border-bottom: 1px solid var(--lijn-zacht);
	position: relative;
}
.he-vinklijst li::before {
	content: "";
	position: absolute;
	left: 2px; top: 17px;
	width: 14px; height: 8px;
	border-left: 2.5px solid var(--blauw);
	border-bottom: 2.5px solid var(--blauw);
	transform: rotate(-45deg);
}
.he-materialen { list-style: none; display: flex; flex-wrap: wrap; gap: 10px; }
.he-materialen li {
	background: var(--vlak);
	border: 1px solid var(--lijn);
	border-radius: 99px;
	padding: 8px 17px;
	font-size: 14.5px;
	font-weight: 600;
}

/* Doe/laat-blokken */
.he-doeblok {
	border-radius: var(--radius);
	padding: 26px 28px;
	border: 1px solid var(--lijn);
}
.he-doeblok h2 { font-size: 22px; }
.he-doeblok ul { list-style: none; margin-top: 14px; }
.he-doeblok li { padding: 8px 0 8px 24px; position: relative; font-size: 15.5px; }
.he-doeblok-doe { background: rgba(43, 74, 207, 0.07); }
.he-doeblok-doe h2 { color: var(--blauw); }
.he-doeblok-doe li::before {
	content: ""; position: absolute; left: 0; top: 14px;
	width: 11px; height: 6px;
	border-left: 2.5px solid var(--blauw); border-bottom: 2.5px solid var(--blauw);
	transform: rotate(-45deg);
}
.he-doeblok-laat { background: rgba(185, 122, 42, 0.1); }
.he-doeblok-laat h2 { color: var(--koper); }
.he-doeblok-laat li::before, .he-doeblok-laat li::after {
	content: ""; position: absolute; left: 2px; top: 15px;
	width: 12px; height: 2.5px; background: var(--koper);
}
.he-doeblok-laat li::before { transform: rotate(45deg); }
.he-doeblok-laat li::after { transform: rotate(-45deg); }

/* ---------- Voor/na-slider ---------- */
.he-voorna {
	position: relative;
	border-radius: var(--radius);
	overflow: hidden;
	user-select: none;
	box-shadow: var(--schaduw);
	touch-action: pan-y;
}
.he-voorna img { width: 100%; aspect-ratio: 3 / 2; object-fit: cover; pointer-events: none; }
.he-voorna-voor {
	position: absolute; inset: 0;
	clip-path: inset(0 calc(100% - var(--positie, 50%)) 0 0);
}
.he-voorna-tag {
	position: absolute; top: 14px; left: 14px;
	background: rgba(25, 35, 31, 0.8);
	color: var(--vlak);
	font-size: 12px; font-weight: 700;
	letter-spacing: 0.08em; text-transform: uppercase;
	padding: 5px 12px;
	border-radius: 99px;
}
.he-voorna-tag-na { left: auto; right: 14px; }
.he-voorna-greep {
	position: absolute;
	top: 0; bottom: 0;
	left: var(--positie, 50%);
	width: 3px;
	background: var(--vlak);
	cursor: ew-resize;
	transform: translateX(-50%);
}
.he-voorna-knop {
	position: absolute;
	top: 50%; left: 50%;
	transform: translate(-50%, -50%);
	width: 44px; height: 44px;
	border-radius: 50%;
	background: var(--vlak);
	color: var(--inkt);
	display: flex; align-items: center; justify-content: center;
	box-shadow: 0 3px 12px rgba(0, 0, 0, 0.25);
}

/* ---------- Inhoudsopgave ---------- */
.he-inhoud {
	background: var(--vlak);
	border: 1px solid var(--lijn);
	border-radius: var(--radius);
	padding: 22px 24px;
	margin: 1.6em 0;
}
.he-inhoud-kop { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 12px; }
.he-inhoud-titel { font-family: var(--font-display); font-weight: 700; font-size: 18px; }
.he-inhoud-voortgang {
	flex: 1; max-width: 160px;
	height: 4px;
	background: var(--lijn-zacht);
	border-radius: 99px;
	overflow: hidden;
}
.he-inhoud-balk { display: block; height: 100%; width: 0; background: var(--blauw); transition: width 0.1s linear; }
.he-inhoud-lijst { list-style: none; counter-reset: he-toc; }
.he-inhoud-lijst li { counter-increment: he-toc; }
.he-inhoud-lijst a {
	display: flex; gap: 14px; align-items: baseline;
	padding: 8px 0;
	text-decoration: none;
	font-size: 15px;
	border-bottom: 1px solid var(--lijn-zacht);
}
.he-inhoud-lijst li:last-child a { border-bottom: 0; }
.he-inhoud-lijst a::before {
	content: counter(he-toc, decimal-leading-zero);
	font-size: 12px; font-weight: 700;
	color: var(--koper);
	flex: none;
}
.he-inhoud-lijst a:hover { color: var(--blauw); }
.he-inhoud-lijst a.is-actief { color: var(--blauw); font-weight: 600; }

@media (min-width: 1240px) {
	.he-artikel-body { position: relative; }
	.he-inhoud-zwevend {
		position: fixed;
		top: 110px;
		width: 230px;
		margin: 0;
		max-height: calc(100vh - 150px);
		overflow-y: auto;
	}
}

/* ---------- Stijltabel ---------- */
.he-stijltabel-wrap { overflow-x: auto; margin: 1.6em 0; }
.he-stijltabel {
	width: 100%;
	border-collapse: collapse;
	background: var(--vlak);
	border: 1px solid var(--lijn);
	border-radius: var(--radius);
	overflow: hidden;
	font-size: 15px;
}
.he-stijltabel th, .he-stijltabel td {
	padding: 14px 18px;
	text-align: left;
	border-bottom: 1px solid var(--lijn-zacht);
	vertical-align: top;
	min-width: 150px;
}
.he-stijltabel thead th {
	font-family: var(--font-display);
	font-size: 17px;
	background: var(--steen);
}
.he-stijltabel thead a { text-decoration: none; color: var(--koper); }
.he-stijltabel thead a:hover { text-decoration: underline; }
.he-stijltabel tbody th { font-weight: 700; font-size: 13px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--inkt-zacht); min-width: 100px; }
.he-tabel-lijst { list-style: none; }
.he-tabel-lijst li { padding: 2px 0; }
.he-tabel-lijst li::before { content: "·"; color: var(--blauw); font-weight: 700; margin-right: 7px; }

/* ---------- FAQ ---------- */
.he-faq { margin: 2em 0; }
.he-faq-kop { margin-bottom: 18px; }
.he-faq-item {
	background: var(--vlak);
	border: 1px solid var(--lijn);
	border-radius: var(--radius);
	margin-bottom: 10px;
}
.he-faq-item summary {
	display: flex; align-items: center; justify-content: space-between; gap: 18px;
	padding: 17px 20px;
	cursor: pointer;
	font-family: var(--font-display);
	font-weight: 600;
	font-size: 17px;
	list-style: none;
}
.he-faq-item summary::-webkit-details-marker { display: none; }
.he-faq-plus { position: relative; width: 16px; height: 16px; flex: none; }
.he-faq-plus::before, .he-faq-plus::after {
	content: ""; position: absolute;
	background: var(--blauw);
	transition: transform 0.2s;
}
.he-faq-plus::before { left: 0; right: 0; top: 7px; height: 2px; }
.he-faq-plus::after { top: 0; bottom: 0; left: 7px; width: 2px; }
.he-faq-item[open] .he-faq-plus::after { transform: scaleY(0); }
.he-faq-antwoord { padding: 0 20px 18px; color: var(--inkt-zacht); font-size: 15.5px; }
.he-faq-antwoord > * + * { margin-top: 0.8em; }

/* ---------- Moodboard ---------- */
.he-moodboard {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
	margin: 1.6em 0;
}
.he-moodboard img {
	border-radius: var(--radius);
	box-shadow: var(--schaduw);
	aspect-ratio: 1;
	object-fit: cover;
	width: 100%;
}
.he-moodboard img:nth-child(3n+1) { transform: rotate(-1deg); }
.he-moodboard img:nth-child(3n+2) { transform: rotate(0.6deg) translateY(6px); }
.he-moodboard img:nth-child(3n) { transform: rotate(-0.4deg); }

/* ---------- Quiz ---------- */
.he-quiz {
	max-width: 660px;
	background: var(--vlak);
	border: 1px solid var(--lijn);
	border-radius: var(--radius);
	padding: 32px;
	margin: 24px 0 88px;
	box-shadow: var(--schaduw);
}
.he-quiz-intro { color: var(--inkt-zacht); max-width: 640px; padding-bottom: 8px; }
.he-quiz-voortgang {
	height: 5px;
	background: var(--lijn-zacht);
	border-radius: 99px;
	overflow: hidden;
	margin-bottom: 28px;
}
.he-quiz-balk { display: block; height: 100%; width: 0; background: var(--blauw); transition: width 0.3s ease; }
.he-quiz-vraagnr { font-size: 12.5px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--koper); margin-bottom: 10px; }
.he-quiz-vraag { font-family: var(--font-display); font-weight: 600; font-size: clamp(21px, 3vw, 27px); line-height: 1.2; margin-bottom: 24px; }
.he-quiz-opties { display: grid; gap: 11px; }
.he-quiz-optie {
	text-align: left;
	font-family: var(--font-body);
	font-size: 16px;
	background: var(--fond);
	border: 1.5px solid var(--lijn);
	border-radius: var(--radius);
	padding: 15px 18px;
	cursor: pointer;
	transition: border-color 0.15s, transform 0.15s;
}
.he-quiz-optie:hover { border-color: var(--blauw); transform: translateX(3px); }
.he-quiz-terug { margin-top: 22px; }

.he-quiz-resultaat { text-align: center; padding: 12px 0; }
.he-quiz-resultaat-eyebrow { font-size: 12.5px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--koper); margin-bottom: 12px; }
.he-quiz-resultaat h2 { font-size: clamp(30px, 5vw, 44px); color: var(--blauw); margin-bottom: 14px; }
.he-quiz-resultaat p { color: var(--inkt-zacht); max-width: 460px; margin: 0 auto 22px; }
.he-quiz-resultaat .he-knop { margin: 4px 6px; }
.he-quiz-tweede { font-size: 14.5px; margin-top: 18px; }
.he-quiz-tweede a { color: var(--blauw); }

/* ---------- Bewaard-pagina ---------- */
.he-bewaard-uitleg { color: var(--inkt-zacht); max-width: 560px; }
.he-bewaard-pagina .he-kaarten-grid { padding: 32px 0 24px; }
.he-bewaard-leeg { padding: 48px 0 64px; max-width: 480px; }
.he-bewaard-leeg p { margin-bottom: 20px; color: var(--inkt-zacht); }
.he-bewaard-wissen { margin-bottom: 88px; }
.he-kaart-verwijder {
	position: absolute; top: 10px; right: 10px;
	background: rgba(255, 255, 255, 0.94);
	border: 1px solid var(--lijn);
	border-radius: 99px;
	width: 32px; height: 32px;
	cursor: pointer;
	font-size: 16px;
	line-height: 1;
	color: var(--inkt);
}
.he-kaart-verwijder:hover { color: var(--blauw); border-color: var(--blauw); }

/* ---------- 404 en zoeken ---------- */
.he-404 { padding: 96px 24px 120px; max-width: 640px; }
.he-404 h1 { font-size: clamp(30px, 5vw, 48px); margin-bottom: 16px; }
.he-404 p { color: var(--inkt-zacht); margin-bottom: 24px; }
.he-404 .he-knop { margin-top: 24px; }
.he-zoekform { display: flex; gap: 10px; max-width: 440px; }
.he-zoekform input {
	flex: 1;
	font-family: var(--font-body);
	font-size: 15.5px;
	padding: 12px 17px;
	border: 1.5px solid var(--lijn);
	border-radius: 99px;
	background: var(--vlak);
	color: var(--inkt);
}
.he-zoekform input:focus { outline: none; border-color: var(--blauw); }
.he-zoekform button {
	font-family: var(--font-body);
	font-weight: 700;
	font-size: 15px;
	background: var(--inkt);
	color: var(--vlak);
	border: 0;
	border-radius: 99px;
	padding: 12px 22px;
	cursor: pointer;
}
.he-zoekform button:hover { background: var(--blauw); }

/* ---------- Footer ---------- */
.he-footer {
	background: var(--inkt);
	color: var(--fond);
	padding: 64px 0 28px;
	position: relative;
	z-index: 2;
}
.he-footer .he-brand { color: var(--vlak); }
.he-footer-grid {
	display: grid;
	grid-template-columns: 1.6fr 1fr 1fr 1fr;
	gap: 44px;
	padding-bottom: 44px;
}
.he-footer-over p { color: rgba(243, 245, 244, 0.65); font-size: 14.5px; margin-top: 16px; max-width: 320px; }
.he-footer-kop {
	font-size: 12.5px; font-weight: 700;
	letter-spacing: 0.12em; text-transform: uppercase;
	color: rgba(243, 245, 244, 0.5);
	margin-bottom: 16px;
}
.he-footer-lijst { list-style: none; }
.he-footer-lijst a {
	display: block;
	color: var(--fond);
	text-decoration: none;
	font-size: 14.5px;
	padding: 4.5px 0;
}
.he-footer-lijst a:hover { color: var(--blauw); }
.he-footer-onder {
	display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap;
	border-top: 1px solid rgba(243, 245, 244, 0.15);
	padding-top: 24px;
	font-size: 13.5px;
	color: rgba(243, 245, 244, 0.55);
}

/* ---------- Responsief ---------- */
@media (max-width: 980px) {
	.he-hero-grid, .he-featured, .he-hub-kop-grid { grid-template-columns: 1fr; gap: 28px; }
	.he-kaarten-grid { grid-template-columns: repeat(2, 1fr); }
	.he-footer-grid { grid-template-columns: 1fr 1fr; }
	.he-hub-twee { grid-template-columns: 1fr; gap: 28px; }
}

@media (max-width: 700px) {
	body.he-porselein { font-size: 16px; }
	.he-nav { display: none; }
	.he-menu-knop { display: block; }
	.he-hero { padding-top: 44px; }
	.he-kaarten-grid { grid-template-columns: 1fr; }
	.he-moodboard { grid-template-columns: repeat(2, 1fr); }
	.he-auteurkaart-inner, .he-auteurbox { flex-direction: column; }
	.he-footer-grid { grid-template-columns: 1fr; gap: 32px; }
	.he-quiz { padding: 24px 18px; }
	.he-artikel-meta { flex-direction: column; align-items: flex-start; }
}
