/* ============================================================
   Skip link (toegankelijkheid)
   ============================================================ */
.bm-skip-link {
	position: absolute;
	left: -9999px;
	top: 0;
	z-index: 9999;
	padding: 12px 16px;
	background: var(--color-charcoal);
	color: var(--color-white);
	font-family: var(--font-body);
	font-size: 14px;
	font-weight: 500;
	text-decoration: none;
}

.bm-skip-link:focus {
	left: 8px;
	top: 8px;
}

/* ============================================================
   Header — sticky bovenaan tijdens scrollen
   ============================================================ */
.bm-header {
	background: rgba(26, 26, 26, 0.55);
	-webkit-backdrop-filter: saturate(160%) blur(14px);
	        backdrop-filter: saturate(160%) blur(14px);
	color: var(--color-white);
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
	position: sticky;
	top: 0;
	z-index: 100;
	box-shadow: 0 1px 0 rgba(0, 0, 0, 0.04);
}

/* Hero-secties beginnen direct onder de header — trek ze omhoog
   zodat de transparante header over de hero-afbeelding heen ligt. */
:root {
	--bm-header-h: clamp(64px, 8vw, 84px);
}
.bm-hero {
	margin-top: calc(-1 * var(--bm-header-h));
}

/* Zorg dat ankerlinks niet onder de sticky header verdwijnen */
html {
	scroll-padding-top: 88px;
}

.bm-header__inner {
	max-width: var(--container-max);
	margin-inline: auto;
	padding: clamp(0.875rem, 2vw, 1.125rem) var(--container-px);
	display: flex;
	align-items: center;
	gap: var(--gap-md);
}

.bm-header__brand {
	display: inline-flex;
	flex-direction: column;
	gap: 2px;
	margin-right: auto;
	color: var(--color-white);
	text-decoration: none;
	transition: color var(--duration) var(--ease);
}

.bm-header__brand:hover,
.bm-header__brand:focus-visible {
	color: var(--color-white);
	text-decoration: none;
}

.bm-header__brand-name {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: clamp(1.125rem, 1.6vw, 1.375rem);
	text-transform: uppercase;
	letter-spacing: var(--tracking-wide);
	line-height: 1;
}

.bm-header__brand-tagline {
	font-family: var(--font-italic);
	font-style: italic;
	font-weight: 400;
	font-size: 0.75rem;
	color: var(--color-accent-light);
	line-height: 1;
}

/* Logo-variant — vervangt de tekst-branding in de header.
   Twee lagen: links de blauwe tekst (origineel), rechts de helm in wit
   (zelfde PNG met invert-filter). Mask zorgt voor de splitsing op ~65%. */
.bm-header__brand--logo {
	flex-direction: row;
	align-items: center;
	gap: 0;
	padding: 4px 0;
}
.bm-header__logo-wrap {
	position: relative;
	display: block;
	height: clamp(36px, 4vw, 48px);
	aspect-ratio: 370 / 150;
	transition: opacity var(--duration) var(--ease);
}
.bm-header__logo {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: contain;
	display: block;
}
.bm-header__logo--text {
	/* volledige logo zichtbaar in blauw — geen masker */
}
.bm-header__logo--helmet {
	/* uitgeschakeld — gehele logo blijft blauw */
	display: none;
}
.bm-header__brand--logo:hover .bm-header__logo-wrap,
.bm-header__brand--logo:focus-visible .bm-header__logo-wrap {
	opacity: 0.85;
}

/* ============================================================
   Hoofdmenu (desktop)
   ============================================================ */
.bm-header__nav {
	display: flex;
	align-items: center;
	gap: var(--gap-lg);
}

.bm-menu {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: var(--gap-lg);
	align-items: center;
}

.bm-menu__item,
.bm-header__nav .menu-item {
	margin: 0;
}

.bm-menu__link,
.bm-header__nav .menu-item > a {
	display: inline-block;
	font-family: var(--font-display);
	font-weight: 500;
	font-size: 0.9375rem;
	text-transform: uppercase;
	letter-spacing: var(--tracking-wide);
	color: var(--color-white);
	text-decoration: none;
	padding: 6px 0;
	border-bottom: 2px solid transparent;
	transition: color var(--duration) var(--ease), border-color var(--duration) var(--ease);
}

.bm-menu__link:hover,
.bm-header__nav .menu-item > a:hover,
.bm-header__nav .menu-item.current-menu-item > a,
.bm-menu__item.is-current .bm-menu__link {
	color: var(--color-accent-light);
	border-bottom-color: var(--color-accent-light);
	text-decoration: none;
}

/* CTA-knop in header */
.bm-header__cta {
	display: inline-flex;
	align-items: center;
	padding: 10px 18px;
	background: var(--color-accent);
	color: var(--color-white);
	font-family: var(--font-body);
	font-weight: 500;
	font-size: 0.875rem;
	text-decoration: none;
	border-radius: var(--radius-sm);
	transition: background-color var(--duration) var(--ease);
}

.bm-header__cta:hover,
.bm-header__cta:focus-visible {
	background: var(--color-accent-dark);
	color: var(--color-white);
	text-decoration: none;
}

/* ============================================================
   Mobile toggle (hamburger)
   ============================================================ */
.bm-header__toggle {
	display: none;
	flex-direction: column;
	justify-content: space-between;
	width: 28px;
	height: 22px;
	padding: 0;
	background: transparent;
	border: 0;
	cursor: pointer;
	margin-left: auto;
}

.bm-header__toggle-bar {
	display: block;
	height: 2px;
	background: var(--color-white);
	border-radius: 2px;
	transition: transform var(--duration) var(--ease), opacity var(--duration) var(--ease);
}

.bm-header__toggle[aria-expanded="true"] .bm-header__toggle-bar:nth-child(1) {
	transform: translateY(10px) rotate(45deg);
}

.bm-header__toggle[aria-expanded="true"] .bm-header__toggle-bar:nth-child(2) {
	opacity: 0;
}

.bm-header__toggle[aria-expanded="true"] .bm-header__toggle-bar:nth-child(3) {
	transform: translateY(-10px) rotate(-45deg);
}

/* ============================================================
   Mobile (< 900px)
   ============================================================ */
@media (max-width: 899px) {
	.bm-header__toggle {
		display: flex;
	}

	.bm-header__nav {
		display: none;
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		flex-direction: column;
		align-items: stretch;
		gap: 0;
		padding: 0.25rem var(--container-px) 0.75rem;
		background: rgba(26, 26, 26, 0.92);
		-webkit-backdrop-filter: saturate(160%) blur(14px);
		        backdrop-filter: saturate(160%) blur(14px);
		border-top: 1px solid rgba(255, 255, 255, 0.06);
		box-shadow: 0 12px 28px rgba(0, 0, 0, 0.25);
	}

	.bm-header__nav.is-open {
		display: flex;
	}

	.bm-menu {
		flex-direction: column;
		align-items: stretch;
		gap: 0;
	}

	.bm-menu__link,
	.bm-header__nav .menu-item > a {
		display: block;
		padding: 12px 4px;
		font-size: 1rem;
		border-bottom: 1px solid rgba(255, 255, 255, 0.06);
		color: var(--color-white);
	}

	.bm-menu__item:last-child .bm-menu__link,
	.bm-header__nav .menu-item:last-child > a {
		border-bottom: 0;
	}

	.bm-menu__link:hover,
	.bm-header__nav .menu-item > a:hover,
	.bm-menu__link:active,
	.bm-header__nav .menu-item > a:active {
		color: var(--color-accent-light);
		background: transparent;
	}

	.bm-header__cta {
		margin-top: 0.75rem;
		justify-content: center;
		text-align: center;
		padding: 12px 16px;
	}
}

/* ============================================================
   Tap-highlight fix — kill de standaard roze/grijze flash bij
   touch op mobiel (Chrome Android, iOS Safari).
   ============================================================ */
* {
	-webkit-tap-highlight-color: transparent;
}
a, button, [role="button"], [tabindex] {
	-webkit-tap-highlight-color: transparent;
}

/* ============================================================
   Main
   ============================================================ */
.bm-main {
	min-height: 50vh;
	display: block;
}

/* ============================================================
   Footer
   ============================================================ */
.bm-footer {
	background: var(--color-charcoal);
	color: var(--color-white);
	margin-top: var(--section-py);
}

.bm-footer__inner {
	max-width: var(--container-max);
	margin-inline: auto;
	padding: clamp(2.5rem, 6vw, 4rem) var(--container-px) clamp(2rem, 4vw, 2.5rem);
	display: grid;
	grid-template-columns: 1.5fr 1fr 1fr;
	gap: var(--gap-xl);
}

@media (max-width: 899px) {
	.bm-footer__inner {
		grid-template-columns: 1fr;
		gap: var(--gap-lg);
	}
}

.bm-footer__col {
	min-width: 0;
}

/* Brand */
.bm-footer__brand {
	display: inline-flex;
	flex-direction: column;
	gap: 4px;
	color: var(--color-white);
	text-decoration: none;
	margin-bottom: 1rem;
}

.bm-footer__brand:hover,
.bm-footer__brand:focus-visible {
	color: var(--color-white);
	text-decoration: none;
}

.bm-footer__brand-name {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: 1.375rem;
	text-transform: uppercase;
	letter-spacing: var(--tracking-wide);
	line-height: 1;
}

.bm-footer__brand-tagline {
	font-family: var(--font-italic);
	font-style: italic;
	font-size: 0.875rem;
	color: var(--color-accent-light);
	line-height: 1;
}

.bm-footer__pitch {
	max-width: 32ch;
	font-size: 0.9375rem;
	color: rgba(255, 255, 255, 0.72);
	line-height: 1.55;
	margin: 0;
}

/* Eyebrow-style heading per kolom */
.bm-footer__heading {
	font-family: var(--font-body);
	font-size: 0.75rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: var(--tracking-widest);
	color: var(--color-accent-light);
	margin: 0 0 1rem;
}

/* Adres */
.bm-footer__address {
	display: flex;
	flex-direction: column;
	gap: 2px;
	font-style: normal;
	font-size: 0.9375rem;
	color: rgba(255, 255, 255, 0.85);
	margin-bottom: 1.25rem;
}

/* Openingstijden */
.bm-footer__hours {
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 4px;
	font-size: 0.9375rem;
	color: rgba(255, 255, 255, 0.85);
}

.bm-footer__hours > div {
	display: flex;
	gap: var(--gap-sm);
}

.bm-footer__hours dt {
	min-width: 5ch;
	color: rgba(255, 255, 255, 0.6);
	font-weight: 500;
}

.bm-footer__hours dd {
	margin: 0;
}

/* Contact */
.bm-footer__contact {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 12px;
	font-size: 0.9375rem;
}

.bm-footer__contact li {
	display: flex;
	align-items: center;
	gap: 10px;
	color: rgba(255, 255, 255, 0.85);
}

.bm-footer__contact li .bm-icon {
	color: var(--color-accent-light);
	flex-shrink: 0;
}

.bm-footer__contact a {
	color: rgba(255, 255, 255, 0.92);
	text-decoration: none;
	transition: color var(--duration) var(--ease);
}

.bm-footer__contact a:hover,
.bm-footer__contact a:focus-visible {
	color: var(--color-white);
	text-decoration: underline;
}

/* Onderbalk */
.bm-footer__bar {
	border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.bm-footer__bar-inner {
	max-width: var(--container-max);
	margin-inline: auto;
	padding: 1rem var(--container-px);
	display: flex;
	flex-wrap: wrap;
	gap: var(--gap-md);
	justify-content: space-between;
	align-items: center;
}

.bm-footer__copy {
	margin: 0;
	font-size: 0.8125rem;
	color: rgba(255, 255, 255, 0.5);
}

.bm-footer__menu {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: var(--gap-md);
}

.bm-footer__menu a {
	color: rgba(255, 255, 255, 0.7);
	font-size: 0.8125rem;
	text-decoration: none;
	transition: color var(--duration) var(--ease);
}

.bm-footer__menu a:hover,
.bm-footer__menu a:focus-visible {
	color: var(--color-white);
	text-decoration: underline;
}

/* Inline SVG-iconen */
.bm-icon {
	display: inline-block;
	flex-shrink: 0;
	vertical-align: middle;
}

/* Afgeronde Elementor image (via _css_classes "bm-rounded-image") */
.bm-rounded-image img {
	border-radius: var(--radius-md);
	display: block;
	width: 100%;
	height: auto;
}

/* Pull-quote — voor quote-blokken op /verhaal */
.bm-pull-quote .elementor-text-editor,
.bm-pull-quote {
	text-align: center;
}

.bm-pull-quote {
	max-width: 720px;
	margin: 0 auto;
}

.bm-pull-quote .elementor-text-editor {
	font-family: var(--font-italic);
	font-style: italic;
	font-size: clamp(1.375rem, 3vw, 1.75rem);
	line-height: 1.4;
	color: var(--color-charcoal);
	padding: clamp(2rem, 5vw, 2.5rem) clamp(1rem, 4vw, 2rem);
	border-top: 2px solid var(--color-accent);
	border-bottom: 2px solid var(--color-accent);
}

/* ============================================================
   Knoppen
   .bm-btn                    — base
   .bm-btn--primary           — blauw, op licht
   .bm-btn--secondary         — outline charcoal, op licht
   .bm-btn--inverse           — wit met blauwe tekst, op donker
   .bm-btn--sm / --lg         — alternatieve maten
   ============================================================ */
.bm-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 12px 24px;
	font-family: var(--font-body);
	font-size: 0.875rem;
	font-weight: 500;
	line-height: 1.2;
	text-decoration: none;
	background: transparent;
	border: 1px solid transparent;
	border-radius: var(--radius-sm);
	cursor: pointer;
	white-space: nowrap;
	transition:
		background-color var(--duration) var(--ease),
		color var(--duration) var(--ease),
		border-color var(--duration) var(--ease),
		transform var(--duration) var(--ease);
}

.bm-btn:hover,
.bm-btn:focus-visible {
	text-decoration: none;
}

.bm-btn:focus-visible {
	outline: 2px solid var(--color-accent);
	outline-offset: 2px;
}

.bm-btn:active {
	transform: translateY(1px);
}

.bm-btn .bm-icon {
	width: 16px;
	height: 16px;
}

/* Primary — huismerk blauw op licht */
.bm-btn--primary {
	background: var(--color-accent);
	color: var(--color-white);
	border-color: var(--color-accent);
}

.bm-btn--primary:hover,
.bm-btn--primary:focus-visible {
	background: var(--color-accent-dark);
	border-color: var(--color-accent-dark);
	color: var(--color-white);
}

/* Secondary — outline charcoal op licht */
.bm-btn--secondary {
	background: transparent;
	color: var(--color-charcoal);
	border-color: var(--color-charcoal);
}

.bm-btn--secondary:hover,
.bm-btn--secondary:focus-visible {
	background: var(--color-charcoal);
	color: var(--color-white);
	border-color: var(--color-charcoal);
}

/* Inverse — wit met blauwe tekst op donker */
.bm-btn--inverse {
	background: var(--color-white);
	color: var(--color-accent);
	border-color: var(--color-white);
}

.bm-btn--inverse:hover,
.bm-btn--inverse:focus-visible {
	background: var(--color-offwhite);
	color: var(--color-accent-dark);
	border-color: var(--color-offwhite);
}

/* Maten */
.bm-btn--sm {
	padding: 8px 16px;
	font-size: 0.8125rem;
}

.bm-btn--lg {
	padding: 14px 28px;
	font-size: 1rem;
}

/* Volledige breedte op mobiel als modifier toegevoegd is */
.bm-btn--block {
	display: flex;
	width: 100%;
}

/* ============================================================
   Elementor button overrides — laat Elementor's standaard
   button widget onze huismerk-stijl gebruiken.
   ============================================================ */
.elementor-button {
	font-family: var(--font-body);
	font-weight: 500;
	letter-spacing: 0;
	white-space: nowrap;
}

.elementor-button .elementor-button-text {
	white-space: nowrap;
}

.elementor-button.elementor-size-md,
.elementor-button.elementor-size-sm {
	border-radius: var(--radius-sm);
}
