/**
 * Components — BEM (editorial homepage + archives + single)
 */

/* —— Homepage: tagline (volle breedte onder header, los van .home-lead) —— */
.editorial-tagline {
	width: 100%;
	max-width: none;
	margin: 0;
	box-sizing: border-box;
	background: var(--color-forest);
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
	padding: 0.85rem clamp(1rem, 4vw, 2rem);
	text-align: center;
}

.editorial-tagline__text {
	margin: 0 auto;
	max-width: min(100%, var(--content-max));
	font-family: var(--font-body);
	font-size: clamp(11px, 1.65vw, 13px);
	font-weight: 500;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--color-warm-white);
}

/* =============================================
   EDITORIAL OPENER — featured + recent (witte kaart, ~60/40, geen datums)
   ============================================= */

/* Homepage: opener + uitgelicht als één kolom; zachte overgang i.p.v. losse rand */
.home-lead {
	max-width: var(--content-max);
	margin-left: auto;
	margin-right: auto;
	padding-left: clamp(1rem, 4vw, 1.5rem);
	padding-right: clamp(1rem, 4vw, 1.5rem);
}

.home-lead .editorial-opener {
	border-bottom: none;
	padding: clamp(1.5rem, 4vw, 2.75rem) 0 clamp(1.25rem, 3vw, 2rem);
}

/* Uitgelicht: geen apart wit vlak — zelfde ondergrond als de pagina; lichte scheiding t.o.v. opener */
.home-lead .featured-grid {
	max-width: none;
	margin-left: 0;
	margin-right: 0;
	margin-top: clamp(0.75rem, 2.5vw, 1.25rem);
	padding: clamp(1.75rem, 3.5vw, 2.75rem) 0 clamp(2.25rem, 5vw, 3.25rem);
	background: transparent;
	border: none;
	border-radius: 0;
	box-shadow: none;
	border-top: 1px solid rgba(200, 169, 110, 0.22);
}

.home-lead .featured-grid__head {
	border-left: 3px solid var(--color-forest);
	padding-left: 0.85rem;
	margin-bottom: clamp(1.25rem, 3vw, 2rem);
}

.editorial-opener {
	padding: clamp(1.25rem, 3vw, 2rem) clamp(1rem, 4vw, 1.5rem) clamp(2rem, 4vw, 2.75rem);
	border-bottom: 1px solid #e8e2d9;
	background: transparent;
}

.editorial-opener__shell {
	max-width: var(--content-max);
	margin: 0 auto;
	padding: 0;
	background: transparent;
	border: none;
	border-radius: 0;
	box-shadow: none;
	overflow: visible;
}

/* Één kaart: wit, rand, hoeken; twee kolommen 60% / 40% */
.editorial-opener__grid {
	display: grid;
	grid-template-columns: minmax(0, 3fr) minmax(0, 2fr);
	gap: 0;
	align-items: stretch;
	margin: 0;
	padding: 0;
	background: #ffffff;
	border: 1px solid #e8e2d9;
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 1px 0 rgba(255, 255, 255, 0.85) inset;
}

/* Linkerkolom: kolom is wit; opbouw = beeld → (padding) badge/lijn → titel | excerpt | lees meer */
.editorial-opener__main {
	display: flex;
	flex-direction: column;
	flex: 1;
	min-width: 0;
	min-height: 100%;
	padding: 0 32px 32px;
	background: #ffffff;
}

.editorial-opener__main-link {
	text-decoration: none;
	display: block;
	color: inherit;
	flex-shrink: 0;
}

.editorial-opener__figure {
	position: relative;
	overflow: hidden;
	margin: 0 -32px 0;
	width: calc(100% + 64px);
	max-width: none;
	display: flex;
	flex-direction: column;
	background: #ffffff;
	border-radius: 12px 0 0 0;
}

.editorial-opener__img {
	width: 100%;
	height: min(52vw, 320px);
	min-height: 260px;
	object-fit: cover;
	object-position: center;
	display: block;
	flex-shrink: 0;
	transition: transform 0.45s cubic-bezier(0.19, 1, 0.22, 1);
}

.editorial-opener__main-link:hover .editorial-opener__img {
	transform: scale(1.02);
}

.editorial-opener__img--placeholder {
	min-height: 260px;
	height: min(52vw, 320px);
	background: #f0ece6;
}

/* Categorie-chip onder de foto — zachte pill met goudaccent */
.editorial-opener__pill {
	position: static;
	align-self: flex-start;
	margin: 26px 32px 0;
	padding: 0.5rem 1rem 0.5rem 0.65rem;
	border-radius: 999px;
	pointer-events: none;
	display: inline-flex;
	flex-direction: row;
	align-items: center;
	gap: 0.5rem;
	font-family: var(--font-body);
	font-size: 0.6875rem;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: #3d5248;
	background: linear-gradient(165deg, #fdfcfa 0%, #f4ebe1 100%);
	border: 1px solid rgba(200, 169, 110, 0.42);
	box-shadow:
		0 1px 0 rgba(255, 255, 255, 0.85) inset,
		0 1px 3px rgba(30, 58, 47, 0.07);
}

.editorial-opener__pill::before {
	content: "";
	width: 7px;
	height: 7px;
	border-radius: 50%;
	flex-shrink: 0;
	background: radial-gradient(circle at 30% 30%, #e8d4a8, #b8924a);
	box-shadow: 0 0 0 2px rgba(201, 149, 58, 0.22);
}

.editorial-opener__pill::after {
	content: none;
	display: none;
}

.editorial-opener__title {
	font-family: var(--font-display), Georgia, serif;
	font-weight: 600;
	font-size: clamp(1.65rem, 2.6vw, 2.125rem);
	line-height: 1.18;
	color: #1a3228;
	margin: 20px 0 0;
	transition: color 0.2s;
}

.editorial-opener__main-link:hover .editorial-opener__title {
	color: #142a22;
}

.editorial-opener__excerpt {
	font-family: var(--font-body);
	font-size: 15px;
	line-height: 1.65;
	color: #6b7b72;
	margin: 16px 0 0;
	max-width: 42rem;
	display: -webkit-box;
	-webkit-line-clamp: 5;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.editorial-opener__read {
	margin-top: 22px;
	font-family: var(--font-body);
	font-size: 14px;
	font-weight: 500;
	color: #1a3228;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	align-self: flex-start;
	gap: 0.35rem;
	padding: 10px 22px;
	border-radius: 999px;
	background: #f5f0e8;
	border: 1px solid #e0d5c0;
	box-shadow: 0 1px 2px rgba(30, 58, 47, 0.06);
	transition:
		background 0.2s ease,
		color 0.2s ease,
		border-color 0.2s ease,
		box-shadow 0.2s ease,
		transform 0.2s ease;
}

.editorial-opener__read:hover,
.editorial-opener__read:focus-visible {
	color: #ffffff;
	background: #c8a96e;
	border-color: #c8a96e;
	box-shadow: 0 4px 14px rgba(200, 169, 110, 0.35);
	transform: translateY(-1px);
}

.editorial-opener__read::after {
	display: none;
}

/* Rechterkolom: compacte lijst (duimnail + badge + titel), fonts gelijk aan rest van thema */
.editorial-opener__rail {
	display: flex;
	flex-direction: column;
	gap: 0;
	min-width: 0;
	min-height: 100%;
	background: #faf8f5;
	border-left: 1px solid #e8e2d9;
	padding: 0;
}

.editorial-opener__rail-head {
	padding: 1.25rem 1.35rem 0.85rem;
	border-bottom: 1px solid #e8e2d9;
	flex-shrink: 0;
}

.editorial-opener__rail-heading {
	margin: 0;
}

.editorial-opener__rail-list {
	display: flex;
	flex-direction: column;
	flex: 1;
	min-width: 0;
}

.editorial-opener__rail-item {
	display: flex;
	flex-direction: row;
	align-items: flex-start;
	gap: 0.875rem;
	padding: 1rem 1.35rem;
	border-bottom: 1px solid rgba(232, 224, 212, 0.95);
	text-decoration: none;
	color: inherit;
	transition: background 0.2s ease;
}

.editorial-opener__rail-item:hover {
	background: rgba(30, 58, 47, 0.04);
}

.editorial-opener__rail-item:hover .editorial-opener__rail-title {
	color: var(--color-gold);
}

.editorial-opener__rail-thumb {
	width: 72px;
	height: 72px;
	border-radius: var(--radius-sm);
	overflow: hidden;
	flex-shrink: 0;
	background: var(--color-ivory-alt);
}

.editorial-opener__rail-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.editorial-opener__rail-thumb-placeholder {
	display: block;
	width: 100%;
	height: 100%;
	min-height: 72px;
	background: var(--color-ivory-alt);
}

.editorial-opener__rail-body {
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
	min-width: 0;
	flex: 1;
}

.editorial-opener__rail-badges {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	align-content: flex-start;
	gap: 0.35rem 0.45rem;
}

/* Zelfde taal als .article-card__cat: bosgroen band, DM Sans */
.editorial-opener__rail-cat {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-family: var(--font-body);
	font-size: 0.625rem;
	font-weight: 700;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0.07em;
	color: var(--color-warm-white);
	background: var(--color-forest);
	padding: 0.24rem 0.5rem;
	border-radius: 2px;
}

/* Leestijd: zelfde systeem als .article-card__meta-badge--read */
.editorial-opener__rail-read {
	display: inline-flex;
	align-items: center;
	font-family: var(--font-body);
	font-size: 0.625rem;
	font-weight: 600;
	line-height: 1.2;
	letter-spacing: 0.02em;
	color: var(--color-forest);
	background: rgba(201, 149, 58, 0.12);
	border: 1px solid rgba(201, 149, 58, 0.38);
	border-radius: 4px;
	padding: 0.22rem 0.45rem;
	white-space: nowrap;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.45);
}

.editorial-opener__rail-title {
	font-family: var(--font-display), Georgia, serif;
	font-weight: 600;
	font-size: clamp(0.9375rem, 1.6vw, 1.0625rem);
	line-height: 1.35;
	color: var(--color-forest);
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;
	line-clamp: 3;
	overflow: hidden;
	transition: color 0.2s ease;
	word-break: break-word;
}

.editorial-opener__rail-all {
	font-family: var(--font-body);
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--color-gold);
	text-decoration: none;
	padding: 1rem 1.35rem;
	display: block;
	margin-top: auto;
	flex-shrink: 0;
	transition: color 0.2s ease, background 0.2s ease;
}

.editorial-opener__rail-all:hover,
.editorial-opener__rail-all:focus-visible {
	color: #a8894a;
	background: rgba(200, 169, 110, 0.08);
}

@media (max-width: 1023px) {
	.editorial-opener__grid {
		grid-template-columns: minmax(0, 1fr);
	}

	.editorial-opener__figure {
		border-radius: 12px 12px 0 0;
	}

	.editorial-opener__rail {
		border-left: none;
		border-top: 1px solid #e8e2d9;
		min-width: 0;
	}
}

@media (max-width: 768px) {
	.editorial-opener__main {
		padding: 0 20px 26px;
	}

	.editorial-opener__figure {
		margin-left: -20px;
		margin-right: -20px;
		width: calc(100% + 40px);
	}

	.editorial-opener__pill {
		margin: 22px 20px 0;
	}

	.editorial-opener__title {
		font-size: clamp(1.4rem, 5.2vw, 2rem);
	}

	.editorial-opener__img,
	.editorial-opener__img--placeholder {
		min-height: 220px;
		height: min(48vw, 280px);
	}

	.editorial-opener__rail-thumb {
		width: 64px;
		height: 64px;
	}

	.editorial-opener__rail-thumb-placeholder {
		min-height: 64px;
	}
}

/* —— Hero fullwidth (legacy / optioneel) —— */
.editorial-hero {
	position: relative;
	min-height: min(72vh, 640px);
	display: flex;
	align-items: flex-end;
	color: var(--color-warm-white);
}

.editorial-hero__media {
	position: absolute;
	inset: 0;
	z-index: 0;
}

.editorial-hero__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.editorial-hero__placeholder {
	position: absolute;
	inset: 0;
	background: linear-gradient(145deg, var(--color-forest) 0%, var(--color-forest-light) 100%);
}

.editorial-hero__overlay {
	position: absolute;
	inset: 0;
	z-index: 1;
	background: rgba(30, 58, 47, 0.5);
}

.editorial-hero__inner {
	position: relative;
	z-index: 2;
	max-width: var(--content-max);
	width: 100%;
	margin: 0 auto;
	padding: clamp(2.5rem, 6vw, 4rem) clamp(1rem, 4vw, 1.5rem);
}

.editorial-hero__title {
	font-family: var(--font-display);
	font-size: clamp(2.25rem, 5vw, 3.5rem);
	font-weight: 600;
	margin: 0 0 1rem;
	line-height: 1.1;
	color: var(--color-warm-white);
}

.editorial-hero__title em {
	font-style: italic;
	font-weight: 600;
	color: var(--color-gold);
}

.editorial-hero__lead {
	font-family: var(--font-body);
	font-size: clamp(1rem, 2vw, 1.2rem);
	max-width: 36rem;
	margin: 0 0 1.75rem;
	opacity: 0.95;
	line-height: 1.65;
}

.editorial-hero__ctas {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
}

.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.85rem 1.5rem;
	font-family: var(--font-body);
	font-size: 0.95rem;
	font-weight: 600;
	text-decoration: none;
	border-radius: var(--radius-sm);
	border: 2px solid transparent;
	cursor: pointer;
	transition: background var(--transition), color var(--transition), border-color var(--transition);
}

.btn--gold {
	background: var(--color-gold);
	color: var(--color-forest);
	border-color: var(--color-gold);
}

.btn--gold:hover {
	background: #ddb24d;
	color: var(--color-forest);
}

.btn--outline-light {
	background: transparent;
	color: var(--color-warm-white);
	border-color: rgba(255, 255, 255, 0.85);
}

.btn--outline-light:hover {
	border-color: var(--color-gold);
	color: var(--color-gold);
}

/* —— Category rail —— */
.cat-rail-wrap {
	position: relative;
	z-index: 50;
}

.cat-rail {
	background: var(--color-ivory);
	border-bottom: 1px solid var(--color-border);
}

.cat-rail--sticky {
	position: sticky;
	top: var(--header-sticky-offset);
	z-index: 150;
	box-shadow: 0 2px 12px rgba(30, 58, 47, 0.06);
}

.cat-rail__track {
	display: flex;
	gap: 0.75rem;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
	padding: 1rem clamp(1rem, 4vw, 1.5rem);
	max-width: var(--content-max);
	margin: 0 auto;
}

.cat-rail__track::-webkit-scrollbar {
	height: 4px;
}

.cat-card {
	flex: 0 0 auto;
	scroll-snap-align: start;
	display: flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.65rem 1rem;
	background: var(--color-warm-white);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	text-decoration: none;
	color: var(--color-forest);
	font-size: 0.85rem;
	font-weight: 600;
	transition: background var(--transition), color var(--transition), border-color var(--transition);
}

.cat-card:hover {
	background: var(--color-forest);
	color: var(--color-warm-white);
	border-color: var(--color-forest);
}

.cat-card__icon {
	width: 28px;
	height: 28px;
	flex-shrink: 0;
	opacity: 0.9;
}

/* Category archive: subcategorieën / menu-children als kaarten */
.category-subcards {
	margin: 0 0 clamp(1.75rem, 4vw, 2.5rem);
	padding: 0;
}

.category-subcards__title {
	font-family: var(--font-display), Georgia, serif;
	font-size: clamp(1.15rem, 2.5vw, 1.35rem);
	font-weight: 600;
	color: var(--color-forest);
	margin: 0 0 1rem;
	line-height: 1.25;
}

.category-subcards__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(158px, 1fr));
	gap: 0.75rem;
}

.category-subcards__grid .category-subcards__card.cat-card {
	flex: none;
	width: 100%;
	min-width: 0;
	scroll-snap-align: unset;
	justify-content: flex-start;
	align-items: center;
	gap: 0.65rem;
	padding: 0.75rem 1rem;
}

.category-subcards__card-title {
	min-width: 0;
	overflow-wrap: anywhere;
	line-height: 1.3;
}

/* —— Featured grid (homepage) — één typografie- + CTA-systeem —— */
.featured-grid {
	padding: clamp(2.5rem, 5vw, 4rem) clamp(1rem, 4vw, 1.5rem);
	max-width: var(--content-max);
	margin: 0 auto;
}

.featured-grid__head {
	margin-bottom: clamp(1.25rem, 3vw, 2rem);
}

/* Label: zelfde “UI”-taal als categorie-pills (sans, caps) — geen losse italic-serif */
.featured-grid__label {
	font-family: var(--font-body);
	font-style: normal;
	font-size: 0.6875rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--color-muted);
	margin: 0 0 0.5rem;
}

.featured-grid__title {
	font-family: var(--font-display);
	font-size: clamp(1.75rem, 3vw, 2.25rem);
	font-weight: 600;
	margin: 0;
	line-height: 1.15;
	color: var(--color-forest);
}

.featured-grid__layout {
	display: grid;
	gap: 1.25rem;
	grid-template-columns: 1fr;
}

.featured-grid__layout > * {
	min-width: 0;
}

.featured-grid__side {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;
}

.featured-grid__side .article-card:nth-last-child(1):nth-child(odd):not(:only-child) {
	grid-column: 1 / -1;
}

/* Categorie + titels: tokens; hover titel = goud (zoals overige cards) */
.featured-grid .article-card__cat {
	font-family: var(--font-body);
	font-size: 0.625rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	padding: 0.35rem 0.65rem;
	border-radius: var(--radius-sm);
	background: var(--color-forest);
	color: var(--color-warm-white);
	border: none;
}

.featured-grid .article-card__tag--year {
	font-size: 0.625rem;
	padding: calc(0.35rem - 1px) 0.45rem;
}

.featured-grid .article-card__title {
	font-family: var(--font-display);
	font-weight: 600;
	color: var(--color-forest);
}

.featured-grid .article-card__link:hover .article-card__title {
	color: var(--color-gold);
}

/* Grote kaart (links) */
.featured-grid__layout > .article-card--featured {
	display: flex;
	flex-direction: column;
	height: 100%;
	min-height: 0;
}

.featured-grid__layout > .article-card--featured .article-card__link {
	flex: 1;
	min-height: 0;
	border-radius: var(--radius-lg);
	box-shadow:
		0 2px 4px rgba(30, 58, 47, 0.04),
		0 12px 40px rgba(30, 58, 47, 0.1);
}

.featured-grid__layout > .article-card--featured .article-card__link:hover {
	box-shadow:
		0 4px 8px rgba(30, 58, 47, 0.06),
		0 16px 48px rgba(30, 58, 47, 0.12);
	transform: translateY(-3px);
}

.featured-grid__layout > .article-card--featured .article-card__media {
	aspect-ratio: 16 / 9;
}

.featured-grid__layout > .article-card--featured .article-card__body {
	display: flex;
	flex-direction: column;
	flex: 1;
	min-height: 0;
	padding: 1.25rem 1.35rem 1.2rem;
}

.featured-grid__layout > .article-card--featured .article-card__title {
	font-size: clamp(1.5rem, 4vw, 2rem);
	line-height: 1.22;
	margin-bottom: 0.65rem;
}

@media (min-width: 768px) {
	.featured-grid__layout > .article-card--featured .article-card__title {
		font-size: 2rem;
	}
}

.featured-grid__layout > .article-card--featured .article-card__excerpt {
	font-size: 1rem;
	line-height: 1.6;
	color: var(--color-muted);
	margin-bottom: 0 !important;
	max-width: 42em;
	display: -webkit-box;
	-webkit-line-clamp: 4;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* Kleine kaarten */
.featured-grid__side .article-card__link {
	display: flex;
	flex-direction: column;
	height: 100%;
	border-radius: var(--radius-md);
	transition: box-shadow var(--transition), transform var(--transition), border-color var(--transition);
}

.featured-grid__side .article-card__link:hover {
	transform: translateY(-2px);
}

.featured-grid__side .article-card__body {
	display: flex;
	flex-direction: column;
	flex: 1;
	min-height: 0;
	padding: 0.9rem 1rem 1rem;
}

.featured-grid__side .article-card__title {
	font-size: 1.05rem;
	line-height: 1.28;
	margin-bottom: 0.4rem;
}

.featured-grid__side .article-card__excerpt {
	font-size: 0.875rem;
	line-height: 1.45;
	margin-bottom: 0 !important;
	color: var(--color-muted);
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.featured-grid__side .article-card {
	height: auto;
}

/* Footer: leestijd + “Lees meer” — identiek op alle featured-kaarten */
.featured-grid .article-card__meta {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-top: auto;
	margin-bottom: 0;
	width: 100%;
	flex-wrap: nowrap;
	gap: 10px;
	padding-top: 0.5rem;
}

.featured-grid .article-card__meta-badge--read {
	font-family: var(--font-body);
	font-size: 11px;
	font-weight: 400;
	line-height: 1.3;
	color: var(--color-muted);
	background: transparent;
	border: none;
	padding: 0;
	letter-spacing: 0.02em;
}

.featured-grid .article-card__meta::after {
	content: "Lees meer";
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-family: var(--font-body);
	font-size: 12px;
	font-weight: 500;
	line-height: 1.2;
	color: var(--color-forest);
	background: var(--color-ivory-alt);
	border: 1px solid var(--color-border);
	padding: 6px 14px;
	border-radius: 999px;
	transition: background var(--transition), color var(--transition), border-color var(--transition);
	flex-shrink: 0;
	pointer-events: none;
}

.featured-grid .article-card__link:hover .article-card__meta::after {
	background: var(--color-gold);
	color: var(--color-warm-white);
	border-color: var(--color-gold);
}

/* —— Article card —— */
.article-card {
	height: 100%;
}

.article-card__link {
	display: flex;
	flex-direction: column;
	height: 100%;
	text-decoration: none;
	color: inherit;
	background: var(--color-warm-white);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	overflow: hidden;
	box-shadow: var(--shadow-soft);
	transition: box-shadow var(--transition), transform var(--transition);
}

.article-card__link:hover {
	box-shadow: 0 8px 32px rgba(30, 58, 47, 0.12);
	transform: translateY(-2px);
}

.article-card__link:hover .article-card__title {
	color: var(--color-gold);
}

.article-card__media {
	position: relative;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: var(--color-ivory-alt);
}

.article-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.article-card__body {
	padding: 1rem 1.15rem 1.25rem;
	flex: 1;
	display: flex;
	flex-direction: column;
}

.article-card__badges {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	align-self: flex-start;
	gap: 0.4rem 0.55rem;
	margin-bottom: 0.5rem;
	max-width: 100%;
}

.article-card__badges .article-card__cat,
.article-card__badges .article-card__tag--year {
	margin-top: 0;
	margin-bottom: 0;
}

.article-card__cat {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 0.7rem;
	font-weight: 700;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--color-warm-white);
	background: var(--color-forest);
	padding: 0.25rem 0.6rem;
	border-radius: 2px;
	margin-bottom: 0;
	text-decoration: none;
}

/* Zelfde bandhoogte als .article-card__cat (border telt mee → padding iets lager) */
.article-card__tag--year {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-sizing: border-box;
	font-family: var(--font-body);
	font-size: 0.625rem;
	font-weight: 600;
	font-variant-numeric: tabular-nums;
	letter-spacing: 0.06em;
	color: var(--color-forest);
	background: var(--color-ivory-alt);
	border: 1px solid rgba(201, 149, 58, 0.45);
	padding: calc(0.25rem - 1px) 0.45rem;
	border-radius: 2px;
	line-height: 1;
	flex-shrink: 0;
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.65),
		0 1px 2px rgba(30, 58, 47, 0.06);
}

/* Samenwerking — goud accent, onderscheidt van jaartag */
.article-card__tag--collab {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-sizing: border-box;
	font-family: var(--font-body);
	font-size: 0.65rem;
	font-weight: 700;
	letter-spacing: 0.07em;
	text-transform: uppercase;
	color: var(--color-forest);
	background: linear-gradient(
		180deg,
		rgba(255, 252, 247, 0.98) 0%,
		rgba(201, 149, 58, 0.14) 100%
	);
	border: 1px solid rgba(201, 149, 58, 0.55);
	padding: calc(0.28rem - 1px) 0.55rem;
	border-radius: 3px;
	line-height: 1.2;
	flex-shrink: 0;
	max-width: 100%;
	text-align: center;
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.75),
		0 1px 2px rgba(30, 58, 47, 0.07);
}

.article-card__title {
	font-family: var(--font-display);
	font-size: 1.35rem;
	font-weight: 600;
	margin: 0 0 0.5rem;
	line-height: 1.25;
	color: var(--color-forest);
	transition: color var(--transition);
}

/* Kaarttitels gelijk houden in grids (niet de grote homepage-uitlichting) */
.article-card:not(.article-card--featured) .article-card__title {
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	overflow: hidden;
	word-break: break-word;
}

.article-card__excerpt {
	font-size: 0.95rem;
	color: var(--color-muted);
	margin: 0 0 0.75rem;
	line-height: 1.55;
}

.article-card__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.35rem 0.45rem;
	margin-top: auto;
}

.article-card__meta-badge {
	display: inline-block;
	font-family: var(--font-body);
	font-size: 0.6875rem;
	font-weight: 600;
	line-height: 1.25;
	letter-spacing: 0.03em;
	color: var(--color-forest);
	background: rgba(30, 58, 47, 0.05);
	border: 1px solid rgba(30, 58, 47, 0.12);
	border-radius: 4px;
	padding: 0.2rem 0.45rem;
}

.article-card__meta-badge--date {
	color: var(--color-muted);
	font-weight: 500;
	border-color: var(--color-border);
	background: var(--color-ivory-alt);
}

.article-card__meta-badge--read {
	border-color: rgba(201, 149, 58, 0.35);
	background: rgba(201, 149, 58, 0.1);
	color: var(--color-forest);
}

.article-card--horizontal .article-card__link {
	flex-direction: row;
	align-items: stretch;
}

.article-card--horizontal .article-card__media {
	width: 120px;
	min-width: 120px;
	aspect-ratio: 1;
}

.article-card--horizontal .article-card__body {
	padding: 0.75rem 1rem;
}

/* —— Trend strip —— */
.trend-strip {
	padding: clamp(2rem, 4vw, 3rem) 0;
	background: var(--color-ivory-alt);
	background-image: none;
	border-top: 1px solid var(--color-border);
	border-bottom: 1px solid var(--color-border);
}

/* Zelfde effen band als .trend-strip (geen gradient) — o.a. recepten-spotlight */
.section-showcase.section-showcase--strip {
	max-width: none;
	width: 100%;
	margin-left: 0;
	margin-right: 0;
	padding: clamp(2rem, 4vw, 3rem) 0;
	background: var(--color-ivory-alt);
	background-image: none;
	border-top: 1px solid var(--color-border);
	border-bottom: 1px solid var(--color-border);
}

.section-showcase.section-showcase--strip .section-showcase__inner {
	max-width: var(--content-max);
	margin-left: auto;
	margin-right: auto;
	padding-left: clamp(1rem, 4vw, 1.5rem);
	padding-right: clamp(1rem, 4vw, 1.5rem);
}

.trend-strip__inner {
	max-width: var(--content-max);
	margin: 0 auto;
	padding: 0 clamp(1rem, 4vw, 1.5rem);
}

.trend-strip__label {
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--color-gold);
	margin: 0 0 1rem;
}

.trend-strip__grid {
	display: grid;
	gap: 1rem;
	grid-template-columns: 1fr;
}

/* —— Section showcase —— */
.section-showcase {
	padding: clamp(2.5rem, 5vw, 3.5rem) clamp(1rem, 4vw, 1.5rem);
	max-width: var(--content-max);
	margin-left: auto;
	margin-right: auto;
	box-sizing: border-box;
}

.section-showcase--alt {
	background: var(--color-ivory-alt);
}

.section-showcase__inner {
	width: 100%;
	margin: 0 auto;
}

.section-showcase__head {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-end;
	justify-content: space-between;
	gap: 1rem;
	margin-bottom: 1.5rem;
}

.section-showcase__links {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-end;
	gap: 1rem 1.75rem;
}

.section-showcase__title-wrap {
	display: flex;
	align-items: center;
	gap: 0.75rem;
}

.section-showcase__icon {
	width: 36px;
	height: 36px;
	color: var(--color-forest);
}

.section-showcase__title {
	font-size: clamp(1.5rem, 2.5vw, 2rem);
	margin: 0;
}

.section-showcase__all {
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--color-forest);
	text-decoration: none;
	border-bottom: 2px solid var(--color-gold);
	padding-bottom: 2px;
}

.section-showcase__all:hover {
	color: var(--color-gold);
}

.section-showcase__grid {
	display: grid;
	gap: 1.25rem;
	grid-template-columns: 1fr;
}

.section-showcase__head--with-intro {
	align-items: flex-start;
}

.section-showcase__head-text {
	flex: 1;
	min-width: min(100%, 36rem);
}

.section-showcase__intro {
	margin: 0.65rem 0 0;
	font-size: 0.95rem;
	line-height: 1.55;
	color: var(--color-muted);
	max-width: 38rem;
}

.section-showcase__grid--recepten .article-card__media {
	aspect-ratio: 4 / 3;
}

.section-showcase__grid--recepten .article-card__media img {
	object-fit: cover;
}

.section-showcase__grid--cadeaus .article-card__media {
	aspect-ratio: 4 / 3;
}

.section-showcase__grid--cadeaus .article-card__media img {
	object-fit: cover;
}

/* Cadeaus (homepage): eigen ivoren band + vlakkere “shop”-kaarten t.o.v. Uitgelicht */
.section-showcase.section-showcase--cadeaus {
	max-width: none;
	width: 100%;
	margin-left: 0;
	margin-right: 0;
	padding: clamp(2.5rem, 5.5vw, 4rem) 0;
	background: var(--color-ivory-alt);
	border-top: 1px solid var(--color-border);
	border-bottom: 1px solid var(--color-border);
	box-sizing: border-box;
}

.section-showcase.section-showcase--cadeaus .section-showcase__inner {
	max-width: var(--content-max);
	margin-left: auto;
	margin-right: auto;
	padding-left: clamp(1rem, 4vw, 1.5rem);
	padding-right: clamp(1rem, 4vw, 1.5rem);
}

.section-showcase.section-showcase--cadeaus .section-showcase__title-wrap {
	padding-left: 0.75rem;
	border-left: 3px solid var(--color-gold);
}

.section-showcase--cadeaus .section-showcase__grid .article-card__link {
	background: rgba(255, 255, 255, 0.94);
	border: 1px solid rgba(30, 58, 47, 0.11);
	box-shadow: 0 1px 3px rgba(30, 58, 47, 0.05);
	transition:
		border-color 0.2s ease,
		box-shadow 0.2s ease,
		transform 0.2s ease;
}

.section-showcase--cadeaus .section-showcase__grid .article-card__link:hover {
	transform: translateY(-2px);
	border-color: rgba(30, 58, 47, 0.2);
	box-shadow: 0 10px 32px rgba(30, 58, 47, 0.1);
}

.section-showcase__empty-wrap {
	padding: 0.25rem 0 0.5rem;
}

.section-showcase__empty {
	margin: 0 0 1rem;
	font-size: 0.95rem;
	line-height: 1.55;
	color: var(--color-muted);
	max-width: 40rem;
}

.section-showcase__empty-cta {
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--color-forest);
	text-decoration: none;
	border-bottom: 2px solid var(--color-gold);
	padding-bottom: 2px;
}

.section-showcase__empty-cta:hover {
	color: var(--color-gold);
}

/* —— Long read row —— */
.long-read-row {
	padding: clamp(2rem, 4vw, 3rem) clamp(1rem, 4vw, 1.5rem);
	max-width: var(--content-max);
	margin: 0 auto;
}

.long-read-row__list {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.long-read-card {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;
	background: var(--color-warm-white);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	overflow: hidden;
	box-shadow: var(--shadow-soft);
}

.long-read-card__media {
	min-height: 200px;
	background: var(--color-ivory-alt);
}

.long-read-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	min-height: 200px;
}

.long-read-card__body {
	padding: 1.25rem 1.5rem 1.5rem;
}

.long-read-card__title {
	font-family: var(--font-display);
	font-size: 1.65rem;
	margin: 0 0 0.5rem;
}

.long-read-card__title a {
	color: var(--color-forest);
	text-decoration: none;
}

.long-read-card__title a:hover {
	color: var(--color-gold);
}

/* Long read: cadeaus + reviews (twee kolommen) */
.long-read-row--gifts-reviews {
	border-top: 1px solid var(--color-border);
	border-bottom: 1px solid var(--color-border);
	background: var(--color-ivory-alt);
	background-image: none;
}

.long-read-row__intro {
	max-width: 42rem;
	margin-bottom: clamp(1.25rem, 3vw, 1.75rem);
}

.long-read-row__section-title {
	font-family: var(--font-display);
	font-size: clamp(1.5rem, 2.5vw, 1.85rem);
	margin: 0 0 0.5rem;
	color: var(--color-forest);
	line-height: 1.2;
}

.long-read-row__section-lead {
	margin: 0;
	font-size: 1rem;
	color: var(--color-muted);
	line-height: 1.5;
}

.long-read-row__duo {
	display: grid;
	gap: clamp(1.75rem, 4vw, 2.5rem);
	grid-template-columns: 1fr;
}

.long-read-row__duo--single {
	max-width: 720px;
}

.long-read-row__col-head {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	justify-content: space-between;
	gap: 0.5rem 1rem;
	margin-bottom: 1rem;
	padding-bottom: 0.65rem;
	border-bottom: 2px solid var(--color-border);
}

.long-read-row__col-title {
	font-family: var(--font-body);
	font-size: 0.78rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	margin: 0;
	color: var(--color-forest);
}

.long-read-row__col-more {
	font-size: 0.85rem;
	font-weight: 600;
	color: var(--color-gold);
	text-decoration: none;
	white-space: nowrap;
}

.long-read-row__col-more:hover,
.long-read-row__col-more:focus-visible {
	text-decoration: underline;
}

.long-read-card--review .long-read-card__meta-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.5rem 0.75rem;
	margin-bottom: 0.45rem;
}

.long-read-card__merk {
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--color-muted);
}

.long-read-card__stars {
	font-size: 0.95rem;
	line-height: 1;
	color: var(--color-gold);
}

/* —— Newsletter —— */
.newsletter-cta {
	background: var(--color-forest);
	color: var(--color-warm-white);
	padding: clamp(2.5rem, 5vw, 4rem) clamp(1rem, 4vw, 1.5rem);
	border-top: 3px solid var(--color-gold);
}

.newsletter-cta__inner {
	max-width: 720px;
	margin: 0 auto;
	text-align: center;
}

.newsletter-cta__title {
	font-family: var(--font-display);
	font-size: clamp(1.75rem, 3vw, 2.25rem);
	margin: 0 0 0.75rem;
	color: var(--color-warm-white);
}

.newsletter-cta__lead {
	font-size: 1.05rem;
	opacity: 0.9;
	margin: 0 0 1.5rem;
}

.newsletter-cta__form {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	justify-content: center;
}

.newsletter-cta__form input[type="email"] {
	flex: 1;
	min-width: 200px;
	padding: 0.85rem 1rem;
	border: 1px solid rgba(255, 255, 255, 0.25);
	border-radius: var(--radius-sm);
	background: rgba(255, 255, 255, 0.08);
	color: var(--color-warm-white);
	font-family: var(--font-body);
}

.newsletter-cta__form input::placeholder {
	color: rgba(255, 255, 255, 0.5);
}

.newsletter-cta__form button,
.newsletter-cta__form .newsletter-cta__btn {
	padding: 0.85rem 1.75rem;
	background: var(--color-gold);
	color: var(--color-forest);
	border: none;
	border-radius: var(--radius-sm);
	font-weight: 700;
	cursor: pointer;
	font-family: var(--font-body);
}

/* Mailster / andere shortcode-formulieren op de groene band */
.newsletter-cta__form--shortcode .mailster-form,
.newsletter-cta__form--shortcode form {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	justify-content: center;
	align-items: stretch;
	width: 100%;
	max-width: 520px;
	margin: 0 auto;
	text-align: left;
}

.newsletter-cta__form--shortcode .mailster-form-fields,
.newsletter-cta__form--shortcode .mailster-field {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	flex: 1 1 auto;
	align-items: stretch;
	justify-content: center;
	min-width: 0;
}

.newsletter-cta__form--shortcode input[type="email"],
.newsletter-cta__form--shortcode input[type="text"],
.newsletter-cta__form--shortcode input[type="tel"] {
	flex: 1 1 200px;
	min-width: min(100%, 200px);
	padding: 0.85rem 1rem;
	border: 1px solid rgba(255, 255, 255, 0.35);
	border-radius: var(--radius-sm);
	background: rgba(255, 255, 255, 0.12);
	color: var(--color-warm-white);
	font-family: var(--font-body);
	font-size: 1rem;
}

.newsletter-cta__form--shortcode input::placeholder {
	color: rgba(255, 255, 255, 0.55);
}

.newsletter-cta__form--shortcode input[type="submit"],
.newsletter-cta__form--shortcode button[type="submit"],
.newsletter-cta__form--shortcode .submit-button,
.newsletter-cta__form--shortcode .mailster-submit {
	padding: 0.85rem 1.5rem;
	background: var(--color-gold);
	color: var(--color-forest);
	border: none;
	border-radius: var(--radius-sm);
	font-weight: 700;
	font-family: var(--font-body);
	cursor: pointer;
	transition: filter 0.2s ease, transform 0.15s ease;
}

.newsletter-cta__form--shortcode input[type="submit"]:hover,
.newsletter-cta__form--shortcode button[type="submit"]:hover,
.newsletter-cta__form--shortcode .mailster-submit:hover {
	filter: brightness(1.05);
}

.newsletter-cta__form--shortcode .mc4wp-form,
.newsletter-cta__form--shortcode .fluentform {
	width: 100%;
	max-width: 520px;
	margin: 0 auto;
}

/* —— Affiliate box —— */
.affiliate-box {
	border: 2px solid var(--color-gold);
	border-radius: var(--radius-md);
	background: var(--color-ivory);
	overflow: hidden;
	margin: 1.5rem 0;
}

.affiliate-box__head {
	background: var(--color-forest);
	color: var(--color-warm-white);
	padding: 0.65rem 1rem;
	font-size: 0.85rem;
	font-weight: 700;
}

.affiliate-box__body {
	padding: 1rem 1.15rem 1.25rem;
}

.affiliate-box__merchant {
	font-size: 0.8rem;
	color: var(--color-muted);
	margin: 0 0 0.35rem;
}

.affiliate-box__title {
	font-family: var(--font-display);
	font-size: 1.25rem;
	margin: 0 0 0.75rem;
	color: var(--color-forest);
}

.affiliate-box__price {
	font-weight: 700;
	margin-bottom: 0.75rem;
	color: var(--color-text);
}

.affiliate-box__cta {
	display: inline-flex;
	padding: 0.65rem 1.25rem;
	background: var(--color-forest);
	color: var(--color-warm-white) !important;
	text-decoration: none;
	border-radius: var(--radius-sm);
	font-weight: 600;
	font-size: 0.9rem;
}

.affiliate-box__cta:hover {
	background: var(--color-forest-light);
	color: var(--color-warm-white) !important;
}

/* —— TOC —— */
.toc-sidebar {
	display: none;
}

.toc-box {
	position: sticky;
	top: 5.75rem;
	background: var(--color-warm-white);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: 1.35rem 1.25rem 1.25rem;
	font-size: 0.9rem;
	box-shadow: var(--shadow-soft);
}

.toc-box::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	border-radius: var(--radius-md) var(--radius-md) 0 0;
	background: linear-gradient(90deg, var(--color-gold), rgba(201, 149, 58, 0.35));
}

.toc-box__title {
	font-family: var(--font-display);
	font-size: 0.8rem;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--color-muted);
	margin: 0 0 1rem;
	padding-bottom: 0.65rem;
	border-bottom: 1px solid var(--color-border);
}

.toc-box ol {
	margin: 0;
	padding-left: 0;
	list-style: none;
	counter-reset: toc-i;
}

.toc-box ol li {
	counter-increment: toc-i;
	margin-bottom: 0.4rem;
	padding-left: 1.5rem;
	position: relative;
}

.toc-box ol li::before {
	content: counter(toc-i) ".";
	position: absolute;
	left: 0;
	top: 0;
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--color-gold);
}

.toc-box a {
	color: var(--color-forest);
	text-decoration: none;
	line-height: 1.45;
	transition: color 0.2s ease;
}

.toc-box a:hover {
	color: var(--color-gold);
}

/* —— Archive / category —— */
.archive-hero {
	position: relative;
	min-height: 220px;
	display: flex;
	align-items: flex-end;
	color: var(--color-warm-white);
}

.archive-hero__bg {
	position: absolute;
	inset: 0;
	background: var(--color-forest);
}

.archive-hero__bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: 0.45;
}

.archive-hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(30, 58, 47, 0.72) 0%, rgba(30, 58, 47, 0.88) 45%, rgba(22, 40, 34, 0.96) 100%);
}

.archive-hero__inner {
	position: relative;
	z-index: 1;
	max-width: var(--content-max);
	width: 100%;
	margin: 0 auto;
	padding: 2rem clamp(1rem, 4vw, 1.5rem);
}

/* Broodkruimels — basis */
.breadcrumbs {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.35rem 0.5rem;
	font-family: var(--font-body);
	font-size: 0.8125rem;
	line-height: 1.45;
	margin: 0 0 1rem;
	letter-spacing: 0.01em;
}

.breadcrumbs__sep {
	color: var(--color-muted);
	opacity: 0.45;
	font-weight: 400;
	user-select: none;
	font-size: 0.7rem;
}

/* Lijntje onder, geen kaart — redactioneel rustig */
.breadcrumbs--panel {
	max-width: 100%;
	padding: 0 0 0.75rem;
	margin: 0 0 1.25rem;
	background: transparent;
	border: none;
	border-radius: 0;
	box-shadow: none;
	border-bottom: 1px solid var(--color-border);
}

.breadcrumbs--panel .breadcrumbs__sep {
	color: var(--color-muted);
	opacity: 0.4;
	font-size: 0.7rem;
}

.breadcrumbs--panel a {
	color: var(--color-forest);
	text-decoration: none;
	font-weight: 500;
}

.breadcrumbs--panel a:hover,
.breadcrumbs--panel a:focus-visible {
	color: var(--color-gold);
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
}

.breadcrumbs--panel .breadcrumbs__current {
	color: var(--color-muted);
	font-weight: 500;
	max-width: 100%;
	line-height: 1.35;
}

/* —— Standaard pagina’s (page.php) —— */
.single-shell {
	max-width: var(--content-max);
	margin: 0 auto;
	padding: clamp(0.35rem, 1.5vw, 0.75rem) clamp(1rem, 4vw, 1.5rem) clamp(1.25rem, 3vw, 2rem);
	box-sizing: border-box;
}

.single-shell--page {
	padding-top: 0;
}

.single-shell__surface {
	background: var(--color-warm-white);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-page);
	overflow: hidden;
}

.page-article {
	max-width: var(--content-max);
	margin: 0 auto;
	padding: clamp(1.75rem, 4vw, 3rem) clamp(1.35rem, 4vw, 2.5rem) clamp(2.25rem, 4vw, 3.25rem);
}

.page-article .entry-header {
	margin-bottom: 0;
	max-width: none;
	width: 100%;
}

.entry-title--page {
	font-family: var(--font-display);
	font-size: clamp(1.85rem, 4.2vw, 2.5rem);
	font-weight: 700;
	line-height: 1.12;
	margin: 0 0 clamp(1.15rem, 3vw, 1.65rem);
	letter-spacing: -0.03em;
	color: var(--color-forest);
	padding-bottom: 0.75rem;
	border-bottom: 1px solid rgba(201, 149, 58, 0.4);
}

.page-featured-media {
	max-width: none;
	width: 100%;
	margin: 0 0 clamp(1.35rem, 3vw, 1.85rem);
	border-radius: var(--radius-md);
	overflow: hidden;
	line-height: 0;
	border: 1px solid rgba(232, 224, 212, 0.95);
	box-shadow: var(--shadow-page);
}

.page-featured-media__img {
	width: 100%;
	height: auto;
	display: block;
	vertical-align: top;
}

.page-article .entry-content {
	font-family: var(--font-body);
	font-size: 1.0625rem;
	line-height: 1.75;
	color: var(--color-text);
	max-width: 100%;
}

/* Gutenberg “constrained” / flow: niet smaller dan de pagina-shell */
body.page .page-article .entry-content :where(.wp-block-group.is-layout-constrained) {
	max-width: 100%;
}

/* Pagina: zelfde bruikbare breedte als shell / grids (geen smalle 42rem-kolom) */
.page-article .entry-content > p,
.page-article .entry-content > .wp-block-separator {
	max-width: none;
	margin-left: 0;
	margin-right: 0;
}

.page-article .entry-content > *:first-child {
	margin-top: 0;
}

.page-article .entry-content > p {
	margin-bottom: 1.35rem;
}

.page-article .entry-content > .envira-gallery-wrap,
.page-article .entry-content > .wp-block-gallery,
.page-article .entry-content > .wp-block-media-text,
.page-article .entry-content > .alignwide {
	max-width: none;
	width: 100%;
	margin-left: 0;
	margin-right: 0;
}

.page-article .entry-content .wp-block-group:not(.alignfull) .envira-gallery-wrap {
	max-width: none;
}

/* Envira Gallery: volle breedte binnen de pagina-shell, rustigere cellen */
.page-article .entry-content .envira-gallery-wrap {
	margin-top: clamp(1.25rem, 3vw, 1.85rem);
	margin-bottom: clamp(1.75rem, 4vw, 2.5rem);
	clear: both;
}

.page-article .envira-gallery-public {
	border-radius: var(--radius-md);
	background: rgba(30, 58, 47, 0.02);
	border: 1px solid rgba(232, 224, 212, 0.85);
	padding: clamp(0.5rem, 1.5vw, 0.85rem);
	box-sizing: border-box;
}

.page-article .envira-gallery-item-inner {
	border-radius: 6px;
	overflow: hidden;
}

.page-article .envira-gallery-item img {
	display: block;
	width: 100%;
	height: auto;
	vertical-align: top;
}

/* Print-knop per thumb: klein en niet visueel domineren */
.page-article .envira-printing-button {
	opacity: 0.85;
}

.page-article .envira-printing-button a {
	font-size: 0.65rem !important;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	padding: 0.2rem 0.45rem;
	border-radius: 4px;
	background: rgba(250, 249, 245, 0.92);
	border: 1px solid rgba(30, 58, 47, 0.12);
	color: var(--color-forest) !important;
	text-decoration: none !important;
}

.page-article .envira-printing-button a:hover {
	border-color: rgba(201, 149, 58, 0.45);
	color: var(--color-gold) !important;
}

@media (max-width: 600px) {
	.page-article .envira-gallery-public[class*="envira-gallery-"][class*="-columns"] .envira-gallery-item {
		padding-left: 4px !important;
		padding-right: 4px !important;
		padding-bottom: 12px !important;
	}
}

.page-article .entry-content h2 {
	font-family: var(--font-display);
	font-size: clamp(1.3rem, 2.5vw, 1.55rem);
	font-weight: 700;
	max-width: none;
	margin: 2rem 0 0.65rem;
	line-height: 1.22;
	color: var(--color-forest);
}

.page-article .entry-content h3 {
	font-family: var(--font-display);
	font-size: clamp(1.1rem, 2vw, 1.28rem);
	font-weight: 700;
	max-width: none;
	margin: 1.5rem 0 0.5rem;
	color: var(--color-forest);
}

.page-article .entry-content > ul,
.page-article .entry-content > ol {
	max-width: none;
	margin: 0 0 1.25rem;
	padding-left: 1.35rem;
	box-sizing: border-box;
}

.page-article .entry-content ul ul,
.page-article .entry-content ol ol,
.page-article .entry-content li > ul,
.page-article .entry-content li > ol {
	max-width: none;
	margin-left: 0;
}

.page-article .entry-content li {
	margin-bottom: 0.4rem;
}

.page-article .entry-content blockquote {
	font-family: var(--font-display);
	font-style: italic;
	color: var(--color-gold);
	border-left: 3px solid rgba(201, 149, 58, 0.45);
	max-width: none;
	margin: 1.5rem 0;
	padding: 0.25rem 0 0.25rem 1.15rem;
	box-sizing: border-box;
}

.page-article .entry-content .wp-block-group,
.page-article .entry-content .wp-block-columns {
	margin-bottom: 1.5rem;
}

.page-links {
	margin-top: 2rem;
	padding-top: 1.25rem;
	border-top: 1px solid var(--color-border);
	font-size: 0.9rem;
	color: var(--color-muted);
}

/* Op categorie-banner (donker): lichte tekst */
.archive-hero .breadcrumbs--hero {
	margin-bottom: 0.75rem;
	padding: 0;
	background: none;
	border: none;
	box-shadow: none;
	font-size: 0.8125rem;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.archive-hero .breadcrumbs--hero .breadcrumbs__sep {
	color: rgba(255, 255, 255, 0.45);
	opacity: 1;
	font-size: 0.75rem;
}

.archive-hero .breadcrumbs--hero a {
	color: rgba(255, 255, 255, 0.88);
	font-weight: 500;
	text-decoration: none;
}

.archive-hero .breadcrumbs--hero a:hover {
	color: var(--color-gold);
}

.archive-hero .breadcrumbs--hero .breadcrumbs__current {
	color: rgba(255, 255, 255, 0.55);
	font-weight: 500;
	text-transform: none;
	letter-spacing: normal;
}

.archive-hero__title {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: clamp(1.65rem, 5.5vw, 2.75rem);
	line-height: 1.12;
	letter-spacing: -0.02em;
	color: var(--color-warm-white);
	margin: 0 0 0.5rem;
	max-width: 100%;
	overflow-wrap: anywhere;
	word-wrap: break-word;
	text-shadow:
		0 1px 2px rgba(0, 0, 0, 0.55),
		0 2px 20px rgba(0, 0, 0, 0.35);
}

.archive-hero__desc {
	margin: 0;
	max-width: 42rem;
	opacity: 0.9;
	line-height: 1.6;
}

.filter-bar {
	position: static;
	background: var(--color-ivory);
	border-bottom: 1px solid var(--color-border);
	padding: 0.75rem 0;
}

.filter-bar__inner {
	max-width: var(--content-max);
	margin: 0 auto;
	padding-left: clamp(1rem, 4vw, 1.5rem);
	padding-right: clamp(1rem, 4vw, 1.5rem);
	width: 100%;
	box-sizing: border-box;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.75rem;
}

.filter-bar__label {
	font-size: 0.8rem;
	font-weight: 600;
	color: var(--color-muted);
}

.filter-bar select,
.filter-bar a {
	font-family: var(--font-body);
	font-size: 0.9rem;
}

.filter-bar__links {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 1rem;
}

.filter-bar__links a {
	text-decoration: none;
	color: var(--color-forest);
	padding: 0.35rem 0;
	border-bottom: 2px solid transparent;
}

.filter-bar__links a.is-active,
.filter-bar__links a:hover {
	border-bottom-color: var(--color-gold);
	color: var(--color-gold);
}

.post-grid {
	display: grid;
	gap: 1.5rem;
	grid-template-columns: 1fr;
}

/* —— Single layout —— */
.single-layout {
	max-width: var(--content-max);
	margin: 0 auto;
	padding: 0 clamp(1rem, 4vw, 1.5rem) 3rem;
	display: grid;
	gap: 2rem;
	grid-template-columns: 1fr;
	align-items: start;
}

.site-main--single .single-layout {
	padding-bottom: 1.5rem;
}

/* Uitgelichte afbeelding: beperkt i.v.m. boven de fold (was 90vh/900px) */
.single-hero {
	margin: 0 0 1.5rem;
	border-radius: var(--radius-md);
	overflow: hidden;
	max-height: min(42vh, 400px);
}

.single-hero img,
.single-hero .single-hero__img {
	width: 100%;
	height: min(42vh, 400px);
	max-height: min(42vh, 400px);
	display: block;
	object-fit: cover;
	object-position: center;
}

/* Single post: hero + artikel als één kaart (broodkruimels: eigen grid-cel; afstand via .single-layout gap) */
.site-main--single .single-layout__breadcrumbs.breadcrumbs--panel {
	margin: 0;
}

.site-main--single .single-layout__main > .single-hero {
	margin: 0;
	border: 1px solid var(--color-border);
	border-bottom: none;
	border-radius: var(--radius-lg) var(--radius-lg) 0 0;
	overflow: hidden;
	background: var(--color-ivory-alt);
}

.site-main--single .single-layout__main > .single-article {
	position: relative;
	margin: 0;
	margin-top: -1px;
	padding: clamp(1.5rem, 3.5vw, 2.35rem) clamp(1.25rem, 3vw, 2rem) clamp(2.5rem, 5vw, 3.5rem);
	background: var(--color-warm-white);
	border: 1px solid var(--color-border);
	border-radius: 0 0 var(--radius-lg) var(--radius-lg);
	box-shadow: var(--shadow-page);
}

.site-main--single .single-layout__main > .single-article .entry-header,
.site-main--single .single-layout__main > .single-article .entry-meta--readtime,
.site-main--single .single-layout__main > .single-article .entry-content,
.site-main--single .single-layout__main > .single-article .kerstmarkt-tips,
.site-main--single .single-layout__main > .single-article .kerstmarkt-infobox,
.site-main--single .single-layout__main > .single-article .author-bio,
.site-main--single .single-layout__main > .single-article #comments,
.site-main--single .single-layout__main > .single-article .comment-respond {
	max-width: 45rem;
	margin-left: auto;
	margin-right: auto;
}

.entry-header .entry-title {
	font-size: clamp(2rem, 4vw, 3rem);
	margin: 0 0 0.5rem;
}

.entry-content a {
	color: var(--color-forest);
	text-decoration: underline;
	text-decoration-color: var(--color-gold);
	text-underline-offset: 3px;
}

.entry-content a:hover {
	color: var(--color-gold);
}

/* Afbeeldingen: onderschrift (Gutenberg “Onderschrift” / klassieke wp-caption) — apart van alt-tekst */
.entry-content figure:has(figcaption) {
	margin-top: 0;
	margin-bottom: 1.75rem;
}

.entry-content .wp-block-image figcaption,
.entry-content .wp-element-caption,
.entry-content .wp-caption .wp-caption-text,
.entry-content figure:not(.wp-block-gallery) figcaption {
	display: block;
	margin: 0.4rem 0 0;
	padding: 0.2rem 0 0 0.55rem;
	font-family: var(--font-body);
	font-size: 0.75rem;
	font-weight: 400;
	font-style: normal;
	line-height: 1.45;
	letter-spacing: 0.03em;
	color: var(--color-muted);
	border-left: 2px solid rgba(201, 149, 58, 0.38);
	background: transparent;
	border-radius: 0;
	max-width: 42rem;
}

.entry-content .wp-caption {
	margin-bottom: 1.75rem;
	max-width: 100%;
}

.entry-content .wp-caption img {
	border-radius: var(--radius-sm);
}

.entry-content .blocks-gallery-item__caption {
	font-family: var(--font-body);
	font-size: 0.8rem;
	line-height: 1.4;
	color: var(--color-warm-white);
	background: linear-gradient(0deg, rgba(30, 58, 47, 0.88) 0%, transparent 100%);
	padding: 2rem 0.65rem 0.5rem;
}

/* —— Sidebar kolom (single + archief) —— */
.single-layout__sidebar,
.content-layout__sidebar {
	display: flex;
	flex-direction: column;
	gap: clamp(1.35rem, 2.5vw, 1.85rem);
}

.archive-sidebar {
	display: flex;
	flex-direction: column;
	gap: clamp(1.35rem, 2.5vw, 1.85rem);
	min-width: 0;
	width: 100%;
}

.archive-sidebar__wp-widgets {
	display: flex;
	flex-direction: column;
	gap: clamp(1.35rem, 2.5vw, 1.85rem);
}

/* Zoek-widget (klassiek + blok) in archief-sidebar */
.content-layout__sidebar .widget_search .search-form,
.archive-sidebar .widget_search .search-form {
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	gap: 0.5rem;
}

.content-layout__sidebar .widget_search .search-form__input,
.archive-sidebar .widget_search .search-form__input {
	flex: 1 1 8rem;
	min-width: 0;
	padding: 0.55rem 0.75rem;
	font-family: var(--font-body);
	font-size: 0.92rem;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	background: var(--color-warm-white);
}

.content-layout__sidebar .widget_search .search-form__submit,
.archive-sidebar .widget_search .search-form__submit {
	flex: 0 0 auto;
	padding: 0.55rem 1rem;
	font-family: var(--font-body);
	font-size: 0.88rem;
	font-weight: 600;
	cursor: pointer;
	border: 1px solid var(--color-forest);
	border-radius: var(--radius-sm);
	background: var(--color-forest);
	color: var(--color-warm-white);
	transition: background 0.2s ease, border-color 0.2s ease;
}

.content-layout__sidebar .widget_search .search-form__submit:hover,
.archive-sidebar .widget_search .search-form__submit:hover {
	background: var(--color-forest-light);
	border-color: var(--color-forest-light);
}

.single-layout__sidebar .sidebar-widget,
.content-layout__sidebar .widget,
.content-layout__sidebar .sidebar-widget {
	position: relative;
	background: var(--color-warm-white);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: 1.4rem 1.35rem 1.25rem;
	box-shadow: var(--shadow-soft);
}

.single-layout__sidebar .sidebar-widget::before,
.content-layout__sidebar .widget::before,
.content-layout__sidebar .sidebar-widget::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	border-radius: var(--radius-md) var(--radius-md) 0 0;
	background: linear-gradient(90deg, var(--color-gold), rgba(201, 149, 58, 0.35));
}

.sidebar-widget__title,
.content-layout__sidebar .widget-title {
	font-family: var(--font-display);
	font-size: 1.2rem;
	font-weight: 600;
	color: var(--color-forest);
	margin: 0 0 1rem;
	padding-bottom: 0.7rem;
	border-bottom: 1px solid var(--color-border);
	letter-spacing: -0.02em;
	line-height: 1.2;
}

.widget-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.widget-list li {
	margin: 0;
	font-size: 0.92rem;
	line-height: 1.45;
	border-bottom: 1px solid rgba(232, 224, 212, 0.9);
}

.widget-list li:last-child {
	border-bottom: none;
}

.widget-list a {
	display: block;
	padding: 0.7rem 0;
	color: var(--color-text);
	text-decoration: none;
	transition: color 0.2s ease, transform 0.2s ease;
}

.widget-list a:hover {
	color: var(--color-gold);
	transform: translateX(2px);
}

/* Populair: genummerde rang */
.widget-list--ranked {
	counter-reset: side-rank;
}

.widget-list--ranked li {
	padding-left: 2.15rem;
	position: relative;
	border-bottom-color: rgba(232, 224, 212, 0.65);
}

.widget-list--ranked li::before {
	content: counter(side-rank);
	counter-increment: side-rank;
	position: absolute;
	left: 0;
	top: 0.65rem;
	min-width: 1.4rem;
	height: 1.4rem;
	padding: 0 0.25rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-family: var(--font-body);
	font-size: 0.68rem;
	font-weight: 700;
	color: var(--color-warm-white);
	background: var(--color-forest);
	border-radius: 3px;
	line-height: 1;
}

.content-layout__sidebar .widget ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.content-layout__sidebar .widget li {
	border-bottom: 1px solid rgba(232, 224, 212, 0.9);
}

.content-layout__sidebar .widget li:last-child {
	border-bottom: none;
}

.content-layout__sidebar .widget a {
	display: block;
	padding: 0.65rem 0;
	color: var(--color-text);
	text-decoration: none;
	font-size: 0.92rem;
	transition: color 0.2s ease;
}

.content-layout__sidebar .widget a:hover {
	color: var(--color-gold);
}

/* Blok-widgets: ruimte tussen titel, zoekveld en lijsten (voorkomt “plakken”) */
.content-layout__sidebar .widget_block .wp-block-group__inner-container,
.single-layout__sidebar .widget_block .wp-block-group__inner-container,
#secondary.sidebar .widget_block .wp-block-group__inner-container {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.content-layout__sidebar .wp-block-search,
.single-layout__sidebar .wp-block-search,
#secondary.sidebar .wp-block-search {
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
	width: 100%;
}

.content-layout__sidebar .wp-block-search .wp-block-search__label,
.single-layout__sidebar .wp-block-search .wp-block-search__label,
#secondary.sidebar .wp-block-search .wp-block-search__label {
	display: block;
	margin: 0;
	font-family: var(--font-display);
	font-size: 1.05rem;
	font-weight: 600;
	color: var(--color-forest);
	line-height: 1.25;
}

.content-layout__sidebar .wp-block-search .wp-block-search__inside-wrapper,
.single-layout__sidebar .wp-block-search .wp-block-search__inside-wrapper,
#secondary.sidebar .wp-block-search .wp-block-search__inside-wrapper {
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	gap: 0.5rem;
	width: 100%;
}

.content-layout__sidebar .wp-block-search .wp-block-search__input,
.single-layout__sidebar .wp-block-search .wp-block-search__input,
#secondary.sidebar .wp-block-search .wp-block-search__input {
	flex: 1 1 8rem;
	min-width: 0;
	padding: 0.55rem 0.75rem;
	font-size: 0.9rem;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	background: var(--color-warm-white);
}

.content-layout__sidebar .wp-block-search .wp-block-search__button,
.single-layout__sidebar .wp-block-search .wp-block-search__button,
#secondary.sidebar .wp-block-search .wp-block-search__button {
	flex: 0 0 auto;
	padding: 0.55rem 1rem;
	font-size: 0.85rem;
	font-weight: 600;
	border-radius: var(--radius-sm);
	cursor: pointer;
}

/* —— Sidebar: widgets met thumbnails (o.a. “Meer Kerstinspiratie”) —— */
.single-layout__sidebar .widget,
#secondary.sidebar .widget {
	padding: 1.5rem 1.4rem 1.4rem;
}

.single-layout__sidebar .widget .widget-title,
#secondary.sidebar .widget .widget-title {
	margin-bottom: 1.1rem;
}

.single-layout__sidebar .widget ul:not(.wp-block-latest-posts),
#secondary.sidebar .widget ul:not(.wp-block-latest-posts),
.content-layout__sidebar .widget ul:not(.wp-block-latest-posts) {
	display: flex;
	flex-direction: column;
	gap: 0;
}

.single-layout__sidebar .widget ul:not(.wp-block-latest-posts) > li,
#secondary.sidebar .widget ul:not(.wp-block-latest-posts) > li,
.content-layout__sidebar .widget ul:not(.wp-block-latest-posts) > li {
	margin: 0;
	padding: 1rem 0;
	border-bottom: 1px solid rgba(232, 224, 212, 0.95);
}

.single-layout__sidebar .widget ul:not(.wp-block-latest-posts) > li:first-child,
#secondary.sidebar .widget ul:not(.wp-block-latest-posts) > li:first-child,
.content-layout__sidebar .widget ul:not(.wp-block-latest-posts) > li:first-child {
	padding-top: 0.25rem;
}

.single-layout__sidebar .widget ul:not(.wp-block-latest-posts) > li:last-child,
#secondary.sidebar .widget ul:not(.wp-block-latest-posts) > li:last-child,
.content-layout__sidebar .widget ul:not(.wp-block-latest-posts) > li:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

/* Items met afbeelding: extra ruimte + “kaart”-gevoel (niet: Gutenberg latest posts; die hebben eigen gap) */
.single-layout__sidebar .widget ul:not(.wp-block-latest-posts) li:has(img),
#secondary.sidebar .widget ul:not(.wp-block-latest-posts) li:has(img),
.content-layout__sidebar .widget ul:not(.wp-block-latest-posts) li:has(img) {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	padding: 1.1rem 0;
}

.single-layout__sidebar .widget ul:not(.wp-block-latest-posts) li:has(img):not(:last-child),
#secondary.sidebar .widget ul:not(.wp-block-latest-posts) li:has(img):not(:last-child),
.content-layout__sidebar .widget ul:not(.wp-block-latest-posts) li:has(img):not(:last-child) {
	margin-bottom: 0.15rem;
}

.single-layout__sidebar .widget li img,
#secondary.sidebar .widget li img,
.content-layout__sidebar .widget li img {
	width: 100% !important;
	max-width: 100%;
	height: auto !important;
	aspect-ratio: 16 / 10;
	object-fit: cover;
	border-radius: var(--radius-md);
	display: block;
	box-shadow: 0 2px 16px rgba(30, 58, 47, 0.1);
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

@supports not (aspect-ratio: 1) {
	.single-layout__sidebar .widget li img,
	#secondary.sidebar .widget li img,
	.content-layout__sidebar .widget li img {
		min-height: 120px;
	}
}

.single-layout__sidebar .widget li a:has(img),
#secondary.sidebar .widget li a:has(img),
.content-layout__sidebar .widget li a:has(img) {
	display: block;
	line-height: 0;
	border-radius: var(--radius-md);
	overflow: hidden;
	padding: 0 !important;
	margin: 0;
}

.single-layout__sidebar .widget li a:has(img):hover img,
#secondary.sidebar .widget li a:has(img):hover img,
.content-layout__sidebar .widget li a:has(img):hover img {
	transform: scale(1.02);
	box-shadow: 0 8px 28px rgba(30, 58, 47, 0.16);
}

/* Titelregels: geen standaard underline, redactioneel */
.single-layout__sidebar .widget li a,
#secondary.sidebar .widget li a,
.content-layout__sidebar .widget li a {
	text-decoration: none !important;
	text-underline-offset: unset;
	font-weight: 500;
	line-height: 1.45;
}

.single-layout__sidebar .widget li > a:not(:has(img)),
#secondary.sidebar .widget li > a:not(:has(img)),
.content-layout__sidebar .widget li > a:not(:has(img)),
.single-layout__sidebar .widget li a.wp-block-latest-posts__post-title,
#secondary.sidebar .widget li a.wp-block-latest-posts__post-title,
.content-layout__sidebar .widget li a.wp-block-latest-posts__post-title {
	font-family: var(--font-body);
	font-size: 0.95rem;
	color: var(--color-forest);
	padding: 0;
	display: block;
}

.single-layout__sidebar .widget li > a:not(:has(img)):hover,
#secondary.sidebar .widget li > a:not(:has(img)):hover,
.content-layout__sidebar .widget li > a:not(:has(img)):hover {
	color: var(--color-gold);
	transform: none;
}

/* Gutenberg latest posts in sidebar */
.single-layout__sidebar .wp-block-latest-posts.is-grid,
#secondary.sidebar .wp-block-latest-posts.is-grid {
	display: flex;
	flex-direction: column;
	gap: 0;
}

.content-layout__sidebar .wp-block-latest-posts__featured-image,
.single-layout__sidebar .wp-block-latest-posts__featured-image,
#secondary.sidebar .wp-block-latest-posts__featured-image {
	border-radius: var(--radius-md);
	overflow: hidden;
	margin-bottom: 0;
}

.content-layout__sidebar .wp-block-latest-posts__featured-image img,
.single-layout__sidebar .wp-block-latest-posts__featured-image img,
#secondary.sidebar .wp-block-latest-posts__featured-image img {
	aspect-ratio: 16 / 10;
	object-fit: cover;
}

/* Blok-widget “Laatste berichten” in sidebar: float (alignright) breekt de kolom */
.content-layout__sidebar .wp-block-latest-posts .wp-block-latest-posts__featured-image,
.single-layout__sidebar .wp-block-latest-posts .wp-block-latest-posts__featured-image,
#secondary.sidebar .wp-block-latest-posts .wp-block-latest-posts__featured-image {
	float: none !important;
	clear: both;
	width: 100% !important;
	max-width: 100%;
	margin-left: 0 !important;
	margin-right: 0 !important;
	margin-bottom: 0;
}

.content-layout__sidebar .wp-block-latest-posts,
.single-layout__sidebar .wp-block-latest-posts,
#secondary.sidebar .wp-block-latest-posts {
	display: flex;
	flex-direction: column;
	gap: 0;
	list-style: none;
	margin: 0;
	padding: 0;
}

.content-layout__sidebar .wp-block-latest-posts li,
.single-layout__sidebar .wp-block-latest-posts li,
#secondary.sidebar .wp-block-latest-posts li {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	align-content: flex-start;
	gap: 0.75rem;
	clear: both;
	overflow: hidden;
	margin: 0 0 1.15rem;
	padding: 0 0 1.1rem;
	border-bottom: 1px solid rgba(232, 224, 212, 0.95);
}

.content-layout__sidebar .wp-block-latest-posts li:last-child,
.single-layout__sidebar .wp-block-latest-posts li:last-child,
#secondary.sidebar .wp-block-latest-posts li:last-child {
	margin-bottom: 0;
	padding-bottom: 0;
	border-bottom: none;
}

/* Genummerde variatie (o.a. Cadence) + blokgroep: geen dubbele marge op kop */
.content-layout__sidebar .wp-block-latest-posts.is-style-cs-numbered-layout,
.single-layout__sidebar .wp-block-latest-posts.is-style-cs-numbered-layout,
#secondary.sidebar .wp-block-latest-posts.is-style-cs-numbered-layout {
	list-style: none;
	margin: 0;
	padding: 0;
}

.content-layout__sidebar .widget_block .wp-block-group__inner-container > .wp-block-heading:first-child,
.single-layout__sidebar .widget_block .wp-block-group__inner-container > .wp-block-heading:first-child,
#secondary.sidebar .widget_block .wp-block-group__inner-container > .wp-block-heading:first-child {
	margin-top: 0;
}

.content-layout__sidebar .widget_block .wp-block-heading,
.single-layout__sidebar .widget_block .wp-block-heading,
#secondary.sidebar .widget_block .wp-block-heading {
	font-family: var(--font-display);
	font-size: 1.2rem;
	font-weight: 600;
	color: var(--color-forest);
	margin: 0 0 1rem;
	padding-bottom: 0.7rem;
	border-bottom: 1px solid var(--color-border);
	line-height: 1.2;
}

/* View Transitions — korte, zachte easing (sitebreed) */
::view-transition-group(*),
::view-transition-old(*),
::view-transition-new(*) {
	animation-duration: 0.25s;
	animation-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
}

/* Sidebar: ka-cards (sidebar-related.php op single; tweede blok op sidebar-archive.php) */
.ka-sidebar-related {
	padding: 0;
}

.ka-sidebar-related .sidebar-widget__title {
	margin-bottom: 0.35rem;
}

.ka-sidebar-item {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 0.45rem;
	padding: 0.8rem 0;
	border: none;
	text-decoration: none;
	color: inherit;
}

.ka-sidebar-item + .ka-sidebar-item {
	border-top: 0.5px solid var(--color-border);
}

.ka-sidebar-item:first-of-type {
	padding-top: 0.15rem;
}

/* Chips: zelfde taal als editorial-opener badge */
.ka-sidebar-pill {
	display: inline-block;
	max-width: 100%;
	padding: 5px 10px;
	border-radius: 4px;
	font-family: var(--font-body);
	font-size: 10px;
	font-weight: 500;
	line-height: 1.25;
}

.ka-sidebar-pill--cat {
	background: #f5f0e8;
	color: #8a6c2e;
	letter-spacing: 0.07em;
	text-transform: uppercase;
}

.ka-sidebar-pill--read {
	background: #eef1ec;
	color: #6b7b72;
	letter-spacing: 0.02em;
	text-transform: none;
}

.ka-sidebar-title {
	font-size: 13.5px;
	line-height: 1.3;
	color: var(--color-text);
	font-family: var(--font-display);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.ka-sidebar-item:hover .ka-sidebar-title {
	color: var(--color-gold);
}

.ka-sidebar-all {
	display: inline-block;
	font-size: 12px;
	font-weight: 500;
	color: var(--color-gold);
	font-family: var(--font-body);
	text-decoration: none;
	margin-top: 12px;
}

.ka-sidebar-all:hover,
.ka-sidebar-all:focus-visible {
	text-decoration: underline;
}

/* Plugins: thumbnail in .post-thumbnail / RPWE */
.single-layout__sidebar .widget .post-thumbnail,
.single-layout__sidebar .widget .rpwe-thumb,
#secondary.sidebar .widget .post-thumbnail,
#secondary.sidebar .widget .rpwe-thumb {
	border-radius: var(--radius-md);
	overflow: hidden;
	line-height: 0;
	box-shadow: 0 2px 16px rgba(30, 58, 47, 0.1);
}

.single-layout__sidebar .widget .post-thumbnail img,
.single-layout__sidebar .widget .rpwe-thumb img,
#secondary.sidebar .widget .post-thumbnail img,
#secondary.sidebar .widget .rpwe-thumb img {
	width: 100%;
	aspect-ratio: 16 / 10;
	object-fit: cover;
	border-radius: var(--radius-md);
}

.author-bio {
	margin-top: 2.5rem;
	padding: 1.5rem;
	background: var(--color-ivory-alt);
	border-radius: var(--radius-md);
	border: 1px solid var(--color-border);
}

/* Kerstmarkt infobox */
.kerstmarkt-infobox {
	display: grid;
	gap: 0.75rem;
	grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
	background: var(--color-ivory-alt);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: 1.25rem;
	margin-bottom: 1.5rem;
}

.kerstmarkt-infobox__item dt {
	font-size: 0.7rem;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--color-muted);
	margin: 0;
}

.kerstmarkt-infobox__item dd {
	margin: 0.25rem 0 0;
	font-weight: 600;
	color: var(--color-forest);
}

.kerstmarkt-tips {
	background: var(--color-forest);
	color: var(--color-warm-white);
	padding: 1.25rem 1.5rem;
	border-radius: var(--radius-md);
	margin: 2rem 0;
}

.kerstmarkt-tips h3 {
	color: var(--color-gold);
	margin: 0 0 0.75rem;
	font-size: 1.15rem;
}

.kerstmarkt-tips ul {
	margin: 0;
	padding-left: 1.1rem;
}

/* Search page */
.search-hero {
	padding: 2rem clamp(1rem, 4vw, 1.5rem);
	background: var(--color-ivory-alt);
	border-bottom: 1px solid var(--color-border);
}

.search-hero__form {
	max-width: 560px;
	margin: 1rem auto 0;
}

.search-grid {
	display: grid;
	gap: 1.25rem;
	grid-template-columns: 1fr;
}

.entry-header__cat {
	margin: 0 0 0.5rem;
}

/* Single: categorie + jaartag op één rij boven de titel */
.entry-header__badges {
	margin: 0 0 0.65rem;
	align-items: center;
}

.site-main--single .entry-header__badges.article-card__badges {
	margin-bottom: 0.65rem;
}

.site-main--single .entry-header__badges .article-card__tag--year {
	font-size: 0.6875rem;
	padding: calc(0.35rem - 1px) 0.55rem;
	border-color: rgba(201, 149, 58, 0.5);
	font-family: var(--font-display);
	font-weight: 600;
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.75),
		0 1px 3px rgba(30, 58, 47, 0.08);
}

.entry-meta__cat {
	display: inline-block;
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-warm-white);
	background: var(--color-forest);
	padding: 0.35rem 0.65rem;
	border-radius: 2px;
	text-decoration: none;
}

.entry-meta__cat:hover {
	color: var(--color-gold);
}

/* Single: leestijd onder de titel — zelfde familie als kaart-badge (goud, licht omkaderd) */
.entry-meta--readtime {
	margin: 0.35rem 0 1.5rem;
	font-family: var(--font-body);
}

.entry-meta--readtime .entry-meta__read {
	display: inline-block;
	font-size: 0.75rem;
	font-weight: 600;
	line-height: 1.3;
	letter-spacing: 0.04em;
	color: var(--color-forest);
	background: rgba(201, 149, 58, 0.12);
	border: 1px solid rgba(201, 149, 58, 0.38);
	border-radius: 4px;
	padding: 0.38rem 0.7rem;
	font-variant-numeric: tabular-nums;
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.65),
		0 1px 2px rgba(30, 58, 47, 0.06);
}

.content-layout {
	display: grid;
	gap: 2rem;
	max-width: var(--content-max);
	min-width: 0;
	width: 100%;
	margin-left: auto;
	margin-right: auto;
	box-sizing: border-box;
	align-items: start;
}

.content-layout--sidebar {
	grid-template-columns: 1fr;
}

.related-posts {
	padding: 3rem 0;
	background: var(--color-ivory-alt);
	border-top: 1px solid var(--color-border);
}

.related-posts__title {
	font-size: 1.75rem;
	margin: 0 0 1.5rem;
	text-align: center;
}

.filter-bar__select {
	display: block;
	width: 100%;
	max-width: 280px;
	padding: 0.5rem 0.75rem;
	font-family: var(--font-body);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
}

@media (min-width: 768px) {
	.filter-bar__select {
		display: none;
	}
}

@media (max-width: 767px) {
	.filter-bar__links {
		display: none;
	}

	.filter-bar__inner {
		flex-direction: column;
		align-items: stretch;
		gap: 0.5rem;
	}

	.filter-bar__select {
		max-width: none;
		width: 100%;
		min-height: 2.75rem;
		box-sizing: border-box;
	}
}

/* —— Archive pagination (the_posts_pagination: .navigation.pagination / .nav-links) —— */
.navigation.pagination {
	margin-top: clamp(2rem, 4vw, 2.75rem);
	margin-bottom: 0;
	clear: both;
}

.navigation.pagination .nav-links,
.content-layout__main .nav-links {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 0.4rem 0.55rem;
	margin: 0;
	padding: 0;
	list-style: none;
	font-family: var(--font-body);
}

.navigation.pagination a.page-numbers,
.navigation.pagination span.page-numbers,
.content-layout__main .nav-links a.page-numbers,
.content-layout__main .nav-links span.page-numbers {
	box-sizing: border-box;
	min-width: 2.5rem;
	height: 2.5rem;
	padding: 0 0.35rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 0.9rem;
	font-weight: 600;
	line-height: 1;
	text-decoration: none;
	color: var(--color-forest);
	background: var(--color-warm-white);
	border: 1px solid var(--color-border);
	border-radius: 999px;
	transition:
		color var(--transition),
		background var(--transition),
		border-color var(--transition),
		box-shadow var(--transition);
}

.navigation.pagination a.page-numbers:hover,
.content-layout__main .nav-links a.page-numbers:hover {
	color: var(--color-forest);
	background: rgba(201, 149, 58, 0.1);
	border-color: rgba(201, 149, 58, 0.45);
	box-shadow: 0 1px 0 rgba(255, 255, 255, 0.9) inset;
}

.navigation.pagination a.page-numbers:focus-visible,
.content-layout__main .nav-links a.page-numbers:focus-visible {
	outline: 2px solid var(--color-gold);
	outline-offset: 2px;
}

.navigation.pagination span.page-numbers.dots,
.content-layout__main .nav-links span.page-numbers.dots {
	min-width: auto;
	padding: 0 0.25rem;
	border: none;
	background: transparent;
	color: var(--color-muted);
	font-weight: 500;
}

.navigation.pagination span.page-numbers.current,
.navigation.pagination span.page-numbers[aria-current="page"],
.content-layout__main .nav-links span.page-numbers.current,
.content-layout__main .nav-links span.page-numbers[aria-current="page"] {
	color: var(--color-forest);
	background: rgba(201, 149, 58, 0.18);
	border-color: rgba(201, 149, 58, 0.5);
	box-shadow: none;
	cursor: default;
}

.navigation.pagination a.prev.page-numbers,
.navigation.pagination a.next.page-numbers,
.content-layout__main .nav-links a.prev.page-numbers,
.content-layout__main .nav-links a.next.page-numbers {
	min-width: auto;
	padding: 0 1rem;
	font-weight: 600;
	font-size: 0.85rem;
	letter-spacing: 0.02em;
}

