/*
 * TilburgWijzer thema — editorial design system
 *
 * Aesthetic: Dutch editorial / newspaper-meets-digital.
 * TilburgsAns Black als grafisch hoofdpersonage. Asymmetrische grids
 * gebouwd op een strakke Crouwel-12. Zwart-wit core, kleur enkel als
 * accent. Dikke regels + haarlijnen als architectuur.
 *
 * Volgorde: tokens → base → masthead → hero → secondary → sections
 *           → cards → header/footer → motion → reduced motion.
 */

/* ──────────────────────────────────────────────────
   Tokens
   ──────────────────────────────────────────────────*/
:root {
	--tw-rule-thick: 4px;
	--tw-rule-medium: 2px;
	--tw-rule-hair: 1px;

	--tw-tracking-eyebrow: 0.12em;
	--tw-tracking-tight: -0.02em;

	--tw-grain-opacity: 0.035;
}

/* ──────────────────────────────────────────────────
   Base — typography polish, smoothing
   ──────────────────────────────────────────────────*/
body {
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
}

a {
	transition: color 0.2s ease-out;
}

/* TilburgsAns brand signature: italic + underline.
   Apply to <em> for inline accent — this is the typeface's own move. */
em,
.tw-mark {
	font-style: italic;
	text-decoration: underline;
	text-decoration-thickness: 2px;
	text-underline-offset: 0.15em;
}

/* ──────────────────────────────────────────────────
   Masthead strip — the issue identifier
   ──────────────────────────────────────────────────*/
.tw-issue-strip {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 1rem;
	padding-block: 0.6rem;
	border-top: var(--tw-rule-thick) solid var(--wp--preset--color--primary);
	border-bottom: var(--tw-rule-medium) solid var(--wp--preset--color--primary);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: var(--tw-tracking-eyebrow);
	text-transform: uppercase;
	color: var(--wp--preset--color--primary);
	font-variant-numeric: tabular-nums;
}

.tw-issue-strip p {
	margin: 0;
}

@media (max-width: 600px) {
	.tw-issue-strip {
		font-size: 0.62rem;
	}
}

/* ──────────────────────────────────────────────────
   Hero — masthead headline asymmetric with image
   Grid: text spans 7, image spans 5, headline overlaps right edge.
   ──────────────────────────────────────────────────*/
.tw-hero {
	padding-block: var(--wp--preset--spacing--60) var(--wp--preset--spacing--50);
}

.tw-hero .wp-block-query,
.tw-hero .wp-block-post-template {
	margin: 0;
	padding: 0;
	list-style: none;
}

.tw-hero .wp-block-post {
	display: grid;
	grid-template-columns: minmax(0, 7fr) minmax(0, 5fr);
	column-gap: var(--wp--preset--spacing--50);
	row-gap: 0;
	align-items: start;
	padding: 0;
	border: none;
	background: transparent;
}

@media (max-width: 900px) {
	.tw-hero .wp-block-post {
		grid-template-columns: 1fr;
		row-gap: var(--wp--preset--spacing--40);
	}
}

/* Text elements stack in column 1 */
.tw-hero .wp-block-post > .wp-block-post-terms,
.tw-hero .wp-block-post > .wp-block-post-title,
.tw-hero .wp-block-post > .wp-block-post-excerpt,
.tw-hero .wp-block-post > .wp-block-post-date {
	grid-column: 1;
}

.tw-hero .wp-block-post-terms {
	font-size: 0.75rem !important;
	font-weight: 700;
	letter-spacing: var(--tw-tracking-eyebrow);
	text-transform: uppercase;
	margin: 0 0 var(--wp--preset--spacing--20);
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
}

.tw-hero .wp-block-post-terms::before {
	content: "";
	display: inline-block;
	width: 0.55rem;
	height: 0.55rem;
	border-radius: 50%;
	background: var(--wp--preset--color--accent);
}

.tw-hero .wp-block-post-terms a {
	color: inherit !important;
	text-decoration: none;
}

.tw-hero .wp-block-post-title {
	font-family: var(--wp--preset--font-family--body);
	font-weight: 700;
	font-size: clamp(2rem, 4vw, 3.25rem) !important;
	line-height: 1.1;
	letter-spacing: -0.005em;
	margin: 0 0 var(--wp--preset--spacing--40);
	max-width: 18ch;
}

@media (max-width: 900px) {
	.tw-hero .wp-block-post-title {
		max-width: none;
	}
}

.tw-hero .wp-block-post-title a {
	color: inherit;
	text-decoration: none;
	background-image: linear-gradient(currentColor, currentColor);
	background-repeat: no-repeat;
	background-size: 0% 3px;
	background-position: 0 100%;
	padding-bottom: 3px;
	transition: background-size 0.4s cubic-bezier(0.2, 0.8, 0.2, 1);
}

.tw-hero .wp-block-post-title a:hover {
	background-size: 100% 3px;
}

.tw-hero .wp-block-post-featured-image,
.tw-hero .tw-featured-gridbalkje {
	grid-column: 2;
	grid-row: 1 / span 5;
	margin: 0;
	overflow: hidden;
}

@media (max-width: 900px) {
	.tw-hero .wp-block-post-featured-image,
	.tw-hero .tw-featured-gridbalkje {
		grid-column: 1;
		grid-row: auto;
	}
}

.tw-hero .wp-block-post-featured-image img {
	display: block;
	width: 100%;
	height: auto;
}

.tw-hero .wp-block-post-excerpt {
	grid-column: 1;
	grid-row: 3;
	font-family: var(--wp--preset--font-family--body);
	font-size: 1.125rem;
	font-weight: 400;
	line-height: 1.5;
	max-width: 32em;
	margin: 0 0 var(--wp--preset--spacing--30);
}

.tw-hero .wp-block-post-excerpt__excerpt {
	margin: 0;
}

.tw-hero .wp-block-post-date {
	grid-column: 1;
	grid-row: 4;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: var(--tw-tracking-eyebrow);
	text-transform: uppercase;
	color: var(--wp--preset--color--gray-600);
	font-variant-numeric: tabular-nums;
}

/* ──────────────────────────────────────────────────
   Hero secondary — 3 columns under hero, hairline-separated
   ──────────────────────────────────────────────────*/
.tw-hero-secondary {
	border-top: var(--tw-rule-thick) solid var(--wp--preset--color--primary);
	padding-block: var(--wp--preset--spacing--40) var(--wp--preset--spacing--60);
}

.tw-hero-secondary .wp-block-post-template {
	display: grid !important;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	column-gap: var(--wp--preset--spacing--50);
	row-gap: 0;
	margin: 0;
	padding: 0;
	list-style: none;
}

@media (max-width: 768px) {
	.tw-hero-secondary .wp-block-post-template {
		grid-template-columns: 1fr;
		column-gap: 0;
	}
}

.tw-hero-secondary .wp-block-post {
	position: relative;
	padding: var(--wp--preset--spacing--30) var(--wp--preset--spacing--40);
	border-bottom: 0;
	background: transparent !important;
	margin: 0;
}

.tw-hero-secondary .wp-block-post:first-child {
	padding-left: 0;
}

.tw-hero-secondary .wp-block-post:last-child {
	padding-right: 0;
}

.tw-hero-secondary .wp-block-post:not(:last-child)::after {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	right: calc(var(--wp--preset--spacing--50) / -2);
	width: var(--tw-rule-hair);
	background: var(--wp--preset--color--gray-200);
}

@media (max-width: 768px) {
	.tw-hero-secondary .wp-block-post {
		padding: var(--wp--preset--spacing--40) 0;
		border-bottom: var(--tw-rule-hair) solid var(--wp--preset--color--gray-200);
	}
	.tw-hero-secondary .wp-block-post:last-child {
		border-bottom: 0;
	}
	.tw-hero-secondary .wp-block-post:not(:last-child)::after {
		content: none;
	}
	.tw-hero-secondary .wp-block-post-featured-image {
		margin-inline: 0;
	}
}

.tw-hero-secondary .wp-block-post-featured-image,
.tw-hero-secondary .tw-featured-gridbalkje {
	margin: 0 calc(-1 * var(--wp--preset--spacing--40)) var(--wp--preset--spacing--30);
	overflow: hidden;
}

.tw-hero-secondary .wp-block-post:first-child .wp-block-post-featured-image,
.tw-hero-secondary .wp-block-post:first-child .tw-featured-gridbalkje {
	margin-left: 0;
}

.tw-hero-secondary .wp-block-post:last-child .wp-block-post-featured-image,
.tw-hero-secondary .wp-block-post:last-child .tw-featured-gridbalkje {
	margin-right: 0;
}

.tw-hero-secondary .wp-block-post-featured-image img {
	display: block;
	width: 100%;
	height: auto;
}

.tw-hero-secondary .wp-block-post-terms {
	font-size: 0.75rem !important;
	font-weight: 700;
	letter-spacing: var(--tw-tracking-eyebrow);
	text-transform: uppercase;
	margin: 0 0 var(--wp--preset--spacing--20);
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
}

.tw-hero-secondary .wp-block-post-terms::before {
	content: "";
	display: inline-block;
	width: 0.5rem;
	height: 0.5rem;
	border-radius: 50%;
	background: var(--wp--preset--color--accent);
}

.tw-hero-secondary .wp-block-post-terms a {
	color: inherit !important;
	text-decoration: none;
}

.tw-hero-secondary .wp-block-post-title {
	font-family: var(--wp--preset--font-family--body);
	font-weight: 700;
	font-size: 1.05rem;
	line-height: 1.25;
	margin: 0 0 var(--wp--preset--spacing--20);
}

.tw-hero-secondary .wp-block-post-date {
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: var(--tw-tracking-eyebrow);
	text-transform: uppercase;
	color: var(--wp--preset--color--gray-600);
	font-variant-numeric: tabular-nums;
}

/* ──────────────────────────────────────────────────
   Sections — numbered editorial blocks
   Numerals are auto-generated via CSS counters so the block
   markup stays plain (no data-attributes).
   ──────────────────────────────────────────────────*/
.tw-front-main {
	counter-reset: tw-section;
}

.tw-section {
	position: relative;
	counter-increment: tw-section;
	padding-block: var(--wp--preset--spacing--70) var(--wp--preset--spacing--60);
}

.tw-section-header {
	position: relative;
	display: grid;
	grid-template-columns: 1fr auto;
	column-gap: var(--wp--preset--spacing--40);
	row-gap: var(--wp--preset--spacing--10);
	align-items: end;
	border-top: var(--tw-rule-thick) solid var(--wp--preset--color--primary);
	padding-top: var(--wp--preset--spacing--30);
	margin-bottom: var(--wp--preset--spacing--50);
}

/* Inline-titel: eyebrow staat links naast de h2 in plaats van erboven.
   WP's `is-layout-constrained` geeft de inner group max-width content-size
   en auto-margins → die moeten we killen om links uit te lijnen met de streep. */
.tw-section-header > div:first-child,
.tw-section-header > .wp-block-group:first-child {
	display: flex;
	align-items: baseline;
	flex-wrap: wrap;
	justify-content: flex-start;
	text-align: left;
	column-gap: var(--wp--preset--spacing--40);
	row-gap: var(--wp--preset--spacing--10);
	max-width: none !important;
	margin-left: 0 !important;
	margin-right: 0 !important;
	padding-left: 0 !important;
	padding-right: 0 !important;
}

/* WP's `is-layout-constrained` injecteert `margin: auto !important` op
   children om ze te centreren. Daar moeten we doorheen breken om de
   eyebrow + title links uit te lijnen met de streep. */
.tw-section-header > div:first-child > .tw-section-eyebrow,
.tw-section-header > div:first-child > .tw-section-title,
.tw-section-header > .wp-block-group:first-child > .tw-section-eyebrow,
.tw-section-header > .wp-block-group:first-child > .tw-section-title {
	margin-left: 0 !important;
	margin-right: 0 !important;
	max-width: none;
}

.tw-section-eyebrow {
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: var(--tw-tracking-eyebrow);
	text-transform: uppercase;
	margin: 0 0 var(--wp--preset--spacing--10);
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
}

/* Inline-context: groter, geen onder-marge, geen line-height-overshoot. */
.tw-section-header .tw-section-eyebrow {
	font-size: clamp(1.4rem, 2.6vw, 2rem);
	margin: 0;
	gap: 0.7rem;
}

.tw-section-header .tw-section-eyebrow::before {
	width: 0.85em;
	height: 0.85em;
}

.tw-section-eyebrow::before {
	content: "";
	display: inline-block;
	width: 0.65rem;
	height: 0.65rem;
	border-radius: 50%;
	background: var(--tw-section-color, var(--wp--preset--color--accent));
}

.tw-section-title {
	font-family: var(--wp--preset--font-family--display);
	font-weight: 900;
	font-size: clamp(1.75rem, 3.5vw, 2.75rem);
	line-height: 1;
	letter-spacing: var(--tw-tracking-tight);
	margin: 0;
}

.tw-section-cta {
	font-family: var(--wp--preset--font-family--body);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	text-decoration: underline;
	text-decoration-thickness: 2px;
	text-underline-offset: 0.35em;
	white-space: nowrap;
	color: inherit;
	margin-bottom: 0.6rem;
	transition: text-underline-offset 0.2s ease-out, text-decoration-thickness 0.2s ease-out;
}

.tw-section-cta:hover {
	text-decoration-thickness: 3px;
	text-underline-offset: 0.45em;
}

@media (max-width: 600px) {
	.tw-section-header {
		grid-template-columns: 1fr;
	}
	.tw-section-cta {
		margin-top: var(--wp--preset--spacing--20);
		justify-self: start;
	}
}

/* Section colour modifiers — drives the eyebrow dot */
.tw-section--news    { --tw-section-color: var(--wp--preset--color--accent); }
.tw-section--agenda  { --tw-section-color: var(--wp--preset--color--feest); }
.tw-section--kunst   { --tw-section-color: var(--wp--preset--color--kunst); }
.tw-section--foto    { --tw-section-color: var(--wp--preset--color--foto); }
.tw-section--locatie { --tw-section-color: var(--wp--preset--color--info); }
.tw-section--intro   { --tw-section-color: var(--wp--preset--color--primary); }

.tw-single-heading {
	margin-bottom: 0;
}

.tw-single-heading__content {
	width: 60%;
	max-width: var(--wp--style--global--content-size);
	margin-left: 0;
	margin-right: auto;
}

.tw-single-heading .tw-breadcrumb {
	max-width: none;
	margin-left: 0 !important;
	margin-right: 0 !important;
}

@media (max-width: 781px) {
	.tw-single-heading__content {
		width: 100%;
	}
}

/* ──────────────────────────────────────────────────
   Intro footer — "wegwijzer voor bewoners en bezoekers"
   Photo in a navy frame (like a postcard) + lead copy
   ──────────────────────────────────────────────────*/
.tw-section--intro {
	padding-block: var(--wp--preset--spacing--80) var(--wp--preset--spacing--70);
	border-top: var(--tw-rule-hair) solid var(--wp--preset--color--gray-200);
	margin-top: var(--wp--preset--spacing--60);
}

.tw-intro-cols {
	column-gap: var(--wp--preset--spacing--70) !important;
	row-gap: var(--wp--preset--spacing--50) !important;
	align-items: center;
}

.tw-intro-image {
	margin: 0;
}

.tw-intro-image .wp-block-image {
	margin: 0;
	background: var(--wp--preset--color--primary);
	border-radius: 1.5rem;
	padding: 0.75rem 0.75rem 0.25rem;
	overflow: hidden;
}

.tw-intro-image .wp-block-image img {
	width: 100%;
	height: auto;
	display: block;
	border-radius: 1rem;
	aspect-ratio: 16 / 10;
	object-fit: cover;
}

.tw-intro-image .wp-element-caption,
.tw-intro-image figcaption {
	color: var(--wp--preset--color--white);
	font-size: 0.85rem;
	font-weight: 400;
	text-align: center;
	margin: 0.6rem 0 0.4rem;
	padding: 0 0.5rem;
}

.tw-intro-text .tw-section-eyebrow {
	font-size: 0.75rem;
	margin: 0 0 var(--wp--preset--spacing--20);
}

.tw-intro-title {
	font-family: var(--wp--preset--font-family--display);
	font-weight: 400;
	font-size: clamp(1.75rem, 4.2vw, 3rem);
	line-height: 1.05;
	letter-spacing: var(--tw-tracking-tight);
	color: var(--wp--preset--color--primary);
	margin: 0 0 var(--wp--preset--spacing--40);
}

.tw-intro-title strong {
	font-weight: 700;
}

.tw-intro-lead {
	font-size: var(--wp--preset--font-size--medium);
	line-height: 1.55;
	max-width: 38rem;
	margin: 0;
	color: var(--wp--preset--color--gray-900);
}

.tw-intro-lead a {
	color: var(--wp--preset--color--accent);
	font-weight: 700;
	text-decoration: none;
	border-bottom: 1px solid currentColor;
}

.tw-intro-lead a:hover {
	color: var(--wp--preset--color--primary);
}

/* Stack op smal scherm — WP doet dit standaard al onder 781px,
   maar we tunen de spacing zodat het ademt. */
@media (max-width: 781px) {
	.tw-section--intro {
		padding-block: var(--wp--preset--spacing--60) var(--wp--preset--spacing--50);
	}
	.tw-intro-cols {
		row-gap: var(--wp--preset--spacing--40) !important;
	}
	.tw-intro-image .wp-block-image {
		border-radius: 1.25rem;
		padding: 0.6rem 0.6rem 0.2rem;
	}
	.tw-intro-image .wp-block-image img {
		border-radius: 0.75rem;
	}
}

/* ──────────────────────────────────────────────────
   Cards — editorial, no shadows, hairline borders
   ──────────────────────────────────────────────────*/
.tw-section .wp-block-query,
.tw-section .wp-block-post-template {
	margin: 0;
	padding: 0;
	list-style: none;
}

.tw-section .wp-block-post-template.is-layout-grid {
	display: grid;
	column-gap: var(--wp--preset--spacing--50) !important;
	row-gap: 0 !important;
	border-top: var(--tw-rule-hair) solid var(--wp--preset--color--gray-200);
}

/* Fallback grid-template-columns voor wanneer WP's auto-CSS ontbreekt
   — gebeurt in dynamic blocks die `do_blocks()` op inner-markup runnen
   (zoals tw-related--by-taxonomy). Op statische block-markup levert WP
   zijn eigen container-rule en is deze regel idempotent. */
.tw-section .wp-block-post-template.is-layout-grid.columns-3 {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}
.tw-section .wp-block-post-template.is-layout-grid.columns-4 {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

@media (max-width: 900px) {
	.tw-section .wp-block-post-template.is-layout-grid.columns-3,
	.tw-section .wp-block-post-template.is-layout-grid.columns-4 {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 600px) {
	.tw-section .wp-block-post-template.is-layout-grid.columns-3,
	.tw-section .wp-block-post-template.is-layout-grid.columns-4 {
		grid-template-columns: 1fr;
	}
}

.tw-section .wp-block-post {
	position: relative;
	padding: var(--wp--preset--spacing--40) 0;
	background: transparent !important;
	margin: 0;
}

/* Horizontal hairline at the bottom of each card, extended into both
   column-gaps so adjacent cards' lines merge into one continuous rule. */
.tw-section .wp-block-post::before {
	content: "";
	position: absolute;
	left: calc(var(--wp--preset--spacing--50) / -2);
	right: calc(var(--wp--preset--spacing--50) / -2);
	bottom: 0;
	height: var(--tw-rule-hair);
	background: var(--wp--preset--color--gray-200);
}

/* Don't let the hairline overshoot the section's outer edges. */
.tw-section:not(.tw-section--compact) .wp-block-post:nth-child(3n+1)::before,
.tw-section--compact .wp-block-post:nth-child(4n+1)::before {
	left: 0;
}

.tw-section:not(.tw-section--compact) .wp-block-post:nth-child(3n)::before,
.tw-section--compact .wp-block-post:nth-child(4n)::before {
	right: 0;
}

/* Vertical hairline centered in the column-gap; suppressed on the right
   edge of each row and on the very last card. */
.tw-section:not(.tw-section--compact) .wp-block-post:not(:nth-child(3n)):not(:last-child)::after,
.tw-section--compact .wp-block-post:not(:nth-child(4n)):not(:last-child)::after {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	right: calc(var(--wp--preset--spacing--50) / -2);
	width: var(--tw-rule-hair);
	background: var(--wp--preset--color--gray-200);
}

@media (max-width: 768px) {
	.tw-section .wp-block-post::before {
		left: 0;
		right: 0;
	}
	.tw-section .wp-block-post::after {
		content: none;
	}
}

.tw-section .wp-block-post-featured-image,
.tw-section .tw-featured-gridbalkje {
	margin: 0 0 var(--wp--preset--spacing--30);
	overflow: hidden;
}

.tw-section .wp-block-post-featured-image img {
	display: block;
	width: 100%;
	height: auto;
	transition: transform 0.5s ease-out;
}

.tw-section .wp-block-post:hover .wp-block-post-featured-image img {
	transform: scale(1.02);
}

.tw-section .wp-block-post-terms {
	font-size: 0.75rem !important;
	font-weight: 700;
	letter-spacing: var(--tw-tracking-eyebrow);
	text-transform: uppercase;
	margin: 0 0 var(--wp--preset--spacing--20);
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
}

.tw-section .wp-block-post-terms::before {
	content: "";
	display: inline-block;
	width: 0.5rem;
	height: 0.5rem;
	border-radius: 50%;
	background: var(--tw-section-color, var(--wp--preset--color--accent));
}

.tw-section .wp-block-post-terms a {
	color: inherit !important;
	text-decoration: none;
	/* Click-area naar 24px+ voor WCAG 2.5.8 target-size, zonder de visuele
	   "inline tekst met ●-dot"-presentatie te wijzigen. */
	display: inline-block;
	padding-block: 4px;
}

.tw-section .wp-block-post-title {
	font-family: var(--wp--preset--font-family--body);
	font-weight: 700;
	line-height: 1.2;
	margin: 0 0 var(--wp--preset--spacing--20);
}

.tw-section .wp-block-post-title a {
	color: inherit;
	text-decoration: none;
	background-image: linear-gradient(currentColor, currentColor);
	background-repeat: no-repeat;
	background-size: 0% 2px;
	background-position: 0 100%;
	transition: background-size 0.3s ease-out;
	padding-bottom: 2px;
}

.tw-section .wp-block-post:hover .wp-block-post-title a {
	background-size: 100% 2px;
}

.tw-section .wp-block-post-date {
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: var(--tw-tracking-eyebrow);
	text-transform: uppercase;
	color: var(--wp--preset--color--gray-600);
	font-variant-numeric: tabular-nums;
}

/* Variant: 4-up grid for kunst/foto/locatie shows just image + small title */
.tw-section--compact .wp-block-post-title {
	font-size: 0.95rem;
	font-weight: 700;
}

/* ──────────────────────────────────────────────────
   Header & footer touches
   ──────────────────────────────────────────────────*/
header.wp-block-group .wp-block-site-title a,
footer.wp-block-group .wp-block-site-title a {
	letter-spacing: var(--tw-tracking-tight);
}

header.wp-block-group .wp-block-navigation a {
	background-image: linear-gradient(currentColor, currentColor);
	background-repeat: no-repeat;
	background-size: 0% 2px;
	background-position: 0 100%;
	padding-bottom: 2px;
	transition: background-size 0.25s ease-out, color 0.2s ease-out;
}

header.wp-block-group .wp-block-navigation a:hover {
	background-size: 100% 2px;
}

footer.wp-block-group a {
	text-decoration: none;
	background-image: linear-gradient(currentColor, currentColor);
	background-repeat: no-repeat;
	background-size: 0% 1px;
	background-position: 0 100%;
	transition: background-size 0.3s ease-out;
	padding-bottom: 1px;
}

footer.wp-block-group a:hover {
	background-size: 100% 1px;
}

/* ──────────────────────────────────────────────────
   Reduced motion
   ──────────────────────────────────────────────────*/
@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		transition-duration: 0.01ms !important;
	}

	.tw-section .wp-block-post-featured-image img {
		transform: none !important;
	}
}

/* ──────────────────────────────────────────────────
   Social icons — gerenderd door tilburgwijzer/social-icons block
   ──────────────────────────────────────────────────*/
.tw-social-icons {
	display: flex;
	flex-wrap: wrap;
	gap: var(--wp--preset--spacing--20);
	margin: 0;
	padding: 0;
	list-style: none;
}

.tw-social-icons__link {
	display: inline-flex;
	width: 2.25rem;
	height: 2.25rem;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: var(--wp--preset--color--gray-50);
	transition: background-color 0.2s ease, transform 0.2s ease;
}

.tw-social-icons__link:hover,
.tw-social-icons__link:focus-visible {
	background: var(--wp--preset--color--primary);
	transform: translateY(-2px);
}

.tw-social-icons__img {
	width: 1.25rem;
	height: 1.25rem;
	object-fit: contain;
	transition: filter 0.2s ease;
}

.tw-social-icons__link:hover .tw-social-icons__img,
.tw-social-icons__link:focus-visible .tw-social-icons__img {
	filter: brightness(0) invert(1);
}

/* ──────────────────────────────────────────────────
   Information card — sidebar op single-CPT pages
   Editorial: dikke top-rule, hairline scheidingslijntjes,
   geen schaduwen. Eyebrow-dot in CPT-kleur via --tw-card-color.
   ──────────────────────────────────────────────────*/
.tw-information-card {
	--tw-card-color: var(--wp--preset--color--info);
	border-top: var(--tw-rule-thick) solid var(--wp--preset--color--primary);
	padding-top: var(--wp--preset--spacing--30);
}

.tw-information-card__eyebrow {
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: var(--tw-tracking-eyebrow);
	text-transform: uppercase;
	margin: 0 0 var(--wp--preset--spacing--20);
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
}

.tw-information-card__eyebrow::before {
	content: "";
	display: inline-block;
	width: 0.65rem;
	height: 0.65rem;
	border-radius: 50%;
	background: var(--tw-card-color);
}

.tw-information-card__row {
	border-top: var(--tw-rule-hair) solid var(--wp--preset--color--gray-200);
	padding-block: var(--wp--preset--spacing--20);
	display: grid;
	grid-template-columns: 7rem 1fr;
	gap: var(--wp--preset--spacing--30);
	align-items: baseline;
}

.tw-information-card__row:last-child {
	border-bottom: var(--tw-rule-hair) solid var(--wp--preset--color--gray-200);
}

.tw-information-card__label {
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: var(--tw-tracking-eyebrow);
	text-transform: uppercase;
	color: var(--wp--preset--color--gray-600);
	margin: 0;
}

.tw-information-card__value {
	margin: 0;
	font-size: 0.95rem;
	line-height: 1.4;
	overflow-wrap: anywhere;
}

.tw-information-card__value:empty {
	display: none;
}

.tw-information-card__value:empty + .tw-information-card__label,
.tw-information-card__row:has(.tw-information-card__value:empty) {
	display: none;
}

.tw-information-card__value a {
	color: var(--tw-card-color);
	text-decoration: underline;
	text-underline-offset: 0.25em;
}

/* Website-row gebruikt een wp:button (vanwege block-bindings die alleen op
   button-tekst+url werken). Hier strippen we de button-styling zodat het
   visueel een gewone tekst-link wordt — consistent met andere rij-waardes. */
.tw-information-card .wp-block-buttons {
	margin: 0;
	display: flex;
	justify-content: flex-start;
	gap: 0;
}

.tw-information-card .wp-block-button {
	margin: 0;
	display: inline;
}

.tw-information-card .wp-block-button__link {
	background: transparent !important;
	background-color: transparent !important;
	color: var(--tw-card-color) !important;
	padding: 0 !important;
	border: 0 !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	font-size: inherit !important;
	font-weight: inherit !important;
	line-height: inherit !important;
	text-decoration: underline;
	text-underline-offset: 0.25em;
}

/* Kaart-row krijgt een eigen full-width layout: label boven, kaart eronder.
   De WP Google Maps wrapper claimt anders te veel breedte voor het 7rem-grid. */
.tw-information-card__row--map {
	grid-template-columns: 1fr;
	gap: var(--wp--preset--spacing--20);
}

.tw-information-card__row--map .tw-information-card__value {
	min-height: 16rem;
}

@media (max-width: 600px) {
	.tw-information-card__row {
		grid-template-columns: 1fr;
		gap: var(--wp--preset--spacing--10);
	}
}

/* ──────────────────────────────────────────────────
   Flickr-album grid — sober photo grid voor single-fotoalbums
   ──────────────────────────────────────────────────*/
.tw-flickr-album-wrap {
	position: relative;
}

.tw-flickr-album {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--wp--preset--spacing--20);
}

.tw-flickr-album__item {
	margin: 0;
}

.tw-flickr-album__link {
	display: block;
	overflow: hidden;
	background: var(--wp--preset--color--gray-50);
}

.tw-flickr-album__img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	aspect-ratio: 3 / 2;
	transition: transform 0.4s ease-out;
}

.tw-flickr-album__link:hover .tw-flickr-album__img {
	transform: scale(1.03);
}

.tw-flickr-album__photographer {
	position: absolute;
	right: var(--wp--preset--spacing--20);
	bottom: var(--wp--preset--spacing--20);
	margin: 0;
	padding: 0.35rem 0.55rem;
	max-width: calc(100% - var(--wp--preset--spacing--40));
	background: color-mix(in srgb, var(--wp--preset--color--contrast) 72%, transparent);
	color: var(--wp--preset--color--base);
	font-size: 0.8125rem;
	line-height: 1.35;
	text-align: right;
}

.tw-flickr-album__photographer-label {
	font-weight: 700;
}

@media (max-width: 900px) {
	.tw-flickr-album {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 480px) {
	.tw-flickr-album {
		grid-template-columns: 1fr;
	}
}

/* ─────────────────────────────────────────────────────────────
   Agenda — overzichtspagina, categoriepills, periode-chips, cards
   ──────────────────────────────────────────────────────────── */

.tw-agenda-overview {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--60);
}

/* — Categoriepills (top 12) ─────────────────────────── */

.tw-agenda-pills {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--30);
	border-top: var(--tw-rule-thick) solid var(--wp--preset--color--primary);
	padding-top: var(--wp--preset--spacing--30);
}

.tw-agenda-pills__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.tw-agenda-pills__item {
	margin: 0;
}

.tw-agenda-pills__link {
	display: inline-flex;
	align-items: baseline;
	gap: 0.55rem;
	padding: 0.55rem 0.95rem;
	border: var(--tw-rule-hair) solid var(--wp--preset--color--gray-200);
	color: var(--wp--preset--color--primary);
	font-size: var(--wp--preset--font-size--small);
	font-weight: 600;
	letter-spacing: 0.01em;
	text-decoration: none;
	transition: border-color 0.15s ease, background-color 0.15s ease, color 0.15s ease;
}

.tw-agenda-pills__link::before {
	content: "";
	display: inline-block;
	width: 0.55em;
	height: 0.55em;
	border-radius: 50%;
	background: var(--tw-cat-color, var(--wp--preset--color--feest));
	flex: 0 0 auto;
	transform: translateY(-0.05em);
}

.tw-agenda-pills__link:hover,
.tw-agenda-pills__link:focus-visible {
	border-color: var(--tw-cat-color, var(--wp--preset--color--primary));
	background: var(--tw-cat-color, var(--wp--preset--color--primary));
	color: var(--wp--preset--color--white);
	outline: none;
}

.tw-agenda-pills__count {
	font-size: 0.75em;
	font-weight: 500;
	color: var(--wp--preset--color--gray-600);
	font-variant-numeric: tabular-nums;
}

.tw-agenda-pills__link:hover .tw-agenda-pills__count,
.tw-agenda-pills__link:focus-visible .tw-agenda-pills__count {
	color: rgba(255, 255, 255, 0.75);
}

/* — Periode-chips (filterbalk) ──────────────────────── */

.tw-agenda-chips {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	border-top: var(--tw-rule-hair) solid var(--wp--preset--color--gray-200);
	border-bottom: var(--tw-rule-hair) solid var(--wp--preset--color--gray-200);
	padding-block: var(--wp--preset--spacing--30);
}

.tw-agenda-chip {
	display: inline-flex;
	align-items: center;
	padding: 0.5rem 0.9rem;
	border: var(--tw-rule-hair) solid var(--wp--preset--color--gray-200);
	color: var(--wp--preset--color--gray-600);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	text-decoration: none;
	transition: border-color 0.15s ease, color 0.15s ease, background-color 0.15s ease;
}

.tw-agenda-chip:hover,
.tw-agenda-chip:focus-visible {
	border-color: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--primary);
	outline: none;
}

.tw-agenda-chip.is-active {
	background: var(--wp--preset--color--primary);
	border-color: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--white);
}

/* — Agenda-secties + grid ──────────────────────────── */

.tw-agenda-section {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--40);
}

.tw-agenda-section .tw-section-header {
	margin-bottom: 0;
}

.tw-agenda-section--by-day {
	gap: var(--wp--preset--spacing--50);
}

.tw-agenda-day {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--30);
}

.tw-agenda-day__title {
	margin: 0;
	font-family: var(--wp--preset--font-family--display);
	font-size: clamp(1.3rem, 2.4vw, 1.75rem);
	font-weight: 800;
	line-height: 1.1;
	letter-spacing: var(--tw-tracking-tight);
	text-transform: capitalize;
	color: var(--wp--preset--color--primary);
	border-bottom: 1px solid var(--wp--preset--color--gray-200);
	padding-bottom: var(--wp--preset--spacing--20);
}

.tw-agenda-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: var(--wp--preset--spacing--50);
}

@media (max-width: 1024px) {
	.tw-agenda-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 768px) {
	.tw-agenda-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: var(--wp--preset--spacing--40);
	}
}

@media (max-width: 480px) {
	.tw-agenda-grid {
		grid-template-columns: 1fr;
	}
}

/* — Agenda-card (één event) ─────────────────────────── */

.tw-agenda-card {
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
	color: inherit;
	text-decoration: none;
	background: transparent;
}

.tw-agenda-card__media {
	overflow: hidden;
	background: var(--wp--preset--color--gray-50);
	margin-bottom: var(--wp--preset--spacing--20);
}

.tw-agenda-card__img,
.tw-agenda-card__placeholder {
	display: block;
	width: 100%;
	aspect-ratio: 3 / 2;
	height: auto;
	object-fit: cover;
	transition: transform 0.5s ease-out;
}

.tw-agenda-card__placeholder {
	background: linear-gradient(135deg, var(--wp--preset--color--gray-50), var(--wp--preset--color--gray-200));
}

.tw-agenda-card:hover .tw-agenda-card__img {
	transform: scale(1.03);
}

.tw-agenda-card__terms {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	margin: 0;
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: var(--tw-tracking-eyebrow);
	text-transform: uppercase;
	color: var(--wp--preset--color--gray-600);
}

.tw-agenda-card__terms::before {
	content: "";
	display: inline-block;
	width: 0.5rem;
	height: 0.5rem;
	border-radius: 50%;
	background: var(--tw-cat-color, var(--wp--preset--color--feest));
	flex: 0 0 auto;
}

.tw-agenda-card__title {
	font-family: var(--wp--preset--font-family--body);
	font-weight: 700;
	font-size: 1.125rem;
	line-height: 1.3;
	margin: 0;
	background-image: linear-gradient(currentColor, currentColor);
	background-repeat: no-repeat;
	background-size: 0% 2px;
	background-position: 0 100%;
	padding-bottom: 2px;
	transition: background-size 0.3s ease-out;
}

.tw-agenda-card:hover .tw-agenda-card__title,
.tw-agenda-card:focus-visible .tw-agenda-card__title {
	background-size: 100% 2px;
}

.tw-agenda-card__when {
	margin: 0;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: var(--tw-tracking-eyebrow);
	text-transform: uppercase;
	color: var(--wp--preset--color--primary);
	font-variant-numeric: tabular-nums;
}

.tw-agenda-card__venue {
	margin: 0;
	font-size: 0.85rem;
	line-height: 1.35;
	color: var(--wp--preset--color--gray-600);
}

.tw-agenda-empty {
	margin: 0;
	padding: var(--wp--preset--spacing--50) 0;
	color: var(--wp--preset--color--gray-600);
	font-style: italic;
}

/* ─────────────────────────────────────────────────────────────
   Kunstwerken — overzichtspagina (monochrome variant van agenda)
   ──────────────────────────────────────────────────────────── */

.tw-page-overview {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--60);
}

/* Pills — monochrome modifier: geen kleur-dot, hover op primary */
.tw-agenda-pills--mono .tw-agenda-pills__link::before {
	display: none;
}

.tw-agenda-pills--mono .tw-agenda-pills__link:hover,
.tw-agenda-pills--mono .tw-agenda-pills__link:focus-visible {
	border-color: var(--wp--preset--color--primary);
	background: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--white);
}

/* Card mono — geen kleur-dot voor de "terms"-eyebrow */
.tw-agenda-card--mono .tw-agenda-card__terms::before,
.tw-agenda-card__terms--mono::before {
	display: none;
}

/* Kaart-sectie */
.tw-kunstwerken-map__frame {
	position: relative;
	overflow: hidden;
	border: var(--tw-rule-hair) solid var(--wp--preset--color--gray-200);
	background: var(--wp--preset--color--gray-50);
	min-height: 420px;
}

.tw-kunstwerken-map__frame .wpgmza_map,
.tw-kunstwerken-map__frame .wpgmza-map-container {
	width: 100%;
	min-height: 420px;
}

.tw-kunstwerken-map__frame .tw-map-facade {
	min-height: inherit;
	border: 0;
}

@media (max-width: 768px) {
	.tw-kunstwerken-map__frame,
	.tw-kunstwerken-map__frame .wpgmza_map,
	.tw-kunstwerken-map__frame .wpgmza-map-container {
		min-height: 320px;
	}
}

/* Categorie-tegels — grote visuele index */
.tw-cat-tile-grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: var(--wp--preset--spacing--50);
}

@media (max-width: 1024px) {
	.tw-cat-tile-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 768px) {
	.tw-cat-tile-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: var(--wp--preset--spacing--40);
	}
}

@media (max-width: 480px) {
	.tw-cat-tile-grid {
		grid-template-columns: 1fr;
	}
}

.tw-cat-tile {
	margin: 0;
}

.tw-cat-tile__link {
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
	color: inherit;
	text-decoration: none;
}

.tw-cat-tile__media {
	overflow: hidden;
	background: var(--wp--preset--color--gray-50);
	margin-bottom: var(--wp--preset--spacing--20);
}

.tw-cat-tile__img,
.tw-cat-tile__placeholder {
	display: block;
	width: 100%;
	aspect-ratio: 4 / 3;
	height: auto;
	object-fit: cover;
	transition: transform 0.5s ease-out;
}

.tw-cat-tile__placeholder {
	background: linear-gradient(135deg, var(--wp--preset--color--gray-50), var(--wp--preset--color--gray-200));
}

.tw-cat-tile__link:hover .tw-cat-tile__img,
.tw-cat-tile__link:focus-visible .tw-cat-tile__img {
	transform: scale(1.03);
}

.tw-cat-tile__body {
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
}

.tw-cat-tile__name {
	font-family: var(--wp--preset--font-family--display);
	font-weight: 700;
	font-size: 1.25rem;
	line-height: 1.15;
	margin: 0;
	background-image: linear-gradient(currentColor, currentColor);
	background-repeat: no-repeat;
	background-size: 0% 2px;
	background-position: 0 100%;
	padding-bottom: 2px;
	transition: background-size 0.3s ease-out;
}

.tw-cat-tile__link:hover .tw-cat-tile__name,
.tw-cat-tile__link:focus-visible .tw-cat-tile__name {
	background-size: 100% 2px;
}

.tw-cat-tile__count {
	margin: 0;
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: var(--tw-tracking-eyebrow);
	text-transform: uppercase;
	color: var(--wp--preset--color--gray-600);
	font-variant-numeric: tabular-nums;
}

/* ─────────────────────────────────────────────────────────
   Archive- en taxonomy-templates
   ───────────────────────────────────────────────────────── */

.tw-archive-header {
	border-top: var(--tw-rule-thick) solid var(--wp--preset--color--primary);
	padding-top: var(--wp--preset--spacing--30);
	margin-bottom: var(--wp--preset--spacing--60);
}

.tw-archive-title {
	font-family: var(--wp--preset--font-family--display);
	font-weight: 900;
	font-size: clamp(2rem, 4.5vw, 3.25rem);
	line-height: 1;
	letter-spacing: var(--tw-tracking-tight);
	margin: 0 0 var(--wp--preset--spacing--30);
}

.tw-archive-intro {
	max-width: 60ch;
	font-size: 1.125rem;
	line-height: 1.55;
	color: var(--wp--preset--color--gray-600);
	margin: 0;
}

.tw-archive-intro:empty {
	display: none;
}

.tw-archive-description {
	border-top: 1px solid var(--wp--preset--color--gray-200);
	margin-top: var(--wp--preset--spacing--70);
	padding-top: var(--wp--preset--spacing--40);
}

.tw-archive-pagination {
	border-top: 1px solid var(--wp--preset--color--gray-200);
	padding-top: var(--wp--preset--spacing--40);
	gap: var(--wp--preset--spacing--30);
	font-size: 0.85rem;
	font-weight: 600;
	letter-spacing: 0.02em;
	text-transform: uppercase;
}

.tw-archive-pagination .wp-block-query-pagination-numbers {
	display: inline-flex;
	gap: 0.4rem;
}

.tw-archive-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.25rem;
	height: 2.25rem;
	padding: 0 0.5rem;
	border: 1px solid var(--wp--preset--color--gray-200);
	color: var(--wp--preset--color--primary);
	text-decoration: none;
	transition: border-color 0.15s ease, background-color 0.15s ease;
}

.tw-archive-pagination .page-numbers:hover {
	border-color: var(--wp--preset--color--primary);
}

.tw-archive-pagination .page-numbers.current {
	background: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--white);
	border-color: var(--wp--preset--color--primary);
}

.tw-archive-pagination .page-numbers.dots {
	border-color: transparent;
}

/* ─────────────────────────────────────────────────────────────
   Related strips (cross-CPT tabs + by-taxonomy)
   ──────────────────────────────────────────────────────────── */

.tw-related {
	margin-top: var(--wp--preset--spacing--70);
	border-top: 4px solid var(--wp--preset--color--primary);
	padding-top: var(--wp--preset--spacing--50);
}

/* Hide the radio inputs — we drive the tab state via :checked + sibling. */
.tw-related-tab-radio {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.tw-related-tabs-bar {
	display: flex;
	flex-wrap: wrap;
	gap: var(--wp--preset--spacing--30);
	border-bottom: 1px solid var(--wp--preset--color--gray-200);
	margin-bottom: var(--wp--preset--spacing--50);
}

.tw-related-tab-label {
	display: inline-flex;
	align-items: baseline;
	gap: 0.4em;
	padding: 0.65em 0.25em 0.85em;
	margin-bottom: -1px;
	color: var(--wp--preset--color--gray-600);
	font-family: var(--wp--preset--font-family--heading);
	font-size: var(--wp--preset--font-size--medium);
	font-weight: 600;
	cursor: pointer;
	border-bottom: 2px solid transparent;
	transition: color 0.15s ease, border-color 0.15s ease;
}

.tw-related-tab-label:hover {
	color: var(--wp--preset--color--primary);
}

.tw-related-tab-count {
	font-size: 0.75em;
	font-weight: 400;
	color: var(--wp--preset--color--gray-600);
}

/* Active tab styling — radio sits before the bar, so we use general sibling. */
.tw-related-tab-radio:checked + .tw-related-tab-radio + .tw-related-tab-radio + .tw-related-tab-radio + .tw-related-tab-radio + .tw-related-tab-radio + .tw-related-tabs-bar .tw-related-tab-label {
	/* placeholder — overruled by per-data-tab rules below */
}

/* Hide all panels by default. Each :checked radio enables its matching panel. */
.tw-related-panel {
	display: none;
}

/* Generate per-CPT visibility rules — the radio's data-tab attribute matches
   the panel's data-tab. Because radios are siblings of .tw-related-tabs-bar
   which is sibling of .tw-related-panels, we use general sibling combinator. */
.tw-related-tab-radio[data-tab="post"]:checked ~ .tw-related-panels .tw-related-panel[data-tab="post"],
.tw-related-tab-radio[data-tab="tribe_events"]:checked ~ .tw-related-panels .tw-related-panel[data-tab="tribe_events"],
.tw-related-tab-radio[data-tab="kunstwerk"]:checked ~ .tw-related-panels .tw-related-panel[data-tab="kunstwerk"],
.tw-related-tab-radio[data-tab="kunstwerken"]:checked ~ .tw-related-panels .tw-related-panel[data-tab="kunstwerken"],
.tw-related-tab-radio[data-tab="fotoalbum"]:checked ~ .tw-related-panels .tw-related-panel[data-tab="fotoalbum"],
.tw-related-tab-radio[data-tab="locatie"]:checked ~ .tw-related-panels .tw-related-panel[data-tab="locatie"],
.tw-related-tab-radio[data-tab="kermisattractie"]:checked ~ .tw-related-panels .tw-related-panel[data-tab="kermisattractie"],
.tw-related-tab-radio[data-tab="kermisattracties"]:checked ~ .tw-related-panels .tw-related-panel[data-tab="kermisattracties"] {
	display: block;
}

/* Active label state — use the same selector pattern but to style the label. */
.tw-related-tab-radio[data-tab="post"]:checked ~ .tw-related-tabs-bar .tw-related-tab-label[data-tab="post"],
.tw-related-tab-radio[data-tab="tribe_events"]:checked ~ .tw-related-tabs-bar .tw-related-tab-label[data-tab="tribe_events"],
.tw-related-tab-radio[data-tab="kunstwerk"]:checked ~ .tw-related-tabs-bar .tw-related-tab-label[data-tab="kunstwerk"],
.tw-related-tab-radio[data-tab="kunstwerken"]:checked ~ .tw-related-tabs-bar .tw-related-tab-label[data-tab="kunstwerken"],
.tw-related-tab-radio[data-tab="fotoalbum"]:checked ~ .tw-related-tabs-bar .tw-related-tab-label[data-tab="fotoalbum"],
.tw-related-tab-radio[data-tab="locatie"]:checked ~ .tw-related-tabs-bar .tw-related-tab-label[data-tab="locatie"],
.tw-related-tab-radio[data-tab="kermisattractie"]:checked ~ .tw-related-tabs-bar .tw-related-tab-label[data-tab="kermisattractie"],
.tw-related-tab-radio[data-tab="kermisattracties"]:checked ~ .tw-related-tabs-bar .tw-related-tab-label[data-tab="kermisattracties"] {
	color: var(--wp--preset--color--primary);
	border-bottom-color: var(--wp--preset--color--primary);
}

/* Card grid binnen een tab-panel. */
.tw-related-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--wp--preset--spacing--50);
	list-style: none;
	margin: 0;
	padding: 0;
}

@media (max-width: 900px) {
	.tw-related-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 600px) {
	.tw-related-grid { grid-template-columns: 1fr; }
}

.tw-related-card {
	display: flex;
	flex-direction: column;
}

.tw-related-card .wp-block-post-featured-image {
	margin: 0 0 var(--wp--preset--spacing--30);
}

.tw-related-card .wp-block-post-featured-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.4s ease;
}

.tw-related-card:hover .wp-block-post-featured-image img {
	transform: scale(1.04);
}

.tw-related-card .wp-block-post-title {
	font-family: var(--wp--preset--font-family--heading);
	font-size: var(--wp--preset--font-size--medium);
	line-height: 1.25;
	margin: 0;
}

.tw-related-card .wp-block-post-title a {
	color: var(--wp--preset--color--primary);
	text-decoration: none;
}

.tw-related-card:hover .wp-block-post-title a {
	text-decoration: underline;
	text-underline-offset: 0.2em;
}

.tw-related-card .wp-block-post-date {
	font-size: var(--wp--preset--font-size--small);
	color: var(--wp--preset--color--gray-600);
	margin: 0.25em 0 0;
}

.tw-related-card .wp-block-post-terms {
	font-size: var(--wp--preset--font-size--small);
	color: var(--wp--preset--color--gray-600);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	margin: 0.5em 0 0.25em;
}

/* ─────────────────────────────────────────────────────────────
   Masthead — three-band newspaper header
   ──────────────────────────────────────────────────────────── */

.tw-masthead {
	margin: 0;
}

/* Band 1 — utility strip (donkerblauwe smalle band) */
.tw-utility-strip {
	padding: 0.45rem var(--wp--style--root--padding-right, 1rem) 0.45rem var(--wp--style--root--padding-left, 1rem);
}

.tw-utility-strip .alignwide {
	font-size: var(--wp--preset--font-size--small);
	letter-spacing: 0.02em;
	max-width: var(--wp--style--global--wide-size, 1240px);
	margin-inline: auto;
	width: 100%;
}

.tw-utility-date {
	margin: 0;
}

.tw-current-date {
	font-feature-settings: "tnum";
}

/* Band 2 — masthead (logo + claim, witte achtergrond) */
.tw-masthead-band {
	padding: var(--wp--preset--spacing--40) var(--wp--style--root--padding-right, 1rem);
	border-bottom: var(--tw-rule-hair) solid var(--wp--preset--color--gray-200);
}

.tw-masthead-band .alignwide {
	align-items: center;
	gap: var(--wp--preset--spacing--40);
	max-width: var(--wp--style--global--wide-size, 1240px);
	margin-inline: auto;
	width: 100%;
}

.wp-block-site-logo.tw-masthead-logo {
	margin: 0;
	flex: 0 0 auto;
}

.wp-block-site-logo.tw-masthead-logo img {
	display: block;
	height: auto;
	max-width: 260px;
}

.tw-masthead-claim {
	margin: 0;
	font-family: var(--wp--preset--font-family--display);
	font-size: var(--wp--preset--font-size--large);
	color: var(--wp--preset--color--gray-600);
	line-height: 1.2;
	text-align: right;
}

@media (max-width: 600px) {
	.tw-masthead-claim {
		display: none;
	}
	.wp-block-site-logo.tw-masthead-logo img {
		max-width: 200px;
	}
}

/* Band 3 — primary navigation (sticky bij scroll) */
.tw-primary-nav {
	position: sticky;
	top: 0;
	z-index: 100;
	border-top: var(--tw-rule-medium) solid var(--wp--preset--color--primary);
	border-bottom: var(--tw-rule-thick) solid var(--wp--preset--color--primary);
	padding-inline: var(--wp--style--root--padding-left, 1rem);
}

.tw-primary-nav .alignwide {
	max-width: var(--wp--style--global--wide-size, 1240px);
	margin-inline: auto;
	width: 100%;
}

.tw-primary-nav-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
}

.tw-primary-nav-item {
	margin: 0;
	position: relative;
}

.tw-primary-nav-item + .tw-primary-nav-item {
	border-left: var(--tw-rule-hair) solid var(--wp--preset--color--gray-200);
}

.tw-primary-nav-item a {
	display: flex;
	align-items: center;
	gap: 0.55em;
	padding: 0.95rem 1.3rem;
	color: var(--wp--preset--color--primary);
	font-family: var(--wp--preset--font-family--heading);
	font-size: var(--wp--preset--font-size--medium);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	text-decoration: none;
	transition: background-color 0.15s ease, color 0.15s ease;
}

.tw-primary-nav-item a:hover,
.tw-primary-nav-item a:focus-visible {
	background: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--white);
}

.tw-nav-dot {
	display: inline-block;
	width: 0.6em;
	height: 0.6em;
	border-radius: 50%;
	background: var(--tw-nav-color, var(--wp--preset--color--primary));
	flex: 0 0 auto;
}

.tw-nav--news    { --tw-nav-color: var(--wp--preset--color--accent); }
.tw-nav--agenda  { --tw-nav-color: var(--wp--preset--color--feest); }
.tw-nav--kunst   { --tw-nav-color: var(--wp--preset--color--kunst); }
.tw-nav--foto    { --tw-nav-color: var(--wp--preset--color--foto); }
.tw-nav--locatie { --tw-nav-color: var(--wp--preset--color--info); }

.tw-nav--search {
	margin-left: auto;
	display: flex;
	align-items: stretch;
}

.tw-primary-nav-item + .tw-primary-nav-item.tw-nav--search {
	border-left: 0;
}

.tw-nav-search-form {
	display: flex;
	align-items: stretch;
	margin: 0;
}

.tw-nav-search-input {
	border: 0;
	border-bottom: var(--tw-rule-hair) solid var(--wp--preset--color--gray-200);
	background: transparent;
	padding: 0 0.75rem;
	font-family: inherit;
	font-size: var(--wp--preset--font-size--small);
	color: var(--wp--preset--color--primary);
	width: 16ch;
	outline: none;
	transition: border-color 0.15s ease;
	align-self: center;
}

.tw-nav-search-input:focus {
	border-bottom-color: var(--wp--preset--color--primary);
}

.tw-nav-search-input::placeholder {
	color: var(--wp--preset--color--gray-500);
	font-weight: 400;
	letter-spacing: 0;
}

.tw-nav-search-button {
	background: transparent;
	border: 0;
	cursor: pointer;
	padding: 0 1.3rem;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--wp--preset--color--primary);
	transition: background-color 0.15s ease, color 0.15s ease;
}

.tw-nav-search-button:hover,
.tw-nav-search-button:focus-visible {
	background: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--white);
}

.tw-nav-search-icon {
	display: block;
	width: 20px;
	height: 20px;
}

@media (max-width: 768px) {
	.tw-primary-nav-list {
		overflow-x: auto;
		flex-wrap: nowrap;
		scrollbar-width: thin;
	}
	.tw-primary-nav-item a {
		padding: 0.7rem 0.9rem;
		font-size: var(--wp--preset--font-size--small);
		white-space: nowrap;
	}
	.tw-nav-search-input {
		display: none;
	}
	.tw-nav-search-button {
		padding: 0 0.9rem;
	}
}

/* ─────────────────────────────────────────────────────────────
   Colophon footer (lichte achtergrond, krant-stijl)
   ──────────────────────────────────────────────────────────── */

.tw-colophon {
	margin-top: var(--wp--preset--spacing--70);
	padding: var(--wp--preset--spacing--70) 0 0;
	border-top: var(--tw-rule-thick) solid var(--wp--preset--color--primary);
}

.tw-colophon-grid {
	display: grid;
	grid-template-columns: 2fr 1fr 1fr 1fr;
	gap: var(--wp--preset--spacing--60);
	padding-bottom: var(--wp--preset--spacing--60);
}

@media (max-width: 900px) {
	.tw-colophon-grid {
		grid-template-columns: 1fr 1fr;
	}
}

@media (max-width: 600px) {
	.tw-colophon-grid {
		grid-template-columns: 1fr;
		gap: var(--wp--preset--spacing--50);
	}
}

.tw-colophon-col {
	margin: 0;
}

.wp-block-site-logo.tw-colophon-logo {
	margin: 0 0 var(--wp--preset--spacing--30);
}

.wp-block-site-logo.tw-colophon-logo img {
	display: block;
	max-width: 200px;
	height: auto;
}

.tw-colophon-tagline {
	margin: 0;
	font-size: var(--wp--preset--font-size--small);
	line-height: 1.5;
}

.tw-colophon-heading {
	margin: 0 0 var(--wp--preset--spacing--30);
	font-family: var(--wp--preset--font-family--heading);
	font-size: var(--wp--preset--font-size--medium);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--wp--preset--color--primary);
}

.tw-colophon-cats,
.tw-colophon-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.tw-colophon-cats li,
.tw-colophon-list li {
	margin-bottom: 0.5rem;
}

.tw-colophon-cats a,
.tw-colophon-list a {
	display: inline-flex;
	align-items: center;
	gap: 0.55em;
	color: var(--wp--preset--color--primary);
	text-decoration: none;
	font-size: var(--wp--preset--font-size--medium);
}

.tw-colophon-cats a:hover,
.tw-colophon-list a:hover {
	text-decoration: underline;
	text-underline-offset: 0.25em;
}

.tw-colophon-social .wp-social-link {
	background: transparent;
}

.tw-colophon-newsletter-hint {
	margin: var(--wp--preset--spacing--30) 0 0;
}

/* Credits row */
.tw-colophon-credits {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	gap: var(--wp--preset--spacing--40);
	border-top: var(--tw-rule-hair) solid var(--wp--preset--color--gray-200);
	padding-block: var(--wp--preset--spacing--40);
	font-size: var(--wp--preset--font-size--small);
}

.tw-colophon-credits p {
	margin: 0;
}

.tw-colophon-credits a {
	color: var(--wp--preset--color--primary);
	text-decoration: underline;
	text-underline-offset: 0.25em;
	text-decoration-thickness: 1px;
}

@media (max-width: 700px) {
	.tw-colophon-credits {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--wp--preset--spacing--20);
	}
}

/* ─────────────────────────────────────────────────────────────
   Gridbalkje — taxonomie 'archief-pagina' overlay linksonder
   featured image. Wit balkje, donkere tekst (editorial / krant).
   Verschijnt automatisch alleen als de post een term heeft —
   wp:post-terms rendert geen output bij lege taxonomy.
   ──────────────────────────────────────────────────────────── */
.tw-featured-gridbalkje {
	position: relative;
}

/* Image binnen de wrapper claimt geen eigen margin meer — de
   wrapper neemt de spacing/grid-positionering over. */
.tw-featured-gridbalkje > .wp-block-post-featured-image {
	margin: 0;
	overflow: hidden;
}

.tw-acf-logo-card {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	margin-bottom: var(--wp--preset--spacing--30);
	padding-bottom: var(--wp--preset--spacing--30);
	border-bottom: var(--tw-rule-hair) solid var(--wp--preset--color--gray-200);
}

.tw-acf-logo-card__image {
	display: block;
	width: auto;
	height: auto;
	max-width: 10rem;
	max-height: 4.5rem;
	object-fit: contain;
}

/* Het balkje — nu.nl-stijl: witte tekst, geen achtergrondvlak,
   stevige donkere shadow voor leesbaarheid op willekeurige foto's.
   Selector pakt specifiek de archief-pagina taxonomy zodat hij niet
   per ongeluk de uppercase+dot eyebrow-styling van hero/section erft. */
.tw-featured-gridbalkje > .wp-block-post-terms.taxonomy-archief-pagina {
	position: absolute;
	left: var(--wp--preset--spacing--30);
	right: var(--wp--preset--spacing--30);
	bottom: var(--wp--preset--spacing--30);
	display: block;
	margin: 0;
	padding: 0;
	max-width: 75%;
	color: var(--wp--preset--color--white);
	font-family: var(--wp--preset--font-family--body);
	font-size: clamp(0.95rem, 1.4vw, 1.25rem) !important;
	font-weight: 800;
	letter-spacing: -0.005em;
	line-height: 1.15;
	text-transform: none;
	text-shadow:
		0 2px 6px rgba(0, 0, 0, 0.75),
		0 0 12px rgba(0, 0, 0, 0.45);
	z-index: 1;
}

/* Schakelt de generieke eyebrow-dot uit die elders op .wp-block-post-terms zit */
.tw-featured-gridbalkje > .wp-block-post-terms.taxonomy-archief-pagina::before {
	content: none;
}

.tw-featured-gridbalkje > .wp-block-post-terms.taxonomy-archief-pagina a {
	color: inherit;
	text-decoration: none;
}

.tw-featured-gridbalkje > .wp-block-post-terms.taxonomy-archief-pagina a:hover {
	text-decoration: underline;
	text-decoration-thickness: 2px;
	text-underline-offset: 0.15em;
}

/* Fotocredit onder de featured image op single nieuwsberichten.
   Bron: ACF-veld `fotobron_bericht`, gerenderd door inc/posts.php.
   Negatieve margin-top "steelt" uit de margin-bottom van de gridbalkje
   zodat de credit visueel dicht bij de foto zit i.p.v. losweg
   halverwege gridbalkje en post-meta. */
.tw-photo-credit {
	margin:
		calc(var(--wp--preset--spacing--40) * -1 + var(--wp--preset--spacing--20))
		0
		var(--wp--preset--spacing--40);
	font-family: var(--wp--preset--font-family--body);
	font-size: 0.8125rem;
	line-height: 1.4;
	color: var(--wp--preset--color--gray-600);
	text-align: right;
}

.tw-photo-credit__label {
	font-weight: 700;
}

.single .wp-block-post-featured-image img.tw-featured-lightbox-trigger {
	cursor: zoom-in;
}

.single .wp-block-post-featured-image img.tw-featured-lightbox-trigger:focus-visible {
	outline: 3px solid var(--wp--preset--color--accent);
	outline-offset: 4px;
}

.tw-lightbox-is-open {
	overflow: hidden;
}

.tw-lightbox {
	position: fixed;
	inset: 0;
	z-index: 100000;
	display: grid;
	place-items: center;
	padding: var(--wp--preset--spacing--50);
	background: color-mix(in srgb, var(--wp--preset--color--primary) 92%, transparent);
	cursor: zoom-out;
}

.tw-lightbox__image {
	display: block;
	width: auto;
	max-width: min(100%, 1200px);
	max-height: calc(100dvh - var(--wp--preset--spacing--70));
	object-fit: contain;
	box-shadow: 0 24px 80px rgba(0, 0, 0, 0.35);
	cursor: default;
}

.tw-lightbox__close {
	position: absolute;
	top: var(--wp--preset--spacing--30);
	right: var(--wp--preset--spacing--30);
	display: grid;
	place-items: center;
	width: 44px;
	height: 44px;
	padding: 0;
	color: var(--wp--preset--color--primary);
	background: var(--wp--preset--color--white);
	border: 0;
	border-radius: 50%;
	font-family: var(--wp--preset--font-family--heading);
	font-size: 2rem;
	line-height: 1;
	cursor: pointer;
}

.tw-lightbox__close:hover,
.tw-lightbox__close:focus-visible {
	color: var(--wp--preset--color--white);
	background: var(--wp--preset--color--accent);
	outline: none;
}

/* Map facade — placeholder vóór wpgmza-init op user-click. Zie
   plugins/tilburgwijzer-content/src/blocks/acf-shortcode/render.php */
.tw-map-facade {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 304px;
	background: var(--wp--preset--color--gray-50);
	border: 1px solid var(--wp--preset--color--gray-200);
}

.tw-map-facade__btn {
	font-family: inherit;
	font-size: var(--wp--preset--font-size--small);
	font-weight: 700;
	letter-spacing: 0.04em;
	padding: 0.75rem 1.5rem;
	color: var(--wp--preset--color--white);
	background: var(--wp--preset--color--primary);
	border: 0;
	cursor: pointer;
}

.tw-map-facade__btn:hover,
.tw-map-facade__btn:focus-visible {
	background: var(--wp--preset--color--accent);
}

/* Breadcrumb (Yoast `[wpseo_breadcrumb]` levert <p>…</p> met breadcrumb_last
   op de huidige pagina). De shortcode-variant zet géén id="breadcrumbs", dus
   we hangen styling aan onze eigen .tw-breadcrumb-wrapper. */
.tw-breadcrumb {
	margin-bottom: var(--wp--preset--spacing--40);
}

.tw-breadcrumb p {
	margin: 0;
	font-size: var(--wp--preset--font-size--small);
	color: var(--wp--preset--color--gray-600);
	line-height: 1.5;
}

.tw-breadcrumb a {
	color: var(--wp--preset--color--gray-600);
	text-decoration: none;
}

.tw-breadcrumb a:hover,
.tw-breadcrumb a:focus-visible {
	color: var(--wp--preset--color--primary);
	text-decoration: underline;
}

.tw-breadcrumb .breadcrumb_last {
	color: var(--wp--preset--color--primary);
	font-weight: 700;
}

/* ──────────────────────────────────────────────────
   Advertenties — AdSense slots
   Doel: herkenbaar als reclame, ingetogen visueel, geen
   layout-shift tijdens load. Loader (adsbygoogle.js) wordt
   door Site Kit ingeladen — de patterns bevatten alleen
   <ins> + push(). Slot-IDs in patterns/ad-*.php.
   ──────────────────────────────────────────────────*/
.tw-ad {
	margin-block: var(--wp--preset--spacing--50);
	margin-inline: auto;
}

.tw-ad__label {
	margin: 0 0 0.5rem;
	font-size: 0.7rem;
	letter-spacing: var(--tw-tracking-eyebrow);
	text-transform: uppercase;
	color: var(--wp--preset--color--gray-600);
	font-weight: 600;
}

.tw-ad__slot {
	display: block;
	min-height: 90px;
}

/* In-article — onder content op single-templates. Smal,
   horizontaal afgekaderd met haarlijntjes om visueel los te
   staan van de body-tekst. */
.tw-ad--in-article {
	max-width: 720px;
	padding-block: var(--wp--preset--spacing--40);
	border-block: var(--tw-rule-hair) solid var(--wp--preset--color--gray-200);
}

/* Footer display — brede responsive banner boven de footer
   of tussen homepage-secties. */
.tw-ad--footer-display {
	max-width: 970px;
}

.tw-ad--footer-display .tw-ad__slot {
	min-height: 100px;
}

/* In-feed — bedoeld om in een card-grid te staan. Achtergrond
   gray-50 + dunne rand zodat het visueel mee-loopt met de cards
   maar nog steeds zichtbaar afwijkt (samen met het label) als
   advertentie. */
.tw-ad--in-feed {
	margin: 0;
	padding: var(--wp--preset--spacing--40);
	background: var(--wp--preset--color--gray-50);
	border: var(--tw-rule-hair) solid var(--wp--preset--color--gray-200);
	display: flex;
	flex-direction: column;
}

.tw-ad--in-feed .tw-ad__slot {
	flex: 1;
	min-height: 260px;
}
