/*
Theme Name: Vakantiehuisje
Theme URI: https://contentvizier.nl
Description: Vakantiehuisje12personen.nl — affiliate theme voor groepsaccommodaties. "Landhuis magazine" design.
Author: ContentVizier
Author URI: https://contentvizier.nl
Version: 3.0
*/

/* ==========================================================================
   Design tokens — Landhuis Magazine
   ========================================================================== */
:root {
	--color-primary: #4C6B3C;        /* dennengroen */
	--color-primary-text: #ffffff;
	--color-accent: #B5482C;         /* stempel-rood / baksteen */
	--color-accent-text: #ffffff;
	--color-deep: #2A1F17;           /* inkt bruin */
	--color-deep-text: #ffffff;
	--color-warm: #E5B64C;           /* mosterd */
	--color-cream: #F2EADA;          /* perkament */
	--color-paper: #FBF6EA;          /* zachter crème */
	--color-wood: #8B5E3C;           /* warme hout */
	--color-ink: #2A1F17;

	--color-text: #3a2e24;
	--color-muted: #7a6b5e;
	--color-border: #d9cfb8;
	--color-border-soft: #ebe2cf;
	--color-bg: #F2EADA;
	--color-card: #FFFBF2;

	/* Radius (landhuis = weinig rondingen) */
	--radius-sm: 2px;
	--radius-md: 4px;
	--radius-lg: 6px;

	/* Shadows — landhuis magazine: dichtbij, hard randje */
	--shadow-hard:  4px 4px 0 rgba(42,31,23,0.12);
	--shadow-hardh: 6px 6px 0 rgba(42,31,23,0.18);
	--shadow-soft:  0 1px 2px rgba(42,31,23,0.06);

	--font-heading: 'Merriweather', Georgia, serif;
	--font-body: 'Raleway', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	--font-script: 'Caveat', 'Brush Script MT', cursive;
}

/* ==========================================================================
   Base
   ========================================================================== */
.alignnone{margin:0}
.aligncenter,div.aligncenter{display:block;margin:5px auto}
.alignright{float:right;margin:0 0 15px 15px}
.alignleft{float:left;margin:0 15px 15px 0}
a img.alignright{float:right;margin:0 0 15px 15px}
a img.alignnone{margin:0}
a img.alignleft{float:left;margin:0 15px 15px 0}
a img.aligncenter{display:block;margin-left:auto;margin-right:auto}

html { scroll-behavior: smooth; }

body {
	font-family: var(--font-body);
	color: var(--color-text);
	background: var(--color-bg);
	padding-top: 76px; /* alleen navbar — geen topbar in dit design */
	background-image:
		radial-gradient(circle at 10% 0%, rgba(139,94,60,0.05) 0, transparent 35%),
		radial-gradient(circle at 90% 10%, rgba(76,107,60,0.05) 0, transparent 30%);
}
@media (max-width: 767px) {
	body { padding-top: 64px; }
}

.full-bleed {
	width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
}

h1, h2, h3, h4, h5, .h1, .h2, .h3, .h4, .h5 {
	font-family: var(--font-heading);
	font-weight: 700;
	color: var(--color-deep);
	line-height: 1.2;
	letter-spacing: -0.01em;
}

h1 { font-size: clamp(2.1rem, 4.5vw, 3.4rem); font-weight: 900; }
h2 { font-size: clamp(1.55rem, 3vw, 2.3rem); }
h3 { font-size: clamp(1.2rem, 2vw, 1.55rem); }

.script {
	font-family: var(--font-script);
	font-weight: 600;
	color: var(--color-accent);
	font-size: 1.5rem;
	line-height: 1;
	display: inline-block;
}

a { color: var(--color-primary); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; text-decoration-color: rgba(76,107,60,0.35); transition: all .2s ease; }
a:hover { color: var(--color-accent); text-decoration-color: var(--color-accent); }

img { max-width: 100%; height: auto; }

/* ==========================================================================
   Buttons — rechthoekig, harde shadow, geen pills
   ========================================================================== */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-family: var(--font-body);
	font-weight: 700;
	font-size: 0.92rem;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	border-radius: var(--radius-sm);
	padding: 0.7rem 1.3rem;
	transition: transform .15s ease, box-shadow .15s ease;
	border: 2px solid var(--color-deep);
	line-height: 1.2;
	text-decoration: none;
	box-shadow: var(--shadow-hard);
}
.btn:hover { transform: translate(-2px, -2px); box-shadow: var(--shadow-hardh); text-decoration: none; }
.btn:active { transform: translate(1px, 1px); box-shadow: 2px 2px 0 rgba(42,31,23,0.12); }
.btn-sm { font-size: 0.78rem; padding: 0.5rem 0.9rem; }
.btn-lg { font-size: 1rem; padding: 0.9rem 1.6rem; }

.btn-primary, .btn-vh-primary {
	background: var(--color-primary);
	color: #fff;
}
.btn-primary:hover, .btn-vh-primary:hover { background: var(--color-primary); color: #fff; }

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

.btn-warm {
	background: var(--color-warm);
	color: var(--color-deep);
}
.btn-warm:hover { background: var(--color-warm); color: var(--color-deep); }

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

/* ==========================================================================
   Header — gecentreerd, geen topbar
   ========================================================================== */
.site-header-fixed {
	position: fixed;
	top: 0; left: 0; right: 0;
	z-index: 1030;
	background: var(--color-card);
	border-bottom: 2px solid var(--color-deep);
}
.usp-topbar { display: none; } /* geen topbar in dit design */

.site-navbar {
	background: transparent !important;
	padding: 0.4rem 0;
}

.site-navbar .container { position: relative; }

.site-navbar .navbar-brand {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	font-family: var(--font-heading);
	font-weight: 900;
	font-size: 1.15rem;
	color: var(--color-deep);
	text-decoration: none;
	padding: 0.4rem 0;
}
.site-navbar .site-logo { height: 40px; width: auto; }
.site-navbar .site-wordmark {
	font-family: var(--font-heading);
	font-weight: 900;
	font-size: 1.05rem;
	line-height: 1.05;
	color: var(--color-deep);
	letter-spacing: -0.01em;
}
.site-navbar .site-wordmark::after {
	content: "";
	display: block;
	width: 34px;
	height: 3px;
	background: var(--color-accent);
	margin-top: 3px;
}

.site-navbar .navbar-nav .nav-link {
	font-family: var(--font-body);
	font-weight: 600;
	font-size: 0.9rem;
	color: var(--color-deep) !important;
	padding: 0.4rem 0.85rem !important;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	position: relative;
	text-decoration: none;
}
.site-navbar .navbar-nav .nav-link::after {
	content: "";
	position: absolute;
	left: 0.85rem;
	right: 0.85rem;
	bottom: 0.1rem;
	height: 2px;
	background: var(--color-accent);
	transform: scaleX(0);
	transform-origin: left;
	transition: transform .2s ease;
}
.site-navbar .navbar-nav .nav-link:hover::after,
.site-navbar .navbar-nav .current-menu-item > .nav-link::after,
.site-navbar .navbar-nav .current_page_item > .nav-link::after {
	transform: scaleX(1);
}
.site-navbar .navbar-nav .nav-link:hover,
.site-navbar .navbar-nav .current-menu-item > .nav-link,
.site-navbar .navbar-nav .current_page_item > .nav-link {
	color: var(--color-accent) !important;
}

.site-navbar .dropdown-menu {
	border: 2px solid var(--color-deep);
	box-shadow: var(--shadow-hard);
	border-radius: var(--radius-sm);
	padding: 0.4rem;
	background: var(--color-card);
}
.site-navbar .dropdown-item {
	padding: 0.4rem 0.7rem;
	color: var(--color-deep);
	font-weight: 500;
	text-transform: none;
	letter-spacing: 0;
	font-size: 0.9rem;
}
.site-navbar .dropdown-item:hover,
.site-navbar .dropdown-item:focus {
	background: var(--color-cream);
	color: var(--color-accent);
}

.btn-header-cta {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	background: var(--color-accent);
	color: #fff;
	border: 2px solid var(--color-deep);
	border-radius: var(--radius-sm);
	padding: 0.45rem 0.9rem;
	font-weight: 700;
	font-size: 0.8rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	box-shadow: 3px 3px 0 var(--color-deep);
	transition: transform .15s ease, box-shadow .15s ease;
	text-decoration: none;
}
.btn-header-cta:hover { transform: translate(-1px, -1px); box-shadow: 4px 4px 0 var(--color-deep); color: #fff; }

/* Search — compact inline */
.site-search .form-control {
	border: 2px solid var(--color-deep);
	border-right: 0;
	border-radius: var(--radius-sm) 0 0 var(--radius-sm);
	font-size: 0.85rem;
	background: var(--color-paper);
}
.site-search .btn-search {
	background: var(--color-deep);
	color: #fff;
	border: 2px solid var(--color-deep);
	border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
	padding: 0 0.9rem;
	box-shadow: none !important;
	transform: none !important;
}

.navbar-toggler { border: 2px solid var(--color-deep) !important; border-radius: var(--radius-sm); padding: 0.25rem 0.5rem; }
.navbar-toggler:focus { box-shadow: none; }

/* ==========================================================================
   Hero — split, full-bleed image rechts
   ========================================================================== */
.hero {
	margin-bottom: 3rem;
	width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	margin-top: -1rem;
	background: var(--color-cream);
	border-bottom: 2px solid var(--color-deep);
}
.hero__grid {
	display: grid;
	grid-template-columns: 1fr 1.1fr;
	min-height: 440px;
	align-items: stretch;
}
.hero__copy {
	padding: 4rem 3rem 4rem max(2rem, calc((100vw - 1140px) / 2 + 1rem));
	display: flex;
	flex-direction: column;
	justify-content: center;
}
.hero__label {
	font-family: var(--font-script);
	font-size: 1.8rem;
	color: var(--color-accent);
	line-height: 1;
	margin-bottom: 0.35rem;
}
.hero__title {
	font-family: var(--font-heading);
	font-weight: 900;
	font-size: clamp(2rem, 4.2vw, 3.1rem);
	line-height: 1.05;
	margin-bottom: 1rem;
	color: var(--color-deep);
}
.hero__title em { color: var(--color-accent); font-style: normal; }
.hero__sub {
	font-size: 1.05rem;
	color: var(--color-text);
	margin-bottom: 1.5rem;
	max-width: 34rem;
	line-height: 1.55;
}
.hero__meta {
	font-size: 0.8rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--color-muted);
	margin-top: 1.5rem;
	display: flex;
	gap: 1.25rem;
	flex-wrap: wrap;
}
.hero__meta i { color: var(--color-primary); margin-right: 0.3rem; }

.hero__img-wrap {
	position: relative;
	overflow: hidden;
	border-left: 2px solid var(--color-deep);
}
.hero__img-wrap img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.hero__stamp {
	position: absolute;
	top: 1.5rem;
	right: 1.5rem;
	width: 110px;
	height: 110px;
	border-radius: 50%;
	background: var(--color-warm);
	color: var(--color-deep);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	font-family: var(--font-script);
	font-size: 1.35rem;
	line-height: 1.05;
	font-weight: 700;
	transform: rotate(-8deg);
	border: 2px solid var(--color-deep);
	box-shadow: var(--shadow-hard);
	padding: 0.5rem;
}
.hero__stamp strong { font-size: 1.7rem; font-family: var(--font-heading); }

@media (max-width: 991px) {
	.hero__grid { grid-template-columns: 1fr; }
	.hero__img-wrap { border-left: 0; border-top: 2px solid var(--color-deep); min-height: 280px; }
	.hero__copy { padding: 2.5rem 1.5rem; }
	.hero__stamp { width: 90px; height: 90px; font-size: 1.1rem; top: 1rem; right: 1rem; }
	.hero__stamp strong { font-size: 1.4rem; }
}

/* Masthead (single/page) — inktrand onderaan */
.masthead {
	background-size: cover;
	background-position: center;
	min-height: 340px;
	display: flex;
	align-items: flex-end;
	overflow: hidden;
	margin-bottom: 2.5rem;
	position: relative;
	width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	margin-top: -1rem;
	border-bottom: 2px solid var(--color-deep);
}
.masthead h1 { color: #fff; margin: 0; padding: 2rem 0; text-shadow: 0 2px 12px rgba(0,0,0,0.4); }
.masthead > .container { width: 100%; }

/* ==========================================================================
   Section header — editorial style
   ========================================================================== */
.section { padding: 3.5rem 0; position: relative; }
.section--paper { background: var(--color-paper); border-top: 1px solid var(--color-border-soft); border-bottom: 1px solid var(--color-border-soft); margin: 0 calc(50% - 50vw); padding-left: max(1rem, calc((100vw - 1140px)/2 + 12px)); padding-right: max(1rem, calc((100vw - 1140px)/2 + 12px)); }
.section--deep { background: var(--color-deep); color: #fff; }
.section--deep h1, .section--deep h2, .section--deep h3 { color: #fff; }

.section-head {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 1rem;
	margin-bottom: 2rem;
	padding-bottom: 1rem;
	border-bottom: 2px solid var(--color-deep);
	flex-wrap: wrap;
}
.section-head__title h2 { margin: 0; }
.section-head__label {
	font-family: var(--font-script);
	color: var(--color-accent);
	font-size: 1.5rem;
	line-height: 1;
	display: block;
	margin-bottom: 0.2rem;
}
.section-head__link {
	font-weight: 700;
	font-size: 0.82rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-deep);
	text-decoration: none;
	border-bottom: 2px solid var(--color-accent);
	padding-bottom: 2px;
}
.section-head__link:hover { color: var(--color-accent); }

/* ==========================================================================
   Bento — homepage pijlers (asymmetrisch)
   ========================================================================== */
.bento {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	grid-auto-rows: 170px;
	gap: 1rem;
}
.bento__cell {
	position: relative;
	border: 2px solid var(--color-deep);
	border-radius: var(--radius-md);
	overflow: hidden;
	background: var(--color-card);
	box-shadow: var(--shadow-hard);
	transition: transform .2s ease, box-shadow .2s ease;
	text-decoration: none;
	color: inherit;
	display: block;
}
.bento__cell:hover { transform: translate(-3px,-3px); box-shadow: var(--shadow-hardh); color: inherit; text-decoration: none; }
.bento__cell img {
	position: absolute; inset: 0;
	width: 100%; height: 100%; object-fit: cover;
	transition: transform .4s ease;
}
.bento__cell:hover img { transform: scale(1.06); }
.bento__cell__overlay {
	position: absolute; inset: 0;
	background: linear-gradient(180deg, rgba(42,31,23,0) 30%, rgba(42,31,23,0.85) 100%);
	display: flex; flex-direction: column; justify-content: flex-end;
	padding: 1rem 1.2rem;
	color: #fff;
}
.bento__cell__label {
	font-family: var(--font-script);
	color: var(--color-warm);
	font-size: 1.2rem;
	line-height: 1;
	margin-bottom: 0.15rem;
}
.bento__cell__title {
	font-family: var(--font-heading);
	font-weight: 900;
	font-size: 1.25rem;
	color: #fff;
	line-height: 1.15;
	margin-bottom: 0.2rem;
}
.bento__cell__sub { font-size: 0.8rem; color: rgba(255,255,255,0.85); }
.bento__cell--hero { grid-column: span 3; grid-row: span 2; }
.bento__cell--tall { grid-column: span 3; grid-row: span 2; }
.bento__cell--wide { grid-column: span 3; grid-row: span 1; }
.bento__cell--std  { grid-column: span 3; grid-row: span 1; }
.bento__cell--small { grid-column: span 2; grid-row: span 1; }
.bento__cell--solid { background: var(--color-deep); color: #fff; }
.bento__cell--solid .bento__cell__overlay { background: none; color: #fff; padding: 1.5rem; justify-content: center; }
.bento__cell--solid .bento__cell__title { color: #fff; }
.bento__cell--solid .bento__cell__sub { color: rgba(255,255,255,0.8); }

@media (max-width: 767px) {
	.bento { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 150px; }
	.bento__cell--hero, .bento__cell--tall { grid-column: span 2; grid-row: span 2; }
	.bento__cell--wide, .bento__cell--std, .bento__cell--small { grid-column: span 1; grid-row: span 1; }
}

/* ==========================================================================
   Feature card (horizontaal, magazine style)
   ========================================================================== */
.feature-card {
	display: grid;
	grid-template-columns: 42% 1fr;
	background: var(--color-card);
	border: 2px solid var(--color-deep);
	border-radius: var(--radius-md);
	overflow: hidden;
	box-shadow: var(--shadow-hard);
	transition: transform .2s ease, box-shadow .2s ease;
	margin-bottom: 1.5rem;
	position: relative;
}
.feature-card:hover { transform: translate(-3px,-3px); box-shadow: var(--shadow-hardh); }
.feature-card__media {
	position: relative;
	overflow: hidden;
	min-height: 240px;
}
.feature-card__media img {
	position: absolute; inset: 0;
	width: 100%; height: 100%; object-fit: cover;
	transition: transform .4s ease;
}
.feature-card:hover .feature-card__media img { transform: scale(1.05); }
.feature-card__badge {
	position: absolute;
	top: 0.8rem; left: 0.8rem;
	background: var(--color-warm);
	color: var(--color-deep);
	border: 2px solid var(--color-deep);
	font-family: var(--font-script);
	font-size: 1.1rem;
	line-height: 1;
	padding: 0.35rem 0.7rem 0.45rem;
	transform: rotate(-4deg);
	box-shadow: 2px 2px 0 var(--color-deep);
}
.feature-card__body {
	padding: 1.5rem 1.75rem;
	display: flex;
	flex-direction: column;
}
.feature-card__eyebrow {
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--color-accent);
	font-weight: 700;
	margin-bottom: 0.4rem;
}
.feature-card__title {
	font-family: var(--font-heading);
	font-weight: 900;
	font-size: 1.35rem;
	color: var(--color-deep);
	line-height: 1.25;
	margin-bottom: 0.5rem;
}
.feature-card__title a { color: inherit; text-decoration: none; }
.feature-card__title a:hover { color: var(--color-accent); }
.feature-card__meta {
	display: flex; flex-wrap: wrap;
	gap: 1rem;
	font-size: 0.82rem;
	color: var(--color-muted);
	margin-bottom: 0.75rem;
}
.feature-card__meta i { color: var(--color-primary); margin-right: 0.3rem; }
.feature-card__text {
	font-size: 0.92rem;
	color: var(--color-text);
	line-height: 1.55;
	margin-bottom: 1rem;
	flex: 1;
}
.feature-card__cta { margin-top: auto; align-self: flex-start; }

@media (max-width: 767px) {
	.feature-card { grid-template-columns: 1fr; }
	.feature-card__media { min-height: 200px; }
}

/* ==========================================================================
   Post card (blog) — verticaal maar magazine stijl
   ========================================================================== */
.post-card {
	background: var(--color-card);
	border: 2px solid var(--color-deep);
	border-radius: var(--radius-md);
	overflow: hidden;
	box-shadow: var(--shadow-hard);
	transition: transform .2s ease, box-shadow .2s ease;
	height: 100%;
	display: flex;
	flex-direction: column;
}
.post-card:hover { transform: translate(-3px,-3px); box-shadow: var(--shadow-hardh); }
.post-card__media {
	aspect-ratio: 3/2;
	overflow: hidden;
	background: var(--color-cream);
	border-bottom: 2px solid var(--color-deep);
	position: relative;
	display: block;
}
.post-card__media img {
	width: 100%; height: 100%; object-fit: cover;
	transition: transform .4s ease;
}
.post-card:hover .post-card__media img { transform: scale(1.05); }
.post-card__body {
	padding: 1.1rem 1.25rem 1.25rem;
	display: flex;
	flex-direction: column;
	flex: 1;
}
.post-card__cat {
	font-size: 0.72rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--color-accent);
	font-weight: 700;
	margin-bottom: 0.35rem;
}
.post-card__title {
	font-family: var(--font-heading);
	font-size: 1.1rem;
	font-weight: 900;
	margin-bottom: 0.5rem;
	color: var(--color-deep);
	line-height: 1.3;
}
.post-card__title a { color: inherit; text-decoration: none; }
.post-card__title a:hover { color: var(--color-accent); }
.post-card__excerpt {
	font-size: 0.88rem;
	color: var(--color-muted);
	margin-bottom: 0.9rem;
	flex: 1;
	line-height: 1.55;
}
.post-card__meta {
	font-size: 0.76rem;
	color: var(--color-muted);
	display: flex;
	gap: 0.9rem;
	padding-top: 0.75rem;
	border-top: 1px dashed var(--color-border);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}
.post-card__meta i { color: var(--color-primary); margin-right: 0.25rem; }

/* ==========================================================================
   Single — sidebar links
   ========================================================================== */
.single-layout {
	display: grid;
	grid-template-columns: 280px 1fr;
	gap: 2.5rem;
	margin-bottom: 3rem;
}
@media (max-width: 991px) {
	.single-layout { grid-template-columns: 1fr; gap: 1.5rem; }
	.single-layout__sidebar { order: 2; }
}

.single-article {
	font-size: 1.05rem;
	line-height: 1.8;
	color: var(--color-text);
	background: var(--color-card);
	border: 2px solid var(--color-deep);
	border-radius: var(--radius-md);
	padding: 2rem 2.25rem;
	box-shadow: var(--shadow-hard);
}
.single-article h2 {
	margin: 2rem 0 1rem;
	position: relative;
	padding-left: 1rem;
	border-left: 4px solid var(--color-accent);
}
.single-article h3 { margin: 1.5rem 0 0.75rem; }
.single-article p { margin-bottom: 1.25rem; }
.single-article img {
	border: 2px solid var(--color-deep);
	border-radius: var(--radius-sm);
	margin: 1.5rem 0;
	box-shadow: var(--shadow-hard);
}
.single-article blockquote {
	border-left: 0;
	background: var(--color-cream);
	border-top: 2px solid var(--color-deep);
	border-bottom: 2px solid var(--color-deep);
	padding: 1.25rem 1.5rem;
	margin: 1.75rem 0;
	font-family: var(--font-heading);
	font-style: italic;
	color: var(--color-deep);
	font-size: 1.1rem;
}
.single-article a { color: var(--color-accent); text-decoration-color: var(--color-accent); }

.article-meta {
	display: flex;
	gap: 1rem;
	flex-wrap: wrap;
	font-size: 0.78rem;
	color: var(--color-muted);
	margin-bottom: 1.5rem;
	padding-bottom: 1rem;
	border-bottom: 1px dashed var(--color-border);
	text-transform: uppercase;
	letter-spacing: 0.08em;
}
.article-meta i { color: var(--color-primary); margin-right: 0.3rem; }

.top-cta {
	background: var(--color-cream);
	border: 2px solid var(--color-deep);
	border-radius: var(--radius-sm);
	padding: 1.1rem 1.25rem;
	margin-bottom: 1.75rem;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	box-shadow: var(--shadow-hard);
	position: relative;
}
.top-cta::before {
	content: "Onze tip";
	position: absolute;
	top: -14px; left: 14px;
	background: var(--color-accent);
	color: #fff;
	font-family: var(--font-script);
	padding: 0 0.6rem;
	font-size: 1.1rem;
	line-height: 1.3;
	border: 2px solid var(--color-deep);
	transform: rotate(-2deg);
}
.top-cta__text { flex: 1; min-width: 14rem; }
.top-cta__text strong { display: block; color: var(--color-deep); font-family: var(--font-heading); font-size: 1.05rem; }
.top-cta__text small { color: var(--color-muted); }

/* ==========================================================================
   Sidebar (single links, archive links)
   ========================================================================== */
#stickIt { top: 90px; }

.sb-block {
	background: var(--color-card);
	border: 2px solid var(--color-deep);
	border-radius: var(--radius-md);
	padding: 1.25rem;
	margin-bottom: 1.25rem;
	box-shadow: var(--shadow-hard);
}
.sb-block h4 {
	font-family: var(--font-heading);
	font-size: 1rem;
	font-weight: 900;
	color: var(--color-deep);
	margin: 0 0 0.9rem;
	padding-bottom: 0.6rem;
	border-bottom: 2px solid var(--color-deep);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}
.sb-block h4 .script {
	display: block;
	font-family: var(--font-script);
	color: var(--color-accent);
	font-size: 1.2rem;
	text-transform: none;
	letter-spacing: 0;
	line-height: 1;
	margin-bottom: 0.1rem;
	font-weight: 600;
}

.sb-trust ul { list-style: none; padding: 0; margin: 0; }
.sb-trust li {
	display: flex;
	gap: 0.6rem;
	font-size: 0.88rem;
	margin-bottom: 0.55rem;
	color: var(--color-deep);
	line-height: 1.45;
}
.sb-trust i { color: var(--color-primary); margin-top: 0.2rem; flex-shrink: 0; }

.sb-partner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	padding: 0.7rem 0.8rem;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	margin-bottom: 0.5rem;
	background: var(--color-paper);
	color: var(--color-deep);
	font-weight: 600;
	text-decoration: none;
	transition: all .15s ease;
}
.sb-partner:hover {
	border-color: var(--color-accent);
	background: #fff;
	color: var(--color-accent);
	transform: translateX(2px);
}
.sb-partner i { color: var(--color-accent); }

.sb-help { background: var(--color-warm); border-color: var(--color-deep); }
.sb-help h4 { border-color: rgba(42,31,23,0.3); }
.sb-help p { font-size: 0.88rem; color: var(--color-deep); margin-bottom: 1rem; line-height: 1.5; }

.sb-recent__item {
	display: flex;
	gap: 0.75rem;
	margin-bottom: 0.85rem;
	padding-bottom: 0.85rem;
	border-bottom: 1px dashed var(--color-border);
}
.sb-recent__item:last-child { border: 0; margin-bottom: 0; padding-bottom: 0; }
.sb-recent__thumb {
	flex: 0 0 64px;
	width: 64px;
	height: 52px;
	overflow: hidden;
	border: 1px solid var(--color-deep);
	border-radius: var(--radius-sm);
}
.sb-recent__thumb img { width:100%; height:100%; object-fit: cover; }
.sb-recent__title {
	font-size: 0.88rem;
	font-weight: 700;
	color: var(--color-deep);
	line-height: 1.3;
	font-family: var(--font-heading);
}
.sb-recent__title a { color: inherit; text-decoration: none; }
.sb-recent__title a:hover { color: var(--color-accent); }

/* ==========================================================================
   CTA / Newsletter
   ========================================================================== */
.cta-banner {
	background: var(--color-deep);
	color: #fff;
	padding: 2.5rem 2rem;
	border-radius: var(--radius-md);
	margin: 3rem 0;
	border: 2px solid var(--color-deep);
	position: relative;
	overflow: hidden;
	display: grid;
	grid-template-columns: 1fr auto;
	align-items: center;
	gap: 1.5rem;
}
.cta-banner::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image: radial-gradient(circle at 85% 50%, rgba(229,182,76,0.15) 0, transparent 50%);
	pointer-events: none;
}
.cta-banner__text h2 {
	color: #fff;
	margin: 0 0 0.35rem;
	font-size: clamp(1.3rem, 2.5vw, 1.85rem);
}
.cta-banner__text p { color: rgba(255,255,255,0.85); margin: 0; }
.cta-banner__label {
	font-family: var(--font-script);
	color: var(--color-warm);
	font-size: 1.35rem;
	line-height: 1;
	margin-bottom: 0.3rem;
	display: block;
}
.cta-banner__actions { display: flex; flex-wrap: wrap; gap: 0.75rem; }

@media (max-width: 767px) {
	.cta-banner { grid-template-columns: 1fr; padding: 2rem 1.5rem; }
}

.newsletter {
	background: var(--color-cream);
	padding: 2.5rem 2rem;
	border: 2px solid var(--color-deep);
	border-radius: var(--radius-md);
	text-align: center;
	margin: 3rem 0;
	box-shadow: var(--shadow-hard);
}
.newsletter h3 { font-family: var(--font-heading); }

/* ==========================================================================
   Trust band (onder content)
   ========================================================================== */
.trust-band {
	background: var(--color-deep);
	color: #fff;
	padding: 1.5rem 0;
	margin-top: 3rem;
	border-top: 2px solid var(--color-deep);
	border-bottom: 2px solid var(--color-deep);
}
.trust-band__inner {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1.5rem;
}
.trust-item {
	display: flex;
	align-items: center;
	gap: 0.7rem;
	font-size: 0.85rem;
	color: rgba(255,255,255,0.9);
	font-weight: 600;
}
.trust-item i { color: var(--color-warm); font-size: 1.3rem; }
@media (max-width: 767px) {
	.trust-band__inner { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
}

/* ==========================================================================
   Footer — stacked, landhuis stijl
   ========================================================================== */
.site-footer {
	background: var(--color-paper);
	color: var(--color-deep);
	padding: 3rem 0 1.5rem;
	border-top: 2px solid var(--color-deep);
}
.site-footer h5 {
	color: var(--color-deep);
	font-family: var(--font-heading);
	font-size: 0.95rem;
	margin-bottom: 1rem;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	padding-bottom: 0.5rem;
	border-bottom: 1px dashed var(--color-border);
}
.site-footer a { color: var(--color-deep); text-decoration: none; }
.site-footer a:hover { color: var(--color-accent); text-decoration: underline; }

.footer-brand-bar {
	display: grid;
	grid-template-columns: auto 1fr auto;
	gap: 2rem;
	align-items: center;
	padding-bottom: 2rem;
	margin-bottom: 2rem;
	border-bottom: 2px solid var(--color-deep);
}
.footer-brand__logo { display: flex; align-items: center; gap: 0.75rem; }
.footer-brand__logo img { height: 44px; width: auto; }
.footer-brand__name {
	font-family: var(--font-heading);
	color: var(--color-deep);
	font-size: 1.3rem;
	font-weight: 900;
	line-height: 1.05;
}
.footer-brand__desc {
	font-size: 0.92rem;
	color: var(--color-muted);
	margin: 0;
	max-width: 40rem;
	line-height: 1.55;
}
.footer-brand__script {
	font-family: var(--font-script);
	color: var(--color-accent);
	font-size: 1.6rem;
	line-height: 1;
	transform: rotate(-4deg);
	display: inline-block;
}
@media (max-width: 767px) {
	.footer-brand-bar { grid-template-columns: 1fr; }
	.footer-brand__script { display: none; }
}

.site-footer .list-unstyled li, .site-footer .list-group-item {
	background: transparent;
	border: 0;
	padding: 0.35rem 0;
}

.site-footer-bottom {
	background: var(--color-deep);
	color: rgba(255,255,255,0.75);
	padding: 1rem 0;
	font-size: 0.82rem;
}
.site-footer-bottom__inner {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 0.5rem;
}
.site-footer-bottom a { color: rgba(255,255,255,0.9); }
.site-footer-bottom a:hover { color: var(--color-warm); }
.site-footer-bottom p { margin: 0; }

/* ==========================================================================
   Pagination
   ========================================================================== */
.pagination .page-link {
	color: var(--color-deep);
	border: 2px solid var(--color-deep);
	margin: 0 0.2rem;
	border-radius: var(--radius-sm);
	background: var(--color-card);
	font-weight: 700;
	box-shadow: 2px 2px 0 var(--color-deep);
}
.pagination .page-link:hover {
	background: var(--color-warm);
	color: var(--color-deep);
	transform: translate(-1px,-1px);
	box-shadow: 3px 3px 0 var(--color-deep);
}
.pagination .active .page-link {
	background: var(--color-accent);
	border-color: var(--color-deep);
	color: #fff;
}

/* ==========================================================================
   Disclaimer / misc
   ========================================================================== */
.aff-disclaimer {
	font-size: 0.78rem;
	color: var(--color-muted);
	background: var(--color-paper);
	border: 1px dashed var(--color-border);
	padding: 0.7rem 0.9rem;
	border-radius: var(--radius-sm);
	margin: 1.5rem 0;
	line-height: 1.5;
}
.aff-disclaimer i { color: var(--color-accent); margin-right: 0.3rem; }

.page-card {
	background: var(--color-card);
	border: 2px solid var(--color-deep);
	border-radius: var(--radius-md);
	padding: 2rem 2.25rem;
	box-shadow: var(--shadow-hard);
}

.text-accent { color: var(--color-accent) !important; }
.text-deep { color: var(--color-deep) !important; }
.bg-cream, .bg-sand { background: var(--color-cream) !important; }
.bg-deep { background: var(--color-deep) !important; color: #fff; }

/* ==========================================================================
   Sticky mobile CTA bar
   ========================================================================== */
.mobile-cta-bar {
	display: none;
}
@media (max-width: 767px) {
	body.single .mobile-cta-bar,
	body.page .mobile-cta-bar { display: none; } /* only when needed via JS/ACF */
}

/* ==========================================================================
   404 / empty
   ========================================================================== */
.empty-state {
	text-align: center;
	padding: 3rem 1.5rem;
	max-width: 42rem;
	margin: 2rem auto;
	background: var(--color-card);
	border: 2px solid var(--color-deep);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-hard);
}
.empty-state > i {
	font-size: 2.5rem;
	color: var(--color-accent);
	margin-bottom: 1rem;
	display: inline-block;
}
.empty-state h1, .empty-state h2 {
	font-size: clamp(1.5rem, 3vw, 2rem);
	margin-bottom: 0.75rem;
}
.empty-state p { color: var(--color-muted); margin-bottom: 1.5rem; }
.empty-state .script { font-size: 1.6rem; display: block; margin-bottom: 0.25rem; }

/* ==========================================================================
   Partner strip (logo's van affiliate partners)
   ========================================================================== */
.partner-strip {
	background: var(--color-paper);
	border: 2px solid var(--color-deep);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-hard);
	padding: 1.5rem 1.75rem;
	margin: 2.5rem 0;
}
.partner-strip__head {
	display: flex;
	align-items: center;
	gap: 1rem;
	margin-bottom: 1.25rem;
	padding-bottom: 1rem;
	border-bottom: 1px dashed var(--color-wood);
}
.partner-strip__head .script {
	font-size: 1.8rem;
	color: var(--color-accent);
	line-height: 1;
	transform: rotate(-3deg);
	display: inline-block;
}
.partner-strip__head h3 {
	margin: 0;
	font-size: clamp(1.1rem, 2vw, 1.35rem);
}
.partner-strip__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
	gap: 1.25rem 2rem;
	align-items: center;
	justify-items: center;
}
.partner-strip__item {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	padding: 0.5rem;
	filter: grayscale(100%);
	opacity: 0.7;
	transition: filter 0.25s ease, opacity 0.25s ease, transform 0.25s ease;
}
.partner-strip__item:hover {
	filter: grayscale(0);
	opacity: 1;
	transform: translateY(-2px);
}
.partner-strip__item img {
	max-height: 48px;
	max-width: 140px;
	width: auto;
	height: auto;
	object-fit: contain;
}
.partner-strip__item--text {
	font-family: var(--font-heading);
	font-weight: 700;
	color: var(--color-deep);
	font-size: 1.1rem;
	letter-spacing: 0.02em;
}

/* ==========================================================================
   Region tiles (kies jouw regio)
   ========================================================================== */
.region-tiles {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1rem;
}
.region-tile {
	position: relative;
	display: block;
	aspect-ratio: 4 / 3;
	border: 2px solid var(--color-deep);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-hard);
	overflow: hidden;
	background: var(--color-primary);
	text-decoration: none;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.region-tile:hover {
	transform: translate(-2px, -2px);
	box-shadow: var(--shadow-hardh);
	text-decoration: none;
}
.region-tile img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.4s ease;
}
.region-tile:hover img {
	transform: scale(1.05);
}
.region-tile::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(42,31,23,0.15) 0%, rgba(42,31,23,0.75) 100%);
	z-index: 1;
}
.region-tile__body {
	position: absolute;
	left: 0; right: 0; bottom: 0;
	padding: 1rem 1.25rem;
	color: #fff;
	z-index: 2;
}
.region-tile__name {
	font-family: var(--font-heading);
	font-weight: 900;
	font-size: clamp(1.1rem, 2vw, 1.5rem);
	line-height: 1.15;
	margin: 0;
	color: #fff;
	text-shadow: 0 1px 2px rgba(0,0,0,0.3);
}
.region-tile__count {
	display: inline-block;
	margin-top: 0.4rem;
	font-size: 0.82rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	background: var(--color-warm);
	color: var(--color-deep);
	padding: 0.18rem 0.55rem;
	border-radius: var(--radius-sm);
}
.region-tile--wide { grid-column: span 2; aspect-ratio: 16 / 9; }
.region-tile--solid {
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--color-primary);
	color: #fff;
	text-align: center;
	padding: 1.5rem;
}
.region-tile--solid::before { display: none; }
.region-tile--solid .region-tile__body { position: static; padding: 0; }

@media (max-width: 767px) {
	.region-tiles { grid-template-columns: repeat(2, 1fr); }
	.region-tile--wide { grid-column: span 2; aspect-ratio: 16 / 10; }
	.partner-strip__head { flex-direction: column; align-items: flex-start; gap: 0.25rem; text-align: left; }
}

/* ==========================================================================
   Responsive helpers
   ========================================================================== */
@media (max-width: 767px) {
	.section { padding: 2.5rem 0; }
	.masthead { min-height: 220px; }
	.single-article { padding: 1.5rem 1.25rem; }
	#stickIt { position: static !important; top: auto; }
}
