/* ==========================================================================
   HET SPORTKAMP — Main Stylesheet
   Geïnspireerd op de flyer-huisstijl: groen, rood, crème, speels en sportief.
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. DESIGN TOKENS
   -------------------------------------------------------------------------- */
:root {
	/* Kleuren — afgeleid van de flyer */
	--hsk-green:        #2D6B3C;
	--hsk-green-bright: #4A8A3D;
	--hsk-green-dark:   #1F4E2A;
	--hsk-green-soft:   #E8F1E4;

	--hsk-red:          #D63D3D;
	--hsk-red-dark:     #B02828;
	--hsk-red-soft:     #FCE8E8;

	--hsk-cream:        #F5EDE0;
	--hsk-cream-soft:   #FAF5EB;
	--hsk-cream-dark:   #ECE0CC;

	--hsk-ink:          #1A1A1A;
	--hsk-ink-soft:     #444;
	--hsk-muted:        #777;
	--hsk-border:       #E5DDD0;
	--hsk-white:        #fff;

	/* Type */
	--hsk-font-display: 'Outfit', system-ui, sans-serif;
	--hsk-font-body:    'Nunito', system-ui, sans-serif;

	/* Maten */
	--hsk-radius-sm:    8px;
	--hsk-radius:       14px;
	--hsk-radius-lg:    24px;
	--hsk-radius-xl:    32px;
	--hsk-radius-pill:  999px;

	--hsk-shadow-sm:    0 2px 6px rgba(26,26,26,0.06);
	--hsk-shadow:       0 8px 24px rgba(26,26,26,0.08);
	--hsk-shadow-lg:    0 20px 50px rgba(26,26,26,0.12);

	--hsk-container:    1200px;
	--hsk-container-narrow: 880px;

	--hsk-transition:   0.25s cubic-bezier(0.2, 0.8, 0.2, 1);
}

/* --------------------------------------------------------------------------
   2. RESET & BASE
   -------------------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }

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

body {
	margin: 0;
	font-family: var(--hsk-font-body);
	font-size: 16px;
	line-height: 1.6;
	color: var(--hsk-ink);
	background: var(--hsk-cream);
	font-weight: 400;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--hsk-font-display);
	font-weight: 600;
	line-height: 1.15;
	margin: 0 0 0.5em;
	color: var(--hsk-ink);
	letter-spacing: -0.015em;
}

h1 { font-size: clamp(2.2rem, 4.5vw, 3.5rem); font-weight: 600; }
h2 { font-size: clamp(1.6rem, 3vw, 2.4rem); font-weight: 600; }
h3 { font-size: clamp(1.15rem, 1.6vw, 1.4rem); font-weight: 600; }

p { margin: 0 0 1rem; }

a {
	color: var(--hsk-green);
	text-decoration: none;
	transition: color var(--hsk-transition);
}
a:hover, a:focus { color: var(--hsk-red); }

img, svg { max-width: 100%; height: auto; display: block; }

::selection { background: var(--hsk-green); color: var(--hsk-white); }

/* Accessibility */
.screen-reader-text {
	border: 0; clip: rect(1px,1px,1px,1px); clip-path: inset(50%);
	height: 1px; width: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute;
}
.skip-link {
	position: absolute; top: -100px; left: 1rem; background: var(--hsk-ink); color: #fff;
	padding: 0.75rem 1.25rem; border-radius: var(--hsk-radius-sm); z-index: 999;
}
.skip-link:focus { top: 1rem; color: #fff; }

:focus-visible {
	outline: 3px solid var(--hsk-green-bright);
	outline-offset: 3px;
	border-radius: 4px;
}

.container {
	width: 100%;
	max-width: var(--hsk-container);
	margin: 0 auto;
	padding: 0 1.5rem;
}

/* --------------------------------------------------------------------------
   3. BUTTONS
   -------------------------------------------------------------------------- */
.btn {
	display: inline-flex;
	align-items: center;
	gap: 0.6em;
	font-family: var(--hsk-font-body);
	font-weight: 700;
	font-size: 0.95rem;
	padding: 0.85em 1.6em;
	border-radius: var(--hsk-radius-pill);
	border: none;
	cursor: pointer;
	text-decoration: none;
	letter-spacing: 0.005em;
	transition: transform var(--hsk-transition), box-shadow var(--hsk-transition), background var(--hsk-transition);
	will-change: transform;
}
.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0); }

.btn-primary {
	background: var(--hsk-red);
	color: var(--hsk-white);
	box-shadow: 0 6px 0 var(--hsk-red-dark), 0 12px 24px rgba(214,61,61,0.25);
}
.btn-primary:hover {
	background: var(--hsk-red-dark);
	color: var(--hsk-white);
	box-shadow: 0 4px 0 var(--hsk-red-dark), 0 16px 32px rgba(214,61,61,0.3);
}

.btn-secondary {
	background: var(--hsk-green);
	color: var(--hsk-white);
	box-shadow: 0 6px 0 var(--hsk-green-dark), 0 12px 24px rgba(45,107,60,0.25);
}
.btn-secondary:hover {
	background: var(--hsk-green-dark);
	color: var(--hsk-white);
}

.btn-ghost {
	background: transparent;
	color: var(--hsk-ink);
	border: 2px solid var(--hsk-ink);
}
.btn-ghost:hover {
	background: var(--hsk-ink);
	color: var(--hsk-white);
}

.btn-link {
	background: transparent;
	color: var(--hsk-ink);
	padding: 0.85em 0.5em;
	text-decoration: underline;
	text-decoration-thickness: 2px;
	text-underline-offset: 5px;
	text-decoration-color: var(--hsk-green);
}
.btn-link:hover {
	color: var(--hsk-red);
	text-decoration-color: var(--hsk-red);
}

.btn-sm { font-size: 0.9rem; padding: 0.6em 1.1em; }
.btn-lg { font-size: 1.1rem; padding: 1em 1.9em; }

/* --------------------------------------------------------------------------
   4. HEADER
   -------------------------------------------------------------------------- */
.site-topbar {
	background: var(--hsk-green);
	color: var(--hsk-cream);
	font-size: 0.85rem;
	padding: 0.5rem 0;
}
.topbar-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 0.5rem 1.5rem;
}
.topbar-meta {
	display: flex;
	gap: 1.5rem;
	flex-wrap: wrap;
}
.topbar-item {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
}
.topbar-parent a {
	color: var(--hsk-cream);
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
	font-weight: 600;
	transition: opacity var(--hsk-transition);
}
.topbar-parent a:hover { opacity: 0.8; color: var(--hsk-cream); }

.site-header-inner {
	background: rgba(250, 245, 235, 0.95);
	border-bottom: 1px solid var(--hsk-border);
	position: sticky;
	top: 0;
	z-index: 100;
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
}

.site-header-inner.is-scrolled {
	box-shadow: var(--hsk-shadow-sm);
}

.header-grid {
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: 2rem;
	padding: 0.75rem 1.5rem;
}

/* Logo */
.site-logo-link {
	display: inline-flex;
	align-items: center;
	text-decoration: none;
}
.site-logo-img {
	max-height: 56px;
	width: auto;
	display: block;
}
.custom-logo {
	max-height: 56px;
	width: auto;
	display: block;
}

/* Primary nav */
.main-navigation {
	display: flex;
	justify-content: center;
}
.primary-menu {
	display: flex;
	gap: 0.25rem;
	list-style: none;
	margin: 0;
	padding: 0;
}
.primary-menu li { position: relative; }
.primary-menu a {
	display: block;
	padding: 0.55rem 1rem;
	color: var(--hsk-ink);
	font-family: var(--hsk-font-body);
	font-weight: 600;
	font-size: 0.95rem;
	border-radius: var(--hsk-radius-pill);
	transition: background var(--hsk-transition), color var(--hsk-transition);
}
.primary-menu a:hover,
.primary-menu .current-menu-item > a,
.primary-menu .current_page_item > a {
	background: var(--hsk-green-soft);
	color: var(--hsk-green-dark);
}
.primary-menu .sub-menu {
	position: absolute;
	top: 100%;
	left: 0;
	min-width: 220px;
	background: #fff;
	border-radius: var(--hsk-radius);
	box-shadow: var(--hsk-shadow);
	padding: 0.5rem;
	list-style: none;
	margin: 0.5rem 0 0;
	opacity: 0;
	visibility: hidden;
	transform: translateY(8px);
	transition: all var(--hsk-transition);
	z-index: 50;
}
.primary-menu li:hover > .sub-menu,
.primary-menu li:focus-within > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}
.primary-menu .sub-menu a { font-size: 0.9rem; padding: 0.5rem 0.8rem; }

.menu-toggle {
	display: none;
	background: transparent;
	border: 2px solid var(--hsk-ink);
	border-radius: var(--hsk-radius-sm);
	padding: 0.5rem;
	cursor: pointer;
	flex-direction: column;
	gap: 4px;
}
.menu-toggle-bar {
	display: block;
	width: 22px; height: 2px;
	background: var(--hsk-ink);
	border-radius: 2px;
	transition: transform var(--hsk-transition), opacity var(--hsk-transition);
}
.menu-toggle[aria-expanded="true"] .menu-toggle-bar:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.menu-toggle[aria-expanded="true"] .menu-toggle-bar:nth-child(2) { opacity: 0; }
.menu-toggle[aria-expanded="true"] .menu-toggle-bar:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

/* --------------------------------------------------------------------------
   5. HERO
   -------------------------------------------------------------------------- */
.hero {
	position: relative;
	background: var(--hsk-cream);
	overflow: hidden;
	padding: 3rem 0 0;
}
.hero-bg { position: absolute; inset: 0; pointer-events: none; }
.hero-blob {
	position: absolute;
	border-radius: 50%;
	filter: blur(100px);
	opacity: 0.2;
}
.hero-blob-1 {
	width: 500px; height: 500px;
	background: var(--hsk-green-bright);
	top: -200px; left: -200px;
}
.hero-blob-2 {
	width: 350px; height: 350px;
	background: var(--hsk-red);
	bottom: -150px; right: -150px;
	opacity: 0.12;
}

.hero-grid {
	display: grid;
	grid-template-columns: 1.15fr 1fr;
	gap: 3rem;
	align-items: center;
	position: relative;
	z-index: 2;
}

.hero-badge {
	display: inline-flex;
	align-items: center;
	gap: 1rem;
	margin-bottom: 1.25rem;
}
.hero-badge-tag {
	display: inline-block;
	background: var(--hsk-red);
	color: #fff;
	font-family: var(--hsk-font-body);
	font-weight: 700;
	font-size: 0.78rem;
	padding: 0.45rem 1.1rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	border-radius: var(--hsk-radius-pill);
	transform: rotate(-2deg);
	box-shadow: 0 4px 12px rgba(214,61,61,0.25);
}
.hero-plane { width: 70px; height: 35px; opacity: 0.7; }

.hero-title {
	font-size: clamp(2.2rem, 5.5vw, 4rem);
	font-weight: 600;
	margin-bottom: 1.25rem;
	letter-spacing: -0.025em;
	line-height: 1.05;
}
.hero-line-1, .hero-line-2 { display: block; }
.hero-line-1 { font-weight: 600; color: var(--hsk-ink); }
.hero-line-2 { margin-top: 0.1em; font-weight: 600; }

.brush-highlight {
	position: relative;
	color: var(--hsk-green);
	display: inline-block;
	padding: 0 0.1em;
	white-space: nowrap;
}
.brush-highlight::after {
	content: "";
	position: absolute;
	left: 0; right: 0; bottom: -0.05em;
	height: 0.18em;
	background: var(--hsk-green-bright);
	border-radius: 50%;
	transform: skewY(-1deg);
	opacity: 0.5;
}

.hero-lead {
	font-size: 1.05rem;
	color: var(--hsk-ink-soft);
	margin-bottom: 1.75rem;
	max-width: 520px;
	line-height: 1.6;
}

.hero-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	align-items: center;
	margin-bottom: 2.5rem;
}

.hero-pills {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1rem;
	list-style: none;
	padding: 0;
	margin: 0;
}
.hero-pills li {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 0.6rem;
	font-weight: 600;
	font-size: 0.85rem;
	color: var(--hsk-ink-soft);
	line-height: 1.3;
}
.pill-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 56px; height: 56px;
	border-radius: 50%;
	color: #fff;
	flex-shrink: 0;
}
.pill-icon-green { background: var(--hsk-green); }
.pill-icon-red { background: var(--hsk-red); }

/* Hero visual */
.hero-visual {
	position: relative;
	border-radius: var(--hsk-radius-xl);
	overflow: hidden;
	box-shadow: var(--hsk-shadow-lg);
	aspect-ratio: 4/5;
}

.age-badge {
	position: absolute;
	top: 1.5rem;
	right: 1.5rem;
	z-index: 3;
	width: 110px; height: 110px;
	background: var(--hsk-green);
	color: #fff;
	border-radius: 50%;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	transform: rotate(6deg);
	box-shadow: 0 8px 24px rgba(45,107,60,0.35);
	font-family: var(--hsk-font-body);
	animation: hsk-wiggle 5s ease-in-out infinite;
}
@keyframes hsk-wiggle {
	0%, 100% { transform: rotate(6deg); }
	50% { transform: rotate(-2deg); }
}
.age-badge-eyebrow {
	font-size: 0.6rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	font-weight: 700;
	opacity: 0.95;
}
.age-badge-number {
	font-family: var(--hsk-font-display);
	font-size: 2.2rem;
	font-weight: 600;
	line-height: 1;
}
.age-badge-suffix { font-size: 0.8rem; font-weight: 700; letter-spacing: 0.08em; margin-top: 0.15rem; }

.hero-photo {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.hero-photo-placeholder {
	width: 100%;
	height: 100%;
	background: linear-gradient(135deg, #87CEEB 0%, #4A8A3D 100%);
	display: flex;
	align-items: center;
	justify-content: center;
	color: rgba(255,255,255,0.6);
	font-family: var(--hsk-font-body);
	font-weight: 600;
	font-size: 0.85rem;
}

/* hero-wave is verwijderd — info-strip valt nu netjes over de cream/wit overgang */
.hero-wave { display: none; }

/* --------------------------------------------------------------------------
   6. INFO STRIP — card valt half over cream-hero, half op wit
   -------------------------------------------------------------------------- */
.info-strip {
	position: relative;
	z-index: 5;
	padding: 4rem 0;
	background: linear-gradient(
		to bottom,
		var(--hsk-cream) 0%,
		var(--hsk-cream) calc(50% + 1px),
		var(--hsk-white) calc(50% + 1px),
		var(--hsk-white) 100%
	);
}
.info-strip-card {
	/* card is gecentreerd in de info-strip — gradient ligt precies door het midden */
	margin: 0;
}
.info-strip-card {
	background: var(--hsk-green);
	color: #fff;
	border-radius: var(--hsk-radius-xl);
	padding: 2rem 2.5rem;
	display: grid;
	grid-template-columns: 1fr auto 1fr auto 1fr;
	gap: 2rem;
	align-items: center;
	box-shadow: var(--hsk-shadow-lg);
	position: relative;
	overflow: hidden;
}
.info-strip-card::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image:
		radial-gradient(circle at 20% 30%, rgba(255,255,255,0.06) 0%, transparent 50%),
		radial-gradient(circle at 80% 70%, rgba(255,255,255,0.04) 0%, transparent 50%);
	pointer-events: none;
}
.info-item {
	display: flex;
	gap: 1rem;
	align-items: center;
	position: relative;
}
.info-icon {
	color: #fff;
	opacity: 0.9;
	flex-shrink: 0;
}
.info-label {
	display: block;
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	opacity: 0.8;
	margin-bottom: 0.2rem;
	font-weight: 600;
}
.info-item strong {
	display: block;
	font-family: var(--hsk-font-display);
	font-size: 1.1rem;
	font-weight: 500;
	letter-spacing: -0.005em;
}
.info-sub {
	display: block;
	font-size: 0.85rem;
	opacity: 0.85;
	margin-top: 0.2rem;
}
.info-divider {
	width: 1px;
	height: 60px;
	background: rgba(255,255,255,0.2);
}

/* --------------------------------------------------------------------------
   7. SECTIONS — gemeenschappelijke headers
   -------------------------------------------------------------------------- */
.section-header { margin-bottom: 2.5rem; max-width: 720px; }
.section-header--center { text-align: center; margin-left: auto; margin-right: auto; }
.section-eyebrow {
	display: inline-block;
	font-family: var(--hsk-font-body);
	font-size: 0.75rem;
	font-weight: 700;
	color: var(--hsk-red);
	text-transform: uppercase;
	letter-spacing: 0.14em;
	margin-bottom: 0.75rem;
}
.section-title { margin-bottom: 0.75rem; font-weight: 600; }
.section-lead {
	font-size: 1.02rem;
	color: var(--hsk-ink-soft);
	margin: 0;
	max-width: 620px;
}

/* --------------------------------------------------------------------------
   8. WEEKS GRID
   -------------------------------------------------------------------------- */
.weeks-section {
	background: var(--hsk-white);
	padding: 6rem 0;
}
.weeks-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 1.5rem;
}
.week-card {
	background: var(--hsk-cream-soft);
	border-radius: var(--hsk-radius-lg);
	padding: 1.75rem;
	border: 2px solid var(--hsk-border);
	transition: transform var(--hsk-transition), box-shadow var(--hsk-transition), border-color var(--hsk-transition);
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	position: relative;
}
.week-card:hover {
	transform: translateY(-6px);
	box-shadow: var(--hsk-shadow-lg);
}
.week-card--green:hover { border-color: var(--hsk-green); }
.week-card--red:hover { border-color: var(--hsk-red); }

/* Maak de hele card klikbaar via de week-link stretch */
.week-title a {
	color: inherit;
	text-decoration: none;
}
.week-title a:hover { color: inherit; }

.week-card-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 0.5rem;
}
.week-number {
	font-family: var(--hsk-font-body);
	font-size: 0.7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	padding: 0.3rem 0.8rem;
	border-radius: var(--hsk-radius-pill);
}
.week-card--green .week-number { background: var(--hsk-green-soft); color: var(--hsk-green-dark); }
.week-card--red .week-number { background: var(--hsk-red-soft); color: var(--hsk-red-dark); }

.week-flag { font-size: 1.6rem; }
.week-title { margin: 0; font-size: 1.4rem; font-weight: 600; }
.week-date {
	font-weight: 600;
	color: var(--hsk-muted);
	margin: 0 0 0.5rem;
	font-size: 0.92rem;
}
.week-desc { color: var(--hsk-ink-soft); flex: 1; }
.week-link {
	margin-top: 0.5rem;
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
	font-weight: 700;
	font-family: var(--hsk-font-display);
	font-size: 0.92rem;
}
.week-link svg { transition: transform var(--hsk-transition); }
.week-link:hover svg { transform: translateX(4px); }

/* Volgeboekt badge */
.week-card {
	position: relative;
}
.week-card-soldout-badge {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	background: #d32f2f;
	color: #fff;
	font-family: var(--hsk-font-display);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	padding: 0.3rem 0.65rem;
	border-radius: 999px;
	margin-bottom: 0.75rem;
	width: fit-content;
}
.week-card--volgeboekt {
	opacity: 0.85;
}
.week-card--volgeboekt .week-link {
	pointer-events: none;
	opacity: 0.45;
}

/* --------------------------------------------------------------------------
   9. DISCOUNT SECTION
   -------------------------------------------------------------------------- */
.discount-section {
	padding: 6rem 0;
	background: var(--hsk-cream);
}
.discount-card {
	background: #fff;
	border-radius: var(--hsk-radius-xl);
	padding: 3rem;
	display: grid;
	grid-template-columns: 1fr 1.2fr;
	gap: 3rem;
	align-items: center;
	box-shadow: var(--hsk-shadow);
	border: 2px dashed var(--hsk-border);
	position: relative;
	overflow: hidden;
}
.discount-card::before {
	content: "%";
	position: absolute;
	top: -60px; right: -30px;
	font-family: var(--hsk-font-display);
	font-size: 12rem;
	font-weight: 600;
	color: var(--hsk-cream-dark);
	opacity: 0.25;
	pointer-events: none;
	line-height: 1;
}
.discount-text { position: relative; z-index: 1; }
.discount-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 72px; height: 72px;
	background: var(--hsk-red);
	color: #fff;
	border-radius: 50%;
	margin-bottom: 1rem;
}
.discount-title { margin-bottom: 0.5rem; font-weight: 600; }
.discount-lead { color: var(--hsk-ink-soft); margin: 0; }

.discount-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 1rem;
	position: relative;
	z-index: 1;
}
.discount-list li {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	gap: 1.5rem;
	padding: 1rem 1.5rem;
	background: var(--hsk-cream-soft);
	border-radius: var(--hsk-radius);
	font-family: var(--hsk-font-body);
}
.discount-qty { font-weight: 600; font-size: 1rem; color: var(--hsk-ink); }
.discount-arrow {
	color: var(--hsk-green);
	font-size: 1.4rem;
	font-weight: 600;
}
.discount-value {
	font-weight: 700;
	color: var(--hsk-red);
	font-size: 1.1rem;
	text-align: right;
	font-family: var(--hsk-font-display);
}
.discount-value--big {
	font-size: 1.4rem;
	color: var(--hsk-red-dark);
}

/* --------------------------------------------------------------------------
   10. BENEFITS
   -------------------------------------------------------------------------- */
.benefits-section {
	padding: 6rem 0;
	background: var(--hsk-green);
	color: #fff;
	position: relative;
	overflow: hidden;
}
.benefits-section::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image:
		radial-gradient(circle at 10% 20%, rgba(255,255,255,0.04) 0%, transparent 40%),
		radial-gradient(circle at 90% 80%, rgba(255,255,255,0.05) 0%, transparent 40%);
	pointer-events: none;
}
.benefits-section .section-header { position: relative; }
.benefits-section .section-eyebrow { color: #FFD93D; }
.benefits-section .section-title { color: #fff; }
.benefits-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 2rem;
	position: relative;
}
.benefit { text-align: center; }
.benefit-check {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 60px; height: 60px;
	background: #fff;
	color: var(--hsk-green);
	border-radius: 50%;
	margin-bottom: 1rem;
}
.benefit h3 { color: #fff; font-size: 1.15rem; font-weight: 600; margin-bottom: 0.5rem; }
.benefit p { color: rgba(255,255,255,0.85); margin: 0; }

/* --------------------------------------------------------------------------
   11. TESTIMONIALS
   -------------------------------------------------------------------------- */
.testimonials-section {
	padding: 6rem 0;
	background: var(--hsk-cream);
}
.testimonials-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 1.5rem;
}
.testimonial {
	background: #fff;
	border-radius: var(--hsk-radius-lg);
	padding: 2rem;
	margin: 0;
	box-shadow: var(--hsk-shadow-sm);
	position: relative;
	border-top: 4px solid var(--hsk-red);
}
.testimonial:nth-child(2n) { border-top-color: var(--hsk-green); }
.quote-mark {
	color: var(--hsk-red);
	opacity: 0.2;
	margin-bottom: 0.5rem;
}
.testimonial:nth-child(2n) .quote-mark { color: var(--hsk-green); }
.testimonial p {
	font-size: 1.02rem;
	color: var(--hsk-ink);
	margin-bottom: 1rem;
}
.testimonial cite {
	font-weight: 700;
	color: var(--hsk-muted);
	font-style: normal;
	font-family: var(--hsk-font-display);
	font-size: 0.92rem;
}

/* --------------------------------------------------------------------------
   12. FAQ
   -------------------------------------------------------------------------- */
.faq-section {
	padding: 6rem 0;
	background: var(--hsk-white);
}
.faq-container { max-width: var(--hsk-container-narrow); }
.faq-list { display: flex; flex-direction: column; gap: 0.75rem; }
.faq-item {
	background: var(--hsk-cream-soft);
	border-radius: var(--hsk-radius);
	padding: 0.25rem 1.5rem;
	border: 1px solid var(--hsk-border);
	transition: border-color var(--hsk-transition), background var(--hsk-transition);
}
.faq-item[open] {
	border-color: var(--hsk-green);
	background: #fff;
	box-shadow: var(--hsk-shadow-sm);
}
.faq-item summary {
	cursor: pointer;
	font-family: var(--hsk-font-display);
	font-weight: 500;
	font-size: 1.05rem;
	padding: 1.25rem 0;
	display: flex;
	justify-content: space-between;
	align-items: center;
	list-style: none;
	color: var(--hsk-ink);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
	content: "+";
	font-size: 1.6rem;
	color: var(--hsk-green);
	transition: transform var(--hsk-transition);
	margin-left: 1rem;
	line-height: 1;
}
.faq-item[open] summary::after { transform: rotate(45deg); }
.faq-answer { padding: 0 0 1.25rem; color: var(--hsk-ink-soft); }
.faq-answer p:last-child { margin-bottom: 0; }

/* --------------------------------------------------------------------------
   13. CTA BAND
   -------------------------------------------------------------------------- */
.cta-band {
	background: var(--hsk-red);
	color: #fff;
	padding: 4rem 0;
	position: relative;
	overflow: hidden;
}
.cta-band::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image:
		repeating-linear-gradient(45deg, transparent 0, transparent 40px, rgba(255,255,255,0.03) 40px, rgba(255,255,255,0.03) 41px);
	pointer-events: none;
}
.cta-band-inner {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 2rem;
	align-items: center;
	position: relative;
}
.cta-eyebrow {
	display: inline-block;
	font-family: var(--hsk-font-body);
	font-size: 0.78rem;
	font-weight: 700;
	background: rgba(255,255,255,0.18);
	padding: 0.3rem 0.9rem;
	border-radius: var(--hsk-radius-pill);
	text-transform: uppercase;
	letter-spacing: 0.12em;
	margin-bottom: 0.75rem;
}
.cta-band h2 { color: #fff; margin: 0; font-weight: 600; }
.cta-band p { margin: 0.5rem 0 0; opacity: 0.95; font-size: 1.02rem; max-width: 600px; }
.cta-band-actions { display: flex; gap: 1rem; flex-wrap: wrap; }
.cta-band .btn-primary {
	background: #fff;
	color: var(--hsk-red);
	box-shadow: 0 6px 0 rgba(0,0,0,0.15), 0 12px 24px rgba(0,0,0,0.2);
}
.cta-band .btn-primary:hover { background: var(--hsk-cream); color: var(--hsk-red-dark); }
.cta-band .btn-ghost { color: #fff; border-color: #fff; }
.cta-band .btn-ghost:hover { background: #fff; color: var(--hsk-red); }

/* --------------------------------------------------------------------------
   14. FOOTER
   -------------------------------------------------------------------------- */
.site-footer { background: var(--hsk-green); color: var(--hsk-cream-soft); }
.footer-decoration { line-height: 0; background: var(--hsk-cream); }
.footer-decoration svg { width: 100%; height: 60px; display: block; }
.footer-main { padding: 4rem 0 2rem; }
.footer-grid {
	display: grid;
	grid-template-columns: 2fr 1fr 1fr 1fr;
	gap: 2.5rem;
}
.footer-col-brand p {
	color: rgba(255,255,255,0.8);
	max-width: 320px;
}
.footer-logo {
	margin-bottom: 1.25rem;
	background: #fff;
	padding: 0.6rem 1rem;
	border-radius: var(--hsk-radius);
	display: inline-block;
}
.footer-logo-img {
	max-height: 48px;
	width: auto;
	display: block;
}
.footer-socials {
	display: flex;
	gap: 0.75rem;
	margin-top: 1.5rem;
}
.footer-socials a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px; height: 40px;
	background: rgba(255,255,255,0.1);
	color: #fff;
	border-radius: 50%;
	transition: background var(--hsk-transition);
}
.footer-socials a:hover { background: var(--hsk-red); color: #fff; }

.footer-title {
	color: #fff;
	font-family: var(--hsk-font-body);
	font-size: 0.8rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	margin-bottom: 1rem;
}
.footer-menu, .widget ul {
	list-style: none;
	padding: 0;
	margin: 0;
}
.footer-menu li, .widget li { margin-bottom: 0.5rem; }
.footer-menu a, .widget a {
	color: rgba(255,255,255,0.8);
	transition: color var(--hsk-transition);
}
.footer-menu a:hover, .widget a:hover { color: #fff; }

.footer-address p { color: rgba(255,255,255,0.8); }
.footer-address a { color: #fff; text-decoration: underline; }
.footer-address a:hover { color: var(--hsk-cream); }

.footer-bottom {
	background: var(--hsk-green-dark);
	padding: 1.25rem 0;
}
.footer-bottom-inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: 1rem;
	font-size: 0.9rem;
	color: rgba(255,255,255,0.7);
}
.footer-bottom a { color: #fff; text-decoration: underline; }
.footer-legal-menu {
	display: flex;
	gap: 1.5rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

/* --------------------------------------------------------------------------
   15. CONTENT (single, page)
   -------------------------------------------------------------------------- */
.page-content, .entry-content {
	max-width: var(--hsk-container-narrow);
	margin: 4rem auto;
	padding: 0 1.5rem;
}
.entry-content h2 { margin-top: 2.5rem; }
.entry-content h3 { margin-top: 2rem; }
.entry-content img { border-radius: var(--hsk-radius); margin: 1.5rem 0; }
.entry-content blockquote {
	border-left: 4px solid var(--hsk-green);
	background: var(--hsk-green-soft);
	padding: 1.5rem;
	margin: 2rem 0;
	border-radius: 0 var(--hsk-radius) var(--hsk-radius) 0;
}
.entry-content code {
	background: var(--hsk-cream-dark);
	padding: 0.2em 0.4em;
	border-radius: 4px;
	font-size: 0.9em;
}

.page-header {
	background: var(--hsk-green);
	color: #fff;
	padding: 4rem 0 5rem;
	text-align: center;
	position: relative;
	overflow: hidden;
}
.page-header::after {
	content: "";
	position: absolute;
	bottom: -1px; left: 0; right: 0;
	height: 50px;
	background: var(--hsk-cream);
	clip-path: polygon(0 100%, 100% 100%, 100% 50%, 0 0);
}
.page-header h1 { color: #fff; margin: 0; position: relative; z-index: 2; }

/* Blog cards */
.blog-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
	gap: 2rem;
	max-width: var(--hsk-container);
	margin: 4rem auto;
	padding: 0 1.5rem;
}
.post-card {
	background: #fff;
	border-radius: var(--hsk-radius-lg);
	overflow: hidden;
	box-shadow: var(--hsk-shadow-sm);
	transition: transform var(--hsk-transition), box-shadow var(--hsk-transition);
	display: flex;
	flex-direction: column;
}
.post-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--hsk-shadow);
}
.post-card-image {
	aspect-ratio: 16/10;
	overflow: hidden;
	background: var(--hsk-cream-dark);
}
.post-card-image img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform 0.5s ease;
}
.post-card:hover .post-card-image img { transform: scale(1.05); }
.post-card-body { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; }
.post-card-meta {
	font-size: 0.85rem;
	color: var(--hsk-muted);
	margin-bottom: 0.5rem;
}
.post-card-title {
	font-size: 1.25rem;
	margin-bottom: 0.5rem;
}
.post-card-title a { color: var(--hsk-ink); }
.post-card-title a:hover { color: var(--hsk-red); }
.post-card-excerpt {
	color: var(--hsk-ink-soft);
	font-size: 0.95rem;
	flex: 1;
}
.post-card-link {
	margin-top: 1rem;
	font-weight: 700;
	font-family: var(--hsk-font-display);
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
}

/* --------------------------------------------------------------------------
   16. PAGINATION
   -------------------------------------------------------------------------- */
.pagination {
	display: flex;
	justify-content: center;
	gap: 0.5rem;
	margin: 3rem 0;
}
.pagination a, .pagination span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 42px; height: 42px;
	padding: 0 0.75rem;
	background: #fff;
	color: var(--hsk-ink);
	border-radius: var(--hsk-radius-pill);
	font-family: var(--hsk-font-display);
	font-weight: 700;
	border: 2px solid var(--hsk-border);
	transition: all var(--hsk-transition);
}
.pagination .current,
.pagination a:hover {
	background: var(--hsk-green);
	color: #fff;
	border-color: var(--hsk-green);
}

/* --------------------------------------------------------------------------
   16A. PAGE CONTENT — opmaak van standaard pagina's in huisstijl
   -------------------------------------------------------------------------- */

/* Container voor de pagina-content — overschrijft de prose-default */
.page .entry-content {
	max-width: 1100px;
	padding: 0 1.5rem;
}

/* Intro-paragraaf bovenaan een pagina — grotere, luchtigere lead */
.hsk-page-intro {
	max-width: 760px;
	margin: 0 0 2.5rem;
}
.hsk-lead {
	font-size: 1.2rem;
	line-height: 1.55;
	color: var(--hsk-ink-soft);
	margin: 0;
}

/* Section title gebruikt door pages */
.hsk-section-title {
	font-size: clamp(1.5rem, 2.5vw, 2rem);
	font-weight: 600;
	margin: 3rem 0 1.25rem;
	letter-spacing: -0.015em;
}
.hsk-section-title:first-child { margin-top: 0; }

/* Praktisch-grid op pages (zelfde stijl als single, maar herbruikbaar) */
.hsk-praktisch-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem;
	margin: 1.5rem 0 2.5rem;
}
.hsk-praktisch-block {
	padding: 1.5rem 1.75rem;
	border-radius: var(--hsk-radius-lg);
	background: var(--hsk-cream-soft);
	border-left: 4px solid var(--hsk-green);
}
.hsk-praktisch-block--red { border-left-color: var(--hsk-red); }
.hsk-praktisch-block h3 {
	font-size: 1.05rem;
	font-weight: 700;
	margin: 0 0 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--hsk-green-dark);
	font-family: var(--hsk-font-body);
}
.hsk-praktisch-block--red h3 { color: var(--hsk-red-dark); }
.hsk-praktisch-list {
	list-style: none;
	padding: 0;
	margin: 0;
}
.hsk-praktisch-list li {
	font-size: 0.95rem;
	color: var(--hsk-ink-soft);
	padding: 0.3rem 0 0.3rem 1.4rem;
	position: relative;
}
.hsk-praktisch-list li::before {
	content: "→";
	position: absolute;
	left: 0;
	color: var(--hsk-green);
	font-weight: 700;
}
.hsk-praktisch-block--red .hsk-praktisch-list li::before { color: var(--hsk-red); }

/* Bewegen-blok */
.hsk-bewegen-block {
	margin: 2.5rem 0;
	padding: 2.25rem;
	background: var(--hsk-green);
	color: #fff;
	border-radius: var(--hsk-radius-lg);
	position: relative;
	overflow: hidden;
}
.hsk-bewegen-block::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image:
		radial-gradient(circle at 85% 15%, rgba(255,255,255,0.06) 0%, transparent 50%),
		radial-gradient(circle at 15% 85%, rgba(255,255,255,0.04) 0%, transparent 50%);
	pointer-events: none;
}
.hsk-bewegen-block h2 {
	color: #fff;
	font-size: 1.5rem;
	font-weight: 600;
	margin: 0 0 0.75rem;
	position: relative;
}
.hsk-bewegen-block p {
	color: rgba(255,255,255,0.92);
	margin: 0 0 1.25rem;
	position: relative;
}
.hsk-bewegen-grid {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0.6rem 1.5rem;
	position: relative;
}
.hsk-bewegen-grid li {
	font-weight: 600;
	font-size: 1rem;
	color: #fff;
}
.hsk-bewegen-arrow {
	color: #FFD93D;
	font-weight: 700;
	margin-right: 0.35rem;
}

/* Info-blok — neutrale tekstblok met titel */
.hsk-info-block {
	margin: 1.5rem 0;
	padding: 1.5rem 1.75rem;
	background: var(--hsk-white);
	border-radius: var(--hsk-radius-lg);
	border: 1px solid var(--hsk-border);
}
.hsk-info-block--cream {
	background: var(--hsk-cream-soft);
	border-color: var(--hsk-border);
}
.hsk-info-block h3 {
	font-size: 1.2rem;
	font-weight: 600;
	margin: 0 0 0.6rem;
}
.hsk-info-block p { margin: 0; color: var(--hsk-ink-soft); }
.hsk-info-block p + p { margin-top: 0.75rem; }

/* Prijs-card op tarieven-pagina */
.hsk-prijs-card {
	background: linear-gradient(135deg, var(--hsk-green) 0%, var(--hsk-green-dark) 100%);
	color: #fff;
	border-radius: var(--hsk-radius-xl);
	padding: 2.5rem;
	text-align: center;
	margin: 1.5rem 0 3rem;
	position: relative;
	overflow: hidden;
	box-shadow: var(--hsk-shadow-lg);
}
.hsk-prijs-card::before {
	content: "€";
	position: absolute;
	top: -3rem;
	right: -1rem;
	font-family: var(--hsk-font-display);
	font-size: 16rem;
	font-weight: 600;
	color: rgba(255,255,255,0.06);
	line-height: 1;
	pointer-events: none;
}
.hsk-prijs-label {
	display: block;
	font-size: 0.85rem;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	font-weight: 700;
	opacity: 0.9;
	margin-bottom: 0.5rem;
	position: relative;
}
.hsk-prijs-bedrag {
	display: block;
	font-family: var(--hsk-font-display);
	font-size: clamp(3rem, 7vw, 4.5rem);
	font-weight: 600;
	line-height: 1;
	margin: 0.25rem 0 0.75rem;
	letter-spacing: -0.02em;
	position: relative;
}
.hsk-prijs-sub {
	font-size: 1rem;
	opacity: 0.92;
	max-width: 480px;
	margin: 0 auto;
	position: relative;
}

/* FAQ-list (zelfde stijl als de homepage maar herbruikbaar) */
.hsk-faq-list {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	margin: 1.5rem 0 2.5rem;
}
.hsk-faq-item {
	background: var(--hsk-cream-soft);
	border-radius: var(--hsk-radius);
	padding: 0.25rem 1.5rem;
	border: 1px solid var(--hsk-border);
	transition: border-color var(--hsk-transition), background var(--hsk-transition);
}
.hsk-faq-item[open] {
	border-color: var(--hsk-green);
	background: #fff;
	box-shadow: var(--hsk-shadow-sm);
}
.hsk-faq-item summary {
	cursor: pointer;
	font-family: var(--hsk-font-display);
	font-weight: 500;
	font-size: 1.05rem;
	padding: 1.25rem 0;
	display: flex;
	justify-content: space-between;
	align-items: center;
	list-style: none;
	color: var(--hsk-ink);
}
.hsk-faq-item summary::-webkit-details-marker { display: none; }
.hsk-faq-item summary::after {
	content: "+";
	font-size: 1.6rem;
	color: var(--hsk-green);
	transition: transform var(--hsk-transition);
	margin-left: 1rem;
	line-height: 1;
}
.hsk-faq-item[open] summary::after { transform: rotate(45deg); }
.hsk-faq-answer { padding: 0 0 1.25rem; color: var(--hsk-ink-soft); }
.hsk-faq-answer p:last-child { margin-bottom: 0; }

/* CTA-blok aan einde van pagina */
.hsk-page-cta {
	margin: 3rem 0 1.5rem;
	padding: 2.5rem 2rem;
	background: var(--hsk-red);
	color: #fff;
	border-radius: var(--hsk-radius-xl);
	text-align: center;
	position: relative;
	overflow: hidden;
}
.hsk-page-cta::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image: repeating-linear-gradient(45deg, transparent 0, transparent 40px, rgba(255,255,255,0.03) 40px, rgba(255,255,255,0.03) 41px);
	pointer-events: none;
}
.hsk-page-cta h2 {
	color: #fff;
	font-size: clamp(1.4rem, 2.8vw, 1.9rem);
	font-weight: 600;
	margin: 0 0 0.5rem;
	position: relative;
}
.hsk-page-cta p {
	color: rgba(255,255,255,0.95);
	margin: 0 0 1.5rem;
	font-size: 1.05rem;
	position: relative;
}
.hsk-page-cta .btn-primary {
	background: #fff;
	color: var(--hsk-red);
	box-shadow: 0 6px 0 rgba(0,0,0,0.15), 0 12px 24px rgba(0,0,0,0.2);
	position: relative;
}
.hsk-page-cta .btn-primary:hover { background: var(--hsk-cream); color: var(--hsk-red-dark); }

/* Contact-grid: form links, info rechts */
.hsk-contact-grid {
	display: grid;
	grid-template-columns: 1.5fr 1fr;
	gap: 3rem;
	align-items: start;
	margin: 1.5rem 0;
}
.hsk-contact-form .hsk-section-title { margin-top: 0; }
.hsk-info-card {
	background: var(--hsk-white);
	border-radius: var(--hsk-radius-xl);
	padding: 1.75rem;
	box-shadow: var(--hsk-shadow);
	border: 1px solid var(--hsk-border);
	position: sticky;
	top: 100px;
}
.hsk-info-card h3 {
	margin: 0 0 1rem;
	font-size: 1.3rem;
	font-weight: 600;
	padding-bottom: 1rem;
	border-bottom: 1px solid var(--hsk-border);
}
.hsk-contact-list {
	list-style: none;
	padding: 0;
	margin: 0 0 1rem;
	display: flex;
	flex-direction: column;
	gap: 1rem;
}
.hsk-contact-list li { display: block; }
.hsk-contact-list strong {
	display: block;
	font-size: 0.7rem;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--hsk-muted);
	font-weight: 700;
	margin-bottom: 0.25rem;
}
.hsk-contact-list span {
	display: block;
	color: var(--hsk-ink);
	font-size: 0.95rem;
	line-height: 1.45;
}
.hsk-contact-list a {
	color: var(--hsk-green-dark);
	text-decoration: underline;
	text-decoration-color: var(--hsk-green-soft);
	text-underline-offset: 3px;
}
.hsk-contact-list a:hover { color: var(--hsk-red); }

/* --------------------------------------------------------------------------
   16B. PROGRAMMA SINGLE — Kidsproof-stijl detail pagina
   -------------------------------------------------------------------------- */
.programma-single { background: var(--hsk-cream-soft); }

/* Header */
.programma-header {
	background: var(--hsk-cream);
	padding: 2rem 0 3rem;
	border-bottom: 1px solid var(--hsk-border);
}
.breadcrumb {
	font-size: 0.85rem;
	color: var(--hsk-muted);
	margin-bottom: 1.5rem;
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
	align-items: center;
}
.breadcrumb a {
	color: var(--hsk-muted);
}
.breadcrumb a:hover { color: var(--hsk-red); }
.breadcrumb span[aria-hidden="true"] { opacity: 0.5; }

.programma-header-inner {
	display: flex;
	align-items: center;
	gap: 2rem;
}
.programma-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-family: var(--hsk-font-body);
	font-size: 0.85rem;
	font-weight: 700;
	color: var(--hsk-red);
	text-transform: uppercase;
	letter-spacing: 0.12em;
	margin-bottom: 0.5rem;
}
.programma-single--green .programma-eyebrow { color: var(--hsk-green); }
.programma-flag { font-size: 1.4rem; }
.programma-title {
	font-size: clamp(2.2rem, 5vw, 3.5rem);
	font-weight: 600;
	margin: 0 0 0.5rem;
	letter-spacing: -0.02em;
}
.programma-tagline {
	font-size: 1.2rem;
	color: var(--hsk-ink-soft);
	margin: 0;
	max-width: 700px;
}

/* Body grid */
.programma-body {
	padding: 3rem 0 5rem;
	background: var(--hsk-cream-soft);
}
.programma-grid {
	display: grid;
	grid-template-columns: 1fr 360px;
	gap: 3rem;
	align-items: start;
}

/* Content links */
.programma-content {
	min-width: 0;
}
.programma-photo {
	margin: 0 0 2.5rem;
	border-radius: var(--hsk-radius-xl);
	overflow: hidden;
	box-shadow: var(--hsk-shadow);
}
.programma-photo img { display: block; width: 100%; }
.programma-photo--placeholder {
	aspect-ratio: 16/9;
	background: linear-gradient(135deg, var(--hsk-green-bright) 0%, var(--hsk-green-dark) 100%);
	display: flex;
	align-items: center;
	justify-content: center;
}
.programma-single--red .programma-photo--placeholder {
	background: linear-gradient(135deg, #E66060 0%, var(--hsk-red-dark) 100%);
}
.placeholder-flag { font-size: 6rem; filter: drop-shadow(0 4px 12px rgba(0,0,0,0.2)); }

.programma-prose h2 {
	font-size: 1.6rem;
	margin-top: 2.5rem;
	margin-bottom: 0.75rem;
}
.programma-prose h3 {
	font-size: 1.25rem;
	margin-top: 2rem;
	margin-bottom: 0.5rem;
}
.programma-prose p { margin-bottom: 1rem; color: var(--hsk-ink-soft); }
.programma-prose ul {
	padding-left: 0;
	list-style: none;
	margin: 1rem 0 2rem;
}
.programma-prose ul li {
	position: relative;
	padding-left: 2rem;
	margin-bottom: 0.6rem;
	color: var(--hsk-ink-soft);
}
.programma-prose ul li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.45em;
	width: 1.2rem;
	height: 1.2rem;
	background: var(--hsk-green);
	border-radius: 50%;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
	background-position: center;
	background-size: 65%;
	background-repeat: no-repeat;
}
.programma-single--red .programma-prose ul li::before { background-color: var(--hsk-red); }

.programma-praktisch {
	margin: 3rem 0 2rem;
	padding: 2rem;
	background: var(--hsk-white);
	border-radius: var(--hsk-radius-lg);
	border: 1px solid var(--hsk-border);
}
.programma-praktisch h2 {
	font-size: 1.4rem;
	margin: 0 0 0.75rem;
}
.programma-praktisch p {
	color: var(--hsk-ink-soft);
	margin: 0 0 1.5rem;
}

/* Je krijgt / Meenemen — 2 koloms grid */
.praktisch-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem;
	margin-top: 1.5rem;
}
.praktisch-block {
	padding: 1.25rem 1.5rem;
	border-radius: var(--hsk-radius);
	background: var(--hsk-cream-soft);
	border-left: 4px solid var(--hsk-green);
}
.praktisch-block--red { border-left-color: var(--hsk-red); }
.praktisch-block h3 {
	font-size: 1rem;
	font-weight: 600;
	margin: 0 0 0.6rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--hsk-green-dark);
}
.praktisch-block--red h3 { color: var(--hsk-red-dark); }
.praktisch-list {
	list-style: none;
	padding: 0;
	margin: 0;
}
.praktisch-list li {
	font-size: 0.92rem;
	color: var(--hsk-ink-soft);
	padding: 0.25rem 0;
	padding-left: 1.2rem;
	position: relative;
}
.praktisch-list li::before {
	content: "→";
	position: absolute;
	left: 0;
	color: var(--hsk-green);
	font-weight: 700;
}
.praktisch-block--red .praktisch-list li::before { color: var(--hsk-red); }

/* Bewegen — waar is dat goed voor */
.programma-bewegen {
	margin: 2rem 0;
	padding: 2rem;
	background: var(--hsk-green);
	color: #fff;
	border-radius: var(--hsk-radius-lg);
	position: relative;
	overflow: hidden;
}
.programma-bewegen::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image:
		radial-gradient(circle at 80% 20%, rgba(255,255,255,0.05) 0%, transparent 50%),
		radial-gradient(circle at 20% 80%, rgba(255,255,255,0.04) 0%, transparent 50%);
	pointer-events: none;
}
.programma-bewegen h2 {
	color: #fff;
	font-size: 1.4rem;
	margin: 0 0 0.75rem;
	position: relative;
}
.programma-bewegen p {
	color: rgba(255,255,255,0.92);
	margin: 0 0 1.25rem;
	position: relative;
}
.bewegen-grid {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0.5rem 1.5rem;
	position: relative;
}
.bewegen-grid li {
	font-weight: 600;
	font-size: 0.95rem;
	color: #fff;
}
.bewegen-arrow {
	color: #FFD93D;
	font-weight: 700;
	margin-right: 0.25rem;
}

/* EHBO badge in sidebar */
.info-card-ehbo {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	background: var(--hsk-red-soft);
	color: var(--hsk-red-dark);
	font-weight: 700;
	font-size: 0.8rem;
	padding: 0.4rem 0.8rem;
	border-radius: var(--hsk-radius-pill);
	margin: 0 0 1.25rem;
}
.info-card-ehbo svg { flex-shrink: 0; }

.programma-korting {
	margin: 2rem 0;
	padding: 2rem;
	background: var(--hsk-cream);
	border-radius: var(--hsk-radius-lg);
	border: 2px dashed var(--hsk-border);
}
.programma-korting h3 {
	font-size: 1.25rem;
	margin: 0 0 1rem;
}
.korting-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}
.korting-list li {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0.75rem 1rem;
	background: #fff;
	border-radius: var(--hsk-radius);
}
.korting-list strong { font-weight: 600; }
.korting-list span {
	font-family: var(--hsk-font-display);
	font-weight: 600;
	color: var(--hsk-red);
}
.korting-big {
	font-size: 1.2rem !important;
	color: var(--hsk-red-dark) !important;
}

.programma-inline-cta {
	margin: 2.5rem 0 0;
	text-align: center;
	display: none; /* alleen op mobiel zichtbaar — desktop heeft sidebar CTA */
}

/* Sidebar */
.programma-sidebar {
	position: sticky;
	top: 100px;
}
.programma-info-card {
	background: #fff;
	border-radius: var(--hsk-radius-xl);
	padding: 1.75rem;
	box-shadow: var(--hsk-shadow);
	border: 1px solid var(--hsk-border);
}
.info-card-title {
	font-size: 1.4rem;
	margin: 0 0 0.25rem;
	font-weight: 600;
}
.info-card-sub {
	color: var(--hsk-muted);
	font-size: 0.9rem;
	margin: 0 0 1.25rem;
	padding-bottom: 1.25rem;
	border-bottom: 1px solid var(--hsk-border);
}
.info-card-list {
	list-style: none;
	padding: 0;
	margin: 0 0 1.5rem;
	display: flex;
	flex-direction: column;
	gap: 1rem;
}
.info-card-list li {
	display: flex;
	gap: 0.85rem;
	align-items: flex-start;
}
.info-card-list svg {
	color: var(--hsk-green);
	flex-shrink: 0;
	margin-top: 2px;
}
.programma-single--red .info-card-list svg { color: var(--hsk-red); }
.info-card-label {
	display: block;
	font-size: 0.7rem;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--hsk-muted);
	font-weight: 700;
	margin-bottom: 0.15rem;
}
.info-card-list strong {
	display: block;
	font-weight: 600;
	color: var(--hsk-ink);
	font-size: 0.95rem;
	line-height: 1.35;
}
.info-card-sub-text {
	display: block;
	font-size: 0.82rem;
	color: var(--hsk-muted);
	margin-top: 0.15rem;
}
.info-card-cta {
	width: 100%;
	justify-content: center;
	margin-bottom: 0.5rem;
}
.info-card-secondary {
	width: 100%;
	justify-content: center;
	font-size: 0.9rem;
	padding: 0.7em 1.5em;
}

/* Related */
.programma-related {
	padding: 4rem 0 6rem;
	background: var(--hsk-cream);
}


/* --------------------------------------------------------------------------
   17. RESPONSIVE
   -------------------------------------------------------------------------- */
@media (max-width: 1024px) {
	.hero-grid { grid-template-columns: 1fr; gap: 3rem; }
	.hero-visual { max-width: 500px; margin: 0 auto; }
	.discount-card { grid-template-columns: 1fr; }
	.footer-grid { grid-template-columns: 1fr 1fr; }
	.cta-band-inner { grid-template-columns: 1fr; text-align: center; }
	.cta-band-actions { justify-content: center; }
}

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

	.topbar-meta { font-size: 0.78rem; gap: 1rem; }
	.topbar-parent { display: none; }

	/* Header mobile: logo links met padding boven/onder, hamburger uiterst rechts */
	.header-grid {
		grid-template-columns: auto 1fr;
		padding: 1rem 1.25rem;
		align-items: center;
	}
	.header-cta { display: none; }
	.site-branding {
		display: flex;
		align-items: center;
	}
	.site-logo-img,
	.custom-logo {
		max-height: 48px;
	}
	.main-navigation {
		justify-self: end;
	}

	.menu-toggle { display: flex; }
	.main-navigation .primary-menu {
		display: none;
		position: absolute;
		top: 100%; left: 0; right: 0;
		flex-direction: column;
		background: #fff;
		padding: 1rem;
		gap: 0;
		box-shadow: var(--hsk-shadow);
		border-bottom: 1px solid var(--hsk-border);
	}
	.main-navigation.toggled .primary-menu { display: flex; }
	.primary-menu a { padding: 0.8rem 1rem; }
	.primary-menu .sub-menu {
		position: static;
		opacity: 1;
		visibility: visible;
		transform: none;
		box-shadow: none;
		background: var(--hsk-cream-soft);
		margin: 0.25rem 0 0.5rem;
	}

	/* ===== HERO MOBILE — foto als achtergrond, tekst eroverheen ===== */
	.site-main { padding: 0 !important; margin: 0 !important; }
	.site-header { margin-bottom: 0; }

	.hero {
		padding: 0;
		min-height: 600px;
		display: flex;
		align-items: flex-end;
		position: relative;
		background: var(--hsk-ink); /* fallback achter foto */
		margin: 0;
		overflow: hidden;
	}
	.hero-bg { display: none; }
	.hero-grid {
		grid-template-columns: 1fr;
		gap: 0;
		position: relative;
		z-index: 2;
		width: 100%;
	}
	/* Op mobiel geen cream/wit gradient meer — info-strip is gewoon op cream */
	.info-strip {
		background: var(--hsk-cream);
		padding: 2rem 0 3rem;
	}
	/* Foto vult de hele hero als achtergrond */
	.hero-visual {
		position: absolute;
		inset: 0;
		width: 100%;
		height: 100%;
		max-width: none;
		margin: 0;
		border-radius: 0;
		box-shadow: none;
		aspect-ratio: auto;
		z-index: 1;
	}
	.hero-photo,
	.hero-photo-placeholder {
		border-radius: 0;
		width: 100%;
		height: 100%;
		object-fit: cover;
	}
	/* Donkere gradient overlay zodat tekst leesbaar blijft */
	.hero-visual::after {
		content: "";
		position: absolute;
		inset: 0;
		background: linear-gradient(
			180deg,
			rgba(245,237,224,0.05) 0%,
			rgba(26,26,26,0.15) 35%,
			rgba(26,26,26,0.7) 75%,
			rgba(26,26,26,0.92) 100%
		);
		pointer-events: none;
	}
	/* Age badge linksboven, niet over tekst */
	.age-badge {
		width: 72px; height: 72px;
		top: 1rem; right: 1rem;
		z-index: 3;
	}
	.age-badge-number { font-size: 1.3rem; }
	.age-badge-suffix { font-size: 0.55rem; margin-top: 0.1rem; }

	/* Content komt onderop met tekst in wit */
	.hero-content {
		position: relative;
		z-index: 2;
		padding: 2rem 1.25rem 1.75rem;
		color: #fff;
	}
	.hero-badge {
		margin-bottom: 0.85rem;
		max-width: calc(100% - 90px); /* maak ruimte voor de age-badge rechtsboven */
	}
	.hero-badge .hero-plane { display: none; }
	.hero-title {
		color: #fff;
		font-size: clamp(1.7rem, 7vw, 2.2rem);
		margin-bottom: 0.85rem;
		text-shadow: 0 2px 12px rgba(0,0,0,0.3);
	}
	.hero-line-1 { color: #fff; }
	.brush-highlight { color: #fff; }
	.brush-highlight::after {
		background: var(--hsk-green-bright);
		opacity: 0.8;
		height: 0.22em;
	}
	.hero-lead {
		color: rgba(255,255,255,0.92);
		font-size: 0.98rem;
		margin-bottom: 1.5rem;
		text-shadow: 0 1px 6px rgba(0,0,0,0.4);
	}
	.hero-actions { margin-bottom: 1.75rem; }
	.btn-link {
		color: #fff;
		text-decoration-color: rgba(255,255,255,0.5);
	}
	.btn-link:hover { color: #fff; text-decoration-color: #fff; }

	/* Pills 2x2 grid, gestyled voor donkere achtergrond */
	.hero-pills {
		grid-template-columns: repeat(2, 1fr);
		gap: 0.85rem 1rem;
	}
	.hero-pills li {
		flex-direction: row;
		align-items: center;
		text-align: left;
		gap: 0.7rem;
		font-size: 0.82rem;
		color: rgba(255,255,255,0.95);
		font-weight: 600;
		line-height: 1.25;
	}
	.pill-icon { width: 40px; height: 40px; }
	.pill-icon svg { width: 18px; height: 18px; }

	/* Hero wave hoort niet bij deze layout */
	.hero-wave { display: none; }

	/* ===== INFO STRIP ===== */
	.info-strip {
		margin-top: 0;
		padding: 1.5rem 0 3rem;
	}
	.info-strip-card {
		grid-template-columns: 1fr;
		gap: 1.25rem;
		padding: 1.5rem;
	}
	.info-divider {
		width: 100%; height: 1px;
	}

	/* ===== WEKEN GRID COMPACT — horizontaal layout ===== */
	.weeks-section, .discount-section, .benefits-section,
	.testimonials-section, .faq-section { padding: 4rem 0; }

	.weeks-grid {
		grid-template-columns: 1fr;
		gap: 0.75rem;
	}
	.week-card {
		padding: 1rem 1.25rem 1rem 1.5rem;
		display: grid;
		grid-template-columns: auto 1fr auto;
		grid-template-rows: auto auto;
		grid-template-areas:
			"number title  flag"
			"date   desc   link";
		gap: 0.15rem 0.85rem;
		align-items: center;
		position: relative;
		border-width: 2px;
	}
	/* Gekleurde linker-rand als onderscheid */
	.week-card::before {
		content: "";
		position: absolute;
		left: 0; top: 1rem; bottom: 1rem;
		width: 4px;
		border-radius: 0 2px 2px 0;
	}
	.week-card--green::before { background: var(--hsk-green); }
	.week-card--red::before { background: var(--hsk-red); }

	.week-card-header {
		display: contents;
	}
	.week-number {
		grid-area: number;
		align-self: center;
		font-size: 0.65rem;
		padding: 0.25rem 0.65rem;
		letter-spacing: 0.1em;
	}
	.week-flag {
		grid-area: flag;
		font-size: 1.5rem;
		align-self: center;
	}
	.week-title {
		grid-area: title;
		font-size: 1.15rem;
		margin: 0;
		line-height: 1.2;
	}
	.week-date {
		grid-area: date;
		font-size: 0.78rem;
		margin: 0;
		font-weight: 600;
		color: var(--hsk-green-dark);
	}
	.week-card--red .week-date { color: var(--hsk-red-dark); }
	.week-desc {
		grid-area: desc;
		font-size: 0.85rem;
		color: var(--hsk-ink-soft);
		margin: 0;
		line-height: 1.4;
	}
	.week-link {
		grid-area: link;
		margin: 0;
		align-self: center;
		justify-self: end;
		font-size: 0;
		width: 36px; height: 36px;
		border-radius: 50%;
		background: var(--hsk-green);
		display: inline-flex;
		align-items: center;
		justify-content: center;
		color: #fff;
		transition: transform var(--hsk-transition);
	}
	.week-card--red .week-link {
		background: var(--hsk-red);
		color: #fff;
	}
	.week-link svg { width: 14px; height: 14px; }
	.week-card:hover .week-link { transform: scale(1.1); }

	/* ===== DISCOUNT ===== */
	.discount-card { padding: 1.75rem 1.5rem; }
	.discount-card::before { display: none; }
	.discount-list li {
		grid-template-columns: 1fr auto;
		text-align: left;
		gap: 0.5rem 1rem;
	}
	.discount-value { text-align: right; }
	.discount-arrow { display: none; }

	/* ===== FOOTER ===== */
	.footer-grid { grid-template-columns: 1fr; gap: 2rem; }
	.footer-bottom-inner { flex-direction: column; text-align: center; }

	/* ===== PROGRAMMA SINGLE MOBILE ===== */
	.programma-grid {
		grid-template-columns: 1fr;
		gap: 2rem;
	}
	.programma-sidebar {
		position: static;
		order: -1; /* sidebar bovenaan op mobiel, na de header */
	}
	.programma-header-inner { display: block; }
	.programma-title { font-size: clamp(1.8rem, 7vw, 2.4rem); }
	.programma-tagline { font-size: 1rem; }
	.programma-praktisch, .programma-korting { padding: 1.5rem; }
	.programma-bewegen { padding: 1.5rem; }
	.praktisch-grid { grid-template-columns: 1fr; }
	.bewegen-grid { grid-template-columns: 1fr; }
	.programma-photo { margin-bottom: 1.5rem; }

	/* ===== PAGE CONTENT MOBILE ===== */
	.hsk-praktisch-grid { grid-template-columns: 1fr; gap: 0.85rem; }
	.hsk-praktisch-block { padding: 1.25rem 1.5rem; }
	.hsk-bewegen-block { padding: 1.5rem; }
	.hsk-bewegen-grid { grid-template-columns: 1fr; }
	.hsk-bewegen-block h2 { font-size: 1.3rem; }
	.hsk-section-title { font-size: 1.3rem; margin-top: 2rem; }
	.hsk-lead { font-size: 1.05rem; }
	.hsk-page-cta { padding: 2rem 1.5rem; }
	.hsk-prijs-card { padding: 2rem 1.5rem; }
	.hsk-prijs-card::before { font-size: 10rem; top: -1.5rem; }
	.hsk-contact-grid {
		grid-template-columns: 1fr;
		gap: 2rem;
	}
	.hsk-info-card { position: static; }
}

@media (max-width: 480px) {
	.btn-lg { font-size: 1rem; padding: 0.85em 1.5em; }
	.hero-actions { flex-direction: column; align-items: stretch; gap: 0.75rem; }
	.hero-actions .btn { justify-content: center; }

	/* Pills blijven 2x2 ook op heel kleine schermen */
	.hero-pills { grid-template-columns: repeat(2, 1fr); gap: 0.7rem; }
	.hero-pills li { font-size: 0.78rem; gap: 0.55rem; }
	.pill-icon { width: 36px; height: 36px; }

	/* Weken iets compacter */
	.week-card {
		grid-template-columns: 1fr auto;
		grid-template-areas:
			"title flag"
			"date  link";
		gap: 0.2rem 0.75rem;
		padding: 0.9rem 1rem;
	}
	.week-number { display: none; }
	.week-desc { display: none; }
	.week-title { font-size: 1.05rem; }

	.container { padding: 0 1rem; }
}

/* --------------------------------------------------------------------------
   18. UTILITIES
   -------------------------------------------------------------------------- */
.alignwide { max-width: 1100px; margin-left: auto; margin-right: auto; }
.alignfull {
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
}

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