/* ==========================================================================
   WK voetbal 2026 — hoofdstijlblad
   Tokens, basis, layout, componenten, donkere modus.
   ========================================================================== */

:root {
	--ink: #0E1A2B;
	--green: #0CA678;
	--green-dk: #087F5B;
	--orange: #FF5A1F;
	--orange-dk: #D9450A;
	--light: #F4F6F8;
	--rule: #D7DEE6;
	--grey: #4A5568;
	--wit: #FFFFFF;

	--bg: var(--light);
	--surface: var(--wit);
	--tekst: var(--ink);
	--tekst-zacht: var(--grey);
	--lijn: var(--rule);
	--accent: var(--green);
	--accent-dk: var(--green-dk);
	--actie: var(--orange);
	--actie-dk: var(--orange-dk);

	--radius-md: 12px;
	--radius-lg: 16px;
	--schaduw: 0 1px 2px rgba(14, 26, 43, 0.06), 0 4px 14px rgba(14, 26, 43, 0.06);
	--schaduw-hover: 0 2px 4px rgba(14, 26, 43, 0.08), 0 12px 30px rgba(14, 26, 43, 0.10);

	--font-body: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
	--font-kop: 'Sora', var(--font-body);

	--max-breedte: 1200px;
	--max-tekst: 720px;
}

/* Donkere modus: kleurschema omzetten. */
@media (prefers-color-scheme: dark) {
	:root:not([data-theme="light"]) {
		--bg: #0B121C;
		--surface: #13202F;
		--tekst: #E7EDF3;
		--tekst-zacht: #B7C2D0;
		--lijn: #243447;
		--schaduw: 0 1px 2px rgba(0,0,0,0.4), 0 4px 14px rgba(0,0,0,0.4);
		--schaduw-hover: 0 2px 4px rgba(0,0,0,0.5), 0 12px 30px rgba(0,0,0,0.55);
	}
}
[data-theme="dark"] {
	--bg: #0B121C;
	--surface: #13202F;
	--tekst: #E7EDF3;
	--tekst-zacht: #B7C2D0;
	--lijn: #243447;
	--schaduw: 0 1px 2px rgba(0,0,0,0.4), 0 4px 14px rgba(0,0,0,0.4);
	--schaduw-hover: 0 2px 4px rgba(0,0,0,0.5), 0 12px 30px rgba(0,0,0,0.55);
}

/* Basis */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
	margin: 0;
	font-family: var(--font-body);
	color: var(--tekst);
	background: var(--bg);
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
	font-feature-settings: "tnum" 1, "lnum" 1;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--accent-dk); text-decoration: underline; text-decoration-thickness: 1.5px; text-underline-offset: 3px; }
a:hover { color: var(--accent); }
h1, h2, h3, h4 { font-family: var(--font-kop); color: var(--tekst); line-height: 1.2; margin: 0 0 0.6em; letter-spacing: -0.01em; }
h1 { font-size: clamp(2rem, 4vw, 3rem); font-weight: 800; }
h2 { font-size: clamp(1.5rem, 2.5vw, 2.125rem); font-weight: 700; }
h3 { font-size: 1.25rem; font-weight: 700; }
p  { margin: 0 0 1em; }
table { border-collapse: collapse; width: 100%; }
:focus-visible { outline: 3px solid var(--actie); outline-offset: 2px; border-radius: 4px; }

/* Hulpklasses */
.wk-container { max-width: var(--max-breedte); margin: 0 auto; padding: 0 1.25rem; }
.wk-tekst { max-width: var(--max-tekst); }
.screen-reader-text {
	position: absolute !important;
	clip: rect(1px, 1px, 1px, 1px);
	width: 1px; height: 1px;
	overflow: hidden;
}
.wk-skip-link {
	position: absolute; top: -40px; left: 0;
	background: var(--actie); color: var(--wit); padding: 0.5rem 1rem;
	z-index: 100; text-decoration: none;
}
.wk-skip-link:focus { top: 0; }

@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
	html { scroll-behavior: auto; }
}

/* Header / navigatie */
.wk-site-header {
	background: var(--ink);
	color: var(--wit);
	position: sticky;
	top: 0;
	z-index: 50;
	border-bottom: 1px solid rgba(255,255,255,0.06);
}
.wk-site-header__inner {
	display: flex;
	align-items: center;
	gap: 1rem;
	min-height: 64px;
	padding-top: 0.5rem;
	padding-bottom: 0.5rem;
}
.wk-logo { display: inline-flex; align-items: center; gap: 0.5rem; text-decoration: none; }
.wk-logo img { height: 40px; width: auto; }
.wk-nav { margin-left: auto; }
.wk-nav__lijst {
	display: flex;
	gap: 1.5rem;
	list-style: none;
	margin: 0;
	padding: 0;
	align-items: center;
}
.wk-nav__lijst a {
	color: var(--wit);
	text-decoration: none;
	font-weight: 500;
	font-size: 0.95rem;
	padding: 0.5rem 0;
	border-bottom: 2px solid transparent;
	transition: border-color 0.15s ease;
}
.wk-nav__lijst a:hover,
.wk-nav__lijst .current-menu-item > a { border-bottom-color: var(--green); color: var(--wit); }

/* "Meer" dropdown */
.wk-nav__lijst .menu-meer { position: relative; }
.wk-nav__lijst .menu-meer > a::after {
	content: ' ▾';
	font-size: 0.7em;
	opacity: 0.7;
}
.wk-nav__lijst .menu-meer .sub-menu {
	position: absolute;
	top: 100%;
	right: 0;
	min-width: 220px;
	background: var(--ink);
	border: 1px solid rgba(255,255,255,0.08);
	border-radius: var(--radius-md);
	padding: 0.5rem;
	list-style: none;
	margin: 0;
	display: none;
	box-shadow: 0 12px 30px rgba(0,0,0,0.4);
}
.wk-nav__lijst .menu-meer:hover .sub-menu,
.wk-nav__lijst .menu-meer:focus-within .sub-menu,
.wk-nav__lijst .menu-meer[data-open="true"] .sub-menu { display: block; }
.wk-nav__lijst .menu-meer .sub-menu a {
	display: block;
	padding: 0.5rem 0.75rem;
	border-radius: 8px;
	border: 0;
}
.wk-nav__lijst .menu-meer .sub-menu a:hover { background: rgba(255,255,255,0.06); }

.wk-menu-toggle {
	display: none;
	margin-left: auto;
	background: transparent;
	border: 0;
	color: var(--wit);
	width: 40px; height: 40px;
	cursor: pointer;
	flex-direction: column;
	justify-content: center;
	gap: 5px;
}
.wk-menu-toggle__bar { display: block; width: 22px; height: 2px; background: currentColor; }
.wk-theme-toggle {
	background: transparent;
	border: 1px solid rgba(255,255,255,0.2);
	color: var(--wit);
	width: 40px; height: 40px;
	border-radius: 50%;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: background 0.15s ease;
}
.wk-theme-toggle:hover { background: rgba(255,255,255,0.08); }
/* In light-stand toon je de maan (klikken om donker te zetten);
   in dark-stand toon je de zon (klikken om licht te zetten). */
.wk-theme-toggle__icoon { display: none; }
.wk-theme-toggle__icoon--donker { display: inline-flex; }
@media (prefers-color-scheme: dark) {
	.wk-theme-toggle__icoon--donker { display: none; }
	.wk-theme-toggle__icoon--licht { display: inline-flex; }
}
[data-theme="light"] .wk-theme-toggle__icoon--donker { display: inline-flex; }
[data-theme="light"] .wk-theme-toggle__icoon--licht { display: none; }
[data-theme="dark"] .wk-theme-toggle__icoon--donker { display: none; }
[data-theme="dark"] .wk-theme-toggle__icoon--licht { display: inline-flex; }

@media (max-width: 900px) {
	.wk-menu-toggle { display: inline-flex; order: 3; }
	.wk-theme-toggle { order: 2; margin-left: auto; }
	.wk-logo { order: 1; }
	.wk-nav { order: 4; flex-basis: 100%; display: none; }
	.wk-nav[data-open="true"] { display: block; padding-bottom: 1rem; }
	.wk-nav__lijst { flex-direction: column; align-items: stretch; gap: 0; }
	.wk-nav__lijst > li { border-top: 1px solid rgba(255,255,255,0.08); }
	.wk-nav__lijst a { display: block; padding: 0.75rem 0; }
	.wk-nav__lijst .menu-meer .sub-menu { position: static; display: block; background: transparent; border: 0; box-shadow: none; padding-left: 1rem; }
}

/* Main */
.wk-main { padding: 2rem 0 4rem; min-height: 60vh; }
.wk-page-title { margin-top: 0; }
.wk-page-intro { color: var(--tekst-zacht); max-width: var(--max-tekst); margin-bottom: 2rem; font-size: 1.125rem; }

/* Knoppen */
.wk-knop {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	padding: 0.75rem 1.25rem;
	font-family: var(--font-kop);
	font-weight: 700;
	font-size: 1rem;
	border-radius: var(--radius-md);
	border: 2px solid transparent;
	text-decoration: none;
	cursor: pointer;
	transition: transform 0.1s ease, background 0.15s ease, border-color 0.15s ease;
}
.wk-knop:hover { transform: translateY(-1px); }
.wk-knop--primair { background: var(--actie); color: var(--wit); }
.wk-knop--primair:hover { background: var(--actie-dk); color: var(--wit); }
.wk-knop--lijn { background: transparent; color: var(--tekst); border-color: var(--tekst); }
.wk-knop--lijn:hover { background: var(--tekst); color: var(--bg); }

/* Hero (home) */
.wk-hero {
	background: linear-gradient(135deg, #0E1A2B 0%, #163356 60%, #0CA678 100%);
	color: var(--wit);
	padding: 4rem 0 5rem;
	margin-bottom: 3rem;
	position: relative;
	overflow: hidden;
}
.wk-hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(circle at 80% 20%, rgba(255, 90, 31, 0.18) 0%, transparent 50%),
		radial-gradient(circle at 20% 80%, rgba(12, 166, 120, 0.25) 0%, transparent 60%);
	pointer-events: none;
}
.wk-hero__inner { position: relative; max-width: 800px; }
.wk-hero__boven { display: inline-block; padding: 0.3rem 0.85rem; background: rgba(255,255,255,0.12); border-radius: 999px; font-size: 0.85rem; font-weight: 500; margin-bottom: 1.5rem; }
.wk-hero h1 { color: var(--wit); margin-bottom: 1rem; font-size: clamp(2.25rem, 5vw, 3.5rem); }
.wk-hero__ondertitel { font-size: clamp(1.05rem, 1.5vw, 1.25rem); max-width: 600px; opacity: 0.92; margin-bottom: 2rem; }
.wk-hero__knoppen { display: flex; flex-wrap: wrap; gap: 0.75rem; }
.wk-hero .wk-knop--lijn { color: var(--wit); border-color: rgba(255,255,255,0.4); }
.wk-hero .wk-knop--lijn:hover { background: var(--wit); color: var(--ink); }

/* Aftelklok */
.wk-countdown {
	display: flex;
	gap: 0.75rem;
	margin-top: 2rem;
	flex-wrap: wrap;
}
.wk-countdown__cel {
	background: rgba(255,255,255,0.10);
	backdrop-filter: blur(8px);
	border-radius: var(--radius-md);
	padding: 0.75rem 1rem;
	min-width: 76px;
	text-align: center;
	border: 1px solid rgba(255,255,255,0.12);
}
.wk-countdown__cijfer { display: block; font-family: var(--font-kop); font-size: 2rem; font-weight: 800; line-height: 1; }
.wk-countdown__label { display: block; font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.08em; opacity: 0.8; margin-top: 0.25rem; }
.wk-countdown--klaar { font-family: var(--font-kop); font-weight: 700; padding: 1rem; background: rgba(255,255,255,0.10); border-radius: var(--radius-md); }

/* Secties */
.wk-section { padding: 3rem 0; }
.wk-section--licht { background: var(--surface); }
.wk-section__kop { display: flex; align-items: end; justify-content: space-between; gap: 1rem; margin-bottom: 1.5rem; flex-wrap: wrap; }
.wk-section__kop h2 { margin-bottom: 0; }
.wk-section__lead { max-width: var(--max-tekst); color: var(--tekst-zacht); margin-bottom: 2rem; font-size: 1.0625rem; }

/* Cijferblokken */
.wk-cijfers { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 1rem; margin: 2rem 0; }
.wk-cijfers__cel {
	background: var(--surface);
	border: 1px solid var(--lijn);
	border-radius: var(--radius-lg);
	padding: 1.5rem;
	text-align: center;
	box-shadow: var(--schaduw);
}
.wk-cijfers__cijfer { display: block; font-family: var(--font-kop); font-size: 2.5rem; font-weight: 800; color: var(--accent); line-height: 1; }
.wk-cijfers__label { display: block; margin-top: 0.5rem; color: var(--tekst-zacht); font-weight: 500; }

/* Wedstrijdkaart */
.wk-matches { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 1rem; }
.wk-match {
	background: var(--surface);
	border: 1px solid var(--lijn);
	border-radius: var(--radius-lg);
	padding: 1.25rem;
	box-shadow: var(--schaduw);
	transition: transform 0.12s ease, box-shadow 0.15s ease;
	display: flex;
	flex-direction: column;
}
.wk-match:hover { transform: translateY(-2px); box-shadow: var(--schaduw-hover); }
.wk-match__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 0.75rem;
	font-size: 0.85rem;
	color: var(--tekst-zacht);
}
.wk-match__groep { font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em; }
.wk-match__label { padding: 0.2rem 0.6rem; background: var(--lijn); border-radius: 999px; font-weight: 600; color: var(--tekst-zacht); }
.wk-match__label--live { background: var(--actie); color: var(--wit); animation: wk-pulse 1.8s ease-in-out infinite; }
.wk-match__label--klaar { background: var(--accent); color: var(--wit); }
@keyframes wk-pulse { 0%, 100% { box-shadow: 0 0 0 0 rgba(255,90,31, 0.55); } 50% { box-shadow: 0 0 0 8px rgba(255,90,31, 0); } }
.wk-match__teams {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	gap: 0.75rem;
	align-items: center;
	margin-bottom: 0.75rem;
}
.wk-match__team {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	min-width: 0;
	text-decoration: none;
	color: inherit;
}
.wk-match__team--uit { flex-direction: row-reverse; }
.wk-match__team:hover .wk-match__naam { color: var(--accent-dk); text-decoration: underline; }
.wk-match__naam { font-weight: 600; font-size: 0.95rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.wk-match__score {
	display: inline-flex; align-items: center; gap: 0.4rem;
	font-family: var(--font-kop); font-weight: 800; font-size: 1.5rem;
	min-width: 80px; justify-content: center;
}
.wk-match__streep { color: var(--tekst-zacht); }
.wk-match__tijd { font-size: 0.95rem; font-weight: 600; color: var(--tekst-zacht); font-family: var(--font-body); }
.wk-match__foot {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 0.5rem;
	margin-top: auto;
	padding-top: 0.75rem;
	border-top: 1px solid var(--lijn);
	font-size: 0.85rem;
	color: var(--tekst-zacht);
	flex-wrap: wrap;
}
.wk-match__details { font-weight: 600; color: var(--accent-dk); text-decoration: none; }
.wk-match__details:hover { text-decoration: underline; }
.wk-match__datum { white-space: nowrap; }
.wk-match--oranje { border-color: var(--actie); border-width: 2px; }
.wk-match--opener { border-color: var(--green); border-width: 2px; position: relative; }
.wk-match--opener::before {
	content: 'Opener';
	position: absolute;
	top: -0.6rem;
	left: 1rem;
	background: var(--green);
	color: var(--wit);
	font-size: 0.7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	padding: 0.2rem 0.6rem;
	border-radius: 999px;
}
.wk-match--compact { padding: 0.85rem; }
.wk-match--compact .wk-match__score { font-size: 1.25rem; }

/* Vlaggen */
.wk-vlag {
	width: 40px; height: 30px;
	object-fit: cover;
	border-radius: 3px;
	flex-shrink: 0;
	box-shadow: 0 0 0 1px rgba(0,0,0,0.06);
}
.wk-vlag--leeg { background: var(--lijn); width: 40px; height: 30px; display: inline-block; border-radius: 3px; }

/* Teamkaart */
.wk-teams-raster {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: 1rem;
}
.wk-team-card {
	display: flex;
	align-items: center;
	gap: 0.85rem;
	padding: 1rem;
	background: var(--surface);
	border: 1px solid var(--lijn);
	border-radius: var(--radius-md);
	box-shadow: var(--schaduw);
	text-decoration: none;
	color: inherit;
	transition: transform 0.12s ease, box-shadow 0.15s ease, border-color 0.15s ease;
}
.wk-team-card:hover { transform: translateY(-2px); box-shadow: var(--schaduw-hover); border-color: var(--accent); }
.wk-team-card__vlag { width: 48px; height: 36px; }
.wk-team-card__body { min-width: 0; }
.wk-team-card__naam { font-size: 1rem; margin: 0 0 0.25rem; }
.wk-team-card__meta { font-size: 0.8125rem; color: var(--tekst-zacht); margin: 0; display: flex; gap: 0.4rem; align-items: center; flex-wrap: wrap; }
.wk-tag {
	display: inline-block;
	padding: 0.1rem 0.45rem;
	font-size: 0.7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	border-radius: 999px;
	background: var(--green);
	color: var(--wit);
}
.wk-tag--debutant { background: var(--actie); }

/* Standentabel */
.wk-standen {
	background: var(--surface);
	border-radius: var(--radius-md);
	box-shadow: var(--schaduw);
	overflow: hidden;
	margin-bottom: 1.5rem;
	font-size: 0.9rem;
	border: 1px solid var(--lijn);
}
.wk-standen__caption {
	font-family: var(--font-kop);
	font-weight: 700;
	font-size: 1.1rem;
	text-align: left;
	padding: 0.85rem 1rem;
	background: var(--ink);
	color: var(--wit);
	caption-side: top;
}
.wk-standen th, .wk-standen td { padding: 0.55rem 0.6rem; text-align: center; }
.wk-standen th { background: rgba(0,0,0,0.04); font-weight: 600; font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--tekst-zacht); }
[data-theme="dark"] .wk-standen th { background: rgba(255,255,255,0.04); }
.wk-standen th:nth-child(2), .wk-standen td:nth-child(2) { text-align: left; }
.wk-standen tbody tr { border-top: 1px solid var(--lijn); }
.wk-standen tbody td:first-child { font-weight: 600; color: var(--tekst-zacht); }
.wk-standen__door { background: rgba(12, 166, 120, 0.08); }
.wk-standen__derde { background: rgba(255, 90, 31, 0.06); }
.wk-standen td a { color: inherit; text-decoration: none; display: inline-flex; align-items: center; gap: 0.5rem; }
.wk-standen__vlag { width: 24px; height: 18px; }

/* Nieuwskaart */
.wk-news-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 1.5rem;
}
.wk-news-card {
	background: var(--surface);
	border: 1px solid var(--lijn);
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--schaduw);
	display: flex;
	flex-direction: column;
	transition: transform 0.12s ease, box-shadow 0.15s ease;
}
.wk-news-card:hover { transform: translateY(-2px); box-shadow: var(--schaduw-hover); }
.wk-news-card__beeld { width: 100%; height: 160px; object-fit: cover; background: linear-gradient(135deg, var(--ink), var(--accent)); }
.wk-news-card__placeholder {
	height: 160px;
	background: linear-gradient(135deg, var(--ink) 0%, var(--accent) 100%);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--wit);
	font-family: var(--font-kop);
	font-weight: 700;
	letter-spacing: 0.06em;
	font-size: 0.9rem;
	text-transform: uppercase;
}
.wk-news-card__body { padding: 1.25rem; display: flex; flex-direction: column; flex: 1 1 auto; }
.wk-news-card__datum { font-size: 0.85rem; color: var(--tekst-zacht); margin-bottom: 0.25rem; }
.wk-news-card__categorie {
	display: inline-block;
	font-size: 0.7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--accent);
	margin-bottom: 0.5rem;
}
.wk-news-card__kop { margin: 0 0 0.5rem; font-size: 1.125rem; }
.wk-news-card__kop a { color: inherit; text-decoration: none; }
.wk-news-card__kop a:hover { color: var(--accent-dk); text-decoration: underline; }
.wk-news-card__lead { color: var(--tekst-zacht); margin-bottom: 1rem; font-size: 0.95rem; }
.wk-news-card__meer { margin-top: auto; font-weight: 600; color: var(--accent-dk); text-decoration: none; }
.wk-news-card__meer:hover { text-decoration: underline; }

/* Filters */
.wk-filters {
	display: flex;
	gap: 0.5rem;
	flex-wrap: wrap;
	margin-bottom: 1.5rem;
	align-items: center;
}
.wk-filter-knop {
	padding: 0.4rem 0.85rem;
	border: 1px solid var(--lijn);
	background: var(--surface);
	color: var(--tekst);
	border-radius: 999px;
	font-size: 0.875rem;
	font-weight: 500;
	cursor: pointer;
	transition: background 0.12s ease, border-color 0.12s ease;
}
.wk-filter-knop:hover { border-color: var(--accent); }
.wk-filter-knop[aria-pressed="true"] { background: var(--accent); color: var(--wit); border-color: var(--accent); }
.wk-filter-label { font-weight: 600; font-size: 0.875rem; color: var(--tekst-zacht); margin-right: 0.5rem; }

.wk-zoek-veld {
	padding: 0.55rem 0.85rem;
	border: 1px solid var(--lijn);
	background: var(--surface);
	color: var(--tekst);
	border-radius: var(--radius-md);
	font: inherit;
	min-width: 220px;
}

/* Tijdlijn (speelschema per dag) */
.wk-tijdlijn { display: flex; flex-direction: column; gap: 2rem; }
.wk-dag {
	border-left: 3px solid var(--accent);
	padding-left: 1.25rem;
	position: relative;
}
.wk-dag::before {
	content: '';
	position: absolute;
	left: -8px; top: 0;
	width: 13px; height: 13px;
	background: var(--accent);
	border-radius: 50%;
	border: 3px solid var(--bg);
}
.wk-dag__kop { display: flex; gap: 1rem; align-items: baseline; flex-wrap: wrap; margin-bottom: 1rem; }
.wk-dag__datum { font-family: var(--font-kop); font-size: 1.25rem; font-weight: 700; margin: 0; }
.wk-dag__telling { color: var(--tekst-zacht); font-size: 0.9rem; }

/* Bracket */
.wk-bracket {
	overflow-x: auto;
	padding-bottom: 1rem;
}
.wk-bracket__inner {
	display: grid;
	grid-auto-flow: column;
	gap: 2rem;
	min-width: 800px;
	align-items: stretch;
}
.wk-bracket__ronde { display: flex; flex-direction: column; gap: 1rem; min-width: 220px; }
.wk-bracket__ronde h3 { font-size: 1rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--tekst-zacht); margin: 0 0 0.5rem; }
.wk-bracket__match {
	background: var(--surface);
	border: 1px solid var(--lijn);
	border-radius: var(--radius-md);
	padding: 0.75rem;
	box-shadow: var(--schaduw);
}
.wk-bracket__rij { display: flex; justify-content: space-between; padding: 0.25rem 0; }
.wk-bracket__rij + .wk-bracket__rij { border-top: 1px solid var(--lijn); }
.wk-bracket__naam { font-weight: 600; }
.wk-bracket__score { font-family: var(--font-kop); font-weight: 800; color: var(--accent-dk); }

/* Speelsteden */
.wk-cities-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: 1rem;
}
.wk-city-card {
	background: var(--surface);
	border: 1px solid var(--lijn);
	border-radius: var(--radius-lg);
	padding: 1.25rem;
	box-shadow: var(--schaduw);
}
.wk-city-card__naam { margin: 0 0 0.25rem; font-size: 1.15rem; }
.wk-city-card__stadion { color: var(--tekst-zacht); font-weight: 500; margin: 0 0 0.5rem; }
.wk-city-card__meta { display: flex; gap: 0.75rem; flex-wrap: wrap; font-size: 0.85rem; color: var(--tekst-zacht); margin-bottom: 0.75rem; }
.wk-city-card__info { font-size: 0.95rem; }

/* FAQ */
.wk-faq { max-width: 800px; }
.wk-faq__item { background: var(--surface); border: 1px solid var(--lijn); border-radius: var(--radius-md); margin-bottom: 0.75rem; overflow: hidden; }
.wk-faq__vraag {
	width: 100%;
	background: transparent;
	border: 0;
	font: inherit;
	font-weight: 600;
	text-align: left;
	padding: 1rem 1.25rem;
	cursor: pointer;
	color: var(--tekst);
	display: flex;
	justify-content: space-between;
	gap: 1rem;
	font-family: var(--font-kop);
}
.wk-faq__vraag::after {
	content: '+';
	font-size: 1.5rem;
	color: var(--accent);
	transition: transform 0.2s ease;
}
.wk-faq__vraag[aria-expanded="true"]::after { transform: rotate(45deg); }
.wk-faq__antwoord { padding: 0 1.25rem 1rem; color: var(--tekst-zacht); }
.wk-faq__antwoord[hidden] { display: none; }

/* Team-profiel */
.wk-team-hero {
	display: flex;
	gap: 1.5rem;
	align-items: center;
	padding: 2rem;
	background: linear-gradient(135deg, var(--ink), #1F3554);
	color: var(--wit);
	border-radius: var(--radius-lg);
	margin-bottom: 2rem;
	flex-wrap: wrap;
}
.wk-team-hero__vlag { width: 96px; height: 72px; box-shadow: 0 0 0 2px rgba(255,255,255,0.15); border-radius: 4px; }
.wk-team-hero h1 { color: var(--wit); margin: 0 0 0.25rem; }
.wk-team-hero__meta { display: flex; gap: 0.75rem; flex-wrap: wrap; font-size: 0.95rem; opacity: 0.92; }
.wk-team-hero__meta .wk-tag { background: var(--actie); }

.wk-feiten {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 1rem;
	margin: 1.5rem 0;
}
.wk-feit { background: var(--surface); border: 1px solid var(--lijn); border-radius: var(--radius-md); padding: 1rem; }
.wk-feit__label { font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--tekst-zacht); margin-bottom: 0.25rem; }
.wk-feit__waarde { font-family: var(--font-kop); font-weight: 700; font-size: 1.05rem; }

.wk-spelers-lijst { list-style: none; padding: 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 0.5rem; }
.wk-spelers-lijst li {
	background: var(--surface);
	border: 1px solid var(--lijn);
	border-radius: var(--radius-md);
	padding: 0.75rem 1rem;
}
.wk-speler__naam { font-weight: 600; }
.wk-speler__club { color: var(--tekst-zacht); font-size: 0.875rem; }

/* Contactformulier */
.wk-form { background: var(--surface); border: 1px solid var(--lijn); border-radius: var(--radius-lg); padding: 1.5rem; max-width: 640px; }
.wk-form__veld { margin-bottom: 1rem; }
.wk-form label { display: block; font-weight: 600; margin-bottom: 0.35rem; }
.wk-form input, .wk-form textarea, .wk-form select {
	width: 100%;
	padding: 0.65rem 0.85rem;
	border: 1px solid var(--lijn);
	background: var(--bg);
	color: var(--tekst);
	border-radius: var(--radius-md);
	font: inherit;
}
.wk-form input:focus, .wk-form textarea:focus, .wk-form select:focus { border-color: var(--accent); outline: 2px solid rgba(12, 166, 120, 0.25); }
.wk-form textarea { min-height: 140px; }
.wk-form__avg { font-size: 0.875rem; color: var(--tekst-zacht); }
.wk-form__melding { padding: 1rem; border-radius: var(--radius-md); margin-bottom: 1rem; }
.wk-form__melding--succes { background: rgba(12,166,120,0.1); border: 1px solid var(--accent); color: var(--accent-dk); }
.wk-form__melding--fout { background: rgba(255,90,31,0.1); border: 1px solid var(--actie); color: var(--actie-dk); }

/* Live status */
.wk-live-status {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.35rem 0.75rem;
	background: var(--surface);
	border: 1px solid var(--lijn);
	border-radius: 999px;
	font-size: 0.85rem;
	color: var(--tekst-zacht);
}
.wk-live-status__bol { width: 8px; height: 8px; border-radius: 50%; background: var(--accent); }
.wk-live-status[data-status="laden"] .wk-live-status__bol { background: var(--actie); animation: wk-pulse 1.5s infinite; }

/* Layout-grids voor de homepagina */
.wk-home-blokken { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 2rem; align-items: start; }

/* Footer */
.wk-site-footer {
	background: var(--ink);
	color: rgba(255,255,255,0.78);
	margin-top: 4rem;
}
.wk-site-footer__inner {
	display: grid;
	grid-template-columns: 1.2fr 2fr;
	gap: 3rem;
	padding: 3rem 1.25rem;
}
.wk-site-footer__logo { filter: brightness(0) invert(1); height: 32px; width: auto; margin-bottom: 1rem; }
.wk-site-footer__nav { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.wk-site-footer__nav h2 { font-size: 0.95rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--wit); margin-bottom: 0.75rem; }
.wk-site-footer__nav ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 0.4rem; font-size: 0.9rem; }
.wk-site-footer__nav a { color: rgba(255,255,255,0.78); text-decoration: none; }
.wk-site-footer__nav a:hover { color: var(--wit); text-decoration: underline; }
.wk-site-footer__bottom {
	padding: 1.25rem;
	border-top: 1px solid rgba(255,255,255,0.08);
	font-size: 0.85rem;
}
.wk-disclaimer { font-size: 0.85rem; opacity: 0.78; margin-top: 0.5rem; }

@media (max-width: 800px) {
	.wk-site-footer__inner { grid-template-columns: 1fr; gap: 2rem; }
	.wk-site-footer__nav { grid-template-columns: 1fr 1fr; }
}

/* Uitgelicht nieuwsartikel op de nieuws-overzichtspagina */
.wk-news-uitgelicht {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0;
	background: var(--surface);
	border: 1px solid var(--lijn);
	border-radius: var(--radius-lg);
	box-shadow: var(--schaduw);
	overflow: hidden;
	margin-bottom: 2.5rem;
}
.wk-news-uitgelicht__beeld {
	background: linear-gradient(135deg, var(--ink) 0%, var(--accent) 100%);
	color: var(--wit);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 2rem;
	min-height: 220px;
	font-family: var(--font-kop);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	font-size: 1rem;
}
.wk-news-uitgelicht__body { padding: 2rem; display: flex; flex-direction: column; gap: 0.5rem; }
.wk-news-uitgelicht__kop { font-size: clamp(1.4rem, 2.2vw, 1.875rem); margin: 0.25rem 0; }
.wk-news-uitgelicht__kop a { color: inherit; text-decoration: none; }
.wk-news-uitgelicht__kop a:hover { color: var(--accent-dk); text-decoration: underline; }
@media (max-width: 720px) {
	.wk-news-uitgelicht { grid-template-columns: 1fr; }
	.wk-news-uitgelicht__beeld { min-height: 140px; }
	.wk-news-uitgelicht__body { padding: 1.5rem; }
}

/* Inhoud van enkele nieuwsartikelen */
.wk-article {
	max-width: var(--max-tekst);
	margin: 0 auto;
}
.wk-article__head { margin-bottom: 2rem; }
.wk-article__categorie {
	display: inline-block;
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--accent-dk);
	background: rgba(12,166,120,0.1);
	padding: 0.2rem 0.6rem;
	border-radius: 999px;
	margin-bottom: 1rem;
}
.wk-article__datum { color: var(--tekst-zacht); font-size: 0.95rem; }
.wk-article__inhoud { font-size: 1.0625rem; }
.wk-article__inhoud p { margin-bottom: 1.2em; }
.wk-nieuws__lead { font-size: 1.2rem; color: var(--tekst); font-weight: 500; margin-bottom: 1.5rem; }

.wk-meer-knoppen { display: flex; gap: 0.5rem; flex-wrap: wrap; margin-top: 1.5rem; }

/* Bestaande WP-search/comment ondersteuning */
.wk-pagination .page-numbers {
	display: inline-block;
	padding: 0.4rem 0.75rem;
	margin-right: 0.25rem;
	border: 1px solid var(--lijn);
	border-radius: var(--radius-md);
	text-decoration: none;
	color: var(--tekst);
}
.wk-pagination .current { background: var(--accent); color: var(--wit); border-color: var(--accent); }

/* ==========================================================================
   Responsieve aanscherpingen voor smalle schermen.
   ========================================================================== */
@media (max-width: 480px) {
	.wk-hero { padding: 3rem 0 3.5rem; }
	.wk-hero__knoppen { flex-direction: column; align-items: stretch; }
	.wk-hero__knoppen .wk-knop { width: 100%; }
	.wk-countdown__cel { min-width: 64px; padding: 0.55rem 0.6rem; }
	.wk-countdown__cijfer { font-size: 1.5rem; }

	.wk-match { padding: 1rem; }
	.wk-match__score { font-size: 1.25rem; min-width: 60px; }
	.wk-match__naam { font-size: 0.875rem; }
	.wk-match__foot { font-size: 0.78rem; }

	.wk-team-card { padding: 0.85rem; }
	.wk-team-card__naam { font-size: 0.95rem; }

	.wk-standen th, .wk-standen td { padding: 0.4rem 0.35rem; font-size: 0.82rem; }
	.wk-standen__vlag { width: 20px; height: 15px; }

	.wk-section { padding: 2rem 0; }
	.wk-section__kop { flex-direction: column; align-items: flex-start; }
}

@media (max-width: 640px) {
	.wk-team-hero { padding: 1.5rem; }
	.wk-team-hero__vlag { width: 72px; height: 54px; }
	.wk-form { padding: 1.25rem; }
}

/* Kleinere standentabel kan horizontaal scrollen op zeer smal scherm. */
@media (max-width: 380px) {
	.wk-standen { display: block; overflow-x: auto; }
}

/* ==========================================================================
   Selectie per linie (teampagina).
   ========================================================================== */
.wk-selectie { display: grid; gap: 1.5rem; margin-bottom: 2rem; }
.wk-selectie__linie {
	background: var(--surface);
	border: 1px solid var(--lijn);
	border-radius: var(--radius-lg);
	padding: 1.25rem;
	box-shadow: var(--schaduw);
}
.wk-selectie__kop {
	font-size: 1rem;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--accent-dk);
	margin: 0 0 0.85rem;
	display: flex;
	align-items: center;
	gap: 0.5rem;
}
.wk-selectie__telling {
	display: inline-block;
	background: var(--lijn);
	color: var(--tekst-zacht);
	font-size: 0.7rem;
	font-weight: 700;
	padding: 0.15rem 0.45rem;
	border-radius: 999px;
}
.wk-speler__noot {
	font-size: 0.78rem;
	color: var(--actie-dk);
	margin-top: 0.25rem;
	font-style: italic;
}

/* ==========================================================================
   WK-finales tijdlijn (geschiedenispagina).
   ========================================================================== */
.wk-finales { display: grid; gap: 0.75rem; margin: 1.5rem 0; }
.wk-finale {
	display: grid;
	grid-template-columns: 96px 1fr;
	gap: 1.25rem;
	background: var(--surface);
	border: 1px solid var(--lijn);
	border-radius: var(--radius-md);
	padding: 1rem 1.25rem;
	box-shadow: var(--schaduw);
	align-items: center;
}
.wk-finale__jaar {
	font-family: var(--font-kop);
	font-size: 1.75rem;
	font-weight: 800;
	color: var(--accent-dk);
	letter-spacing: -0.02em;
}
.wk-finale__kop {
	margin: 0 0 0.25rem;
	font-size: 1.05rem;
	display: flex;
	align-items: baseline;
	flex-wrap: wrap;
	gap: 0.5rem;
}
.wk-finale__uitslag {
	font-family: var(--font-kop);
	font-weight: 800;
	font-size: 0.95rem;
	background: var(--lijn);
	padding: 0.15rem 0.5rem;
	border-radius: 6px;
}
.wk-finale__meta { font-size: 0.85rem; color: var(--tekst-zacht); margin: 0 0 0.25rem; }
.wk-finale__noot { font-size: 0.9rem; color: var(--tekst-zacht); margin: 0.25rem 0 0; font-style: italic; }
.wk-finale--oranje { border-color: var(--actie); border-width: 2px; }
@media (max-width: 540px) {
	.wk-finale { grid-template-columns: 1fr; gap: 0.5rem; }
	.wk-finale__jaar { font-size: 1.5rem; }
}

/* ==========================================================================
   Speelstad-cards als links + telling.
   ========================================================================== */
a.wk-city-card { text-decoration: none; color: inherit; display: block; transition: transform 0.12s ease, box-shadow 0.15s ease, border-color 0.15s ease; }
a.wk-city-card:hover { transform: translateY(-2px); box-shadow: var(--schaduw-hover); border-color: var(--accent); }
.wk-city-card__telling { font-size: 0.85rem; color: var(--tekst-zacht); margin: 0.75rem 0 0; padding-top: 0.75rem; border-top: 1px solid var(--lijn); }
.wk-city-card__telling strong { color: var(--accent-dk); font-family: var(--font-kop); font-size: 1rem; }

/* ==========================================================================
   News-card landen-tags.
   ========================================================================== */
.wk-news-card__landen { display: flex; flex-wrap: wrap; gap: 0.3rem; margin: 0 0 0.75rem; }
.wk-tag--land { background: var(--ink); color: var(--wit); font-size: 0.65rem; padding: 0.18rem 0.55rem; text-decoration: none; }
.wk-tag--land:hover { background: var(--accent); color: var(--wit); }
.wk-tag--meer { background: var(--lijn); color: var(--tekst-zacht); font-size: 0.65rem; padding: 0.18rem 0.45rem; }
[data-theme="dark"] .wk-tag--land { background: var(--surface); border: 1px solid var(--lijn); }

/* ==========================================================================
   Voorspeller v2.
   ========================================================================== */
.wk-vp-groepen { display: grid; grid-template-columns: repeat(auto-fill, minmax(420px, 1fr)); gap: 1.5rem; }
.wk-vp-groep {
	background: var(--surface);
	border: 1px solid var(--lijn);
	border-radius: var(--radius-lg);
	padding: 1.25rem;
	box-shadow: var(--schaduw);
}
.wk-vp-groep__kop { margin-bottom: 0.85rem; }
.wk-vp-groep__kop h3 { margin: 0; }
.wk-vp-groep__wedstrijden { display: grid; gap: 0.55rem; margin-bottom: 1rem; }
.wk-vp-wedstrijd {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	gap: 0.6rem;
	align-items: center;
	padding: 0.55rem 0.75rem;
	background: var(--bg);
	border: 1px solid var(--lijn);
	border-radius: var(--radius-md);
}
.wk-vp-wedstrijd__team { display: flex; align-items: center; gap: 0.4rem; font-weight: 600; font-size: 0.875rem; min-width: 0; }
.wk-vp-wedstrijd__team span { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.wk-vp-wedstrijd__team--uit { flex-direction: row-reverse; justify-content: flex-end; }
.wk-vp-wedstrijd__team img { width: 28px; height: 21px; }
.wk-vp-wedstrijd__score { display: inline-flex; align-items: center; gap: 0.35rem; font-family: var(--font-kop); font-weight: 800; }
.wk-vp-wedstrijd__score input {
	width: 44px;
	padding: 0.35rem;
	text-align: center;
	font: inherit;
	font-family: var(--font-kop);
	font-weight: 800;
	font-size: 1.05rem;
	border: 1px solid var(--lijn);
	background: var(--surface);
	color: var(--tekst);
	border-radius: 6px;
	-moz-appearance: textfield;
}
.wk-vp-wedstrijd__score input::-webkit-outer-spin-button,
.wk-vp-wedstrijd__score input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.wk-vp-wedstrijd__score input:focus { border-color: var(--accent); outline: 2px solid rgba(12,166,120,0.25); }

.wk-vp-standen { margin: 0; font-size: 0.85rem; }
.wk-vp-standen td, .wk-vp-standen th { padding: 0.4rem 0.5rem; }
.wk-vp-standen td:nth-child(2) a, .wk-vp-standen td:nth-child(2) { font-size: 0.85rem; }

.wk-vp-ko { padding: 0; overflow: hidden; }
.wk-vp-ko__rij {
	width: 100%;
	border: 0;
	background: var(--surface);
	font: inherit;
	font-weight: 600;
	text-align: left;
	padding: 0.55rem 0.85rem;
	cursor: pointer;
	color: var(--tekst);
	border-bottom: 1px solid var(--lijn);
	transition: background 0.12s ease;
}
.wk-vp-ko__rij:last-child { border-bottom: 0; }
.wk-vp-ko__rij:hover:not(:disabled) { background: rgba(12,166,120,0.08); }
.wk-vp-ko__rij:disabled { color: var(--tekst-zacht); cursor: not-allowed; opacity: 0.65; }
.wk-vp-ko__rij--winnaar { background: var(--accent); color: var(--wit); border-color: var(--accent); }
.wk-vp-ko__rij--winnaar:hover:not(:disabled) { background: var(--accent-dk); }

.wk-vp-kampioen {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, var(--actie) 0%, var(--actie-dk) 100%);
	color: var(--wit);
	padding: 1.5rem 1rem;
	min-height: 140px;
	border-radius: var(--radius-md);
	text-align: center;
}
.wk-vp-kampioen__naam { font-family: var(--font-kop); font-weight: 800; font-size: 1.5rem; line-height: 1.1; }
.wk-vp-kampioen__sub { display: block; font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.08em; margin-top: 0.4rem; opacity: 0.9; }
.wk-vp-kampioen__placeholder { font-size: 0.85rem; opacity: 0.85; }

.wk-empty {
	color: var(--tekst-zacht);
	font-style: italic;
	padding: 1.5rem 1rem;
	background: var(--surface);
	border: 1px dashed var(--lijn);
	border-radius: var(--radius-md);
	text-align: center;
}
