/* Fiscale Wegwijs — tweakcn/shadcn Slate-thema (UTF-8, geen BOM)
 * Visuele vervanging Hypothesis-kleuren (Lato, #23b1ec).
 * Tokens in lijn met https://tweakcn.com (shadcn/ui Slate preset). */

:root {
	--background: #ffffff;
	--foreground: #0f172a;
	--card: #ffffff;
	--card-foreground: #0f172a;
	--primary: #1e3a5f;
	--primary-foreground: #f8fafc;
	--secondary: #f1f5f9;
	--secondary-foreground: #1e293b;
	--muted: #64748b;
	--muted-foreground: #64748b;
	--accent: #0f766e;
	--accent-foreground: #ffffff;
	--border: #e2e8f0;
	--input: #e2e8f0;
	--ring: #94a3b8;
	--radius: 0.625rem;
	--font-sans: "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
	--shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.06);
	--shadow-md: 0 4px 12px rgba(15, 23, 42, 0.08);
}

/* Typografie */
body,
input,
select,
textarea,
button {
	font-family: var(--font-sans) !important;
}

body {
	background-color: var(--background);
	color: var(--foreground);
	letter-spacing: -0.01em;
}

h1, h2, h3, h4, h5, h6 {
	font-weight: 600;
	letter-spacing: -0.02em;
	color: var(--foreground);
}

a {
	color: var(--primary);
	border-bottom-color: transparent;
}

a:hover {
	color: var(--accent) !important;
	border-bottom-color: var(--accent) !important;
}

/* Skip link (WCAG 2.4.1) */
.fw-skip-link {
	position: absolute;
	left: 0.75rem;
	top: -4rem;
	z-index: 10010;
	padding: 0.6rem 1rem;
	background: var(--card);
	color: var(--primary) !important;
	border: 2px solid var(--ring);
	border-radius: var(--radius);
	font-weight: 600;
	text-decoration: none;
	box-shadow: var(--shadow-md);
}

.fw-skip-link:focus {
	top: 0.75rem;
	outline: 0;
}

@media (prefers-reduced-motion: reduce) {
	.fw-nav,
	.fw-nav-toggle__bar,
	#banner.fw-banner .content.primary {
		transition: none !important;
		animation: none !important;
	}
}

/* Logo */
#header > .logo .fw-logo {
	display: flex;
	align-items: center;
	height: inherit;
	border: 0;
}

#header > .logo .fw-logo {
	padding: 0.25rem 0;
}

#header > .logo .fw-logo img {
	display: block;
	height: 2.5rem;
	width: auto;
	max-width: min(260px, 58vw);
	filter: none !important;
}

/* Logo leesbaar op hero: lichte achtergrond i.p.v. invert-filter */
#header.fw-header--alt:not(.fw-header--reveal) > .logo .fw-logo {
	display: inline-flex;
	align-items: center;
	padding: 0.4rem 0.85rem;
	margin: 0.2rem 0;
	background: rgba(255, 255, 255, 0.98);
	border-radius: var(--radius);
	box-shadow: 0 2px 18px rgba(15, 23, 42, 0.35);
	border: 1px solid rgba(255, 255, 255, 0.92);
}

#header.fw-header--alt:not(.fw-header--reveal) > .logo .fw-logo img {
	height: 2.15rem;
}

#header.fw-header--alt:not(.fw-header--reveal) {
	background-color: transparent !important;
	box-shadow: none !important;
	border-bottom: 0;
}

#header.fw-header--alt:not(.fw-header--reveal) .fw-nav__item > a,
#header.fw-header--alt:not(.fw-header--reveal) .fw-nav__parent,
#header.fw-header--alt:not(.fw-header--reveal) .fw-nav__subtoggle {
	color: rgba(255, 255, 255, 0.98) !important;
	box-shadow: none;
	text-shadow: 0 1px 10px rgba(15, 23, 42, 0.85), 0 0 2px rgba(15, 23, 42, 0.6);
}

#header.fw-header--alt:not(.fw-header--reveal) .fw-nav__item.is-current > a,
#header.fw-header--alt:not(.fw-header--reveal) .fw-nav__item.is-current > .fw-nav__row .fw-nav__parent {
	color: #ffffff !important;
	box-shadow: inset 0 -2px 0 #ffffff;
}

#header.fw-header--alt:not(.fw-header--reveal) .fw-nav-toggle__bar {
	background: #ffffff;
}

#header.fw-header--alt:not(.fw-header--reveal) .fw-nav__cta.button {
	background: #ffffff !important;
	color: var(--primary) !important;
}

#header.fw-header--alt:not(.fw-header--reveal) .fw-nav__cta.button:hover {
	background: var(--secondary) !important;
	color: var(--primary) !important;
}

#header.fw-header--reveal {
	background-color: rgba(255, 255, 255, 0.96) !important;
	box-shadow: var(--shadow-sm) !important;
}

@media screen and (max-width: 736px) {
	#header > .logo .fw-logo img {
		height: 1.85rem;
		max-width: 200px;
	}

	#banner.fw-banner .fw-banner__bg img,
	#banner.fw-banner .fw-banner__bg .fw-banner__bg-img {
		object-position: 30% 32%;
	}

	#banner.fw-banner .content.primary::before {
		right: -0.5rem;
		left: -0.75rem;
	}
}

/* Header & navigatie (fw-nav) */
#header {
	background-color: rgba(255, 255, 255, 0.92) !important;
	backdrop-filter: blur(10px);
	box-shadow: var(--shadow-sm) !important;
	border-bottom: 1px solid var(--border);
}

#header > .navPanelToggle {
	display: none !important;
}

.fw-nav-toggle {
	display: none;
	position: absolute;
	top: 0;
	right: 0;
	height: 3.25rem;
	width: 3.25rem;
	padding: 0;
	margin: 0;
	border: 0;
	background: transparent;
	cursor: pointer;
	z-index: 10001;
}

.fw-nav-toggle__bar {
	display: block;
	width: 1.25rem;
	height: 2px;
	margin: 5px auto;
	background: var(--primary);
	border-radius: 1px;
	transition: transform 0.2s ease, opacity 0.2s ease;
}

.fw-header--nav-open .fw-nav-toggle__bar:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}

.fw-header--nav-open .fw-nav-toggle__bar:nth-child(2) {
	opacity: 0;
}

.fw-header--nav-open .fw-nav-toggle__bar:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

.fw-nav-backdrop {
	position: fixed;
	inset: 0;
	z-index: 9998;
	background: rgba(15, 23, 42, 0.45);
}

.fw-nav {
	position: absolute;
	right: 0;
	top: 0;
	height: 3.25rem;
	display: flex;
	align-items: center;
}

.fw-nav__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	align-items: center;
	gap: 0.25rem;
}

.fw-nav__item {
	position: relative;
	margin: 0;
}

.fw-nav__item > a,
.fw-nav__parent {
	display: block;
	padding: 0 1rem;
	line-height: 3.25rem;
	color: var(--foreground);
	font-weight: 500;
	border-bottom: 0;
	white-space: nowrap;
}

.fw-nav__item > a:hover,
.fw-nav__parent:hover {
	color: var(--accent) !important;
}

.fw-nav__item > a:focus-visible,
.fw-nav__parent:focus-visible,
.fw-nav__sub a:focus-visible,
.fw-nav__subtoggle:focus-visible,
.fw-nav__cta:focus-visible,
.fw-nav-toggle:focus-visible {
	outline: 2px solid var(--ring);
	outline-offset: 2px;
}

.fw-nav__item.is-current > a,
.fw-nav__item.is-current > .fw-nav__row .fw-nav__parent {
	color: var(--primary);
	box-shadow: inset 0 -2px 0 var(--accent);
}

.fw-nav__row {
	display: flex;
	align-items: center;
}

.fw-nav__subtoggle {
	display: none;
	border: 0;
	background: transparent;
	padding: 0 0.5rem 0 0;
	line-height: 3.25rem;
	cursor: pointer;
	color: var(--muted);
	border-radius: var(--radius);
}

@media screen and (min-width: 981px) {
	.fw-nav__subtoggle {
		display: block;
	}

	.fw-nav__item--dropdown.is-open .fw-nav__subtoggle .icon:before {
		transform: rotate(180deg);
	}
}

.fw-nav__subtoggle .icon:before {
	margin: 0;
}

.fw-nav__sub {
	display: none;
	position: absolute;
	top: 100%;
	right: 0;
	min-width: 17rem;
	margin: 0;
	padding: 0.35rem 0;
	list-style: none;
	background: var(--card);
	border: 1px solid var(--border);
	border-radius: var(--radius);
	box-shadow: var(--shadow-md);
	z-index: 10002;
}

.fw-nav__item--dropdown.is-open > .fw-nav__sub {
	display: block;
}

.fw-nav__sub a {
	display: block;
	padding: 0.65rem 1rem;
	line-height: 1.35;
	border-bottom: 0;
	color: var(--foreground);
}

.fw-nav__sub a:hover {
	background: var(--secondary);
	color: var(--accent) !important;
}

.fw-nav__sub--overview a {
	border-bottom: 1px solid var(--border);
}

.fw-nav__sub-label {
	display: block;
	font-weight: 600;
}

.fw-nav__sub-desc {
	display: block;
	font-size: 0.8125rem;
	color: var(--muted);
	font-weight: 400;
	margin-top: 0.15rem;
}

.fw-nav__sub .is-current a {
	background: var(--secondary);
	color: var(--primary) !important;
}

.fw-nav__item--cta {
	margin-left: 0.35rem;
}

.fw-nav__cta.button {
	line-height: 2.25rem !important;
	height: 2.25rem;
	padding: 0 1.1rem !important;
	margin-top: 0.5rem;
	font-size: 0.875rem !important;
	border-bottom: 0 !important;
}

.fw-nav__cta.button:hover {
	color: var(--primary-foreground) !important;
}

@media screen and (min-width: 981px) and (max-width: 1180px) {
	.fw-nav__item > a,
	.fw-nav__parent {
		padding: 0 0.75rem;
		font-size: 0.9375rem;
	}

	.fw-nav__cta.button {
		padding: 0 0.9rem !important;
	}
}

@media screen and (max-width: 980px) {
	.fw-nav-toggle {
		display: block;
	}

	.fw-nav {
		position: fixed;
		top: 0;
		right: 0;
		width: min(100%, 20rem);
		height: 100vh;
		height: 100dvh;
		padding: 4rem 0 1.5rem;
		background: var(--card);
		border-left: 1px solid var(--border);
		box-shadow: var(--shadow-md);
		transform: translateX(100%);
		transition: transform 0.25s ease;
		z-index: 9999;
		overflow-y: auto;
		align-items: stretch;
	}

	.fw-header--nav-open .fw-nav {
		transform: translateX(0);
	}

	.fw-nav__list {
		flex-direction: column;
		align-items: stretch;
		gap: 0;
	}

	.fw-nav__item > a,
	.fw-nav__parent,
	.fw-nav__row .fw-nav__parent {
		line-height: 1.4;
		padding: 0.85rem 1.25rem;
		white-space: normal;
	}

	.fw-nav__item.is-current > a,
	.fw-nav__item.is-current > .fw-nav__row .fw-nav__parent {
		box-shadow: inset 3px 0 0 var(--accent);
		background: var(--secondary);
	}

	.fw-nav__row {
		width: 100%;
	}

	.fw-nav__subtoggle {
		display: block;
		margin-left: auto;
		line-height: 1;
		padding: 0.85rem 1rem;
	}

	.fw-nav__item--dropdown.is-open .fw-nav__subtoggle .icon:before {
		transform: rotate(180deg);
	}

	.fw-nav__sub {
		position: static;
		border: 0;
		border-radius: 0;
		box-shadow: none;
		background: var(--secondary);
		min-width: 0;
	}

	.fw-nav__sub a {
		padding-left: 1.75rem;
	}

	.fw-nav__item--cta {
		margin: 0.75rem 1.25rem 0;
	}

	.fw-nav__cta.button {
		display: block;
		text-align: center;
		width: 100%;
		margin-top: 0;
		line-height: 2.75rem !important;
		height: auto;
	}
}

@media screen and (max-width: 736px) {
	.fw-nav-toggle {
		height: 44px;
		width: 44px;
	}

	#header > .logo .fw-logo img {
		height: 1.85rem;
	}
}

/* Kenniscentrum-overzicht */
.fw-topic-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(16rem, 1fr));
	gap: 1.25rem;
	margin: 2rem 0;
}

.fw-topic-card {
	border: 1px solid var(--border);
	border-radius: var(--radius);
	padding: 1.25rem 1.35rem;
	background: var(--card);
	box-shadow: var(--shadow-sm);
}

.fw-topic-card h2 {
	font-size: 1.1rem;
	margin: 0 0 0.5rem;
}

.fw-topic-card h2 a {
	border-bottom: 0;
}

.fw-topic-card p {
	margin: 0 0 1rem;
	color: var(--muted);
	font-size: 0.9375rem;
}

.fw-topic-card .actions {
	margin: 0;
}

/* Knoppen */
.button,
button,
input[type="submit"],
input[type="reset"],
input[type="button"] {
	border-radius: var(--radius) !important;
	font-weight: 500 !important;
	transition: background-color 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
}

.button.primary,
input[type="submit"],
input[type="reset"],
button.primary,
#banner .content.primary .button.primary {
	background-color: var(--primary) !important;
	color: var(--primary-foreground) !important;
	box-shadow: var(--shadow-sm);
}

.button.primary:hover,
input[type="submit"]:hover,
input[type="reset"]:hover,
#banner .content.primary .button.primary:hover {
	background-color: #152a45 !important;
}

.button:hover {
	box-shadow: var(--shadow-sm);
}

.button:not(.primary) {
	box-shadow: inset 0 0 0 1px var(--border);
}

/* Sectiekoppen (was accent1 / cyaan) */
#wrapper > .main > header.accent1,
header.accent1 {
	background-color: var(--accent) !important;
	color: rgba(255, 255, 255, 0.9) !important;
}

#wrapper > .main > header.accent1 h1,
#wrapper > .main > header.accent1 h2,
#wrapper > .main > header.accent1 h3,
header.accent1 h1,
header.accent1 h2 {
	color: #ffffff !important;
}

#wrapper > .main > header.accent1 + .tabs > .titles,
#wrapper > .main > header.accent1 + .tabs > .titles:before {
	background-color: var(--primary) !important;
}

#wrapper > .main > header.accent1 + .tabs > .titles > .title.active {
	color: var(--primary) !important;
	background-color: #ffffff !important;
	border-radius: var(--radius) var(--radius) 0 0;
}

/* Sectie accent2 (was groen) */
#wrapper > .main > header.accent2,
#two.main.accent2,
.main.accent2 > header {
	background-color: var(--primary) !important;
	color: rgba(255, 255, 255, 0.88) !important;
}

#wrapper > .main > header.accent2 a {
	color: #a7f3d0 !important;
}

/* Banner (statische hero i.p.v. video) */
#banner video {
	display: none !important;
}

#banner.fw-banner .fw-banner__bg {
	position: fixed;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100vh;
	z-index: -2;
	overflow: hidden;
	pointer-events: none;
}

#banner.fw-banner .fw-banner__bg img,
#banner.fw-banner .fw-banner__bg .fw-banner__bg-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: 22% 38%;
}

#banner.fw-banner::after {
	position: fixed !important;
	top: 0 !important;
	left: 0 !important;
	width: 100vw !important;
	height: 100vh !important;
	z-index: -1 !important;
	opacity: 1 !important;
	background: linear-gradient(
		102deg,
		rgba(15, 23, 42, 0.93) 0%,
		rgba(15, 23, 42, 0.82) 32%,
		rgba(30, 58, 95, 0.68) 52%,
		rgba(15, 118, 110, 0.52) 72%,
		rgba(15, 23, 42, 0.45) 100%
	) !important;
}

#banner.fw-banner .content.primary {
	position: relative;
	z-index: 1;
}

#banner.fw-banner .content.primary::before {
	content: "";
	position: absolute;
	z-index: -1;
	top: -0.75rem;
	right: 5%;
	bottom: -0.75rem;
	left: -1.25rem;
	border-radius: calc(var(--radius) + 6px);
	background: linear-gradient(
		120deg,
		rgba(15, 23, 42, 0.62) 0%,
		rgba(15, 23, 42, 0.28) 100%
	);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
}

#banner.fw-banner .content.primary header h1,
#banner.fw-banner .content.primary header p {
	color: #ffffff !important;
	text-shadow: 0 2px 4px rgba(15, 23, 42, 0.9), 0 4px 32px rgba(0, 0, 0, 0.45);
}

#banner.fw-banner .content.primary header p {
	color: rgba(255, 255, 255, 0.92) !important;
}

#banner.fw-banner .content.primary .button.primary {
	background: #ffffff !important;
	color: var(--primary) !important;
	border: 0;
}

#banner.fw-banner .content.primary .button.primary:hover {
	background: var(--secondary) !important;
	color: var(--primary) !important;
}

#banner.fw-banner .content.primary .button:not(.primary) {
	color: #ffffff !important;
	background: transparent !important;
	box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.92) !important;
}

#banner.fw-banner .content.primary .button:not(.primary):hover {
	background: rgba(255, 255, 255, 0.12) !important;
	color: #ffffff !important;
}

#banner .content.secondary {
	background-color: rgba(255, 255, 255, 0.94) !important;
	backdrop-filter: blur(10px);
	border-top: 1px solid var(--border);
}

/* Afbeeldingen: volle breedte op grote schermen */
.image.main img,
#wrapper > .main > .inner > .content > .image.main img {
	width: 100% !important;
	height: auto;
	max-width: 100%;
	display: block;
}

.posts > div > article > .image img {
	width: 100% !important;
	height: auto;
	object-fit: cover;
	aspect-ratio: 4 / 3;
}

/* Tabs & spotlight */
.spotlight > .image img {
	border-radius: 50%;
	box-shadow: var(--shadow-md);
	object-fit: cover;
}

@media screen and (min-width: 981px) {
	.spotlight > .image img {
		width: 22rem !important;
		height: 22rem !important;
	}
}

@media screen and (min-width: 1680px) {
	.spotlight > .image img {
		width: 26rem !important;
		height: 26rem !important;
	}
}

.tabs > .panels > .panel {
	border-top: 1px solid var(--border);
}

/* Nieuws / posts */
.posts > div > article {
	border: 1px solid var(--border) !important;
	border-radius: var(--radius) !important;
	box-shadow: var(--shadow-sm) !important;
	overflow: hidden;
}

.posts > div > article > .content {
	background: var(--card);
}

.posts > div > article .meta,
.posts > div > article .fw-post-kicker,
.main.alt .content .fw-post-kicker {
	color: var(--muted);
	font-size: 0.9em;
	margin: 0 0 0.75em;
	letter-spacing: 0.02em;
}

.fw-content-disclaimer {
	color: var(--muted);
	font-size: 0.875rem;
	line-height: 1.5;
	margin: 1.5rem 0 0;
	padding-top: 1rem;
	border-top: 1px solid var(--border);
}

#three .fw-content-disclaimer {
	margin-top: 2rem;
}

/* Formulieren */
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="password"],
select,
textarea {
	border-radius: var(--radius) !important;
	border-color: var(--input) !important;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
select:focus,
textarea:focus {
	border-color: var(--ring) !important;
	box-shadow: 0 0 0 3px rgba(148, 163, 184, 0.35) !important;
}

input[type="checkbox"]:checked + label:before,
input[type="radio"]:checked + label:before {
	background-color: var(--primary) !important;
	border-color: var(--primary) !important;
}

/* Footer */
#footer.fw-footer {
	background: linear-gradient(180deg, var(--secondary) 0%, #e8edf2 100%) !important;
	border-top: 1px solid var(--border);
	padding: 0;
	color: var(--foreground);
}

#footer.fw-footer .inner {
	width: 68rem;
	max-width: calc(100% - 3rem);
}

.fw-footer__main {
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1.1fr;
	gap: 2.5rem 2rem;
	padding: 3.5rem 0 2.5rem;
	align-items: start;
}

.fw-footer--compact .fw-footer__main {
	grid-template-columns: 1fr auto;
	gap: 2rem;
	padding: 2.5rem 0 2rem;
}

.fw-footer__logo {
	display: inline-block;
	border-bottom: 0;
}

.fw-footer__logo img {
	display: block;
	height: 2.75rem;
	width: auto;
	max-width: 100%;
	filter: none !important;
}

.fw-footer__tagline {
	margin: 0.85rem 0 0;
	font-size: 0.9375rem;
	line-height: 1.55;
	color: var(--muted);
	max-width: 22rem;
}

.fw-footer__heading {
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--muted);
	margin: 0 0 1rem;
}

.fw-footer__links {
	list-style: none;
	margin: 0;
	padding: 0;
}

.fw-footer__links li {
	margin: 0;
	padding: 0;
}

.fw-footer__links a {
	display: block;
	padding: 0.35rem 0;
	border-bottom: 0;
	color: var(--foreground);
	font-size: 0.9375rem;
	font-weight: 500;
}

.fw-footer__links a:hover {
	color: var(--accent) !important;
	padding-left: 0.15rem;
}

.fw-footer__cta p {
	margin: 0 0 1rem;
	font-size: 0.9375rem;
	line-height: 1.5;
	color: var(--muted);
}

.fw-footer__cta .actions {
	margin: 0 0 0.75rem;
}

.fw-footer__email {
	margin: 0;
	font-size: 0.9375rem;
}

.fw-footer__email a {
	font-weight: 600;
	border-bottom: 0;
}

.fw-footer__bar {
	background: var(--primary);
	color: rgba(255, 255, 255, 0.85);
	padding: 0;
}

.fw-footer__bar-inner {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	gap: 0.5rem 1.5rem;
	padding: 1rem 0;
	font-size: 0.875rem;
}

.fw-footer__bar p {
	margin: 0;
	color: inherit;
}

.fw-footer__bar a {
	color: #ffffff;
	border-bottom: 0;
	font-weight: 500;
}

.fw-footer__bar a:hover {
	color: #a7f3d0 !important;
}

#footer.fw-footer > .copyright,
#footer.fw-footer .inner > section {
	display: none;
}

@media screen and (max-width: 980px) {
	.fw-footer__main {
		grid-template-columns: 1fr 1fr;
	}

	.fw-footer--compact .fw-footer__main {
		grid-template-columns: 1fr;
	}

	.fw-footer__brand {
		grid-column: 1 / -1;
	}
}

@media screen and (max-width: 736px) {
	.fw-footer__main,
	.fw-footer--compact .fw-footer__main {
		grid-template-columns: 1fr;
		gap: 1.75rem;
		padding: 2.5rem 0 1.75rem;
	}

	.fw-footer__bar-inner {
		flex-direction: column;
		align-items: flex-start;
	}
}

/* Contactformulier */
.fw-contact-form {
	max-width: 40rem;
	margin-top: 1.5rem;
}

.fw-contact-form label {
	display: block;
	font-weight: 600;
	margin: 0.75rem 0 0.35rem;
	color: var(--secondary-foreground);
}

.fw-contact-form input[type="text"],
.fw-contact-form input[type="email"],
.fw-contact-form input[type="tel"],
.fw-contact-form select,
.fw-contact-form textarea {
	width: 100%;
}

.fw-contact-form textarea {
	min-height: 9rem;
}

.fw-hp {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

.fw-form-msg {
	padding: 0.85rem 1rem;
	border-radius: var(--radius);
	margin: 1rem 0;
}

.fw-form-msg--ok {
	background: #ecfdf5;
	border: 1px solid #a7f3d0;
	color: #065f46;
}

.fw-form-msg--err {
	background: #fef2f2;
	border: 1px solid #fecaca;
	color: #991b1b;
}

/* Captcha */
.fw-captcha {
	margin: 1.5rem 0 0;
	padding: 1.1rem 1.15rem;
	border: 1px solid var(--border);
	border-radius: var(--radius);
	background: var(--secondary);
}

.fw-captcha__label {
	display: block;
	font-weight: 600;
	margin: 0 0 0.75rem;
	color: var(--secondary-foreground);
}

.fw-captcha__hint {
	margin: 0 0 0.5rem;
	font-size: 0.9375rem;
	color: var(--foreground);
}

.fw-captcha__desc {
	margin: 0.35rem 0 0;
	font-size: 0.8125rem;
	color: var(--muted);
}

.fw-captcha input[type="text"] {
	max-width: 6rem;
}

.fw-captcha .cf-turnstile {
	min-height: 65px;
}

.fw-required {
	color: var(--accent);
	font-weight: 700;
}

.fw-footer__sep {
	margin: 0 0.35rem;
	opacity: 0.65;
}

.fw-a11y-content h2 {
	margin-top: 1.75rem;
}

.fw-a11y-content h2:first-of-type {
	margin-top: 1.25rem;
}

.fw-a11y-content ul {
	margin: 0.75rem 0 1rem;
	padding-left: 1.35rem;
}

.fw-a11y-content li {
	margin-bottom: 0.35rem;
}

.fw-a11y-updated {
	margin-top: 1.5rem;
	color: var(--muted);
}

.fw-contact-form input[type="submit"]:disabled {
	opacity: 0.55;
	cursor: not-allowed;
}

/* Overige Hypothesis-accenten neutraliseren */
.icon.major:before {
	box-shadow: inset 0 0 0 2px var(--primary) !important;
	color: var(--primary) !important;
}

#wrapper > .main > header.accent1 .icon.major:before {
	box-shadow: inset 0 0 0 2px #ffffff !important;
	color: #ffffff !important;
}
