/* Design tokens */
:root {
	--bg: #ffffff;
	--panel: #ffffff;
	--panel-2: #f7f9fc;
	--text: #1a1d25;
	--muted: #5d6470;
	--primary: #ebcb4f; /* goud */
	--accent: #bfc7d6; /* neutraal ipv paars */
	--radius: 18px;
	--shadow-1: 0 18px 42px rgba(0,0,0,.14);
	/* Layout safe areas */
	--navH: 64px; /* approx navbar height */
	--footerH: 56px; /* approx footer height */
	--safeV: calc(var(--navH) + var(--footerH) + 40px); /* extra breathing room */
}
* { box-sizing: border-box; }
html, body { height: 100%; }
body {
	margin: 0;
	font-family: 'Inter', system-ui, -apple-system, Segoe UI, Arial, sans-serif;
	color: var(--text);
	background: radial-gradient(1600px 1000px at 50% -25%, #ffffff 0%, #f3f5f8 30%, #e4e8ed 60%, #d5dbe2 85%, #c9d1da 100%);
	display: grid;
	grid-template-rows: auto 1fr auto;
}

/* Navbar */
.nav {
	position: sticky; top: 0; z-index: 20;
	display: flex; align-items: center; justify-content: space-between;
	padding: 14px 20px; gap: 14px;
	backdrop-filter: blur(10px);
	background: linear-gradient(135deg, #ffffff 0%, #eef2f7 50%, #d7dfeb 100%);
	border-bottom: 1px solid #d2d9e4;
}
.brand { display:flex; align-items:center; text-decoration:none; }
.brand__logo { display:block; height: 44px; width: auto; object-fit: contain; }
.nav__actions { display:flex; align-items:center; gap: 12px; flex-wrap: wrap; }
.nav__iconBtn { display:inline-flex; align-items:center; justify-content:center; width: 36px; height: 36px; border-radius: 999px; border: 1px solid #d4dae2; background: #f2f4f7; color: var(--text); text-decoration: none; box-shadow: 0 2px 6px rgba(0,0,0,.08); }
.nav__iconBtn:hover { background: #e9eef5; border-color: #c8d0dc; }
.nav__iconBtn svg { width: 18px; height: 18px; }
.nav__link { color: var(--text); opacity: .78; text-decoration: none; margin-left: 12px; font-weight: 500; }
.nav__link:hover { opacity: 1; }
.nav__link .icon { display:inline-block; vertical-align:middle; margin-right: 4px; color: var(--text); }

/* Stage en kaart full-height tussen nav en footer */
.stage { display: block; padding: 0; }
.map { position: relative; width: 100%; height: 100%; overflow: hidden; background: #f2f5f9; cursor: grab; touch-action: none; user-select: none; }
.map__hint {
	position: absolute; left: 50%; bottom: 72px; transform: translateX(-50%);
	display: inline-flex; align-items: center; gap: 8px;
	padding: 8px 12px; border-radius: 999px; color: #1a1d25;
	background:
		radial-gradient(120% 80% at 50% 0%, rgba(255,255,255,0.95) 0%, rgba(255,255,255,0.75) 40%, rgba(255,255,255,0) 70%),
		linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(242,246,252,1) 52%, rgba(223,229,239,1) 100%),
		linear-gradient(145deg, rgba(255,255,255,0) 0%, rgba(0,0,0,.08) 100%);
	border: 1px solid #d4dae2; box-shadow: 0 6px 16px rgba(0,0,0,.08);
	font-size: 14px; font-weight: 600;
	pointer-events: none; /* purely informational */
}
.map__hintIcon { font-size: 16px; opacity: .85; }
.map__hint.is-hidden { opacity: 0; visibility: hidden; transition: opacity .2s ease, visibility .2s ease; }
@media (max-width: 720px) {
	.map__hint { bottom: 64px; font-size: 13px; padding: 7px 10px; }
}
.map.is-panning { cursor: grabbing; }
.map *, .map__inner, .map__inner * { cursor: inherit; }
.map__inner { position: absolute; left: 0; top: 0; transform-origin: 0 0; }
.map__inner img { position: absolute; left: 0; top: 0; width: 100%; height: auto; display: block; }

/* Hotspots */
.hotspot { position: absolute; transform: translate(-50%, -100%); transform-origin: 50% 100%; }
.hotspot__btn {
	--bgc: rgba(255,255,255,.85);
	display: inline-flex; align-items: center; gap: 6px;
	padding: 11px 20px; border-radius: 999px;
	font-size: 19px; line-height: 1.13; letter-spacing: .12px; font-weight: 600;
	background:
		radial-gradient(120% 80% at 50% 0%, rgba(255,255,255,0.95) 0%, rgba(255,255,255,0.75) 40%, rgba(255,255,255,0) 70%),
		linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(242,246,252,1) 52%, rgba(223,229,239,1) 100%),
		linear-gradient(145deg, rgba(255,255,255,0) 0%, rgba(0,0,0,.10) 100%);
	color: var(--text);
	border: 1px solid #d4dae2;
	backdrop-filter: blur(6px) saturate(110%);
	cursor: pointer; text-decoration: none;
	box-shadow: 0 2px 6px rgba(0,0,0,.10);
	transition: box-shadow .16s ease, background .16s ease; /* avoid transform to prevent glitch with scale */
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
	transform: scale(var(--hsScale, calc(1 / var(--mapScale, 1))));
	transform-origin: 50% 100%;
	backface-visibility: hidden;
}
.hotspot__btn:hover {
	background:
		radial-gradient(120% 80% at 50% 0%, rgba(255,255,255,0.98) 0%, rgba(255,255,255,0.78) 40%, rgba(255,255,255,0) 70%),
		linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(240,244,250,1) 52%, rgba(214,220,231,1) 100%),
		linear-gradient(145deg, rgba(255,255,255,0) 0%, rgba(0,0,0,.14) 100%);
	/* subtle lift using shadow only to avoid transform stacking glitches */
	box-shadow: 0 4px 10px rgba(0,0,0,.14);
}
.hotspot__arrow { width: 8px; height: 8px; border: solid currentColor; border-width: 0 2px 2px 0; transform: rotate(-45deg); display: inline-block; }

/* Modal */
.modal { position: fixed; inset: 0; display: none; z-index: 1000; }
.modal[aria-hidden="false"] { display: grid; place-items: center; padding-top: calc(var(--navH) + 20px); padding-bottom: calc(var(--footerH) + 20px); }
.modal__backdrop { position: absolute; inset: 0; background: rgba(0,0,0,.7); backdrop-filter: blur(2px); }
.modal__dialog { position: relative; z-index: 1; max-width: 900px; width: calc(100% - 32px); margin: 0 auto; background: var(--panel); border-radius: var(--radius); border: 1px solid #d5dae2; box-shadow: var(--shadow-1); overflow: hidden; display: flex; flex-direction: column; max-height: calc(100vh - var(--safeV)); }
.modal__content { padding: 20px 18px 84px; background:
		radial-gradient(1400px 420px at 50% -120px, #ffffff 0%, #f3f6fa 40%, #e8edf4 70%, #dde4ee 100%),
		linear-gradient(180deg, rgba(0,0,0,.03), rgba(0,0,0,0));
	overflow: auto; }
/* Compact modal layout for Contact: fit without scrolling */
.modal.is-contact .modal__dialog { max-height: 86vh; }
.modal.is-contact .modal__content { padding: 10px 14px calc(var(--footerH) + 24px); }
.card--contact .card__title { font-size: 28px; margin: 0 0 2px; }
.card--contact .card__desc { margin: 0 0 6px; }
.card--contact .card__list { gap: 8px; }
.card--contact .contact-actions { display: flex; flex-direction: column; align-items: flex-start; gap: 10px; padding: 8px 0 4px; }
.card--contact .contact-actions .btn { display: inline-flex; align-items: center; gap: 10px; padding: 10px 16px; }
.card--contact .contact-actions .btn svg { width: 18px; height: 18px; }
.card--contact .contact-actions .btn .label { font-weight: 600; }
.card--contact .contact-form .form-row input,
.card--contact .contact-form .form-row textarea { padding: 10px 12px; }
.card--contact .form-actions { position: sticky; bottom: 0; display: flex; justify-content: flex-end; gap: 10px; padding-top: 6px; background: transparent; }

.section-sep { height: 1px; background: linear-gradient(90deg, rgba(207,214,226,0) 0%, rgba(207,214,226,1) 10%, rgba(207,214,226,1) 90%, rgba(207,214,226,0) 100%); border-radius: 1px; opacity: .9; animation: fadeLine .35s ease both; }
.section-sep:hover { opacity: 1; transition: opacity .2s ease; }
.section-sep:active { opacity: .95; }
.detail .section-sep { margin: 8px 0; }
.card--list .section-sep { margin: 6px 0; }

@keyframes fadeLine {
	0% { opacity: 0; }
	100% { opacity: .9; }
}

/* Card content */
.card { display: grid; gap: 16px; grid-template-columns: 1fr; }
.card__title { font-size: 40px; line-height: 1.12; margin: 0; letter-spacing: .06px; font-family: 'Inter', sans-serif; font-weight: 700; }
.card__desc { color: var(--muted); margin: 0 0 8px; }
.card__list { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
.card--list .card__list li + li { position: relative; padding-top: 12px; }
.card--list .card__list li + li::before {
	content: "";
	position: absolute; left: 0; right: 0; top: 0; height: 1px;
	background: linear-gradient(90deg,
		rgba(198, 207, 219, 0) 0%,
		rgba(198, 207, 219, 0.55) 12%,
		rgba(198, 207, 219, 0.85) 50%,
		rgba(198, 207, 219, 0.55) 88%,
		rgba(198, 207, 219, 0) 100%
	);
}
.card__link { position: relative; display: grid; gap: 6px; grid-template-columns: 1fr; padding: 22px 62px 22px 26px; min-height: 64px; border-radius: var(--radius);
	background:
		radial-gradient(140% 160% at 50% -80%, rgba(255,255,255,.85) 0%, rgba(255,255,255,.35) 70%),
		linear-gradient(180deg, rgba(255,255,255,.75) 0%, rgba(245,247,250,.55) 55%, rgba(236,240,245,.45) 100%),
		linear-gradient(145deg, rgba(255,255,255,.0) 0%, rgba(0,0,0,.06) 100%);
	backdrop-filter: blur(12px) saturate(110%);
	border: none;
	text-decoration: none; color: var(--text);
	box-shadow: 0 1px 0 rgba(255,255,255,.85) inset, 0 10px 24px -10px rgba(0,0,0,.18);
	cursor: pointer;
}
.card__link:hover {
	transform: translateY(-2px);
	box-shadow: 0 1px 0 rgba(255,255,255,.9) inset, 0 14px 30px -10px rgba(0,0,0,.22);
	transition: transform .16s ease, box-shadow .16s ease;
}
.card__link:active { transform: translateY(-1px); }
.card__link .chev { position: absolute; right: 18px; top: 50%; transform: translateY(-50%); width: 30px; height: 30px; display: flex; align-items: center; justify-content: center; border-radius: 50%; background: rgba(0,0,0,.06); color: #1a1d25; font-size: 16px; font-weight: 700; letter-spacing: -1px; box-shadow: 0 1px 2px rgba(0,0,0,.12); opacity: .85; transition: background .18s ease, box-shadow .18s ease; pointer-events: none; }
.card__link:hover .chev { background: rgba(0,0,0,.12); box-shadow: 0 3px 8px -2px rgba(0,0,0,.28); }

/* Chips & meta */
.chip { display: inline-flex; align-items: center; padding: 6px 10px; border-radius: 999px; font-weight: 600; font-size: 13px; color: #1a1d25; background: rgba(235,203,79,.96); }
.chip--ghost { background: #eef0f5; color: #37404a; font-weight: 500; }
.item-title { font-weight: 600; letter-spacing: .1px; }
.item-sub { color: var(--muted); font-size: 14px; }

/* Detail layout */
.detail__title { font-size: 48px; line-height: 1.06; margin: 6px 0 8px; letter-spacing: .06px; font-family: 'Inter', sans-serif; font-weight: 700; }
.detail__chips { display: flex; gap: 8px; flex-wrap: wrap; margin: 4px 0 10px; }
.detail-list { list-style: none; padding: 0; margin: 8px 0 12px; display: grid; gap: 6px; }
.detail-list li { position: relative; padding-left: 22px; }
.detail-list li::before {
	content: "";
	position: absolute; left: 0; top: 4px; width: 14px; height: 10px;
	background-image: url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='10' viewBox='0 0 14 10'%3E%3Cpath d='M1.2 5.6 L4.8 9 L12.8 1.4' fill='none' stroke='%231a1d25' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat; background-size: 14px 10px;
}
.meta { color: var(--muted); margin: 2px 0; }
.back-btn { display: inline-flex; align-items: center; gap: 8px; padding: 8px 12px; border-radius: 999px; border: 1px solid #d4dae2; background: #f2f4f7; color: var(--text); text-decoration: none; justify-self: start; width: max-content; white-space: nowrap; margin: 2px 0 6px; cursor: pointer; user-select: none; transition: background-color .15s ease, border-color .15s ease, box-shadow .15s ease, transform .15s ease; }
.back-btn:hover { background: #e9eef5; border-color: #c8d0dc; box-shadow: 0 1px 0 rgba(255,255,255,.9) inset, 0 6px 14px -8px rgba(0,0,0,.18); transform: translateY(-1px); }
.back-btn:active { transform: translateY(0); box-shadow: none; }

/* Contact form */
.contact-form { display: grid; gap: 12px; }
.form-row { display: grid; gap: 6px; }
.form-row label { font-weight: 600; font-size: 14px; color: #37404a; }
.form-row input, .form-row textarea {
	width: 100%;
	padding: 12px 14px;
	border-radius: 12px;
	border: 1px solid #d4dae2;
	background: #f7f9fc;
	color: var(--text);
	box-shadow: 0 1px 0 rgba(255,255,255,.85) inset;
}
.form-row input:focus, .form-row textarea:focus { outline: none; border-color: #b7c0cf; background: #ffffff; }
.form-actions { display: flex; align-items: center; gap: 10px; }
.form-status { font-size: 14px; color: var(--muted); }

/* Decorative keyboard strip */
.keyboard { position: absolute; left: 0; right: 0; bottom: 0; height: 60px; border-top: 1px solid #d9dee5; box-shadow: inset 0 6px 12px rgba(0,0,0,.08);
	background:
		url("data:image/svg+xml;utf8,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='168'%20height='60'%20viewBox='0%200%20168%2060'%3E%3Crect%20width='168'%20height='60'%20fill='%23ffffff'/%3E%3Cdefs%3E%3Cpattern%20id='whiteKeys'%20x='0'%20y='0'%20width='24'%20height='60'%20patternUnits='userSpaceOnUse'%3E%3Crect%20width='24'%20height='60'%20fill='%23ffffff'/%3E%3Crect%20x='23'%20width='1'%20height='60'%20fill='%23e3e7ed'/%3E%3C/pattern%3E%3C/defs%3E%3Crect%20y='0'%20width='168'%20height='60'%20fill='url(%23whiteKeys)'/%3E%3Cg%3E%3Crect%20x='18'%20y='0'%20width='12'%20height='34'%20fill='%231a1d25'%20rx='2'%20ry='2'/%3E%3Crect%20x='42'%20y='0'%20width='12'%20height='34'%20fill='%231a1d25'%20rx='2'%20ry='2'/%3E%3Crect%20x='96'%20y='0'%20width='12'%20height='34'%20fill='%231a1d25'%20rx='2'%20ry='2'/%3E%3Crect%20x='120'%20y='0'%20width='12'%20height='34'%20fill='%231a1d25'%20rx='2'%20ry='2'/%3E%3Crect%20x='144'%20y='0'%20width='12'%20height='34'%20fill='%231a1d25'%20rx='2'%20ry='2'/%3E%3C/g%3E%3C/svg%3E") left bottom / 168px 60px repeat-x,
		linear-gradient(180deg, #ffffff 0%, #f3f6f9 100%);
}
.keyboard::before { content: ""; position: absolute; inset: 0; border-bottom-left-radius: var(--radius); border-bottom-right-radius: var(--radius); }
.keyboard::after { content: ""; position: absolute; inset: 0; box-shadow: inset 0 -4px 8px rgba(0,0,0,.05); border-bottom-left-radius: var(--radius); border-bottom-right-radius: var(--radius); }

/* Buttons */
.btn { display: inline-flex; align-items: center; justify-content: center; padding: 10px 18px; border-radius: 999px; text-decoration: none; font-weight: 600; font-family: 'Inter', sans-serif; transition: box-shadow .16s ease, transform .1s ease-out, background .16s ease; }
.btn--primary {
	color: #1a1d25;
	border: 1px solid #d4dae2;
	background:
		radial-gradient(120% 80% at 50% 0%, rgba(255,255,255,0.95) 0%, rgba(255,255,255,0.75) 40%, rgba(255,255,255,0) 70%),
		linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(242,246,252,1) 52%, rgba(223,229,239,1) 100%),
		linear-gradient(145deg, rgba(255,255,255,0) 0%, rgba(0,0,0,.10) 100%);
	box-shadow: 0 6px 16px rgba(0,0,0,.08);
}
.btn--primary:hover {
	background:
		radial-gradient(120% 80% at 50% 0%, rgba(255,255,255,0.98) 0%, rgba(255,255,255,0.78) 40%, rgba(255,255,255,0) 70%),
		linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(240,244,250,1) 52%, rgba(214,220,231,1) 100%),
		linear-gradient(145deg, rgba(255,255,255,0) 0%, rgba(0,0,0,.14) 100%);
	box-shadow: 0 6px 14px rgba(0,0,0,.12);
	transform: translateY(-1px);
}
.btn--primary:active { transform: translateY(0); box-shadow: 0 4px 12px rgba(0,0,0,.08); }

/* CTA rij in detail: wachttijd links, knop rechts */
.detail__cta { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-top: 10px; padding-top: 6px; }
.detail__cta .meta { margin: 0; font-style: italic; color: var(--muted); }
.detail__cta .btn { margin-left: auto; }

/* Zorg dat zinnetje links blijft en knop rechts, ook bij smalle schermen */
@media (max-width: 640px) {
	.detail__cta { flex-wrap: wrap; }
	.detail__cta .meta { order: 1; width: auto; }
	.detail__cta .btn { order: 2; margin-left: auto; }
}

/* Transport: platte titels en tekst, met subtiele scheiding */
.card--transport .card__list li { padding: 8px 2px 14px; border-top: 1px solid #e5e9f0; }
.card--transport .card__list li:first-child { border-top: none; }
.card--transport .item-title { font-weight: 800; }
.card--transport .detail__chips { margin: 6px 0 8px; }

/* Footer */
.footer { position: relative; display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 10px 16px; border-top: 1px solid #cfd6e2; background: linear-gradient(135deg, #d6deea 0%, #eef2f7 50%, #ffffff 100%); backdrop-filter: blur(6px); }
.footer__left { display: grid; gap: 4px; }
.footer__left span { color: var(--muted); font-size: 13px; }
.footer__center { position: absolute; left: 50%; transform: translateX(-50%); text-align: center; }
.footer__hint { color: var(--muted); font-size: 13px; font-weight: 600; }
.footer__right { display: inline-flex; align-items: center; gap: 10px; margin-left: auto; }
.social__link { display: inline-flex; align-items: center; color: var(--text); text-decoration: none; }
.social__icon { width: 20px; height: 20px; opacity: .5; transition: opacity .2s ease; }
.social__link:hover .social__icon { opacity: .9; }

/* Lock page scroll when modal open */
body.no-scroll { overflow: hidden; }

/* Responsive */
@media (max-width: 720px) {
	/* Navbar compact: voeg veilige top-inset toe en iets meer ademruimte */
	.nav { padding: calc(12px + env(safe-area-inset-top, 0px)) 14px 12px; gap: 10px; flex-wrap: nowrap; align-items: center; justify-content: space-between; background: linear-gradient(180deg, #ffffff 0%, #eef2f7 60%, #cfd6e2 100%); }
	.brand { display:flex; align-items:center; justify-content:flex-start; width: auto; }
	.brand__logo { height: 36px; }
	.nav__actions { display:flex; align-items:center; gap: 8px; flex-wrap: nowrap; }
	.nav__iconBtn { width: 34px; height: 34px; }
	/* Maak afspraak-knop kleiner zodat tekst netjes past */
	.nav .btn { padding: 7px 12px; font-size: 15px; line-height: 1.1; white-space: nowrap; }

	/* Hotspots iets kleiner zodat ze minder overlappen */
	.hotspot__btn { font-size: 16px; padding: 10px 16px; }

	/* Modal dimensies */
	.modal__dialog { margin: 8vh auto 4vh; max-height: 78vh; }
	.detail__title { font-size: 38px; }
	.card__title { font-size: 30px; }
	.card__link { padding: 16px 56px 16px 18px; min-height: 56px; }

	/* Footer: compacter — minder verticale ruimte op mobile */
	.footer { padding: 6px 12px; flex-wrap: wrap; }
	.footer__left { display: none; }
	.footer__center { position: static; transform: none; width: 100%; order: 1; margin: 4px 0; }
	.footer__right { order: 2; margin-left: 0; width: 100%; justify-content: center; gap: 16px; }
	.social__icon { width: 22px; height: 22px; }
}
