/* ==========================================================================
   Solida Theme — main.css — v0.1.0
   Sections: Variables · Reset · Layout · Header · Footer · Post cards ·
             Single · Entry content · Post footer · Author · Archive ·
             404 · Buttons · Pagination · Gutenberg blocks · Block patterns ·
             GravityForms · Responsive
   ========================================================================== */

/* --------------------------------------------------------------------------
   Custom Properties
   -------------------------------------------------------------------------- */
:root {
	--color-bg:           #ffffff;
	--color-bg-dark:      #0f1923;
	--color-text:         #1a1a1a;
	--color-text-muted:   #6b7280;
	--color-text-on-dark: rgba(255,255,255,.75);
	--color-border:       #e5e7eb;
	--color-border-dark:  rgba(255,255,255,.12);
	--color-accent:       #3188b9;
	--color-accent-hover: #2571a0;
	--color-orange:       #f5931f;
	--color-orange-hover: #d97d10;
	--color-purple:       #92298f;
	--color-accent-alt:   #f0f7fb;   /* lichte tint van --color-accent */

	--font-sans:   system-ui, -apple-system, 'Segoe UI', sans-serif;
	--font-serif:  Georgia, 'Times New Roman', serif;

	--size-xs:   0.75rem;
	--size-sm:   0.875rem;
	--size-base: 1rem;
	--size-lg:   1.125rem;
	--size-xl:   1.25rem;
	--size-2xl:  1.5rem;
	--size-3xl:  1.875rem;
	--size-4xl:  2.25rem;
	--size-5xl:  3rem;

	--radius-sm: 4px;
	--radius:    8px;
	--radius-lg: 16px;

	--space-1:  0.25rem;
	--space-2:  0.5rem;
	--space-3:  0.75rem;
	--space-4:  1rem;
	--space-6:  1.5rem;
	--space-8:  2rem;
	--space-12: 3rem;
	--space-16: 4rem;
	--space-24: 6rem;

	--container-width: 1200px;
	--content-width:   720px;

	--transition: 180ms ease;

	--header-height: 80px;

	--shadow-sm:   0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.05);
	--shadow-card: 0 4px 16px rgba(0,0,0,.07), 0 1px 4px rgba(0,0,0,.04);
	--shadow-hover: 0 12px 40px rgba(0,0,0,.13), 0 4px 12px rgba(0,0,0,.06);
}

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

/* Lege <p> elementen die ontstaan door ongeldige <p>-in-<p> nesting
   na "attempt block recovery" in Gutenberg — browser sluit buitenste <p>
   automatisch, waardoor een lege <p> met margin overblijft. */
p:empty { display: none !important; margin: 0 !important; padding: 0 !important; }

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

body {
	margin: 0;
	/* Subtiele kleurwolken: blauw rechtsbovenin, paars linksonderin */
	background:
		radial-gradient(ellipse 70% 50% at 95% 2%,  rgba(49,136,185,.045) 0%, transparent 65%),
		radial-gradient(ellipse 60% 40% at 4%  96%,  rgba(146,41,143,.03)  0%, transparent 65%),
		var(--color-bg);
	color: var(--color-text);
	font-family: var(--font-sans);
	font-size: var(--size-base);
	line-height: 1.6;
}

img, video, svg { display: block; max-width: 100%; height: auto; }
a { color: inherit; }
a:focus-visible { outline: 2px solid var(--color-accent); outline-offset: 3px; }

h1, h2, h3, h4, h5, h6 {
	margin: 0 0 var(--space-4);
	line-height: 1.2;
	font-weight: 700;
}

p { margin: 0 0 var(--space-4); }
ul, ol { margin: 0 0 var(--space-4); padding-left: var(--space-6); }

/* --------------------------------------------------------------------------
   Layout
   -------------------------------------------------------------------------- */
.container {
	width: 100%;
	max-width: var(--container-width);
	margin-inline: auto;
	padding-inline: var(--space-6);
}

.site-main { min-height: calc(100vh - var(--header-height)); }

/* --------------------------------------------------------------------------
   Header
   -------------------------------------------------------------------------- */
.site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background: var(--color-bg);
	border-bottom: 1px solid var(--color-border);
	height: var(--header-height);
	transition: box-shadow 280ms ease, border-color 280ms ease;
}

.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: var(--header-height);
	gap: var(--space-8);
}

.site-logo { text-decoration: none; display: flex; align-items: center; flex-shrink: 0; }
.site-logo img { height: 44px; width: auto; }
.site-logo__text { font-weight: 800; font-size: var(--size-xl); letter-spacing: -0.03em; }

/* Primary nav — rechts uitgelijnd */
.site-nav { margin-left: auto; }

.site-nav__list {
	display: flex;
	list-style: none;
	margin: 0;
	padding: 0;
	gap: var(--space-6);
}

.site-nav__list a {
	text-decoration: none;
	font-size: 1rem;
	font-weight: 500;
	letter-spacing: 0.01em;
	color: var(--color-text);
	transition: color var(--transition);
	position: relative;
}

.site-nav__list a::after {
	content: '';
	position: absolute;
	bottom: -4px;
	left: 0;
	right: 0;
	height: 2px;
	background: var(--color-accent);
	transform: scaleX(0);
	transform-origin: left;
	transition: transform var(--transition);
}

.site-nav__list a:hover { color: var(--color-accent); }
.site-nav__list a:hover::after,
.site-nav__list .current-menu-item > a::after,
.site-nav__list .current_page_item > a::after { transform: scaleX(1); }
.site-nav__list .current-menu-item > a,
.site-nav__list .current_page_item > a { color: var(--color-accent); }

/* Header CTA knop */
.nav-cta {
	display: inline-flex;
	align-items: center;
	padding: 0.5rem 1.25rem;
	background: var(--color-orange);
	color: #fff;
	font-size: var(--size-sm);
	font-weight: 600;
	text-decoration: none;
	border-radius: var(--radius-sm);
	white-space: nowrap;
	transition: background var(--transition), transform var(--transition);
	flex-shrink: 0;
}

.nav-cta:hover {
	background: var(--color-orange-hover);
	transform: translateY(-1px);
}

/* Mobiele CTA — alleen zichtbaar in het open mobiele menu */
.nav-cta--mobile { display: none; }

/* Mobile toggle */
.nav-toggle {
	display: none;
	flex-direction: column;
	gap: 5px;
	background: none;
	border: none;
	cursor: pointer;
	padding: var(--space-2);
	flex-shrink: 0;
}

.nav-toggle span {
	display: block;
	width: 24px;
	height: 2px;
	background: var(--color-text);
	transition: transform 220ms ease, opacity 220ms ease;
	transform-origin: center;
}

/* Hamburger → X animatie */
.nav-toggle.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle.is-open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.nav-toggle.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Header: schaduw na scrollen */
.site-header.is-scrolled {
	border-bottom-color: transparent;
	box-shadow: 0 2px 24px rgba(0,0,0,.10);
}

/* Nav-overlay (backdrop) — aangemaakt via JS */
.nav-backdrop {
	position: fixed;
	inset: 0;
	background: rgba(15,25,35,.55);
	z-index: 98;
	opacity: 0;
	visibility: hidden;
	transition: opacity 220ms ease, visibility 220ms ease;
	backdrop-filter: blur(2px);
	-webkit-backdrop-filter: blur(2px);
}

.nav-backdrop.is-visible {
	opacity: 1;
	visibility: visible;
}

/* --------------------------------------------------------------------------
   Footer
   -------------------------------------------------------------------------- */
.site-footer {
	background: linear-gradient(160deg, #0f1923 0%, #0e2840 60%, #0f1923 100%);
	border-top: 3px solid var(--color-accent);
	padding-block: var(--space-16) var(--space-8);
	margin-top: 0;
	color: var(--color-text-on-dark);
	position: relative;
	overflow: hidden;
}

/* Decoratief O-icoon als achtergrond watermark */
.site-footer::before {
	content: '';
	position: absolute;
	right: -80px;
	top: -80px;
	width: 360px;
	height: 360px;
	background: url('../img/Solida-O.png') no-repeat center / contain;
	opacity: .04;
	pointer-events: none;
}

/* Vierkoloms grid */
.site-footer__grid {
	display: grid;
	grid-template-columns: 1.6fr 1fr 1fr 1.2fr;
	gap: var(--space-12);
	padding-bottom: var(--space-12);
	border-bottom: 1px solid var(--color-border-dark);
}

/* Kolom 1: merk */
.site-footer__col--brand { display: flex; flex-direction: column; gap: var(--space-4); }

.footer-logo img { height: 38px; width: auto; }

.footer-tagline {
	margin: 0;
	font-size: var(--size-sm);
	color: var(--color-text-on-dark);
	line-height: 1.65;
	max-width: 240px;
}

.footer-o-icon {
	width: 48px;
	height: 48px;
	opacity: .6;
	margin-top: var(--space-2);
}

/* Kolomtitels */
.footer-col-title {
	font-size: var(--size-xs);
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--color-accent);
	margin: 0 0 var(--space-4);
}

/* Kolomlijsten */
.footer-col__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}

.footer-col__list a {
	text-decoration: none;
	font-size: var(--size-sm);
	color: var(--color-text-on-dark);
	transition: color var(--transition);
}

.footer-col__list a:hover { color: #fff; }

/* Adres */
.footer-address {
	font-style: normal;
	font-size: var(--size-sm);
	color: var(--color-text-on-dark);
	line-height: 1.7;
}

/* Onderste balk */
.site-footer__bottom {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding-top: var(--space-6);
	flex-wrap: wrap;
	gap: var(--space-3);
}

.site-footer__copy { margin: 0; font-size: var(--size-sm); color: rgba(255,255,255,.4); }

.footer-legal-list {
	display: flex;
	list-style: none;
	margin: 0;
	padding: 0;
	gap: var(--space-6);
}

.footer-legal-list a {
	text-decoration: none;
	font-size: var(--size-sm);
	color: rgba(255,255,255,.4);
	transition: color var(--transition);
}

.footer-legal-list a:hover { color: rgba(255,255,255,.75); }

/* --------------------------------------------------------------------------
   Post list / cards
   -------------------------------------------------------------------------- */
.post-list {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(min(100%, 340px), 1fr));
	gap: var(--space-8);
	padding-block: var(--space-12);
}

.post-card {
	display: flex;
	flex-direction: column;
	border: none;
	border-radius: var(--radius);
	overflow: hidden;
	box-shadow: var(--shadow-card);
	transition: box-shadow var(--transition), transform var(--transition);
	background: var(--color-bg);
}

.post-card:hover { box-shadow: var(--shadow-hover); transform: translateY(-3px); }

.post-card__thumb img { width: 100%; aspect-ratio: 16/9; object-fit: cover; }

.post-card__body { padding: var(--space-6); display: flex; flex-direction: column; gap: var(--space-2); flex: 1; }

.post-card__title { margin: 0; font-size: var(--size-xl); }
.post-card__title a { text-decoration: none; }
.post-card__title a:hover { text-decoration: underline; }

.post-card__meta { margin: 0; font-size: var(--size-sm); color: var(--color-text-muted); }
.post-card__excerpt p { margin: 0; font-size: var(--size-sm); color: var(--color-text-muted); }

/* --------------------------------------------------------------------------
   Page hero — titelbalk boven standaardpagina's
   -------------------------------------------------------------------------- */
.page-hero {
	background: linear-gradient(160deg, var(--color-accent-alt) 0%, #fff 65%);
	padding-block: clamp(3rem, 8vh, 5rem) clamp(4rem, 8vh, 6rem); /* extra bottom → uitgelichte afb. zweeft erin */
	position: relative;
	overflow: hidden;
}

/* 'S' watermark verwijderd op verzoek */
.page-hero::after { display: none; }

.page-title {
	font-size: clamp(var(--size-3xl), 5vw, var(--size-5xl));
	font-weight: 800;
	letter-spacing: -0.03em;
	margin: 0;
	text-align: center;
}

/* Gekleurd streepje onder paginatitel — gecentreerd */
.page-title::after {
	content: '';
	display: block;
	width: 44px;
	height: 3px;
	background: linear-gradient(90deg, var(--color-accent) 0%, var(--color-purple) 100%);
	margin-top: 0.75rem;
	border-radius: 2px;
	margin-inline: auto;
}

/* --------------------------------------------------------------------------
   Post hero — titelbalk boven nieuwsartikelen (optioneel met afbeelding)
   -------------------------------------------------------------------------- */
.post-hero {
	padding-block: clamp(3rem, 8vh, 5rem) clamp(2rem, 5vh, 3.5rem);
	background: linear-gradient(160deg, var(--color-accent-alt) 0%, #fff 65%);
	border-bottom: 1px solid var(--color-border);
	position: relative;
	overflow: hidden;
}

/* Variant met featured image als achtergrond */
.post-hero--has-image {
	padding-block: clamp(5rem, 14vh, 9rem);
	background: none;
	border-bottom: none;
}

.post-hero__bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	z-index: 0;
}

.post-hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(160deg, rgba(15,25,35,.78) 0%, rgba(49,136,185,.45) 100%);
	z-index: 1;
}

.post-hero__inner {
	position: relative;
	z-index: 2;
}

.post-hero__meta {
	font-size: var(--size-sm);
	color: var(--color-text-muted);
	margin: 0 0 var(--space-3);
}
.post-hero__meta a { color: inherit; text-decoration: none; }
.post-meta__sep { margin-inline: var(--space-2); }

.post-hero--has-image .post-hero__meta,
.post-hero--has-image .post-hero__meta a { color: rgba(255,255,255,.7); }

.post-title {
	font-size: clamp(var(--size-3xl), 5vw, var(--size-5xl));
	letter-spacing: -0.02em;
	margin: 0;
}

/* Gekleurd streepje onder artikeltitel */
.post-title::after {
	content: '';
	display: block;
	width: 44px;
	height: 3px;
	background: linear-gradient(90deg, var(--color-accent) 0%, var(--color-orange) 100%);
	margin-top: 0.75rem;
	border-radius: 2px;
}

.post-hero--has-image .post-title { color: #fff; }
.post-hero--has-image .post-title::after {
	background: linear-gradient(90deg, rgba(255,255,255,.9) 0%, rgba(255,255,255,.3) 100%);
}

/* --------------------------------------------------------------------------
   Single post / pagina content-area
   -------------------------------------------------------------------------- */
.post-single,
.page-single {
	max-width: var(--container-width);
	margin-inline: auto;
	padding-block: var(--space-8) var(--space-12);
	position: relative;
	isolation: isolate;
}

/* Pagina's: schone content-area, geen kaartje — gewoon lopende tekst */
.page-single {
	padding-block: var(--space-12) var(--space-16);
	margin-bottom: var(--space-8);
}

/* --------------------------------------------------------------------------
   Uitgelichte afbeelding op standaardpagina's (page.php)
   Hangt in de hero-band, content loopt er gewoon onder door
   -------------------------------------------------------------------------- */
.page-thumbnail {
	position: relative;
	z-index: 2;
	margin-top: -2.5rem; /* zweeft in de hero-band */
}

.page-thumbnail__img {
	display: block;
	width: 100%;
	max-height: 520px;
	aspect-ratio: 16 / 6;
	object-fit: cover;
	object-position: center;
	border-radius: 1.5rem;
	box-shadow: 0 20px 60px rgba(0,0,0,.16), 0 4px 16px rgba(0,0,0,.07);
}

/* Mét afbeelding: content begint met wat lucht onder de foto */
.has-post-thumbnail .page-single { padding-top: var(--space-10); }

/* Zachte gloed op artikelen (post-single) */
.post-single::before {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(ellipse 120% 35% at 50% 55%, rgba(49,136,185,.04) 0%, transparent 70%);
	pointer-events: none;
	z-index: -1;
}

/* --------------------------------------------------------------------------
   Entry content (Gutenberg)
   -------------------------------------------------------------------------- */
.entry-content {
	font-size: var(--size-lg);
	line-height: 1.75;
}

.entry-content > * { max-width: var(--content-width); margin-inline: auto; }
.entry-content > .alignwide { max-width: calc(var(--content-width) + 200px); }
.entry-content > .alignfull { max-width: 100%; margin-inline: 0; }
/* Kolommen in pagina-content: ruime tussenruimte.
   Gutenberg stelt de gap in via --wp--style--block-gap (inline CSS-variabele) —
   we overschrijven die variabele én de gap-property zelf.
   Let op: GEEN bare .wp-block-columns — dat breekt geneste kolommen in kaarten. */
.entry-content > .wp-block-columns,
.page-single .wp-block-columns {
	--wp--style--block-gap: clamp(3rem, 6vw, 6rem);
	gap: clamp(3rem, 6vw, 6rem) !important;
}
.entry-content > .wp-block-columns { max-width: 100%; margin-inline: 0; }

/* Geneste kolommen in compacte kaarten: kleine gap + min-width reset */
.solida-fonds-card .wp-block-columns,
.project-card .wp-block-columns,
.fonds-percentage-header .wp-block-columns,
.news-card .wp-block-columns {
	--wp--style--block-gap: 0.5rem !important;
	gap: 0.5rem !important;
}

/* min-width resetten zodat smalle kolommen (bv. 30% percentagekolom) niet wrappen */
.solida-fonds-card .wp-block-column {
	min-width: 0;
}

.entry-content h2 { font-size: var(--size-3xl); margin-top: var(--space-12); }
.entry-content h3 { font-size: var(--size-2xl); margin-top: var(--space-8); }
.entry-content a { text-decoration: underline; }
.entry-content blockquote {
	border-left: 3px solid var(--color-accent);
	margin-inline: 0;
	padding-left: var(--space-6);
	font-style: italic;
	color: var(--color-text-muted);
}

.entry-content pre {
	background: var(--color-accent-alt);
	padding: var(--space-4);
	border-radius: var(--radius-sm);
	overflow-x: auto;
	font-size: var(--size-sm);
}

/* --------------------------------------------------------------------------
   Post footer
   -------------------------------------------------------------------------- */
.post-footer { margin-top: var(--space-12); padding-top: var(--space-8); border-top: 1px solid var(--color-border); }

.post-tags { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-bottom: var(--space-6); }
.tag {
	display: inline-block;
	padding: var(--space-1) var(--space-3);
	background: var(--color-accent-alt);
	border-radius: var(--radius-sm);
	font-size: var(--size-xs);
	text-decoration: none;
	font-weight: 500;
}

.post-nav {
	display: flex;
	justify-content: space-between;
	gap: var(--space-4);
	font-size: var(--size-sm);
}

.post-nav a { text-decoration: none; font-weight: 500; }
.post-nav a:hover { text-decoration: underline; }

/* --------------------------------------------------------------------------
   Author page
   -------------------------------------------------------------------------- */
.author-header {
	display: flex;
	align-items: center;
	gap: var(--space-8);
	padding-block: var(--space-12);
}

.author-avatar img { border-radius: 50%; width: 120px; height: 120px; object-fit: cover; }
.author-name { font-size: var(--size-3xl); margin: 0 0 var(--space-2); }
.author-bio { margin: 0; color: var(--color-text-muted); }

/* --------------------------------------------------------------------------
   Archive / search header
   -------------------------------------------------------------------------- */
.archive-header { padding-block: var(--space-12) var(--space-8); }
.archive-title { font-size: var(--size-3xl); margin: 0; }
.archive-description { color: var(--color-text-muted); margin-top: var(--space-2); }

/* --------------------------------------------------------------------------
   404
   -------------------------------------------------------------------------- */
.error-404 {
	text-align: center;
	padding-block: var(--space-24);
}

.error-404__title { font-size: 8rem; font-weight: 900; margin: 0; line-height: 1; opacity: .1; }
.error-404__text { font-size: var(--size-xl); margin-block: var(--space-4) var(--space-8); }

/* --------------------------------------------------------------------------
   Buttons
   -------------------------------------------------------------------------- */
.btn {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	padding: var(--space-3) var(--space-6);
	border-radius: var(--radius-sm);
	font-size: var(--size-sm);
	font-weight: 600;
	text-decoration: none;
	cursor: pointer;
	transition: opacity var(--transition), background var(--transition);
	border: 2px solid transparent;
}

.btn--primary {
	background: var(--color-accent);
	color: #fff;
}

.btn--primary:hover { background: var(--color-accent-hover); }

.btn--primary-orange {
	background: var(--color-orange);
	color: #fff;
}

.btn--primary-orange:hover { background: var(--color-orange-hover); }

.btn--outline {
	background: transparent;
	border-color: var(--color-accent);
	color: var(--color-accent);
}

.btn--outline:hover { background: var(--color-accent); color: #fff; }

/* --------------------------------------------------------------------------
   Pagination
   -------------------------------------------------------------------------- */
.nav-links {
	display: flex;
	align-items: center;
	gap: var(--space-2);
	padding-block: var(--space-8);
	justify-content: center;
}

.page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 36px;
	height: 36px;
	padding-inline: var(--space-3);
	border-radius: var(--radius-sm);
	border: 1px solid var(--color-border);
	text-decoration: none;
	font-size: var(--size-sm);
	font-weight: 500;
}

.page-numbers.current {
	background: var(--color-accent);
	border-color: var(--color-accent);
	color: #fff;
}

/* --------------------------------------------------------------------------
   Gutenberg: brede pagina lay-out (page-wide template + front-page)
   -------------------------------------------------------------------------- */

/* Geen container-beperking, blocks regelen hun eigen breedte */
.page-wide,
.page-content { margin: 0; padding: 0; }

/* Tekst-blokken op brede pagina's: centreer op content-breedte.
   Gutenberg rendert op de frontend geen .wp-block class — we targeten
   de echte HTML-elementen die elk bloktype uitspuugt. */
.page-wide > p,
.page-wide > .wp-block-paragraph,
.page-wide > h1, .page-wide > h2, .page-wide > h3,
.page-wide > h4, .page-wide > h5, .page-wide > h6,
.page-wide > .wp-block-heading,
.page-wide > ul, .page-wide > ol,
.page-wide > .wp-block-list,
.page-wide > figure:not([class*="alignfull"]):not([class*="alignwide"]),
.page-wide > .wp-block-image:not([class*="alignfull"]):not([class*="alignwide"]),
.page-content > p,
.page-content > .wp-block-paragraph,
.page-content > h1, .page-content > h2, .page-content > h3,
.page-content > h4, .page-content > h5, .page-content > h6,
.page-content > .wp-block-heading,
.page-content > ul, .page-content > ol,
.page-content > .wp-block-list,
.page-content > figure:not([class*="alignfull"]):not([class*="alignwide"]),
.page-content > .wp-block-image:not([class*="alignfull"]):not([class*="alignwide"]) {
	max-width: var(--content-width);
	margin-inline: auto;
	padding-inline: clamp(var(--space-4), 5vw, var(--space-6)); /* mobiel: min. 1rem zijmarge */
}

/* Paragrafen en lijsten: groter font, ruime marge — geen achtergrond per <p> */
.page-wide > p,
.page-wide > .wp-block-paragraph,
.page-wide > ul,
.page-wide > ol,
.page-wide > .wp-block-list,
.page-content > p,
.page-content > .wp-block-paragraph,
.page-content > ul,
.page-content > ol,
.page-content > .wp-block-list {
	font-size: 1.125rem;
	line-height: 1.875;
	margin-block: 1.375rem;
	padding-block: 0.5rem;
	background: none;
	border-radius: 0;
	box-shadow: none;
}

/* Body-tekst in geneste blokken (Group, Columns) op brede pagina's: ook 18px.
   Gebruikt !important om Gutenberg inline-stijlen (0.9375rem / 1rem) te overschrijven.
   Uitzonderingen: kaart-labels, badges, kleine meta-tekst. */
.page-wide .wp-block-group p:not(.badge):not(.nav-cta):not(.footer-tagline):not(.stat-number),
.page-wide .wp-block-column p:not(.badge):not(.stat-number),
.page-content .wp-block-group p:not(.badge):not(.stat-number),
.page-content .wp-block-column p:not(.badge):not(.stat-number) {
	font-size: 1.125rem !important;
	line-height: 1.8;
}

/* Uitzonderingen: kleine tekst in compacte kaarten en labels */
.page-wide .solida-fonds-card p,
.page-wide .project-card p,
.page-wide .news-card p,
.page-wide .callout-box p,
.page-wide .process-step__text,
.page-wide .testimonial-author p,
.page-wide .team-card__role,
.page-wide .fonds-row,
.page-wide .badge {
	font-size: inherit !important;
}

/* Hele brede pagina: één subtiele kleurwas als achtergrond van het article.
   Full-width blokken (hero, stats, etc.) hebben eigen achtergrond en dekken dit af.
   Zo krijgt de tekstruimte tussen blokken een zachte gradient zonder losse kaartjes. */
.page-wide {
	background:
		radial-gradient(ellipse 90% 25% at 50% 52%, rgba(240,247,251,.6) 0%, transparent 70%),
		linear-gradient(160deg,
			rgba(240,247,251,.35)  0%,
			rgba(255,255,255,1)   12%,
			rgba(255,255,255,1)   88%,
			rgba(248,245,253,.25) 100%
		);
}

/* Headings op brede pagina: meer adem boven */
.page-wide > h2, .page-wide > .wp-block-heading,
.page-wide > h3,
.page-content > h2, .page-content > .wp-block-heading,
.page-content > h3 {
	margin-block: 2.25rem 0.375rem;
}

/* --------------------------------------------------------------------------
   Tekst-vlak — samengesteld kaartje voor een groep tekst-blokken
   Gebruik: voeg class 'solida-tekst-vlak' toe aan een Group-blok in GB
   -------------------------------------------------------------------------- */
.solida-tekst-vlak {
	background: linear-gradient(145deg, #f5f9fd 0%, #ffffff 55%, #f8f5fd 100%) !important;
	border-radius: 1.25rem !important;
	box-shadow:
		0 -3px 0 0 rgba(49,136,185,.15),
		0 6px 28px rgba(49,136,185,.08),
		0 1px 6px rgba(0,0,0,.04) !important;
	margin-inline: auto;
	max-width: var(--content-width) !important;
	margin-block: 2.5rem;
}

/* Binnen een tekst-vlak: geen dubbele ghost-card achtergrond */
.solida-tekst-vlak > p,
.solida-tekst-vlak > .wp-block-paragraph,
.solida-tekst-vlak > ul,
.solida-tekst-vlak > ol,
.solida-tekst-vlak > .wp-block-list {
	background: none !important;
	box-shadow: none !important;
	border-radius: 0 !important;
	padding-block: 0.25rem;
	margin-block: 0.625rem;
}

/* Geen extra footer-marge als laatste blok al padding heeft */
.page-wide + .site-footer,
.page-content + .site-footer {
	margin-top: 0;
}

/* --------------------------------------------------------------------------
   Gutenberg: Cover block (hero)
   -------------------------------------------------------------------------- */
.wp-block-cover {
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	overflow: hidden;
}

.wp-block-cover.alignfull {
	width: 100%;
	max-width: 100%;
	margin-inline: 0;
}

.wp-block-cover__inner-container {
	position: relative;
	z-index: 2;
	width: 100%;
	max-width: var(--container-width);
	margin-inline: auto;
	padding-inline: var(--space-6);
	padding-block: var(--space-16);
}

/* Zorg dat de achtergrondafbeelding het hele blok bedekt */
.wp-block-cover__image-background,
.wp-block-cover__video-background {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* Overlay (kleur/dim) over de afbeelding */
.wp-block-cover__background,
.wp-block-cover__gradient-background {
	position: absolute;
	inset: 0;
	z-index: 1;
	opacity: 0.5; /* fallback als er geen dim-class of inline opacity is */
}

/* Dim-klassen — alle stappen + tussenstappen die Gutenberg genereert */
.wp-block-cover__background.has-background-dim-0  { opacity: 0;    }
.wp-block-cover__background.has-background-dim-10 { opacity: 0.1;  }
.wp-block-cover__background.has-background-dim-20 { opacity: 0.2;  }
.wp-block-cover__background.has-background-dim-30 { opacity: 0.3;  }
.wp-block-cover__background.has-background-dim-40 { opacity: 0.4;  }
.wp-block-cover__background.has-background-dim-50 { opacity: 0.5;  }
.wp-block-cover__background.has-background-dim-60 { opacity: 0.6;  }
.wp-block-cover__background.has-background-dim-62 { opacity: 0.62; }
.wp-block-cover__background.has-background-dim-70 { opacity: 0.7;  }
.wp-block-cover__background.has-background-dim-80 { opacity: 0.8;  }
.wp-block-cover__background.has-background-dim-90 { opacity: 0.9;  }
.wp-block-cover__background.has-background-dim-100{ opacity: 1;    }

/* --------------------------------------------------------------------------
   Editor color palette — gegenereerde kleurklassen
   WordPress genereert has-{slug}-background-color / has-{slug}-color klassen
   vanuit de editor-color-palette, maar classic themes leveren die CSS zelf.
   -------------------------------------------------------------------------- */

/* Achtergrondkleur */
.has-solida-donker-background-color { background-color: #0f1923; }
.has-solida-blauw-background-color  { background-color: #3188b9; }
.has-solida-oranje-background-color { background-color: #f5931f; }
.has-solida-paars-background-color  { background-color: #92298f; }
.has-solida-licht-background-color  { background-color: #f0f7fb; }
.has-solida-tekst-background-color  { background-color: #1a1a1a; }
.has-white-background-color         { background-color: #ffffff; }

/* Tekstkleur */
.has-solida-donker-color { color: #0f1923; }
.has-solida-blauw-color  { color: #3188b9; }
.has-solida-oranje-color { color: #f5931f; }
.has-solida-paars-color  { color: #92298f; }
.has-solida-licht-color  { color: #f0f7fb; }
.has-solida-tekst-color  { color: #1a1a1a; }
.has-white-color         { color: #ffffff; }

/* Hero-specifiek */
.solida-hero .wp-block-cover__inner-container {
	padding-block: clamp(var(--space-16), 12vh, 8rem);
}

/* --------------------------------------------------------------------------
   Gutenberg: Group block (gekleurde secties)
   -------------------------------------------------------------------------- */
.wp-block-group.alignfull {
	width: 100%;
	max-width: 100%;
	margin-inline: 0;
}

/* Inner container van constrained layout groups */
.wp-block-group.alignfull > .wp-block-group__inner-container,
.wp-block-group[class*="is-layout-constrained"] > * {
	max-width: var(--container-width);
	margin-inline: auto;
	padding-inline: var(--space-6);
}

/* Secties met achtergrondkleur: standaard verticale padding */
.wp-block-group[style*="background"] {
	padding-block: var(--space-16);
}

/* Donkere secties: tekst aanpassen */
.wp-block-group[style*="background-color:#0f1923"],
.wp-block-group[style*="background-color:#3188b9"],
.wp-block-group[style*="background-color:#92298f"] {
	color: #fff;
}

/* --------------------------------------------------------------------------
   Gutenberg: Columns block (pilaren, twee-koloms, etc.)
   -------------------------------------------------------------------------- */
.wp-block-columns {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-6);
	margin-bottom: 0;
}

/* Group-blokken met horizontale flex-layout (is-layout-flex / Row):
   WordPress core stelt slechts 0.5em in via :where() — wij overschrijven dat. */
.wp-block-group.is-layout-flex,
.wp-block-group-is-layout-flex {
	gap: clamp(2rem, 5vw, 5rem);
}

.wp-block-column {
	flex: 1 1 0;
	min-width: min(100%, 240px);
}

/* Kaarten-stijl columns (wit blok met schaduw bij hover) */
.wp-block-column[style*="background-color:#ffffff"] {
	transition: box-shadow var(--transition), transform var(--transition);
}

.wp-block-column[style*="background-color:#ffffff"]:hover {
	box-shadow: 0 8px 32px rgba(0,0,0,.08);
	transform: translateY(-2px);
}

/* --------------------------------------------------------------------------
   Vastgoedproject kaarten
   -------------------------------------------------------------------------- */
.project-card {
	border: none;
	box-shadow: var(--shadow-card);
	transition: box-shadow var(--transition), transform var(--transition);
	background: var(--color-bg);
}

.project-card:hover {
	box-shadow: var(--shadow-hover);
	transform: translateY(-4px);
}

/* Kolommen binnen projectkaarten: min-width resetten zodat ze niet overlopen */
.project-card .wp-block-column {
	min-width: 0;
	overflow: hidden;
}

.project-card .wp-block-columns {
	flex-wrap: nowrap;
}

/* Foto-sectie van projectkaart */
.project-card__img {
	position: relative;
}

.project-card__img .wp-block-cover__inner-container {
	padding: var(--space-4) !important;
	display: flex;
	align-items: flex-start;
	justify-content: flex-start;
}

/* Status badge */
.project-card__badge {
	margin: 0 !important;
	line-height: 1.4;
}

/* Statistieken sectie */
.solida-stats .wp-block-column {
	transition: background var(--transition);
}

.solida-stats .wp-block-column:hover {
	background: rgba(255,255,255,.03);
}

/* --------------------------------------------------------------------------
   Gutenberg: Button block
   -------------------------------------------------------------------------- */
.wp-block-button__link,
.wp-element-button {
	display: inline-flex;
	align-items: center;
	font-family: var(--font-sans);
	font-size: var(--size-sm);
	font-weight: 600;
	text-decoration: none !important;
	cursor: pointer;
	transition: opacity var(--transition), background var(--transition), transform var(--transition);
	border-radius: var(--radius-sm);
}

.wp-block-button__link:hover { opacity: .88; transform: translateY(-1px); }

/* Volle-breedte knop: tekst centreren */
.wp-block-button__width-100 .wp-block-button__link {
	display: flex;
	justify-content: center;
	width: 100%;
}

.wp-block-button.is-style-outline .wp-block-button__link {
	background: transparent !important;
}

.wp-block-button.is-style-outline .wp-block-button__link:hover {
	opacity: .85;
}

.wp-block-buttons {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
}

/* --------------------------------------------------------------------------
   Gutenberg: Query Loop (nieuws grid)
   -------------------------------------------------------------------------- */
.solida-news-grid .wp-block-post-template {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(min(100%, 300px), 1fr));
	gap: var(--space-8);
	list-style: none;
	margin: 0;
	padding: 0;
}

/* Nieuwskaart (gebruikt in de nieuws-sectie pattern) */
.news-card {
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	overflow: hidden;
	transition: box-shadow var(--transition), transform var(--transition);
	background: var(--color-bg);
}

.news-card:hover {
	box-shadow: 0 8px 32px rgba(0,0,0,.08);
	transform: translateY(-2px);
}

.news-card .wp-block-post-featured-image img {
	width: 100%;
	aspect-ratio: 16/9;
	object-fit: cover;
	display: block;
}

.news-card .wp-block-post-title {
	margin: 0 0 var(--space-2);
	font-size: var(--size-lg);
	font-weight: 600;
	line-height: 1.3;
}

.news-card .wp-block-post-title a {
	text-decoration: none;
	color: var(--color-text);
}

.news-card .wp-block-post-title a:hover { color: var(--color-accent); }

.news-card .wp-block-post-date {
	font-size: var(--size-xs);
	color: var(--color-text-muted);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.news-card .wp-block-post-excerpt {
	font-size: var(--size-sm);
	color: var(--color-text-muted);
	margin: 0;
}

.news-card .wp-block-post-excerpt p { margin: 0; }

/* --------------------------------------------------------------------------
   Gutenberg: overige blocks
   -------------------------------------------------------------------------- */

/* Image */
.wp-block-image img {
	border-radius: var(--radius);
}

.wp-block-image.alignfull img {
	border-radius: 0;
	width: 100%;
}

/* Separator */
.wp-block-separator {
	border: none;
	border-top: 1px solid var(--color-border);
	margin-block: var(--space-8);
}

.wp-block-separator.is-style-wide {
	max-width: 100%;
}

/* Quote */
.wp-block-quote {
	border-left: 3px solid var(--color-accent);
	margin-inline: 0;
	padding-left: var(--space-6);
	font-style: italic;
	color: var(--color-text-muted);
}

.wp-block-quote cite { font-style: normal; font-size: var(--size-sm); }

/* Table */
.wp-block-table table {
	width: 100%;
	border-collapse: collapse;
	font-size: var(--size-sm);
}

.wp-block-table td,
.wp-block-table th {
	padding: var(--space-3) var(--space-4);
	border-bottom: 1px solid var(--color-border);
	text-align: left;
}

.wp-block-table th { font-weight: 600; }

/* Embed / video */
.wp-block-embed { border-radius: var(--radius); overflow: hidden; }

/* Bullets: marker erft altijd de tekstkleur van het lijstelement */
li::marker { color: inherit; }

/* Lijsten in donkere secties: altijd lichte kleur, ook na edits in de editor */
.solida-dark-section li,
.solida-dark-section li::marker,
.solida-stats li,
.solida-stats li::marker,
[style*="background:linear-gradient(160deg,#92298f"] li,
[style*="background:linear-gradient(160deg,#92298f"] li::marker {
	color: rgba(255,255,255,.75);
}

/* Wit kaartje binnen donkere sectie: tekst weer donker */
.solida-fonds-card li,
.solida-fonds-card li::marker {
	color: var(--color-text);
}

/* --------------------------------------------------------------------------
   Typografie-verfijningen
   -------------------------------------------------------------------------- */

/* em in koppen → accent-oranje ipv cursief (gebruikt in hero, CTAs) */
h1 em, h2 em, h3 em { font-style: normal; color: var(--color-orange); }

/* Grote intro-alinea (eerste p na h1/h2 in wide pages) */
.page-wide .intro-lead,
.page-content .intro-lead {
	font-size: var(--size-xl);
	line-height: 1.7;
	color: var(--color-text-muted);
	max-width: 680px;
}

/* Decoratieve scheidingslijn met gradient */
.solida-divider {
	border: none;
	height: 2px;
	background: linear-gradient(90deg, var(--color-accent) 0%, var(--color-orange) 50%, var(--color-purple) 100%);
	border-radius: 2px;
	margin-block: var(--space-12);
	max-width: 80px;
}

/* --------------------------------------------------------------------------
   Badges / pills
   -------------------------------------------------------------------------- */
.badge {
	display: inline-flex;
	align-items: center;
	padding: 0.2em 0.75em;
	border-radius: 100px;
	font-size: var(--size-xs);
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.6;
}

.badge--blue   { background: rgba(49,136,185,.12);  color: var(--color-accent); }
.badge--orange { background: rgba(245,147,31,.12);  color: var(--color-orange); }
.badge--purple { background: rgba(146,41,143,.12);  color: var(--color-purple); }
.badge--dark   { background: var(--color-bg-dark);  color: rgba(255,255,255,.8); }

/* --------------------------------------------------------------------------
   Callout box (fiscaal voordeel, disclaimer, info)
   -------------------------------------------------------------------------- */
.callout-box {
	border-left: 4px solid var(--color-orange);
	background: linear-gradient(135deg, #fff8f0 0%, #fff5e8 100%);
	padding: var(--space-6) var(--space-8);
	border-radius: 0 var(--radius) var(--radius) 0;
}

.callout-box--blue {
	border-left-color: var(--color-accent);
	background: linear-gradient(135deg, var(--color-accent-alt) 0%, #e0eff8 100%);
}

.callout-box h3, .callout-box h4 {
	color: var(--color-orange);
	font-size: var(--size-base);
	font-weight: 700;
	margin: 0 0 var(--space-2);
}

.callout-box--blue h3,
.callout-box--blue h4 { color: var(--color-accent); }

.callout-box p { margin: 0; font-size: var(--size-sm); color: var(--color-text-muted); line-height: 1.7; }

/* --------------------------------------------------------------------------
   Testimonial
   -------------------------------------------------------------------------- */
.solida-testimonial {
	position: relative;
	background: var(--color-bg);
	border-radius: var(--radius-lg);
	padding: var(--space-12) var(--space-8) var(--space-8);
	box-shadow: var(--shadow-card);
	overflow: hidden;
}

/* Decoratief groot aanhalingsteken */
.solida-testimonial::before {
	content: '\201C';
	position: absolute;
	top: -0.2rem;
	left: var(--space-6);
	font-size: 8rem;
	line-height: 1;
	color: var(--color-accent);
	opacity: .08;
	font-family: Georgia, serif;
	pointer-events: none;
	user-select: none;
}

.testimonial-quote {
	font-size: var(--size-lg);
	line-height: 1.75;
	color: var(--color-text);
	font-style: italic;
	margin: 0 0 var(--space-6);
	position: relative;
	z-index: 1;
}

.testimonial-author {
	display: flex;
	align-items: center;
	gap: var(--space-4);
	border-top: 1px solid var(--color-border);
	padding-top: var(--space-4);
}

.testimonial-author__avatar img {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	object-fit: cover;
}

.testimonial-author__name  { font-weight: 700; font-size: var(--size-sm); margin: 0; }
.testimonial-author__role  { font-size: var(--size-xs); color: var(--color-text-muted); margin: 0; }

/* Grid van meerdere testimonials */
.testimonial-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(min(100%, 340px), 1fr));
	gap: var(--space-8);
}

/* --------------------------------------------------------------------------
   Processtappen
   -------------------------------------------------------------------------- */
.process-steps {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-8);
	counter-reset: process-step;
}

.process-step {
	position: relative;
}

/* Verbindingslijn tussen stappen */
.process-step:not(:last-child)::after {
	content: '';
	position: absolute;
	top: 24px;
	left: calc(50% + 28px);
	right: calc(-50% + 28px);
	height: 1px;
	background: linear-gradient(90deg, var(--color-accent) 0%, var(--color-border) 100%);
}

/* Lege wrapper-<p> met has-background die ontstaat door ongeldige nesting in GB */
.process-step p.has-background:not(.process-step__number) {
	display: none !important;
}

.process-step__number {
	width: 48px !important;
	height: 48px !important;
	max-width: 48px !important;
	min-width: 48px !important;
	border-radius: 50% !important;
	background: linear-gradient(135deg, var(--color-accent) 0%, #2571a0 100%);
	color: #fff !important;
	font-size: var(--size-lg);
	font-weight: 800;
	line-height: 1 !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	padding: 0 !important;
	overflow: hidden;
	flex-shrink: 0;
	margin-bottom: var(--space-4);
	position: relative;
	z-index: 1;
	box-shadow: 0 4px 16px rgba(49,136,185,.35);
}

.process-step__title  { font-size: var(--size-lg); font-weight: 700; margin: 0 0 var(--space-2); }
.process-step__text   { font-size: var(--size-sm); color: var(--color-text-muted); line-height: 1.7; margin: 0; }

/* --------------------------------------------------------------------------
   Team sectie
   -------------------------------------------------------------------------- */
.team-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(min(100%, 220px), 1fr));
	gap: var(--space-8);
}

.team-card { text-align: center; }

.team-card__photo {
	width: 120px;
	height: 120px;
	border-radius: 50%;
	object-fit: cover;
	margin-inline: auto;
	display: block;
	margin-bottom: var(--space-4);
	border: 3px solid var(--color-accent-alt);
	transition: border-color var(--transition), transform var(--transition);
}

.team-card:hover .team-card__photo {
	border-color: var(--color-accent);
	transform: scale(1.03);
}

.team-card__name     { font-size: var(--size-lg); font-weight: 700; margin: 0 0 var(--space-1); }
.team-card__role     { font-size: var(--size-sm); color: var(--color-text-muted); margin: 0; }

/* --------------------------------------------------------------------------
   Block pattern: solida-pillar-icon (O-icoon boven pilaar)
   -------------------------------------------------------------------------- */
.solida-pillar-icon {
	margin: 0 0 var(--space-4) !important;
}

.solida-pillar-icon img {
	border-radius: 0 !important;
}

/* --------------------------------------------------------------------------
   L-haak accent vóór headings (Value.nl-stijl)
   Gebruik: voeg class "accent-heading" toe via blok-instellingen
   -------------------------------------------------------------------------- */
.accent-heading {
	padding-left: 1.125rem;
	position: relative;
}

.accent-heading::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0.1em;
	width:  8px;
	height: 0.7em;
	border-left: 3px solid var(--color-orange);
	border-top:  3px solid var(--color-orange);
	border-radius: 1px 0 0 0;
}

/* Blauwe variant */
.accent-heading--blue::before {
	border-color: var(--color-accent);
}

/* Feature-lijst sectie: h3's met separator tussen items */
.feature-list > * + * {
	border-top: 1px solid var(--color-border);
	padding-top: var(--space-8);
	margin-top: var(--space-8);
}

/* --------------------------------------------------------------------------
   Fonds-kaart (floating wit kaartje op donkere achtergrond)
   -------------------------------------------------------------------------- */
.solida-fonds-sectie {
	display: grid;
	grid-template-columns: 1fr 1fr;
	align-items: center;
	gap: var(--space-12);
}

.solida-fonds-card {
	background: var(--color-bg) !important;
	border-radius: 16px !important;
	box-shadow: 0 32px 80px rgba(0,0,0,.35) !important;
	overflow: hidden;
}

/* Percentage header in kaart */
.fonds-percentage-header {
	background: #f3f4f6;
	border-radius: var(--radius);
	padding: var(--space-4) var(--space-6);
	margin-bottom: var(--space-4);
}

/* Statistieken-rijen in kaart */
.fonds-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: var(--space-4) 0;
	border-bottom: 1px solid var(--color-border);
	font-size: 0.9375rem;
}

.fonds-row:last-of-type { border-bottom: none; }

/* Checklist items */
.solida-checklist {
	list-style: none !important;
	padding-left: 0 !important;
}

.solida-checklist li {
	position: relative;
	padding-left: 1.75rem;
	margin-bottom: var(--space-3);
	font-size: var(--size-sm);
}

.solida-checklist li::before {
	content: '✓';
	position: absolute;
	left: 0;
	top: 0;
	font-weight: 700;
	color: var(--color-accent);
	font-size: 0.9em;
}

/* --------------------------------------------------------------------------
   Donkere tweekolomssectie (Benkey-stijl)
   Afbeelding links met grote border-radius, tekst rechts
   -------------------------------------------------------------------------- */
.solida-dark-section {
	background: linear-gradient(160deg, #92298f 0%, #12324d 60%, #3188b9 100%);
}

.solida-dark-section .wp-block-image img {
	border-radius: 20px !important;
	box-shadow: 0 24px 64px rgba(0,0,0,.4);
}

/* Tweekleurige kop: wit + oranje via <span> in heading */
.split-heading-accent { color: var(--color-orange); font-style: normal; }

/* Outline buttons voor op donkere achtergrond */
.btn-outline-dark {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	padding: 0.75rem 1.5rem;
	border: 1.5px solid rgba(255,255,255,.35);
	border-radius: var(--radius-sm);
	color: #fff;
	font-size: var(--size-sm);
	font-weight: 600;
	text-decoration: none !important;
	transition: border-color var(--transition), background var(--transition);
}

.btn-outline-dark:hover {
	border-color: rgba(255,255,255,.75);
	background: rgba(255,255,255,.07);
}

/* Pijl-icoon in buttons */
.btn-arrow::after { content: ' ↗'; font-size: 0.85em; opacity: .8; }

/* Verticale knoppen (Gutenberg buttons met orientation:vertical) */
.wp-block-buttons.is-vertical {
	flex-direction: column;
	align-items: flex-start;
}

/* --------------------------------------------------------------------------
   Block pattern: solida/kennismaking
   Donker navy kaartje (kop + lead + knoppen + contactpersoon) naast grote foto
   -------------------------------------------------------------------------- */

/* Foto-kolom: vult de volledige hoogte van het donkere kaartje */
.solida-kennismaking-foto {
	overflow: hidden;
	border-radius: 16px;
	display: flex;
	align-items: stretch;
}

.solida-kennismaking-foto .wp-block-image {
	flex: 1;
	margin: 0;
	display: flex;
}

.solida-kennismaking-foto .wp-block-image img {
	width: 100%;
	height: 100%;
	min-height: 420px;
	object-fit: cover;
	border-radius: 16px;
	display: block;
}

@media (max-width: 768px) {
	.solida-kennismaking-foto {
		min-height: 260px;
		border-radius: 12px;
	}
	.solida-kennismaking-foto .wp-block-image img {
		min-height: 260px;
		border-radius: 12px;
	}
}

/* --------------------------------------------------------------------------
   GravityForms — Inline variant (lichte achtergrond, contactpagina etc.)
   -------------------------------------------------------------------------- */
.gform_wrapper {
	max-width: 640px;
}

.gform_wrapper .gform_body { padding: 0; }

.gform_wrapper .gform_fields {
	display: flex;
	flex-direction: column;
	gap: var(--space-5);
	list-style: none;
	margin: 0;
	padding: 0;
}

/* Labels */
.gform_wrapper .gfield_label {
	display: block;
	font-size: var(--size-sm);
	font-weight: 600;
	color: var(--color-text);
	margin-bottom: var(--space-2);
}

.gform_wrapper .gfield_required { color: var(--color-orange); margin-left: 2px; }

/* Input fields */
.gform_wrapper input[type="text"],
.gform_wrapper input[type="email"],
.gform_wrapper input[type="tel"],
.gform_wrapper input[type="url"],
.gform_wrapper input[type="number"],
.gform_wrapper input[type="date"],
.gform_wrapper textarea,
.gform_wrapper select {
	width: 100%;
	padding: 0.75rem 1rem;
	border: 1.5px solid var(--color-border);
	border-radius: var(--radius-sm);
	font-family: var(--font-sans);
	font-size: var(--size-base);
	background: var(--color-bg);
	color: var(--color-text);
	transition: border-color var(--transition), box-shadow var(--transition);
	appearance: none;
	line-height: 1.5;
}

.gform_wrapper input[type="text"]:hover,
.gform_wrapper input[type="email"]:hover,
.gform_wrapper input[type="tel"]:hover,
.gform_wrapper textarea:hover,
.gform_wrapper select:hover {
	border-color: #c8d8e4;
}

.gform_wrapper input[type="text"]:focus,
.gform_wrapper input[type="email"]:focus,
.gform_wrapper input[type="tel"]:focus,
.gform_wrapper input[type="url"]:focus,
.gform_wrapper input[type="number"]:focus,
.gform_wrapper input[type="date"]:focus,
.gform_wrapper textarea:focus,
.gform_wrapper select:focus {
	outline: none;
	border-color: var(--color-accent);
	box-shadow: 0 0 0 3px rgba(49,136,185,.15);
}

.gform_wrapper textarea { min-height: 140px; resize: vertical; }

/* Submit footer */
.gform_wrapper .gform_footer,
.gform_wrapper .gform_page_footer {
	margin-top: var(--space-6);
}

.gform_wrapper .gform_button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.75rem 2rem;
	background: var(--color-accent);
	color: #fff;
	border: none;
	border-radius: var(--radius-sm);
	font-family: var(--font-sans);
	font-size: var(--size-sm);
	font-weight: 600;
	cursor: pointer;
	transition: background var(--transition), transform var(--transition);
}

.gform_wrapper .gform_button:hover {
	background: var(--color-accent-hover);
	transform: translateY(-1px);
}

/* Validatie */
.gform_wrapper .gfield_error input,
.gform_wrapper .gfield_error textarea,
.gform_wrapper .gfield_error select {
	border-color: #dc2626;
	box-shadow: 0 0 0 3px rgba(220,38,38,.12);
}

.gform_wrapper .validation_message {
	font-size: var(--size-sm);
	color: #dc2626;
	margin-top: var(--space-1);
}

.gform_wrapper .validation_error {
	background: #fef2f2;
	border: 1px solid #fecaca;
	border-radius: var(--radius-sm);
	padding: var(--space-4);
	color: #dc2626;
	font-size: var(--size-sm);
	margin-bottom: var(--space-6);
}

/* Bevestigingsbericht */
.gform_confirmation_wrapper .gform_confirmation_message {
	background: #f0fdf4;
	border: 1px solid #bbf7d0;
	border-left: 4px solid #16a34a;
	border-radius: var(--radius-sm);
	padding: var(--space-6) var(--space-8);
	color: #15803d;
	font-weight: 500;
}

/* Beschrijving */
.gform_wrapper .gfield_description {
	font-size: var(--size-sm);
	color: var(--color-text-muted);
	margin-top: var(--space-1);
	line-height: 1.5;
}

/* Checkbox & radio */
.gform_wrapper .gfield_checkbox,
.gform_wrapper .gfield_radio {
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
	list-style: none;
	margin: 0;
	padding: 0;
}

.gform_wrapper .gfield_checkbox label,
.gform_wrapper .gfield_radio label {
	display: flex;
	align-items: center;
	gap: var(--space-3);
	font-size: var(--size-sm);
	font-weight: 400;
	cursor: pointer;
}

/* --------------------------------------------------------------------------
   GravityForms — Dark variant (.solida-form-dark)
   Gebruik: wikkel het GF shortcode-blok in een HTML-blok met
   class="solida-form-dark" — of voeg de class toe aan het Group-blok
   -------------------------------------------------------------------------- */
.solida-form-dark .gform_wrapper {
	max-width: 100%;
}

/* 2-koloms grid voor voornaam / email naast elkaar */
.solida-form-dark .gform_wrapper .gform_fields {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-4) var(--space-6);
}

/* Brede velden over beide kolommen */
.solida-form-dark .gfield--width-full,
.solida-form-dark .gfield--type-textarea,
.solida-form-dark .gfield--type-select,
.solida-form-dark .gfield--type-consent,
.solida-form-dark .gform_wrapper .gform_footer,
.solida-form-dark .gform_wrapper .gform_page_footer {
	grid-column: 1 / -1;
}

/* Labels: wit */
.solida-form-dark .gform_wrapper .gfield_label {
	color: rgba(255,255,255,.85);
	font-weight: 500;
}

.solida-form-dark .gform_wrapper .gfield_required { color: var(--color-orange); }

/* Input fields: transparant glas-effect op donkere achtergrond */
.solida-form-dark .gform_wrapper input[type="text"],
.solida-form-dark .gform_wrapper input[type="email"],
.solida-form-dark .gform_wrapper input[type="tel"],
.solida-form-dark .gform_wrapper input[type="url"],
.solida-form-dark .gform_wrapper input[type="number"],
.solida-form-dark .gform_wrapper input[type="date"],
.solida-form-dark .gform_wrapper textarea,
.solida-form-dark .gform_wrapper select {
	background: rgba(255,255,255,.1);
	border-color: rgba(255,255,255,.2);
	color: #fff;
}

.solida-form-dark .gform_wrapper input::placeholder,
.solida-form-dark .gform_wrapper textarea::placeholder {
	color: rgba(255,255,255,.4);
}

.solida-form-dark .gform_wrapper input:hover,
.solida-form-dark .gform_wrapper textarea:hover {
	border-color: rgba(255,255,255,.4);
}

.solida-form-dark .gform_wrapper input:focus,
.solida-form-dark .gform_wrapper textarea:focus,
.solida-form-dark .gform_wrapper select:focus {
	background: rgba(255,255,255,.14);
	border-color: var(--color-orange);
	box-shadow: 0 0 0 3px rgba(245,147,31,.25);
}

/* Submit knop: oranje, volledige breedte */
.solida-form-dark .gform_wrapper .gform_button {
	display: flex;
	width: 100%;
	padding: 1rem 2rem;
	background: var(--color-orange);
	font-size: var(--size-base);
	font-weight: 700;
	letter-spacing: 0.01em;
}

.solida-form-dark .gform_wrapper .gform_button:hover {
	background: var(--color-orange-hover);
	transform: translateY(-2px);
}

/* Bevestigingsbericht (dark variant) */
.solida-form-dark .gform_confirmation_wrapper .gform_confirmation_message {
	background: rgba(22,163,74,.15);
	border-color: rgba(22,163,74,.3);
	border-left-color: #4ade80;
	color: #86efac;
}

/* Validatiefouten (dark variant) */
.solida-form-dark .gform_wrapper .validation_message { color: #fca5a5; }

.solida-form-dark .gform_wrapper .validation_error {
	background: rgba(220,38,38,.15);
	border-color: rgba(220,38,38,.3);
	color: #fca5a5;
}

/* --------------------------------------------------------------------------
   Block pattern: solida/pagina-intro
   Donkere gradient header → grote foto die 5rem omhoog zweeft → content
   -------------------------------------------------------------------------- */

/* Donkere header-sectie: normale verticale padding */
.solida-pagina-intro {
	overflow: visible;
	padding-bottom: 5rem !important;
}

/* Witte inhoudssectie: ruime padding boven de afbeelding */
.solida-pagina-intro__body {
	position: relative;
	z-index: 1;
	padding-top: 4rem !important;
}

/* Foto: netjes in het witte vlak, geen negatieve margin */
.solida-pagina-intro__img {
	margin-top: 0 !important;
	border-radius: 1rem;
	overflow: hidden;
	box-shadow: 0 24px 72px rgba(0,0,0,.26);
	position: relative;
	z-index: 2;
	margin-bottom: 0 !important;
}

.solida-pagina-intro__img img {
	display: block;
	width: 100%;
	aspect-ratio: 16 / 7;
	object-fit: cover;
	height: auto;
}

/* Responsive: op smal scherm minder overlap */
@media (max-width: 768px) {
	.solida-pagina-intro__img {
		margin-top: -2.5rem !important;
		border-radius: 0.625rem;
	}
	.solida-pagina-intro__img img { aspect-ratio: 4 / 3; }
}

/* --------------------------------------------------------------------------
   Responsive
   -------------------------------------------------------------------------- */
@media (max-width: 1024px) {
	/* Footer: 2 kolommen op tablet */
	.site-footer__grid {
		grid-template-columns: 1fr 1fr;
		gap: var(--space-8);
	}
}

@media (max-width: 768px) {
	/* Header: verberg nav en cta, toon toggle */
	.site-nav {
		position: fixed;
		top: var(--header-height);
		left: 0;
		right: 0;
		transition: opacity 220ms ease, transform 220ms ease, visibility 220ms ease;
		background: var(--color-bg);
		border-bottom: 1px solid var(--color-border);
		box-shadow: 0 8px 32px rgba(0,0,0,.12);
		padding: var(--space-4) var(--space-6) var(--space-6);
		z-index: 99;
		/* Verborgen staat */
		opacity: 0;
		visibility: hidden;
		transform: translateY(-6px);
		transition: opacity 220ms ease, transform 220ms ease, visibility 220ms ease;
	}

	.site-nav.is-open {
		opacity: 1;
		visibility: visible;
		transform: translateY(0);
	}

	.site-nav__list { flex-direction: column; gap: var(--space-4); }
	.site-nav__list a { font-size: var(--size-base); }

	/* Verberg desktop-CTA en toon toggle */
	.nav-cta { display: none; }
	.nav-toggle { display: flex; }


	/* CTA knop onderaan het mobiele menu (overschrijft display:none hierboven) */
	.nav-cta--mobile {
		display: block;
		margin-top: var(--space-6);
		text-align: center;
		background: var(--color-orange);
		color: #fff !important;
		padding: 0.75rem var(--space-6);
		border-radius: var(--radius-sm);
		font-size: var(--size-sm);
		font-weight: 700;
		text-decoration: none;
		transition: background var(--transition);
		transform: none;
	}

	.nav-cta--mobile:hover { background: var(--color-orange-hover); transform: none; }

	/* Footer: 1 kolom */
	.site-footer__grid { grid-template-columns: 1fr; gap: var(--space-8); }
	.site-footer__bottom { flex-direction: column; text-align: center; }
	.footer-legal-list { flex-wrap: wrap; justify-content: center; gap: var(--space-3); }

	/* Author */
	.author-header { flex-direction: column; text-align: center; }

	/* Columns: stapelen op mobiel.
	   !important nodig: WP core-block-supports-inline-css injecteert
	   flex-wrap:nowrap (en soms flex-direction:row) met dubbele class-specificiteit
	   ná onze main.css, waardoor de kolommen toch naast elkaar blijven. */
	.wp-block-columns {
		flex-direction: column !important;
		flex-wrap: wrap !important;
	}
	.wp-block-column { min-width: 100%; }

	/* Nieuws grid: 1 kolom */
	.solida-news-grid .wp-block-post-template { grid-template-columns: 1fr; }

	/* Hero */
	.wp-block-cover__inner-container { padding-block: var(--space-12); }

	/* Statistieken: 2 kolommen naast elkaar op mobiel (uitzondering op column-stapel) */
	.solida-stats .wp-block-columns {
		flex-direction: row !important;
		flex-wrap: wrap !important;
	}
	.solida-stats .wp-block-column {
		min-width: calc(50% - var(--space-4));
		border-right: none !important;
		border-bottom: 1px solid rgba(255,255,255,0.1);
	}

	/* Fonds-kaart rijen: label + waarde naast elkaar houden op mobiel */
	.solida-fonds-card .wp-block-columns {
		flex-direction: row !important;
		flex-wrap: nowrap !important;
		align-items: center;
	}
	.solida-fonds-card .wp-block-column {
		min-width: 0;
	}

	/* Project-kaart: foto + info naast elkaar houden op mobiel */
	.project-card .wp-block-columns {
		flex-direction: row !important;
		flex-wrap: nowrap !important;
	}

	/* Outer kolommen met asymmetrische inline desktop-padding (één kant 0, andere
	   kant 3rem — gebruikt o.a. door fonds-kaart pattern voor gap tussen kaart en
	   tekst): resetten op mobiel zodat content gecentreerd staat ipv links/rechts
	   uitgelijnd. */
	.wp-block-column[style*="padding-left:0"],
	.wp-block-column[style*="padding-right:0"] {
		padding-left: 0 !important;
		padding-right: 0 !important;
	}

	/* Sectie-headers (titel + "Alle X →"): wrappen op mobiel i.p.v. overflow.
	   !important nodig omdat WP inline <style> met dubbele class-specificiteit
	   (.wp-container-core-group-is-layout-X.wp-container-core-group-is-layout-X)
	   flex-wrap:nowrap ná onze CSS injecteert. */
	.wp-block-group.is-layout-flex {
		flex-wrap: wrap !important;
		gap: 0.5rem;
	}
}

@media (max-width: 480px) {
	.post-list { grid-template-columns: 1fr; }
	.wp-block-buttons { flex-direction: column; }
	.wp-block-button  { width: 100%; }
	.wp-block-button__link { justify-content: center; width: 100%; }

	/* Statistieken: 1 kolom */
	.solida-stats .wp-block-column { min-width: 100%; }

	/* Processtappen: stapelen */
	.process-steps { grid-template-columns: 1fr; }
	.process-step:not(:last-child)::after { display: none; }

	/* Team grid: 2 kolommen */
	.team-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-6); }
	.team-card__photo { width: 80px; height: 80px; }

	/* GravityForms dark: 1 kolom op smal scherm */
	.solida-form-dark .gform_wrapper .gform_fields { grid-template-columns: 1fr; }
}
