:root {
	--db-ink: #101828;
	--db-navy: #0b1f3a;
	--db-cream: #faf7f0;
	--db-surface: #ffffff;
	--db-border: #e8e2d8;
	--db-muted: #667085;
	--db-green: #5f8d4e;
	--db-rust: #d96b3b;
	--db-blue-soft: #eaf2f8;
	--db-sand-soft: #f7efe3;
	--db-lavender-soft: #f3eef8;
	--db-radius-sm: 8px;
	--db-radius-md: 16px;
	--db-radius-lg: 24px;
	--db-shadow: 0 18px 45px rgba(16, 24, 40, 0.08);
}

html {
	min-height: 100%;
	scroll-behavior: smooth;
	overflow-x: clip;
}

body {
	min-height: 100%;
	background: var(--db-cream);
	color: var(--db-ink);
	font-size: 17px;
	line-height: 1.7;
	overflow-x: clip;
}

body.is-dark {
	--db-ink: #f4efe5;
	--db-navy: #f8f3ea;
	--db-cream: #111a24;
	--db-surface: #182330;
	--db-border: #344154;
	--db-muted: #c7d0dd;
	--db-blue-soft: #17283a;
	--db-sand-soft: #2b241b;
	--db-lavender-soft: #261f32;
	background: var(--db-cream);
	color: var(--db-ink);
}

a {
	text-decoration-thickness: 1px;
	text-underline-offset: 0.18em;
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
	outline: 3px solid color-mix(in srgb, var(--db-rust), white 22%);
	outline-offset: 3px;
}

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

.wp-site-blocks {
	position: relative;
	min-height: 100vh;
	display: flex;
	flex-direction: column;
	padding-top: 0;
	overflow-x: clip;
}

.wp-site-blocks > main,
.wp-site-blocks > .wp-block-group[tagname="main"] {
	flex: 1 0 auto;
}

.wp-site-blocks > .wp-block-template-part:has(.dagbouwer-footer) {
	margin-top: auto;
}

.wp-site-blocks::before {
	content: "";
	position: fixed;
	z-index: -1;
	top: 112px;
	right: max(-120px, -8vw);
	width: clamp(280px, 34vw, 520px);
	aspect-ratio: 0.82;
	border: 1px solid color-mix(in srgb, var(--db-green), transparent 72%);
	border-radius: 48% 52% 44% 56% / 58% 42% 55% 45%;
	transform: rotate(8deg);
	pointer-events: none;
}

.wp-site-blocks > .wp-block-template-part:first-child,
.wp-site-blocks > header:first-child,
.wp-site-blocks > header:first-child + .dagbouwer-hero {
	margin-block-start: 0 !important;
	margin-top: 0 !important;
}

.wp-site-blocks > .wp-block-template-part:first-child {
	margin-block-end: 0 !important;
}

.wp-site-blocks > .wp-block-template-part:first-child + .dagbouwer-hero,
.wp-site-blocks > .dagbouwer-hero:first-child,
.editor-styles-wrapper .dagbouwer-header + .dagbouwer-hero {
	margin-block-start: -24px !important;
}

.dagbouwer-container {
	max-width: 1240px;
	margin-inline: auto;
	padding-inline: clamp(20px, 4vw, 40px);
}

.dagbouwer-header {
	position: sticky;
	top: 0;
	z-index: 30;
	margin: 0 !important;
	background: color-mix(in srgb, var(--db-surface), transparent 4%);
	border-bottom: 1px solid var(--db-border);
	backdrop-filter: blur(12px);
}

.dagbouwer-header + .wp-block-html,
.wp-block-html:has(.dagbouwer-search-overlay) {
	display: contents;
	margin: 0 !important;
}

.dagbouwer-header__inner {
	display: grid;
	grid-template-columns: minmax(96px, 1fr) auto minmax(112px, 1fr);
	align-items: center;
	gap: 20px;
	min-height: 72px;
}

.dagbouwer-logo-mark {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 54px;
	border: 1px solid color-mix(in srgb, var(--db-rust), transparent 35%);
	border-radius: 48% 52% 44% 56% / 58% 42% 55% 45%;
	background: linear-gradient(135deg, rgba(255, 255, 255, 0.92), rgba(247, 239, 227, 0.9));
	color: var(--db-rust);
	font-family: Georgia, "Times New Roman", serif;
	font-size: 1.45rem;
	font-weight: 800;
	line-height: 1;
	text-decoration: none;
	transform: rotate(-5deg);
	box-shadow: 0 10px 24px rgba(16, 24, 40, 0.06);
}

.dagbouwer-logo-mark:hover {
	transform: rotate(-2deg) translateY(-1px);
}

.dagbouwer-logo {
	display: inline-flex;
	align-items: center;
	min-height: 44px;
	font-family: Georgia, "Times New Roman", serif;
	font-size: 1.45rem;
	font-weight: 700;
	line-height: 1;
	letter-spacing: 0;
	text-decoration: none;
	color: var(--db-navy);
}

.dagbouwer-header .wp-block-navigation {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 44px;
	margin: 0;
}

.dagbouwer-header .wp-block-navigation__container {
	align-items: center;
	gap: 18px;
}

.dagbouwer-header .wp-block-navigation a {
	position: relative;
	min-height: 44px;
	display: inline-flex;
	align-items: center;
	line-height: 1;
	text-decoration: none;
}

.dagbouwer-dynamic-nav ul {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	gap: 18px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.dagbouwer-dynamic-nav li {
	margin: 0;
}

.dagbouwer-dynamic-nav a {
	position: relative;
	min-height: 44px;
	display: inline-flex;
	align-items: center;
	color: var(--db-navy);
	font-size: 0.95rem;
	font-weight: 700;
	line-height: 1;
	text-decoration: none;
}

.dagbouwer-dynamic-nav .is-page a {
	color: var(--db-rust);
}

.dagbouwer-dynamic-nav .is-current a,
.dagbouwer-dynamic-nav a[aria-current="page"] {
	color: var(--db-rust);
}

.dagbouwer-dynamic-nav a:hover::after,
.dagbouwer-dynamic-nav .is-current a::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 7px;
	height: 2px;
	background: var(--db-rust);
	border-radius: 99px;
}

.dagbouwer-header .wp-block-navigation a:hover::after,
.dagbouwer-header .current-menu-item > a::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 7px;
	height: 2px;
	background: var(--db-rust);
	border-radius: 99px;
}

.dagbouwer-header__actions {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 8px;
	min-height: 44px;
	line-height: 1;
}

.dagbouwer-icon-button {
	appearance: none;
	-webkit-appearance: none;
	width: 44px;
	height: 44px;
	display: inline-grid;
	place-items: center;
	flex: 0 0 44px;
	align-self: center;
	margin: 0;
	padding: 0;
	border: 1px solid var(--db-border);
	border-radius: 50%;
	background: var(--db-surface);
	color: var(--db-navy);
	cursor: pointer;
	line-height: 1;
	vertical-align: middle;
}

.dagbouwer-icon-button svg {
	width: 20px;
	height: 20px;
	fill: none;
	stroke: currentColor;
	stroke-width: 1.8;
	stroke-linecap: round;
	stroke-linejoin: round;
}

.dagbouwer-mobile-menu {
	display: none;
}

.dagbouwer-hero {
	position: relative;
	min-height: clamp(440px, 64vh, 720px);
	display: grid;
	place-items: center;
	margin: 0;
	overflow: hidden;
	background:
		linear-gradient(rgba(11, 31, 58, 0.34), rgba(11, 31, 58, 0.52)),
		linear-gradient(135deg, #304b3f 0%, #6f8f76 42%, #d8ad7a 100%);
	color: #fff;
}

.dagbouwer-hero.has-custom-hero {
	background-size: cover;
	background-position: center;
}

.dagbouwer-hero__content {
	max-width: 820px;
	padding: 72px 24px;
	text-align: center;
}

.dagbouwer-hero h1 {
	margin: 0 0 16px;
	color: #fff;
	font-size: clamp(2.5rem, 8vw, 5.125rem);
}

.dagbouwer-hero p {
	margin: 0 auto 20px;
	max-width: 650px;
	font-size: clamp(1.05rem, 2vw, 1.35rem);
}

.dagbouwer-hero a {
	color: #fff;
	font-weight: 700;
}

.dagbouwer-main-grid {
	display: grid;
	grid-template-columns: minmax(0, 2fr) minmax(280px, 340px);
	gap: clamp(28px, 4vw, 48px);
	align-items: start;
	margin-block: clamp(72px, 8vw, 112px) clamp(56px, 7vw, 88px);
}

.dagbouwer-sidebar {
	display: grid;
	gap: 24px;
	position: sticky;
	top: 96px;
}

.dagbouwer-card,
.dagbouwer-sidebar-card,
.dagbouwer-post-card,
.dagbouwer-recipe-card,
.dagbouwer-empty-state,
.dagbouwer-newsletter {
	background: var(--db-surface);
	border: 1px solid var(--db-border);
	border-radius: var(--db-radius-md);
}

.dagbouwer-sidebar-card {
	padding: 24px;
}

.dagbouwer-section {
	margin-block-end: clamp(48px, 7vw, 84px);
	clear: both;
}

.dagbouwer-section .wp-block-query {
	overflow: visible;
}

.dagbouwer-featured-query,
.dagbouwer-photo-query,
.dagbouwer-section,
.dagbouwer-card-grid,
.dagbouwer-featured-grid,
.dagbouwer-photo-grid {
	max-height: none !important;
	overflow: visible !important;
	scrollbar-width: none;
}

.dagbouwer-featured-query::-webkit-scrollbar,
.dagbouwer-photo-query::-webkit-scrollbar,
.dagbouwer-section::-webkit-scrollbar,
.dagbouwer-card-grid::-webkit-scrollbar,
.dagbouwer-featured-grid::-webkit-scrollbar,
.dagbouwer-photo-grid::-webkit-scrollbar {
	display: none;
}

[data-block]:has(.dagbouwer-featured-grid),
[data-block]:has(.dagbouwer-photo-grid),
[data-block]:has(.dagbouwer-card-grid),
[data-block]:has(.dagbouwer-latest-list),
[data-type="core/html"]:has(.dagbouwer-featured-grid),
[data-type="core/html"]:has(.dagbouwer-photo-grid),
[data-type="core/html"]:has(.dagbouwer-card-grid),
[data-type="core/html"]:has(.dagbouwer-latest-list) {
	contain: none !important;
	max-height: none !important;
	overflow: visible !important;
	scrollbar-width: none;
}

[data-block]:has(.dagbouwer-featured-grid)::-webkit-scrollbar,
[data-block]:has(.dagbouwer-photo-grid)::-webkit-scrollbar,
[data-block]:has(.dagbouwer-card-grid)::-webkit-scrollbar,
[data-block]:has(.dagbouwer-latest-list)::-webkit-scrollbar,
[data-type="core/html"]:has(.dagbouwer-featured-grid)::-webkit-scrollbar,
[data-type="core/html"]:has(.dagbouwer-photo-grid)::-webkit-scrollbar,
[data-type="core/html"]:has(.dagbouwer-card-grid)::-webkit-scrollbar,
[data-type="core/html"]:has(.dagbouwer-latest-list)::-webkit-scrollbar {
	display: none;
}

.dagbouwer-section__header {
	display: flex;
	align-items: end;
	justify-content: space-between;
	gap: 18px;
	margin-block-end: 22px;
}

.dagbouwer-section__header p {
	margin: 0;
}

.dagbouwer-section__header h2,
.dagbouwer-sidebar-card h2 {
	position: relative;
	margin: 0;
	font-size: clamp(1.75rem, 4vw, 2.625rem);
}

.dagbouwer-section__header h2::after {
	content: "";
	position: absolute;
	left: -10px;
	bottom: -8px;
	z-index: -1;
	width: 68px;
	height: 22px;
	border: 1px solid color-mix(in srgb, var(--db-rust), transparent 50%);
	border-radius: 48% 52% 44% 56% / 58% 42% 55% 45%;
	transform: rotate(-5deg);
}

.dagbouwer-sidebar-card h2 {
	font-size: 1.35rem;
}

.dagbouwer-featured-grid,
.wp-block-post-template.dagbouwer-featured-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 22px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.dagbouwer-featured-grid > li,
.dagbouwer-featured-grid > .wp-block-post {
	min-width: 0;
	margin: 0;
}

.dagbouwer-post-card {
	position: relative;
	height: 100%;
	overflow: hidden;
	transition: transform 180ms ease, box-shadow 180ms ease;
}

.dagbouwer-recipe-card {
	position: relative;
	display: grid;
	grid-template-rows: auto 1fr;
	height: 100%;
	min-height: 100%;
	overflow: hidden;
}

.dagbouwer-post-card::after {
	content: "";
	position: absolute;
	right: -34px;
	bottom: -38px;
	width: 112px;
	height: 82px;
	border: 1px solid color-mix(in srgb, var(--db-green), transparent 66%);
	border-radius: 48% 52% 44% 56% / 58% 42% 55% 45%;
	transform: rotate(12deg);
	pointer-events: none;
}

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

.dagbouwer-post-card__image {
	position: relative;
	display: block;
	width: 100%;
	aspect-ratio: 16 / 10;
	background:
		linear-gradient(135deg, rgba(11, 31, 58, 0.06), rgba(95, 141, 78, 0.18)),
		var(--db-blue-soft);
	overflow: hidden;
}

.dagbouwer-featured-grid .dagbouwer-post-card__image {
	aspect-ratio: 16 / 9;
}

.dagbouwer-post-card__image img,
.dagbouwer-photo-card img,
.dagbouwer-recipe-card img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.dagbouwer-single-featured,
.dagbouwer-single-featured a,
.dagbouwer-single-featured img,
.dagbouwer-post-card .wp-block-post-featured-image,
.dagbouwer-post-card .wp-block-post-featured-image a,
.dagbouwer-post-card .wp-block-post-featured-image img,
.dagbouwer-recipe-card .wp-block-post-featured-image,
.dagbouwer-recipe-card .wp-block-post-featured-image a,
.dagbouwer-recipe-card .wp-block-post-featured-image img {
	display: block;
	width: 100%;
	overflow: hidden;
}

.dagbouwer-recipe-card .wp-block-post-featured-image {
	aspect-ratio: 4 / 3;
	margin: 0;
	background:
		linear-gradient(135deg, rgba(11, 31, 58, 0.06), rgba(95, 141, 78, 0.18)),
		var(--db-blue-soft);
}

.dagbouwer-recipe-card:not(:has(.wp-block-post-featured-image))::before,
.dagbouwer-recipe-card .wp-block-post-featured-image:empty {
	content: "";
	display: block;
	width: 100%;
	aspect-ratio: 4 / 3;
	background:
		linear-gradient(135deg, rgba(11, 31, 58, 0.06), rgba(95, 141, 78, 0.18)),
		var(--db-blue-soft);
}

.dagbouwer-single-featured img,
.dagbouwer-post-card .wp-block-post-featured-image img,
.dagbouwer-recipe-card .wp-block-post-featured-image img {
	height: 100%;
	object-fit: cover;
}

.dagbouwer-post-card__body,
.dagbouwer-recipe-card__body {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-rows: auto auto auto 1fr;
	align-content: stretch;
	gap: 8px;
	padding: 20px;
	height: 100%;
}

.dagbouwer-recipe-rating {
	display: inline-flex;
	align-items: center;
	justify-self: start;
	gap: 8px;
	min-height: 30px;
	margin: 0;
	padding: 4px 10px;
	border: 1px solid color-mix(in srgb, var(--db-rust), transparent 58%);
	border-radius: 999px;
	background: color-mix(in srgb, var(--db-rust), white 88%);
	color: var(--db-navy);
	font-size: 0.86rem;
	font-weight: 850;
}

.dagbouwer-rating-chip {
	display: inline-flex;
	align-items: center;
	min-height: 28px;
	padding: 3px 9px;
	border: 1px solid color-mix(in srgb, var(--db-rust), transparent 60%);
	border-radius: 999px;
	background: color-mix(in srgb, var(--db-rust), white 88%);
	color: var(--db-navy);
	font-weight: 850;
}

.dagbouwer-recipe-rating span {
	color: var(--db-muted);
	font-size: 0.78rem;
}

.dagbouwer-recipe-rating strong {
	font-family: Georgia, "Times New Roman", serif;
}

.dagbouwer-recipe-rating-overlay {
	position: absolute;
	top: 12px;
	right: 12px;
	z-index: 4;
	display: inline-flex;
	align-items: center;
	gap: 7px;
	max-width: calc(100% - 24px);
	padding: 6px 10px;
	border: 1px solid color-mix(in srgb, var(--db-rust), white 24%);
	border-radius: 999px;
	background: color-mix(in srgb, var(--db-paper), transparent 10%);
	box-shadow: 0 10px 24px rgba(11, 31, 58, 0.14);
	color: var(--db-navy);
	font-size: 0.82rem;
	font-weight: 850;
	line-height: 1;
}

.dagbouwer-recipe-rating-overlay span {
	color: var(--db-muted);
	font-size: 0.72rem;
}

.dagbouwer-recipe-rating-overlay strong {
	font-family: Georgia, "Times New Roman", serif;
}

.dagbouwer-recipe-filter-bar {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	width: min(100%, var(--wp--style--global--wide-size));
	margin: 0 auto 18px;
	padding: 10px 12px;
	border: 1px solid color-mix(in srgb, var(--db-blue-soft), transparent 20%);
	border-radius: 999px;
	background:
		repeating-linear-gradient(125deg, rgba(11, 31, 58, 0.035) 0 1px, transparent 1px 9px),
		color-mix(in srgb, var(--db-paper), white 28%);
}

.dagbouwer-recipe-filter-bar span {
	color: var(--db-muted);
	font-size: 0.84rem;
	font-weight: 850;
}

.dagbouwer-recipe-filter-bar a {
	display: inline-flex;
	align-items: center;
	min-height: 30px;
	padding: 4px 11px;
	border: 1px solid transparent;
	border-radius: 999px;
	color: var(--db-navy);
	font-size: 0.86rem;
	font-weight: 850;
	text-decoration: none;
}

.dagbouwer-recipe-filter-bar a:hover,
.dagbouwer-recipe-filter-bar a.is-active {
	border-color: color-mix(in srgb, var(--db-rust), transparent 52%);
	background: color-mix(in srgb, var(--db-rust), white 86%);
}

.dagbouwer-recipe-details > .dagbouwer-recipe-rating {
	margin-top: -4px;
	margin-bottom: 10px;
}

.dagbouwer-post-meta,
.dagbouwer-badge-row {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	align-items: center;
	color: var(--db-muted);
	font-size: 0.86rem;
}

.dagbouwer-badge,
.dagbouwer-topic-pill,
.dagbouwer-meta-chip {
	display: inline-flex;
	align-items: center;
	min-height: 32px;
	padding: 4px 11px;
	border-radius: 999px;
	background: var(--db-sand-soft);
	color: var(--db-navy);
	font-size: 0.83rem;
	font-weight: 700;
	text-decoration: none;
}

.dagbouwer-badge.is-recipe,
.category-recepten .dagbouwer-badge {
	background: color-mix(in srgb, var(--db-rust), white 82%);
}

.category-code .dagbouwer-badge {
	background: var(--db-lavender-soft);
}

.category-reizen .dagbouwer-badge {
	background: color-mix(in srgb, var(--db-green), white 82%);
}

.dagbouwer-card-title {
	margin: 0;
	font-family: Georgia, "Times New Roman", serif;
	font-size: 1.35rem;
	line-height: 1.18;
}

.dagbouwer-card-title a {
	text-decoration: none;
}

.dagbouwer-card-excerpt {
	margin: 0;
	min-height: 74px;
	padding: 12px 14px;
	border: 1px solid color-mix(in srgb, var(--db-border), transparent 16%);
	border-radius: 42% 58% 49% 51% / 18% 24% 76% 82%;
	background:
		linear-gradient(135deg, rgba(247, 239, 227, 0.74), rgba(234, 242, 248, 0.58));
	color: var(--db-muted);
	font-size: 0.96rem;
}

.dagbouwer-author {
	text-align: left;
}

.dagbouwer-author,
.dagbouwer-sidebar-card {
	position: relative;
	overflow: hidden;
}

.dagbouwer-sidebar-card > * {
	position: relative;
	z-index: 1;
}

.dagbouwer-sidebar-card::after {
	content: "";
	position: absolute;
	right: -28px;
	top: 18px;
	width: 86px;
	height: 116px;
	border: 1px solid color-mix(in srgb, var(--db-rust), transparent 72%);
	border-radius: 48% 52% 44% 56% / 58% 42% 55% 45%;
	transform: rotate(10deg);
	pointer-events: none;
}

.dagbouwer-author__image {
	position: relative;
	width: 120px;
	height: 145px;
	margin: -6px 0 18px 8px;
	border-radius: 48% 52% 44% 56% / 58% 42% 55% 45%;
	transform: rotate(4deg);
	overflow: hidden;
	background:
		linear-gradient(135deg, rgba(95, 141, 78, 0.32), rgba(217, 107, 59, 0.24)),
		var(--db-sand-soft);
	outline: 8px solid color-mix(in srgb, var(--db-sand-soft), transparent 16%);
}

.dagbouwer-author__image img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: 52% 30%;
}

.dagbouwer-socials {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 18px;
}

.dagbouwer-socials a,
.dagbouwer-button-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 42px;
	padding: 8px 14px;
	border: 1px solid var(--db-border);
	border-radius: 999px;
	background: var(--db-surface);
	font-weight: 700;
	text-decoration: none;
}

.dagbouwer-text-link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 2px 0;
	color: var(--db-navy);
	font-weight: 800;
	text-decoration: none;
}

.dagbouwer-text-link::after {
	content: "";
	width: 22px;
	height: 1px;
	background: currentColor;
	transition: width 160ms ease;
}

.dagbouwer-text-link:hover::after {
	width: 34px;
}

.dagbouwer-card-action {
	margin: 6px 0 0;
}

.dagbouwer-latest-list,
.wp-block-post-template.dagbouwer-latest-list {
	display: grid;
	gap: 16px;
	margin: 18px 0;
	padding: 0;
	list-style: none;
}

.dagbouwer-latest-item,
.dagbouwer-latest-list li {
	display: grid;
	grid-template-columns: 72px minmax(0, 1fr);
	gap: 12px;
	align-items: start;
	min-height: 72px;
	margin: 0;
	min-width: 0;
}

.dagbouwer-latest-list img,
.dagbouwer-latest-thumb,
.dagbouwer-latest-item .wp-block-post-featured-image {
	width: 72px;
	height: 72px;
	display: block;
	margin: 0;
	border-radius: var(--db-radius-sm);
	background: var(--db-blue-soft);
	object-fit: cover;
	overflow: hidden;
}

.dagbouwer-latest-item .wp-block-post-featured-image a,
.dagbouwer-latest-item .wp-block-post-featured-image img {
	display: block;
	width: 72px;
	height: 72px;
	object-fit: cover;
}

.dagbouwer-latest-title {
	margin: 0 0 3px;
	font-family: Georgia, "Times New Roman", serif;
	font-size: 1rem;
	line-height: 1.22;
}

.dagbouwer-latest-title a {
	text-decoration: none;
}

.dagbouwer-topic-list {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 10px;
	margin: 18px 0 0;
}

.dagbouwer-photo-grid,
.wp-block-post-template.dagbouwer-photo-grid {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	grid-auto-flow: dense;
	gap: 10px;
	margin: 0;
	padding: 0;
	list-style: none;
	overflow: visible;
}

.dagbouwer-photo-section {
	margin-block-end: 0;
}

.dagbouwer-photo-grid > li,
.dagbouwer-photo-grid > .wp-block-post {
	min-width: 0;
	margin: 0;
}

.dagbouwer-photo-card {
	position: relative;
	min-height: 104px;
	overflow: hidden;
	border-radius: 12px;
	background:
		linear-gradient(135deg, rgba(95, 141, 78, 0.28), rgba(234, 242, 248, 0.7)),
		var(--db-surface);
	border: 1px solid var(--db-border);
}

.dagbouwer-photo-card::after {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(180deg, rgba(11, 31, 58, 0.02), rgba(11, 31, 58, 0.28)),
		linear-gradient(135deg, rgba(247, 239, 227, 0.18), rgba(95, 141, 78, 0.14));
	mix-blend-mode: multiply;
	pointer-events: none;
}

.dagbouwer-photo-grid.is-normal {
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 14px;
}

.dagbouwer-photo-grid.is-normal .dagbouwer-photo-card {
	min-height: 140px;
}

.dagbouwer-photo-grid.is-large {
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.dagbouwer-photo-grid.is-large .dagbouwer-photo-card {
	min-height: 180px;
}

.dagbouwer-editor-photo-preview {
	display: none;
}

.dagbouwer-photo-card.is-square { aspect-ratio: 1 / 1; }
.dagbouwer-photo-card.is-portrait { aspect-ratio: 3 / 4; }
.dagbouwer-photo-card.is-landscape { aspect-ratio: 4 / 3; }
.dagbouwer-photo-card.is-wide { aspect-ratio: 16 / 9; }
.dagbouwer-photo-card.is-tall { aspect-ratio: 2 / 3; }
.dagbouwer-photo-card.is-panorama { aspect-ratio: 21 / 9; }
.dagbouwer-photo-card.is-featured {
	grid-column: span 2;
	grid-row: span 1;
}

.dagbouwer-photo-card__caption {
	position: absolute;
	inset: auto 10px 10px;
	padding: 10px 12px;
	border-radius: var(--db-radius-sm);
	background: rgba(11, 31, 58, 0.78);
	color: #fff;
	opacity: 0;
	transform: translateY(6px);
	transition: opacity 180ms ease, transform 180ms ease;
}

.dagbouwer-photo-card__caption strong {
	font-size: 0.92rem;
}

.dagbouwer-photo-card:hover .dagbouwer-photo-card__caption,
.dagbouwer-photo-card:focus-within .dagbouwer-photo-card__caption {
	opacity: 1;
	transform: translateY(0);
}

.dagbouwer-card-grid,
.wp-block-post-template.dagbouwer-card-grid,
.dagbouwer-recipe-grid,
.dagbouwer-search-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 22px;
	margin: 0;
	padding: 0;
	list-style: none;
	overflow: visible;
}

.dagbouwer-card-grid > li,
.dagbouwer-card-grid > .wp-block-post {
	min-width: 0;
	margin: 0;
}

.dagbouwer-recipe-grid > li,
.dagbouwer-recipe-grid > .wp-block-post {
	display: flex;
	min-width: 0;
	margin: 0;
}

.dagbouwer-recipe-grid .dagbouwer-recipe-card {
	width: 100%;
}

.dagbouwer-card-grid.is-2x2,
.wp-block-post-template.dagbouwer-card-grid.is-2x2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.dagbouwer-card-grid.is-3x2,
.dagbouwer-card-grid.is-3x3,
.wp-block-post-template.dagbouwer-card-grid.is-3x2,
.wp-block-post-template.dagbouwer-card-grid.is-3x3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.dagbouwer-card-grid.is-4x2,
.wp-block-post-template.dagbouwer-card-grid.is-4x2 { grid-template-columns: repeat(4, minmax(0, 1fr)); }

.dagbouwer-newsletter {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
	gap: 24px;
	align-items: center;
	max-width: 980px;
	margin-inline: auto;
	padding: clamp(24px, 4vw, 40px);
	background:
		linear-gradient(135deg, color-mix(in srgb, var(--db-rust), white 86%), transparent 44%),
		var(--db-surface);
	box-shadow: 0 20px 60px rgba(16, 24, 40, 0.09);
	position: relative;
	overflow: hidden;
}

.dagbouwer-newsletter::after {
	content: "";
	position: absolute;
	z-index: 0;
	right: clamp(18px, 5vw, 72px);
	top: 50%;
	width: 128px;
	height: 172px;
	border: 1px solid color-mix(in srgb, var(--db-rust), transparent 58%);
	border-radius: 48% 52% 44% 56% / 58% 42% 55% 45%;
	transform: translateY(-50%) rotate(7deg);
	pointer-events: none;
}

.dagbouwer-newsletter::before {
	content: "";
	position: absolute;
	inset: 14px;
	border: 1px solid color-mix(in srgb, var(--db-rust), transparent 55%);
	border-radius: 12px;
	pointer-events: none;
}

.dagbouwer-newsletter > * {
	position: relative;
	z-index: 1;
}

.dagbouwer-eyebrow {
	margin: 0 0 8px;
	color: var(--db-rust);
	font-size: 0.8rem;
	font-weight: 850;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.dagbouwer-newsletter form,
.dagbouwer-search-form {
	display: flex;
	gap: 10px;
}

.dagbouwer-newsletter label,
.dagbouwer-search-form label {
	position: absolute;
	width: 1px;
	height: 1px;
	overflow: hidden;
	clip: rect(0 0 0 0);
}

.dagbouwer-newsletter input,
.dagbouwer-search-form input,
.dagbouwer-json-import textarea,
.dagbouwer-json-import input,
.dagbouwer-json-import select {
	width: 100%;
	min-height: 46px;
	border: 1px solid var(--db-border);
	border-radius: 999px;
	padding: 10px 15px;
	background: var(--db-surface);
	color: var(--db-ink);
}

.dagbouwer-newsletter button,
.dagbouwer-search-form button,
.dagbouwer-button {
	min-height: 46px;
	border: 0;
	border-radius: 999px;
	padding: 10px 18px;
	background: var(--db-navy);
	color: var(--db-surface);
	font-weight: 800;
	cursor: pointer;
}

.dagbouwer-search-overlay {
	position: fixed;
	inset: 0;
	z-index: 80;
	display: none;
	place-items: start center;
	padding: 110px 24px 24px;
	background: rgba(11, 31, 58, 0.46);
}

.dagbouwer-search-overlay.is-open {
	display: grid;
}

.dagbouwer-search-panel {
	width: min(720px, 100%);
	padding: 26px;
	border-radius: var(--db-radius-lg);
	background: var(--db-surface);
	box-shadow: var(--db-shadow);
}

.dagbouwer-search-panel__header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 16px;
	margin-bottom: 18px;
}

.dagbouwer-filter-row {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin: 18px 0 28px;
}

.dagbouwer-archive-hero {
	position: relative;
	max-width: 880px;
	margin: clamp(44px, 7vw, 78px) auto clamp(28px, 5vw, 48px);
	text-align: center;
	overflow: hidden;
}

.dagbouwer-archive-hero::after {
	content: "";
	position: absolute;
	z-index: -1;
	left: 50%;
	bottom: 2px;
	width: clamp(180px, 30vw, 340px);
	height: clamp(54px, 8vw, 92px);
	border: 1px solid color-mix(in srgb, var(--db-green), transparent 62%);
	border-radius: 48% 52% 44% 56% / 58% 42% 55% 45%;
	transform: translateX(-50%) rotate(3deg);
	pointer-events: none;
}

.dagbouwer-archive-hero h1 {
	margin: 0 0 14px;
	font-size: clamp(2.4rem, 7vw, 4.75rem);
}

.dagbouwer-archive-hero p:not(.dagbouwer-eyebrow) {
	max-width: 680px;
	margin-inline: auto;
	color: var(--db-muted);
}

.dagbouwer-archive-hero.is-code::after,
.dagbouwer-archive-hero.is-topic::after {
	border-color: color-mix(in srgb, var(--db-lavender-soft), var(--db-navy) 30%);
}

.dagbouwer-archive-hero.is-recepten::after,
.dagbouwer-archive-hero.is-verhalen::after {
	border-color: color-mix(in srgb, var(--db-rust), transparent 58%);
}

.dagbouwer-archive-hero.is-404::after {
	border-color: color-mix(in srgb, var(--db-rust), transparent 54%);
	transform: translateX(-50%) rotate(-4deg);
}

.dagbouwer-404-page {
	padding-block-end: clamp(42px, 7vw, 84px);
}

.dagbouwer-404-card {
	position: relative;
	max-width: 760px;
	margin: 0 auto clamp(44px, 7vw, 78px);
	padding: clamp(22px, 4vw, 34px);
	box-shadow: 0 18px 45px rgba(16, 24, 40, 0.07);
	overflow: hidden;
}

.dagbouwer-404-card::after {
	content: "";
	position: absolute;
	right: -36px;
	bottom: -42px;
	width: 150px;
	height: 96px;
	border: 1px solid color-mix(in srgb, var(--db-green), transparent 66%);
	border-radius: 48% 52% 44% 56% / 58% 42% 55% 45%;
	transform: rotate(12deg);
	pointer-events: none;
}

.dagbouwer-404-card > * {
	position: relative;
	z-index: 1;
}

.dagbouwer-404-card .dagbouwer-search-form {
	max-width: 620px;
	margin-inline: auto;
}

.dagbouwer-404-card .dagbouwer-topic-list {
	max-width: 620px;
	margin: 22px auto 0;
}

.dagbouwer-archive-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(280px, 340px);
	gap: clamp(28px, 4vw, 48px);
	align-items: start;
}

.dagbouwer-archive-query .dagbouwer-post-card .wp-block-post-featured-image,
.dagbouwer-archive-query .dagbouwer-post-card .wp-block-post-featured-image a {
	display: block;
	margin: 0;
	width: 100%;
}

.dagbouwer-archive-query .wp-block-post-terms a {
	display: inline-flex;
	align-items: center;
	min-height: 30px;
	padding: 3px 10px;
	border-radius: 999px;
	background: var(--db-sand-soft);
	color: var(--db-navy);
	font-size: 0.82rem;
	font-weight: 800;
	text-decoration: none;
}

.dagbouwer-card-excerpt .wp-block-post-excerpt__excerpt {
	margin: 0;
}

.dagbouwer-card-excerpt .wp-block-post-excerpt__more-text {
	margin: 10px 0 0;
}

.dagbouwer-card-excerpt .wp-block-post-excerpt__more-link {
	color: var(--db-navy);
	font-weight: 800;
	text-decoration: none;
}

.dagbouwer-pagination {
	gap: 10px;
	margin-top: 28px;
}

.dagbouwer-pagination a,
.dagbouwer-pagination .page-numbers,
.dagbouwer-pagination .wp-block-query-pagination-previous,
.dagbouwer-pagination .wp-block-query-pagination-next {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 38px;
	min-width: 38px;
	padding: 6px 12px;
	border: 1px solid var(--db-border);
	border-radius: 999px;
	background: var(--db-surface);
	color: var(--db-navy);
	font-weight: 800;
	text-decoration: none;
}

.dagbouwer-photo-card .wp-block-post-featured-image,
.dagbouwer-photo-card .wp-block-post-featured-image a {
	display: block;
	width: 100%;
	height: 100%;
	margin: 0;
}

.dagbouwer-photo-card .wp-block-post-featured-image img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.dagbouwer-photo-card__caption h3 {
	margin: 0;
	font-size: 1rem;
	line-height: 1.2;
}

.dagbouwer-photo-card__caption a {
	color: #fff;
	text-decoration: none;
}

.dagbouwer-archive-search {
	max-width: 680px;
	margin: -18px auto 38px;
}

.dagbouwer-photo-page {
	max-width: 1320px;
}

.dagbouwer-photo-experience {
	position: relative;
	margin-block: clamp(38px, 6vw, 72px) clamp(52px, 7vw, 90px);
	overflow: visible;
}

.dagbouwer-photo-experience::before,
.dagbouwer-photo-experience::after {
	content: "";
	position: absolute;
	z-index: -1;
	border-radius: 48% 52% 44% 56% / 58% 42% 55% 45%;
	pointer-events: none;
}

.dagbouwer-photo-experience::before {
	top: -24px;
	left: max(-90px, -6vw);
	width: clamp(180px, 24vw, 340px);
	aspect-ratio: 0.74;
	border: 1px solid color-mix(in srgb, var(--db-rust), transparent 62%);
	transform: rotate(-11deg);
}

.dagbouwer-photo-experience::after {
	right: max(-80px, -5vw);
	bottom: 8%;
	width: clamp(210px, 28vw, 420px);
	aspect-ratio: 1.75;
	border: 1px solid color-mix(in srgb, var(--db-green), transparent 64%);
	transform: rotate(8deg);
}

.dagbouwer-photo-experience__hero {
	position: relative;
	margin-bottom: 24px;
	padding: clamp(30px, 5vw, 58px);
	border: 1px solid var(--db-border);
	border-radius: var(--db-radius-lg);
	background:
		linear-gradient(135deg, rgba(234, 242, 248, 0.78), rgba(247, 239, 227, 0.72)),
		var(--db-surface);
	box-shadow: 0 22px 60px rgba(16, 24, 40, 0.08);
	overflow: hidden;
}

.dagbouwer-photo-experience__hero::after {
	content: "";
	position: absolute;
	right: clamp(20px, 7vw, 110px);
	top: 26px;
	width: clamp(150px, 22vw, 300px);
	aspect-ratio: 1.65;
	border: 1px solid color-mix(in srgb, var(--db-navy), transparent 78%);
	border-radius: 48% 52% 44% 56% / 58% 42% 55% 45%;
	transform: rotate(-5deg);
	pointer-events: none;
}

.dagbouwer-photo-experience__hero > * {
	position: relative;
	z-index: 1;
	max-width: 720px;
}

.dagbouwer-photo-experience__hero h1 {
	margin: 0 0 12px;
	font-size: clamp(3rem, 9vw, 7rem);
	line-height: 0.92;
}

.dagbouwer-photo-experience__hero p:not(.dagbouwer-eyebrow) {
	color: var(--db-muted);
	font-size: clamp(1.05rem, 2vw, 1.22rem);
}

.dagbouwer-photo-search {
	max-width: 640px;
	margin-top: 24px;
}

.dagbouwer-photo-filter-row {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin: 0 0 22px;
	padding: 0;
	overflow: visible;
}

.dagbouwer-photo-filter {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	min-height: 36px;
	padding: 6px 13px;
	border: 1px solid var(--db-border);
	border-radius: 999px;
	background: var(--db-surface);
	color: var(--db-navy);
	font-size: 0.9rem;
	font-weight: 800;
	text-decoration: none;
}

.dagbouwer-photo-filter span {
	color: var(--db-muted);
	font-weight: 700;
}

.dagbouwer-photo-filter.is-active {
	background: var(--db-navy);
	border-color: var(--db-navy);
	color: var(--db-surface);
}

.dagbouwer-photo-filter.is-active span {
	color: color-mix(in srgb, var(--db-surface), transparent 18%);
}

.dagbouwer-photo-experience-grid {
	display: grid;
	grid-template-columns: repeat(6, minmax(0, 1fr));
	grid-auto-flow: dense;
	grid-auto-rows: 78px;
	gap: 14px;
	margin: 0;
	overflow: visible;
}

.dagbouwer-photo-experience-card {
	position: relative;
	grid-column: span 2;
	grid-row: span 2;
	min-width: 0;
	border: 1px solid color-mix(in srgb, var(--db-border), transparent 8%);
	border-radius: 18px;
	background:
		linear-gradient(135deg, rgba(95, 141, 78, 0.22), rgba(217, 107, 59, 0.14)),
		var(--db-blue-soft);
	box-shadow: 0 10px 28px rgba(16, 24, 40, 0.08);
	overflow: hidden;
	transform: rotate(-0.35deg);
	transition: transform 180ms ease, box-shadow 180ms ease;
}

.dagbouwer-photo-experience-card:nth-child(3n) {
	transform: rotate(0.45deg);
}

.dagbouwer-photo-experience-card:nth-child(5n) {
	transform: rotate(-0.8deg);
}

.dagbouwer-photo-experience-card:hover,
.dagbouwer-photo-experience-card:focus-within {
	transform: translateY(-4px) rotate(0deg);
	box-shadow: 0 24px 54px rgba(16, 24, 40, 0.14);
}

.dagbouwer-photo-experience-card a,
.dagbouwer-photo-experience-card img {
	display: block;
	width: 100%;
	height: 100%;
}

.dagbouwer-photo-experience-card img {
	object-fit: cover;
	transform: scale(1.01);
	transition: transform 320ms ease;
}

.dagbouwer-photo-experience-card:hover img,
.dagbouwer-photo-experience-card:focus-within img {
	transform: scale(1.055);
}

.dagbouwer-photo-experience-card.is-wide {
	grid-column: span 3;
	grid-row: span 2;
}

.dagbouwer-photo-experience-card.is-panorama {
	grid-column: span 4;
	grid-row: span 2;
}

.dagbouwer-photo-experience-card.is-featured {
	grid-column: span 3;
	grid-row: span 3;
}

.dagbouwer-photo-experience-card.is-portrait,
.dagbouwer-photo-experience-card.is-tall {
	grid-column: span 3;
	grid-row: span 3;
}

.dagbouwer-photo-experience-grid:has(.dagbouwer-photo-experience-card:nth-child(3):last-child) .dagbouwer-photo-experience-card:first-child {
	grid-column: span 3;
	grid-row: span 4;
}

.dagbouwer-photo-experience-grid:has(.dagbouwer-photo-experience-card:nth-child(3):last-child) .dagbouwer-photo-experience-card:nth-child(2) {
	grid-column: span 3;
	grid-row: span 2;
}

.dagbouwer-photo-experience-grid:has(.dagbouwer-photo-experience-card:nth-child(3):last-child) .dagbouwer-photo-experience-card:nth-child(3) {
	grid-column: span 3;
	grid-row: span 2;
}

.dagbouwer-photo-experience-grid:has(.dagbouwer-photo-experience-card:nth-child(3):last-child) .dagbouwer-photo-experience-card:nth-child(3).is-wide,
.dagbouwer-photo-experience-grid:has(.dagbouwer-photo-experience-card:nth-child(3):last-child) .dagbouwer-photo-experience-card:nth-child(3).is-landscape,
.dagbouwer-photo-experience-grid:has(.dagbouwer-photo-experience-card:nth-child(3):last-child) .dagbouwer-photo-experience-card:nth-child(3).is-panorama {
	grid-column: 4 / span 3;
}

.dagbouwer-photo-experience-card__shade {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(180deg, transparent 38%, rgba(11, 31, 58, 0.64) 100%);
	pointer-events: none;
}

.dagbouwer-photo-experience-card__text {
	position: absolute;
	left: 14px;
	right: 14px;
	bottom: 14px;
	display: grid;
	gap: 4px;
	padding: 12px 14px;
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: var(--db-radius-sm);
	background: rgba(11, 31, 58, 0.54);
	color: #fff;
	backdrop-filter: blur(8px);
}

.dagbouwer-photo-kicker,
.dagbouwer-photo-experience-card small {
	color: rgba(255, 255, 255, 0.78);
	font-size: 0.78rem;
	font-weight: 800;
}

.dagbouwer-photo-experience-card strong {
	font-family: Georgia, "Times New Roman", serif;
	font-size: clamp(1.05rem, 1.8vw, 1.38rem);
	line-height: 1.1;
}

@media (prefers-reduced-motion: no-preference) {
	.dagbouwer-photo-experience-card {
		animation: dagbouwer-photo-rise 520ms ease both;
		animation-delay: calc((var(--photo-index, 1) - 1) * 35ms);
	}

	@keyframes dagbouwer-photo-rise {
		from {
			opacity: 0;
			transform: translateY(12px) rotate(-0.35deg);
		}
		to {
			opacity: 1;
		}
	}
}

.dagbouwer-photo-story {
	display: grid;
	gap: clamp(22px, 4vw, 38px);
	max-width: 980px;
	margin: clamp(42px, 6vw, 76px) auto 0;
}

.dagbouwer-photo-story__layer {
	position: relative;
	display: grid;
	grid-template-columns: minmax(0, 1.35fr) minmax(240px, 0.75fr);
	gap: clamp(18px, 3vw, 34px);
	align-items: center;
	padding: clamp(16px, 3vw, 28px);
	border: 1px solid var(--db-border);
	border-radius: var(--db-radius-lg);
	background:
		repeating-linear-gradient(135deg, rgba(11, 31, 58, 0.035) 0 1px, transparent 1px 18px),
		var(--db-surface);
	box-shadow: 0 16px 44px rgba(16, 24, 40, 0.07);
	overflow: hidden;
}

.dagbouwer-photo-story__layer::after {
	content: "";
	position: absolute;
	right: -34px;
	bottom: -42px;
	width: 150px;
	height: 98px;
	border: 1px solid color-mix(in srgb, var(--db-rust), transparent 66%);
	border-radius: 48% 52% 44% 56% / 58% 42% 55% 45%;
	transform: rotate(9deg);
	pointer-events: none;
}

.dagbouwer-photo-story__layer.is-wide {
	grid-template-columns: 1fr;
}

.dagbouwer-photo-story__layer.is-stack .dagbouwer-photo-story__media,
.dagbouwer-photo-story__layer.has-multiple .dagbouwer-photo-story__media {
	grid-template-columns: repeat(auto-fit, minmax(148px, 1fr));
}

.dagbouwer-photo-story__media {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 12px;
}

.dagbouwer-photo-story__media figure {
	margin: 0;
	overflow: hidden;
	padding: 8px;
	border: 1px solid color-mix(in srgb, var(--db-border), transparent 16%);
	border-radius: 16px;
	background: rgba(255, 255, 255, 0.9);
	box-shadow: 0 12px 30px rgba(16, 24, 40, 0.08);
}

.dagbouwer-photo-story__media img {
	display: block;
	width: 100%;
	height: 100%;
	aspect-ratio: 4 / 3;
	border-radius: 10px;
	object-fit: cover;
}

.dagbouwer-photo-story__layer.has-multiple .dagbouwer-photo-story__media figure:nth-child(3n + 1) {
	transform: rotate(-0.6deg);
}

.dagbouwer-photo-story__layer.has-multiple .dagbouwer-photo-story__media figure:nth-child(3n + 2) {
	transform: rotate(0.5deg);
}

.dagbouwer-photo-story__copy {
	position: relative;
	z-index: 1;
	padding: 10px 0;
}

.dagbouwer-photo-story__copy h2 {
	margin: 0 0 10px;
	font-size: clamp(1.55rem, 3vw, 2.35rem);
}

.dagbouwer-photo-story__copy p {
	margin: 0;
	color: var(--db-muted);
}

.dagbouwer-single-content .wp-block-gallery,
.dagbouwer-single-content .wp-block-image {
	margin-block: clamp(22px, 4vw, 38px);
}

.dagbouwer-single-content .wp-block-gallery {
	position: relative;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
	gap: 12px;
	padding: clamp(14px, 3vw, 24px);
	border: 1px solid var(--db-border);
	border-radius: var(--db-radius-lg);
	background:
		repeating-linear-gradient(135deg, rgba(11, 31, 58, 0.035) 0 1px, transparent 1px 18px),
		var(--db-surface);
	box-shadow: 0 16px 44px rgba(16, 24, 40, 0.07);
	overflow: hidden;
}

.dagbouwer-single-content .wp-block-gallery::after {
	content: "";
	position: absolute;
	right: -34px;
	bottom: -42px;
	width: 150px;
	height: 98px;
	border: 1px solid color-mix(in srgb, var(--db-rust), transparent 66%);
	border-radius: 48% 52% 44% 56% / 58% 42% 55% 45%;
	transform: rotate(9deg);
	pointer-events: none;
}

.wp-block-gallery.is-style-dagbouwer-photo-grid-2,
.wp-block-gallery.is-style-dagbouwer-photo-grid-3,
.wp-block-gallery.is-style-dagbouwer-photo-grid-4,
.wp-block-gallery.is-style-dagbouwer-photo-mosaic,
.wp-block-gallery.is-style-dagbouwer-photo-contain {
	position: relative;
	display: grid !important;
	gap: 14px !important;
	padding: clamp(16px, 3vw, 28px) !important;
	border: 1px solid var(--db-border);
	border-radius: var(--db-radius-lg);
	background:
		repeating-linear-gradient(135deg, rgba(11, 31, 58, 0.035) 0 1px, transparent 1px 18px),
		var(--db-surface);
	box-shadow: 0 16px 44px rgba(16, 24, 40, 0.07);
	overflow: hidden;
}

.wp-block-gallery.is-style-dagbouwer-photo-grid-2::after,
.wp-block-gallery.is-style-dagbouwer-photo-grid-3::after,
.wp-block-gallery.is-style-dagbouwer-photo-grid-4::after,
.wp-block-gallery.is-style-dagbouwer-photo-mosaic::after,
.wp-block-gallery.is-style-dagbouwer-photo-contain::after {
	content: "";
	position: absolute;
	right: -34px;
	bottom: -42px;
	width: 150px;
	height: 98px;
	border: 1px solid color-mix(in srgb, var(--db-rust), transparent 66%);
	border-radius: 48% 52% 44% 56% / 58% 42% 55% 45%;
	transform: rotate(9deg);
	pointer-events: none;
}

.wp-block-gallery.is-style-dagbouwer-photo-grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
.wp-block-gallery.is-style-dagbouwer-photo-grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; }
.wp-block-gallery.is-style-dagbouwer-photo-grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)) !important; }
.wp-block-gallery.is-style-dagbouwer-photo-contain { grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)) !important; }
.wp-block-gallery.is-style-dagbouwer-photo-mosaic {
	grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
	grid-auto-rows: 86px;
	grid-auto-flow: dense;
}

.wp-block-gallery.is-style-dagbouwer-photo-grid-2 .wp-block-image,
.wp-block-gallery.is-style-dagbouwer-photo-grid-3 .wp-block-image,
.wp-block-gallery.is-style-dagbouwer-photo-grid-4 .wp-block-image,
.wp-block-gallery.is-style-dagbouwer-photo-mosaic .wp-block-image,
.wp-block-gallery.is-style-dagbouwer-photo-contain .wp-block-image,
.dagbouwer-single-content .wp-block-gallery .wp-block-image {
	position: relative;
	z-index: 1;
	display: block !important;
	width: 100% !important;
	margin: 0 !important;
	padding: 8px;
	border: 1px solid color-mix(in srgb, var(--db-border), transparent 16%);
	border-radius: 16px;
	background: rgba(255, 255, 255, 0.92);
	box-shadow: 0 12px 30px rgba(16, 24, 40, 0.08);
	overflow: hidden;
}

.wp-block-gallery.is-style-dagbouwer-photo-mosaic .wp-block-image {
	grid-column: span 2;
	grid-row: span 2;
}

.wp-block-gallery.is-style-dagbouwer-photo-mosaic .wp-block-image:nth-child(5n + 1) {
	grid-column: span 3;
	grid-row: span 3;
}

.wp-block-gallery.is-style-dagbouwer-photo-mosaic .wp-block-image:nth-child(5n + 3) {
	grid-column: span 3;
}

.wp-block-gallery.is-style-dagbouwer-photo-grid-2 img,
.wp-block-gallery.is-style-dagbouwer-photo-grid-3 img,
.wp-block-gallery.is-style-dagbouwer-photo-grid-4 img,
.wp-block-gallery.is-style-dagbouwer-photo-mosaic img,
.wp-block-gallery.is-style-dagbouwer-photo-contain img,
.wp-block-image.is-style-dagbouwer-frame-cover img,
.wp-block-image.is-style-dagbouwer-frame-contain img,
.wp-block-image.is-style-dagbouwer-frame-zoom img,
.wp-block-image.is-style-dagbouwer-focus-top img,
.wp-block-image.is-style-dagbouwer-focus-bottom img,
.wp-block-image.is-style-dagbouwer-focus-left img,
.wp-block-image.is-style-dagbouwer-focus-right img {
	display: block;
	width: 100% !important;
	height: 100% !important;
	aspect-ratio: 4 / 3;
	border-radius: 10px;
	object-fit: cover;
	object-position: center;
}

.wp-block-gallery.is-style-dagbouwer-photo-contain img,
.wp-block-image.is-style-dagbouwer-frame-contain img {
	object-fit: contain;
	background: color-mix(in srgb, var(--db-blue-soft), white 42%);
}

.wp-block-image.is-style-dagbouwer-frame-cover,
.wp-block-image.is-style-dagbouwer-frame-contain,
.wp-block-image.is-style-dagbouwer-frame-zoom,
.wp-block-image.is-style-dagbouwer-focus-top,
.wp-block-image.is-style-dagbouwer-focus-bottom,
.wp-block-image.is-style-dagbouwer-focus-left,
.wp-block-image.is-style-dagbouwer-focus-right {
	padding: 8px;
	border: 1px solid color-mix(in srgb, var(--db-border), transparent 16%);
	border-radius: 16px;
	background:
		repeating-linear-gradient(135deg, rgba(11, 31, 58, 0.035) 0 1px, transparent 1px 18px),
		rgba(255, 255, 255, 0.92);
	box-shadow: 0 12px 30px rgba(16, 24, 40, 0.08);
}

.wp-block-image.is-style-dagbouwer-frame-zoom img {
	transform: scale(1.14);
}

.wp-block-image.is-style-dagbouwer-focus-top img { object-position: center top; }
.wp-block-image.is-style-dagbouwer-focus-bottom img { object-position: center bottom; }
.wp-block-image.is-style-dagbouwer-focus-left img { object-position: left center; }
.wp-block-image.is-style-dagbouwer-focus-right img { object-position: right center; }

.dagbouwer-single-content .wp-block-gallery .wp-block-image {
	position: relative;
	z-index: 1;
	margin: 0;
	padding: 8px;
	border: 1px solid color-mix(in srgb, var(--db-border), transparent 16%);
	border-radius: 16px;
	background: rgba(255, 255, 255, 0.92);
}

.single-db_photo_entry .dagbouwer-single-content > .wp-block-image:not(.dagbouwer-single-featured) {
	position: relative;
	padding: clamp(14px, 3vw, 24px);
	border: 1px solid var(--db-border);
	border-radius: var(--db-radius-lg);
	background:
		repeating-linear-gradient(135deg, rgba(11, 31, 58, 0.035) 0 1px, transparent 1px 18px),
		var(--db-surface);
	box-shadow: 0 16px 44px rgba(16, 24, 40, 0.07);
	overflow: hidden;
}

.single-db_photo_entry .dagbouwer-single-content > .wp-block-image:not(.dagbouwer-single-featured) img {
	padding: 8px;
	border: 1px solid color-mix(in srgb, var(--db-border), transparent 16%);
	background: rgba(255, 255, 255, 0.92);
}

.dagbouwer-single-content .wp-block-gallery img,
.dagbouwer-single-content .wp-block-image img {
	border-radius: var(--db-radius-md);
	box-shadow: 0 14px 34px rgba(16, 24, 40, 0.08);
}

.dagbouwer-contact-page {
	padding-block: clamp(36px, 6vw, 72px);
}

.dagbouwer-contact-page .dagbouwer-archive-hero {
	max-width: 760px;
	margin-inline: auto;
	text-align: center;
}

.dagbouwer-contact-layout {
	display: grid;
	grid-template-columns: minmax(0, 680px);
	justify-content: center;
	max-width: 760px;
	margin-inline: auto;
}

.dagbouwer-contact-card {
	position: relative;
	padding: clamp(22px, 4vw, 36px);
	border: 1px solid var(--db-border);
	border-radius: var(--db-radius-lg);
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.9), rgba(247, 239, 227, 0.74)),
		var(--db-surface);
	box-shadow: 0 18px 48px rgba(16, 24, 40, 0.09);
	overflow: hidden;
}

.dagbouwer-contact-card::after {
	content: "";
	position: absolute;
	right: -38px;
	top: 22px;
	width: 140px;
	height: 92px;
	border: 1px solid color-mix(in srgb, var(--db-green), transparent 58%);
	border-radius: 48% 52% 44% 56% / 58% 42% 55% 45%;
	transform: rotate(12deg);
	pointer-events: none;
}

.dagbouwer-contact-card form {
	position: relative;
	z-index: 1;
	display: grid;
	gap: 14px;
}

.dagbouwer-contact-card p {
	margin: 0;
}

.dagbouwer-contact-card label {
	display: block;
	margin-bottom: 6px;
	font-weight: 800;
}

.dagbouwer-contact-card input,
.dagbouwer-contact-card textarea {
	width: 100%;
	border: 1px solid var(--db-border);
	border-radius: 18px;
	padding: 11px 14px;
	background: var(--db-surface);
	color: var(--db-ink);
	font: inherit;
}

.dagbouwer-contact-card textarea {
	resize: vertical;
}

.dagbouwer-contact-status {
	position: relative;
	z-index: 1;
	margin: 0 0 16px;
	padding: 11px 14px;
	border: 1px solid color-mix(in srgb, var(--db-green), transparent 42%);
	border-radius: 999px;
	background: color-mix(in srgb, var(--db-green), white 88%);
	color: var(--db-navy);
	font-weight: 800;
}

.dagbouwer-single-header {
	max-width: 900px;
	margin: clamp(48px, 8vw, 88px) auto 32px;
	text-align: center;
}

.dagbouwer-single-content {
	max-width: 820px;
	margin-inline: auto;
}

.dagbouwer-about-page {
	padding-top: clamp(42px, 7vw, 78px);
}

.dagbouwer-about-card {
	position: relative;
	max-width: 980px;
	margin-inline: auto;
	padding: clamp(28px, 5vw, 58px);
	border: 1px solid var(--db-border);
	border-radius: 22px;
	background:
		linear-gradient(135deg, rgba(247, 239, 227, 0.82), rgba(234, 242, 248, 0.58)),
		var(--db-surface);
	box-shadow: 0 24px 70px rgba(16, 24, 40, 0.1);
	overflow: hidden;
}

.dagbouwer-about-card::before {
	content: "";
	position: absolute;
	right: clamp(-84px, -6vw, -34px);
	top: clamp(26px, 7vw, 74px);
	width: clamp(180px, 24vw, 310px);
	height: clamp(240px, 31vw, 420px);
	border: 1px solid color-mix(in srgb, var(--db-rust), transparent 58%);
	border-radius: 48% 52% 44% 56% / 58% 42% 55% 45%;
	transform: rotate(8deg);
	pointer-events: none;
}

.dagbouwer-about-card::after {
	content: "";
	position: absolute;
	left: clamp(-76px, -5vw, -28px);
	bottom: clamp(22px, 5vw, 58px);
	width: clamp(150px, 18vw, 240px);
	height: clamp(78px, 10vw, 128px);
	border: 1px solid color-mix(in srgb, var(--db-green), transparent 66%);
	border-radius: 48% 52% 44% 56% / 58% 42% 55% 45%;
	transform: rotate(-8deg);
	pointer-events: none;
}

.dagbouwer-about-card > * {
	position: relative;
	z-index: 1;
}

.dagbouwer-about-card__intro {
	display: grid;
	grid-template-columns: 170px minmax(0, 1fr);
	column-gap: clamp(22px, 4vw, 42px);
	align-items: center;
	margin-bottom: clamp(24px, 4vw, 42px);
}

.dagbouwer-about-card__image {
	grid-row: span 3;
	width: 172px;
	height: 214px;
	margin: 0;
	border: 1px solid color-mix(in srgb, var(--db-green), var(--db-surface) 58%);
	outline: 10px solid color-mix(in srgb, var(--db-blue-soft), white 36%);
	transform: translateX(12px) rotate(var(--db-about-oval-angle, 9deg));
	box-shadow: 0 18px 40px rgba(16, 24, 40, 0.12), 0 0 0 1px color-mix(in srgb, var(--db-green), transparent 78%);
}

.dagbouwer-about-card__image img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: center;
	transform: translate(var(--db-about-image-x, 0%), var(--db-about-image-y, 0%)) rotate(var(--db-about-image-angle, -9deg)) scale(var(--db-about-image-zoom, 0.86));
	transform-origin: center;
}

.dagbouwer-about-card__image.is-empty {
	background:
		linear-gradient(135deg, rgba(95, 141, 78, 0.2), rgba(217, 107, 59, 0.16)),
		var(--db-sand-soft);
}

.dagbouwer-about-card__image.is-empty::after {
	content: "";
	position: absolute;
	inset: 13px;
	border: 1px solid color-mix(in srgb, var(--db-green), transparent 56%);
	border-radius: inherit;
}

.dagbouwer-about-card h1 {
	margin: 0 0 10px;
	font-size: clamp(2.4rem, 6vw, 4.6rem);
}

.dagbouwer-about-card__content {
	max-width: 760px;
	padding: clamp(18px, 3vw, 28px);
	border: 1px solid color-mix(in srgb, var(--db-border), transparent 24%);
	border-radius: var(--db-radius-md);
	background: rgba(255, 255, 255, 0.46);
}

.dagbouwer-about-card__content > *:first-child {
	margin-top: 0;
}

.dagbouwer-single-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(280px, 340px);
	gap: clamp(28px, 4vw, 48px);
	align-items: start;
	margin-top: 18px;
}

.dagbouwer-single-layout .dagbouwer-single-content {
	max-width: 820px;
	margin-inline: 0;
}

.dagbouwer-single-sidebar {
	position: sticky;
	top: 88px;
}

.dagbouwer-sidebar-intro {
	margin: 8px 0 16px;
	color: var(--db-muted);
	font-size: 0.96rem;
}

.dagbouwer-post-navigation {
	margin-top: 34px;
	padding-top: 20px;
	border-top: 1px solid var(--db-border);
}

.dagbouwer-comments {
	margin-top: 46px;
	padding-top: 28px;
	border-top: 1px solid var(--db-border);
}

.dagbouwer-comments .wp-block-comments-title {
	margin-bottom: 18px;
	font-size: clamp(1.65rem, 3vw, 2.25rem);
}

.dagbouwer-comments .wp-block-comment-template {
	display: grid;
	gap: 14px;
	margin: 0 0 24px;
	padding: 0;
	list-style: none;
}

.dagbouwer-comment {
	padding: 18px;
	border: 1px solid var(--db-border);
	border-radius: var(--db-radius-md);
	background: var(--db-surface);
}

.dagbouwer-comment .wp-block-comment-author-name,
.dagbouwer-comment .wp-block-comment-date {
	display: inline-flex;
	margin-right: 10px;
	font-size: 0.9rem;
}

.dagbouwer-comment .wp-block-comment-author-name {
	font-weight: 800;
}

.dagbouwer-comments .comment-reply-link,
.dagbouwer-comments .wp-block-comments-pagination a,
.dagbouwer-comments input[type="submit"] {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 40px;
	padding: 7px 13px;
	border: 1px solid var(--db-border);
	border-radius: 999px;
	background: var(--db-surface);
	color: var(--db-navy);
	font-weight: 800;
	text-decoration: none;
}

.dagbouwer-comments input[type="submit"] {
	border: 0;
	background: var(--db-navy);
	color: var(--db-surface);
}

.dagbouwer-recipe-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(270px, 320px);
	gap: 34px;
	align-items: start;
}

.dagbouwer-recipe-layout .dagbouwer-single-content {
	max-width: 920px;
}

.dagbouwer-recipe-box {
	position: relative;
	padding: 22px;
	border: 1px solid var(--db-border);
	border-radius: var(--db-radius-md);
	background: var(--db-surface);
	overflow: hidden;
}

.dagbouwer-recipe-box::after {
	content: "";
	position: absolute;
	right: -32px;
	top: 20px;
	width: 110px;
	height: 72px;
	border: 1px solid color-mix(in srgb, var(--db-rust), transparent 70%);
	border-radius: 48% 52% 44% 56% / 58% 42% 55% 45%;
	transform: rotate(10deg);
	pointer-events: none;
}

.dagbouwer-recipe-details {
	display: grid;
	gap: 18px;
	margin-top: 30px;
}

.dagbouwer-recipe-cookmode {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 18px;
	align-items: center;
	padding: 18px 20px;
	border: 1px solid color-mix(in srgb, var(--db-green), transparent 50%);
	border-radius: var(--db-radius-md);
	background:
		linear-gradient(135deg, rgba(95, 141, 78, 0.14), rgba(247, 239, 227, 0.78)),
		var(--db-surface);
}

.dagbouwer-recipe-cookmode h2,
.dagbouwer-recipe-cookmode p {
	margin: 0;
}

.dagbouwer-recipe-cookmode p {
	color: var(--db-muted);
}

.is-cookmode .dagbouwer-header {
	position: static;
}

.is-cookmode .dagbouwer-recipe-cookmode {
	position: sticky;
	top: 12px;
	z-index: 20;
	box-shadow: var(--db-shadow);
}

.dagbouwer-recipe-meta-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 14px;
	align-items: stretch;
}

.dagbouwer-recipe-stat {
	position: relative;
	display: grid;
	align-content: center;
	min-height: 106px;
	padding: 18px 16px;
	border: 1px solid var(--db-border);
	border-radius: 22px;
	background:
		linear-gradient(135deg, rgba(247, 239, 227, 0.86), rgba(234, 242, 248, 0.56)),
		var(--db-surface);
	overflow: hidden;
	text-align: center;
	box-shadow: 0 12px 28px rgba(37, 43, 46, 0.06);
}

.dagbouwer-recipe-stat::before {
	content: "";
	position: absolute;
	inset: 13px 18px;
	border: 1px solid color-mix(in srgb, var(--db-rust), transparent 64%);
	border-radius: 45% 55% 52% 48% / 56% 46% 54% 44%;
	opacity: 0.62;
	pointer-events: none;
	transform: rotate(3deg);
}

.dagbouwer-recipe-stat span {
	position: relative;
	display: block;
	color: var(--db-muted);
	font-size: 0.8rem;
	font-weight: 800;
	z-index: 1;
}

.dagbouwer-recipe-stat strong {
	position: relative;
	display: block;
	margin-top: 5px;
	font-family: Georgia, "Times New Roman", serif;
	font-size: 1.25rem;
	line-height: 1.15;
	z-index: 1;
}

.dagbouwer-recipe-box__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	margin-bottom: 14px;
}

.dagbouwer-recipe-box__header h2,
.dagbouwer-recipe-box h2 {
	margin: 0;
}

.dagbouwer-serving-control {
	display: inline-grid;
	grid-template-columns: 38px 48px 38px;
	align-items: center;
	border: 1px solid var(--db-border);
	border-radius: 999px;
	background: var(--db-surface);
	overflow: hidden;
}

.dagbouwer-serving-control button {
	width: 38px;
	height: 38px;
	border: 0;
	background: transparent;
	color: var(--db-navy);
	font-size: 1.15rem;
	font-weight: 900;
	cursor: pointer;
}

.dagbouwer-serving-control output {
	text-align: center;
	font-weight: 900;
}

.dagbouwer-check-list {
	display: grid;
	gap: 9px;
	margin: 10px 0 0;
	padding: 0;
	list-style: none;
}

.dagbouwer-tips-card ul {
	margin: 12px 0 0;
	padding-left: 1.2rem;
	list-style: disc;
}

.dagbouwer-tips-card li + li {
	margin-top: 8px;
}

.dagbouwer-recipe-note {
	margin: 8px 0 12px;
	color: var(--db-muted);
	font-size: 0.95rem;
}

.dagbouwer-check-list label {
	display: grid;
	grid-template-columns: 22px minmax(0, 1fr);
	gap: 10px;
	align-items: start;
	cursor: pointer;
}

.dagbouwer-check-list input {
	width: 18px;
	height: 18px;
	margin-top: 4px;
	accent-color: var(--db-green);
}

.dagbouwer-check-list input:checked + span {
	color: var(--db-muted);
	text-decoration: line-through;
}

.dagbouwer-step-list {
	display: grid;
	gap: 14px;
	margin: 16px 0 0;
	padding: 0;
	list-style: none;
	counter-reset: step;
}

.dagbouwer-step-list li {
	display: grid;
	grid-template-columns: 54px minmax(0, 1fr);
	gap: 14px;
	align-items: start;
	padding: 14px;
	border: 1px solid color-mix(in srgb, var(--db-border), transparent 20%);
	border-radius: var(--db-radius-md);
	background: color-mix(in srgb, var(--db-surface), var(--db-sand-soft) 38%);
}

.dagbouwer-step-toggle {
	display: inline-grid;
	place-items: center;
	width: 48px;
	height: 58px;
	border: 1px solid color-mix(in srgb, var(--db-rust), transparent 44%);
	border-radius: 48% 52% 44% 56% / 58% 42% 55% 45%;
	background: var(--db-surface);
	color: var(--db-rust);
	font-family: Georgia, "Times New Roman", serif;
	font-weight: 900;
	cursor: pointer;
	transform: rotate(-5deg);
}

.dagbouwer-step-toggle[aria-pressed="true"] {
	background: color-mix(in srgb, var(--db-green), white 82%);
	color: var(--db-navy);
	border-color: color-mix(in srgb, var(--db-green), transparent 35%);
}

.dagbouwer-step-list h3,
.dagbouwer-step-list p {
	margin: 0;
}

.dagbouwer-step-list h3 {
	font-size: 1.12rem;
}

.dagbouwer-step-list p {
	color: var(--db-muted);
}

.dagbouwer-step-list li.is-done p,
.dagbouwer-step-list li.is-done h3 {
	color: var(--db-muted);
	text-decoration: line-through;
}

.dagbouwer-comment-rating-field select {
	width: 100%;
	max-width: 260px;
	min-height: 42px;
	border: 1px solid var(--db-border);
	border-radius: 999px;
	padding: 8px 12px;
	background: var(--db-surface);
}

.dagbouwer-comment-rating {
	margin: 0 0 8px;
	color: var(--db-rust);
	letter-spacing: 0;
}

.dagbouwer-empty-state {
	padding: clamp(24px, 4vw, 40px);
	text-align: center;
}

.dagbouwer-footer {
	position: relative;
	margin-top: 72px;
	padding: 38px 0 24px;
	border-top: 1px solid var(--db-border);
	background:
		repeating-linear-gradient(135deg, rgba(11, 31, 58, 0.045) 0 1px, transparent 1px 16px),
		linear-gradient(180deg, #fffdfa 0%, #f7efe3 100%);
	color: var(--db-ink);
	overflow: clip;
	scrollbar-width: none;
}

.dagbouwer-footer::-webkit-scrollbar {
	display: none;
}

.dagbouwer-footer a,
.dagbouwer-footer h3,
.dagbouwer-footer .dagbouwer-logo {
	color: var(--db-navy);
}

.dagbouwer-footer p {
	color: var(--db-muted);
}

.dagbouwer-footer__grid {
	display: grid;
	grid-template-columns: minmax(260px, 1.15fr) minmax(300px, 1.4fr) minmax(190px, 0.8fr);
	gap: 26px;
	align-items: start;
	min-width: 0;
	overflow: visible;
}

.dagbouwer-footer-links {
	display: grid;
	grid-template-columns: repeat(2, minmax(130px, 1fr));
	gap: 24px;
}

.dagbouwer-footer ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

.dagbouwer-footer li + li {
	margin-top: 8px;
}

.dagbouwer-footer__bottom {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 16px;
	margin-top: 24px;
	padding-top: 16px;
	border-top: 1px solid var(--db-border);
	color: var(--db-muted);
	font-size: 0.9rem;
}

@media (max-width: 960px) {
	.dagbouwer-header__inner {
		grid-template-columns: auto 1fr auto;
		gap: 12px;
	}

	.dagbouwer-header__nav {
		justify-content: flex-end;
		min-width: 44px;
	}

	.dagbouwer-mobile-menu {
		display: inline-grid;
	}

	.dagbouwer-main-grid,
	.dagbouwer-archive-layout,
	.dagbouwer-single-layout,
	.dagbouwer-recipe-layout,
	.dagbouwer-contact-layout,
	.dagbouwer-newsletter {
		grid-template-columns: 1fr;
	}

	.dagbouwer-sidebar,
	.dagbouwer-single-sidebar {
		position: static;
	}

	.dagbouwer-dynamic-nav ul {
		justify-content: flex-end;
		gap: 12px;
	}

	.dagbouwer-about-card__intro {
		grid-template-columns: 1fr;
		text-align: left;
	}

	.dagbouwer-about-card__image {
		grid-row: auto;
		margin-bottom: 18px;
	}

	.dagbouwer-featured-grid,
	.dagbouwer-card-grid,
	.dagbouwer-recipe-grid,
	.dagbouwer-search-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.dagbouwer-card-grid.is-4x2 {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.dagbouwer-photo-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.dagbouwer-photo-experience-grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
		grid-auto-rows: 76px;
	}

	.dagbouwer-photo-experience-card,
	.dagbouwer-photo-experience-card.is-wide,
	.dagbouwer-photo-experience-card.is-featured,
	.dagbouwer-photo-experience-card.is-panorama {
		grid-column: span 2;
	}

	.dagbouwer-photo-story__layer,
	.dagbouwer-photo-story__layer.is-wide {
		grid-template-columns: 1fr;
	}

	.wp-block-gallery.is-style-dagbouwer-photo-grid-4,
	.wp-block-gallery.is-style-dagbouwer-photo-grid-3 {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
	}

	.wp-block-gallery.is-style-dagbouwer-photo-mosaic {
		grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
	}

	.dagbouwer-recipe-meta-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 640px) {
	body {
		font-size: 16px;
	}

	.dagbouwer-header__inner {
		min-height: 64px;
	}

	.dagbouwer-featured-grid,
	.dagbouwer-card-grid,
	.dagbouwer-card-grid.is-2x2,
	.dagbouwer-card-grid.is-3x2,
	.dagbouwer-card-grid.is-3x3,
	.dagbouwer-card-grid.is-4x2,
	.dagbouwer-recipe-grid,
	.dagbouwer-search-grid,
	.dagbouwer-photo-grid {
		grid-template-columns: 1fr;
	}

	.dagbouwer-topic-list {
		grid-template-columns: 1fr;
	}

	.dagbouwer-photo-card.is-featured {
		grid-column: auto;
		grid-row: auto;
	}

	.dagbouwer-newsletter form,
	.dagbouwer-search-form {
		flex-direction: column;
	}

	.dagbouwer-photo-experience__hero {
		border-radius: var(--db-radius-md);
	}

	.dagbouwer-photo-experience-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		grid-auto-rows: 72px;
	}

	.dagbouwer-photo-experience-card,
	.dagbouwer-photo-experience-card.is-wide,
	.dagbouwer-photo-experience-card.is-featured,
	.dagbouwer-photo-experience-card.is-panorama {
		grid-column: span 2;
	}

	.wp-block-gallery.is-style-dagbouwer-photo-grid-2,
	.wp-block-gallery.is-style-dagbouwer-photo-grid-3,
	.wp-block-gallery.is-style-dagbouwer-photo-grid-4,
	.wp-block-gallery.is-style-dagbouwer-photo-contain {
		grid-template-columns: 1fr !important;
	}

	.wp-block-gallery.is-style-dagbouwer-photo-mosaic {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
		grid-auto-rows: 72px;
	}

	.wp-block-gallery.is-style-dagbouwer-photo-mosaic .wp-block-image,
	.wp-block-gallery.is-style-dagbouwer-photo-mosaic .wp-block-image:nth-child(5n + 1),
	.wp-block-gallery.is-style-dagbouwer-photo-mosaic .wp-block-image:nth-child(5n + 3) {
		grid-column: span 2;
		grid-row: span 2;
	}

	.dagbouwer-photo-experience-card__text {
		left: 10px;
		right: 10px;
		bottom: 10px;
	}

	.dagbouwer-recipe-cookmode,
	.dagbouwer-recipe-box__header {
		grid-template-columns: 1fr;
	}

	.dagbouwer-recipe-box__header {
		display: grid;
	}

	.dagbouwer-recipe-meta-grid {
		grid-template-columns: 1fr;
	}

	.dagbouwer-step-list li {
		grid-template-columns: 46px minmax(0, 1fr);
		padding: 12px;
	}

	.dagbouwer-step-toggle {
		width: 42px;
		height: 50px;
	}

	.dagbouwer-footer__grid {
		grid-template-columns: 1fr;
	}
}
