:root {
	--brand:       #991B1B;
	--brand-dark:  #7A1515;
	--brand-light: #fbeded;
	--cta:         #FDE68A;
	--cta-dark:    #F59E0B;
	--cta-text:    #1C1C1C;
	--ink:         #1A1A1A;
	--muted:       #555555;
	--line:        #dddddd;
	--soft:        #f7f7f7;
	--white:       #FFFFFF;
	--font-title:  Verdana, Geneva, Tahoma, sans-serif;
	--font-body:   Verdana, Geneva, Tahoma, sans-serif;
	--radius:      8px;
}

/* ---- Reset ---- */
*, *::before, *::after { box-sizing: border-box; }
html, body { overflow-x: hidden; margin: 0; }

body {
	font-family: var(--font-body);
	font-size: 17px;
	font-weight: 400;
	line-height: 1.65;
	color: var(--ink);
	background: var(--white);
}

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

a { color: var(--brand); }
a:hover { color: var(--brand-dark); }

h1, h2, h3, h4 {
	font-family: var(--font-title);
	font-weight: 700;
	line-height: 1.5;
	margin: 0 0 14px;
	color: var(--brand);
}
h1 { font-size: 2.4rem; }
h2 { font-size: 1.75rem; }
h3 { font-size: 1.2rem; }
h4 { font-size: 1.05rem; }

p { margin: 0 0 16px; }
p:last-child { margin-bottom: 0; }
ul, ol { margin: 0 0 16px; padding-left: 22px; }
li { margin-bottom: 7px; }
strong { font-weight: 700; }

/* ---- Skip link ---- */
.xsk9pa { position: absolute; left: -999px; top: 0; background: var(--brand); color: #fff; padding: 10px 16px; z-index: 200; text-decoration: none; }
.xsk9pa:focus { left: 8px; top: 8px; color: #fff; }

:focus-visible { outline: 3px solid var(--brand); outline-offset: 2px; }

/* ================================================================
   KNOPPEN
================================================================ */
.btn9xk {
	display: inline-block;
	font-family: var(--font-body);
	font-weight: 700;
	font-size: 1rem;
	text-decoration: none;
	border: 0;
	border-radius: var(--radius);
	padding: 14px 28px;
	cursor: pointer;
	transition: background-color .18s ease, color .18s ease;
	line-height: 1.3;
}
.btn9xk-cta { background: var(--cta); color: var(--cta-text); }
.btn9xk-cta:hover { background: var(--cta-dark); color: var(--cta-text); }
.btn9xk-outline {
	background: transparent;
	color: var(--brand);
	border: 2px solid var(--brand);
	padding: 12px 26px;
}
.btn9xk-outline:hover { background: var(--brand-light); }
.btn9xk-full { display: block; width: 100%; text-align: center; }

/* ================================================================
   HEADER
================================================================ */
.hdr7cq {
	position: relative;
	background: var(--white);
	border-bottom: 1px solid var(--line);
}
.hdr7cq-inner {
	max-width: 1180px;
	margin: 0 auto;
	padding: 14px 24px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
}
.hdr7cq-logo { display: inline-flex; flex-shrink: 1; min-width: 0; max-width: calc(100% - 60px); }
.hdr7cq-logo img { height: 52px; width: auto; max-width: 100%; object-fit: contain; object-position: left center; }
@media (max-width: 560px) { .hdr7cq-logo img { height: 36px; max-width: 220px; } }

.nav7md .nav-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	align-items: center;
	gap: 26px;
}
.nav7md .nav-list li { margin: 0; }
.nav7md a {
	text-decoration: none;
	color: var(--ink);
	font-size: 1rem;
	font-weight: 400;
	padding: 6px 0;
}
.nav7md a:hover { color: var(--brand); }
.nav7md .e26pz9une a,
.nav7md .menu-item-cta a {
	background: var(--brand);
	color: #fff;
	padding: 10px 20px;
	border-radius: var(--radius);
}
.nav7md .e26pz9une a:hover,
.nav7md .menu-item-cta a:hover { background: var(--brand-dark); color: #fff; }

/* Hamburger */
.nav-tog { display: none; }
.ham7btn {
	display: none;
	cursor: pointer;
	padding: 6px;
	background: transparent;
	border: 0;
}
.ham7btn span {
	display: block;
	width: 26px;
	height: 3px;
	background: var(--brand);
	border-radius: 2px;
	transition: transform .2s ease, opacity .2s ease;
}
.ham7btn span + span { margin-top: 5px; }

/* ================================================================
   HERO - form-droite (tekst links + bullets, formulier rechts)
================================================================ */
.hero9vz {
	position: relative;
	background-color: var(--brand-dark);
	background-image: url("img/hero.webp");
	background-size: cover;
	background-position: center;
}
.hero9vz::before {
	content: "";
	position: absolute;
	inset: 0;
	background: rgba(100, 8, 8, 0.78);
}
.hero9vz-inner {
	position: relative;
	max-width: 1180px;
	margin: 0 auto;
	padding: 64px 24px 72px;
	display: grid;
	grid-template-columns: 1.1fr 0.9fr;
	gap: 48px;
	align-items: start;
}
.hero9vz-copy { color: #f5f0f0; padding-top: 8px; }
.hero9vz-copy h1 {
	font-family: var(--font-title);
	color: #fff;
	font-size: 2.55rem;
	margin-bottom: 18px;
}
.hero9vz-sub {
	font-size: 1.15rem;
	color: #F0D8D8;
	margin-bottom: 26px;
}
.hero9vz-bullets { list-style: none; margin: 0; padding: 0; }
.hero9vz-bullets li {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	margin-bottom: 14px;
	color: #fff;
	font-size: 1.03rem;
}
.hero9vz-bullets svg { color: rgba(255,255,255,0.85); flex-shrink: 0; margin-top: 2px; }

/* Formulierkaart */
.form9kd {
	background: var(--white);
	border-radius: 10px;
	padding: 30px 28px 28px;
	border: 1px solid var(--line);
}
.form9kd-title {
	font-family: var(--font-title);
	font-size: 1.4rem;
	color: var(--brand);
	margin-bottom: 6px;
}
.form9kd-sub { font-size: 0.95rem; color: var(--muted); margin-bottom: 18px; }

.form9kd .frow2 {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 14px;
}
.fld9u { margin-bottom: 14px; }
.fld9u label {
	display: block;
	font-size: 0.88rem;
	font-weight: 700;
	color: var(--ink);
	margin-bottom: 5px;
}
.fld9u input {
	width: 100%;
	font-family: var(--font-body);
	font-size: 16px;
	padding: 11px 12px;
	border: 1.5px solid #cccccc;
	border-radius: 4px;
	background: #FAFAFA;
	color: var(--ink);
}
.fld9u input:focus {
	outline: none;
	border-color: var(--brand);
	box-shadow: 0 0 0 3px rgba(153, 27, 27, 0.18);
}
.fhoney { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }
.form9kd .btn9xk-full { margin-top: 6px; }
.form9kd-note { font-size: 0.8rem; color: #888; margin-top: 10px; margin-bottom: 0; }

.msg9ok { font-size: 0.95rem; padding: 12px 14px; border-radius: var(--radius); margin-bottom: 16px; }
.msg9ok-success { background: var(--brand-light); color: var(--brand-dark); border: 1px solid var(--line); }
.msg9ok-error   { background: var(--soft); color: var(--ink); border: 1px solid var(--line); }

/* ================================================================
   SECTIONS - layout
================================================================ */
.awrcua2y { background: var(--white); }

.sec9 { padding: 64px 0; }
.sec9-alt { background: var(--soft); }
.sec9-brand { background: var(--brand); }

.wrap9 { max-width: 1180px; margin: 0 auto; padding: 0 24px; }

.sec9-head { max-width: 780px; margin-bottom: 38px; }
.sec9-head.center { margin-left: auto; margin-right: auto; text-align: center; }
.sec9-head p { color: var(--muted); font-size: 1.07rem; }

/* force descendants sur fond brand */
.sec9-brand h2, .sec9-brand h3, .sec9-brand h4,
.sec9-brand p, .sec9-brand li, .sec9-brand span, .sec9-brand strong {
	color: #fff;
}
.sec9-brand .sec9-head p { color: rgba(255,255,255,0.82); }

/* ================================================================
   DIENSTENRASTER (services) - info-cards
================================================================ */
.srv9-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 24px;
}
.srv9-card {
	background: var(--white);
	border: 1.5px solid var(--line);
	border-top: 4px solid var(--brand);
	border-radius: var(--radius);
	padding: 26px 22px 24px;
	display: flex;
	flex-direction: column;
}
.srv9-icon {
	color: var(--brand);
	margin-bottom: 14px;
	line-height: 1;
}
.srv9-icon svg { width: 34px; height: 34px; }
.srv9-card h3 { margin-bottom: 8px; color: var(--brand); }
.srv9-card p { color: var(--muted); font-size: 0.97rem; margin-bottom: 0; }

/* ================================================================
   FAQ - <details>/<summary> natif
================================================================ */
.faq9-list { max-width: 860px; }
.faq9-item {
	border-bottom: 1px solid var(--line);
}
.faq9-item:first-child { border-top: 1px solid var(--line); }

.faq9-item summary {
	list-style: none;
	cursor: pointer;
	padding: 20px 0;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	font-family: var(--font-title);
	font-weight: 700;
	font-size: 1.08rem;
	color: var(--brand);
	user-select: none;
}
.faq9-item summary::-webkit-details-marker { display: none; }
.faq9-item summary::after {
	content: "";
	flex-shrink: 0;
	width: 22px;
	height: 22px;
	background: var(--brand);
	border-radius: 50%;
	-webkit-mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='white' d='M19 13H13v6h-2v-6H5v-2h6V5h2v6h6v2Z'/%3E%3C/svg%3E") center/16px no-repeat;
	mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='white' d='M19 13H13v6h-2v-6H5v-2h6V5h2v6h6v2Z'/%3E%3C/svg%3E") center/16px no-repeat;
	transition: transform .2s ease;
}
.faq9-item[open] summary::after {
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='white' d='M19 13H5v-2h14v2Z'/%3E%3C/svg%3E");
	mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='white' d='M19 13H5v-2h14v2Z'/%3E%3C/svg%3E");
}
.faq9-body {
	padding: 0 0 20px;
	color: var(--muted);
	font-size: 1rem;
	line-height: 1.7;
}

/* ================================================================
   ETAPES - visuele stappenlijst (bullets visuelles)
================================================================ */
.steps9-list {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 24px;
	counter-reset: step-counter;
}
.step9-item {
	background: var(--white);
	border: 1.5px solid var(--line);
	border-radius: var(--radius);
	padding: 28px 22px 24px;
	position: relative;
	counter-increment: step-counter;
}
.step9-num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	background: var(--brand);
	color: #fff;
	font-family: var(--font-title);
	font-size: 1.2rem;
	font-weight: 700;
	border-radius: 50%;
	margin-bottom: 16px;
}
.step9-item h3 { color: var(--brand); margin-bottom: 8px; }
.step9-item p { color: var(--muted); font-size: 0.97rem; margin-bottom: 0; }

/* ================================================================
   PRICING - kaarten
================================================================ */
.price9-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 24px;
}
.price9-card {
	background: var(--white);
	border: 1.5px solid var(--line);
	border-radius: var(--radius);
	overflow: hidden;
	display: flex;
	flex-direction: column;
}
.price9-card-head {
	background: var(--brand);
	color: #fff;
	padding: 20px 22px 18px;
}
.price9-card-head h3 {
	font-family: var(--font-title);
	font-size: 1.1rem;
	margin-bottom: 4px;
	color: #fff;
}
.price9-unit { font-size: 0.87rem; color: rgba(255,255,255,0.75); }
.price9-card-body { padding: 20px 22px 22px; flex: 1; display: flex; flex-direction: column; }
.price9-amount {
	font-family: var(--font-title);
	font-size: 2rem;
	font-weight: 700;
	color: var(--brand);
	margin-bottom: 4px;
}
.price9-note { font-size: 0.88rem; color: var(--muted); margin-bottom: 14px; }
.price9-features { list-style: none; padding: 0; margin: 0; }
.price9-features li {
	display: flex;
	align-items: flex-start;
	gap: 9px;
	font-size: 0.94rem;
	color: var(--ink);
	margin-bottom: 8px;
}
.price9-features li::before {
	content: "";
	flex-shrink: 0;
	width: 18px;
	height: 18px;
	margin-top: 2px;
	background: var(--brand);
	border-radius: 50%;
	-webkit-mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='white' d='m9.6 16.6-4.2-4.2 1.4-1.4 2.8 2.8 7.6-7.6 1.4 1.4-9 9Z'/%3E%3C/svg%3E") center/14px no-repeat;
	mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='white' d='m9.6 16.6-4.2-4.2 1.4-1.4 2.8 2.8 7.6-7.6 1.4 1.4-9 9Z'/%3E%3C/svg%3E") center/14px no-repeat;
}
.price9-disclaimer {
	font-size: 0.84rem;
	color: var(--muted);
	margin-top: 20px;
	text-align: center;
}

/* ================================================================
   CTA-BAND - encart centré fond clair
================================================================ */
.ctaband9 {
	background: var(--brand-light);
	border: 1.5px solid #FECACA;
	border-radius: var(--radius);
	padding: 44px 40px;
	text-align: center;
}
.ctaband9 h2 { color: var(--brand); margin-bottom: 12px; }
.ctaband9 p { color: var(--muted); font-size: 1.07rem; max-width: 560px; margin: 0 auto 24px; }

/* ================================================================
   PAGINA-INHOUD (the_content) - split-blokken, keuzehulp, etc.
================================================================ */

/* split text + media */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: 44px; align-items: center; }
.split-media img { border-radius: var(--radius); }

/* info-grid (services in content) */
.info-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 24px; }
.info-card {
	background: var(--white);
	border: 1.5px solid var(--line);
	border-top: 4px solid var(--brand);
	border-radius: var(--radius);
	padding: 24px 22px;
}
.card-icon { color: var(--brand); display: block; margin-bottom: 12px; }
.card-icon svg { width: 32px; height: 32px; }
.info-card h3 { color: var(--brand); margin-bottom: 8px; }
.info-card p { color: var(--muted); font-size: 0.96rem; margin-bottom: 0; }

/* choice-grid */
.choice-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(244px, 1fr)); gap: 22px; }
.choice-card {
	background: var(--white);
	border: 1.5px solid var(--line);
	border-top: 4px solid var(--cta-dark);
	border-radius: var(--radius);
	padding: 24px 22px;
}
.choice-card h3 { color: var(--brand); margin-bottom: 6px; }
.choice-for { color: var(--brand); font-weight: 700; font-size: 0.93rem; margin-bottom: 12px; }
.choice-card ul { padding-left: 20px; margin-bottom: 0; }
.choice-card li { color: var(--muted); font-size: 0.96rem; }

/* table-wrap */
.table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; border-radius: var(--radius); margin-bottom: 20px; }
.price-table {
	width: 100%;
	border-collapse: collapse;
	background: var(--white);
	min-width: 540px;
}
.price-table caption { caption-side: bottom; font-size: 0.84rem; color: var(--muted); padding-top: 10px; text-align: left; }
.price-table th, .price-table td { padding: 13px 16px; text-align: left; border-bottom: 1px solid var(--line); }
.price-table thead th { background: var(--brand); color: #fff; font-size: 0.95rem; }
.price-table tbody th { font-weight: 700; color: var(--ink); }
.price-table tbody tr:nth-child(even) { background: var(--soft); }
.price-cell { font-weight: 700; color: var(--brand); white-space: nowrap; }

/* steps (in content) */
.steps { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 22px; }
.step {
	background: var(--white);
	border: 1.5px solid var(--line);
	border-radius: var(--radius);
	padding: 26px 22px;
}
.step-num {
	display: inline-block;
	font-family: var(--font-title);
	font-size: 1.4rem;
	font-weight: 700;
	color: var(--brand);
	margin-bottom: 6px;
}
.step h3 { color: var(--brand); margin-bottom: 8px; }
.step p { color: var(--muted); font-size: 0.97rem; margin-bottom: 0; }

/* faq (in content) */
.faq { max-width: 860px; }
.faq-item { border-bottom: 1px solid var(--line); padding: 22px 0; }
.faq-item:first-child { padding-top: 0; }
.faq-item h3 { color: var(--brand); margin-bottom: 8px; }
.faq-item p { color: var(--muted); margin-bottom: 0; }

/* cta-band (in content) */
.cta-band {
	background: var(--brand-light);
	border: 1.5px solid #FECACA;
	border-radius: var(--radius);
	padding: 42px 38px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 28px;
	flex-wrap: wrap;
}
.cta-band h2 { color: var(--brand); margin-bottom: 6px; }
.cta-band-text { max-width: 600px; }
.cta-band p { color: var(--muted); margin-bottom: 0; font-size: 1.05rem; }
.btn-cta { background: var(--brand); color: #fff; border-radius: var(--radius); padding: 14px 28px; font-weight: 700; text-decoration: none; white-space: nowrap; }
.btn-cta:hover { background: var(--brand-dark); color: #fff; }

/* media-duo */
.media-duo { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.figure { margin: 0; }
.figure img { border-radius: var(--radius); }
.figure figcaption { font-size: 0.88rem; color: var(--muted); margin-top: 10px; }

/* check-list */
.check-list { list-style: none; padding: 0; margin: 0; }
.check-list li { display: flex; align-items: flex-start; gap: 11px; margin-bottom: 12px; color: var(--ink); }
.check-list svg { color: var(--brand); flex-shrink: 0; margin-top: 3px; }

/* section / content-wrap wrappers (used by the_content) */
.section { padding: 60px 0; }
.section-alt { background: var(--soft); }
.content-wrap { max-width: 1180px; margin: 0 auto; padding: 0 24px; }
.section-head { max-width: 780px; margin-bottom: 36px; }
.section-head p { color: var(--muted); font-size: 1.05rem; }
.geo-article .section-head h2 { color: var(--brand); }

/* lead paragraph in content */
.lead { font-size: 1.12rem; }

/* ================================================================
   FOOTER
================================================================ */
.ftr9 { background: var(--brand-dark); color: #E8D8D8; }
.ftr9-grid {
	max-width: 1180px;
	margin: 0 auto;
	padding: 52px 24px 38px;
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1.2fr;
	gap: 36px;
}
.ftr9-col p { color: #C9B4B4; font-size: 0.95rem; }
img.ftr9-logo {
	height: auto;
	width: 200px;
	max-width: 100%;
	margin-bottom: 14px;
	background: var(--white);
	border-radius: var(--radius);
	padding: 7px 10px;
}
.ftr9-label {
	display: block;
	font-family: var(--font-title);
	font-weight: 700;
	font-size: 1.05rem;
	color: #fff;
	margin-bottom: 14px;
}
.ftr9-list { list-style: none; padding: 0; margin: 0; }
.ftr9-list li { color: #C9B4B4; font-size: 0.94rem; padding: 5px 0; }
.ftr9-col .btn9xk-cta { margin-top: 8px; }

.ftr9-bar {
	border-top: 1px solid rgba(255,255,255,0.14);
	max-width: 1180px;
	margin: 0 auto;
	padding: 20px 24px 32px;
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.ftr9-bar span { color: #D4A0A0; font-size: 0.85rem; }

/* ================================================================
   MAILLAGE GEO-VL styles compat
================================================================ */
.geovl-maillage h2 { color: var(--brand); }
.geovl-list a { color: var(--brand); }
.geovl-list a:hover { color: var(--brand-dark); }

/* ================================================================
   RESPONSIVE
================================================================ */
@media (max-width: 980px) {
	.hero9vz-inner { grid-template-columns: 1fr; gap: 36px; }
	.split { grid-template-columns: 1fr; gap: 30px; }
	.split-media { order: -1; }
	.ftr9-grid { grid-template-columns: 1fr 1fr; gap: 28px; }
}

@media (max-width: 900px) {
	.ham7btn { display: block; }
	.nav7md {
		display: none;
		position: absolute;
		left: 0; right: 0; top: 100%;
		background: var(--white);
		border-bottom: 1px solid var(--line);
		box-shadow: 0 16px 28px rgba(0,0,0,0.1);
		z-index: 90;
	}
	.nav-tog:checked ~ .nav7md { display: block; }
	.nav7md .nav-list {
		flex-direction: column;
		align-items: stretch;
		gap: 0;
		padding: 8px 24px 18px;
	}
	.nav7md .nav-list li { border-bottom: 1px solid var(--line); }
	.nav7md .nav-list li:last-child { border-bottom: 0; }
	.nav7md a { display: block; padding: 14px 0; }
	.nav7md .e26pz9une a,
	.nav7md .menu-item-cta a { text-align: center; margin: 14px 0 4px; padding: 13px 20px; }
	.nav-tog:checked ~ .ham7btn span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
	.nav-tog:checked ~ .ham7btn span:nth-child(2) { opacity: 0; }
	.nav-tog:checked ~ .ham7btn span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }
}

@media (max-width: 680px) {
	body { font-size: 16px; }
	h1 { font-size: 1.75rem; }
	.hero9vz-copy h1 { font-size: 2rem; }
	h2 { font-size: 1.45rem; }
	.hero9vz-inner { padding: 42px 20px 48px; }
	.hdr7cq-inner { padding: 12px 20px; }
	.hdr7cq-logo img { height: 36px; max-width: 220px; }
	.wrap9 { padding: 0 20px; }
	.content-wrap { padding: 0 20px; }
	.sec9 { padding: 44px 0; }
	.section { padding: 44px 0; }
	.form9kd .frow2 { grid-template-columns: 1fr; gap: 0; }
	.media-duo { grid-template-columns: 1fr; }
	.ftr9-grid { grid-template-columns: 1fr; gap: 26px; }
	.ctaband9 { padding: 30px 22px; }
	.cta-band { padding: 30px 22px; flex-direction: column; }
	.form9kd { padding: 22px 18px; }
}


/* aps-post-content-fix : constrain AI-generated <section> children of main */
.awrcua2y > section,
.awrcua2y > p,
.awrcua2y > h2,
.awrcua2y > h3,
.awrcua2y > ul,
.awrcua2y > ol,
.awrcua2y > dl {
	max-width: 1180px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 24px;
	padding-right: 24px;
}
.awrcua2y > section {
	padding-top: 44px;
	padding-bottom: 44px;
}
.awrcua2y > section + section {
	border-top: 1px solid rgba(0,0,0,.08);
}
.awrcua2y > section h2 {
	margin-bottom: 18px;
}
.awrcua2y > section h3 {
	margin-top: 26px;
	margin-bottom: 10px;
}
.awrcua2y > section p {
	margin-bottom: 14px;
}
.awrcua2y > section ul,
.awrcua2y > section ol {
	padding-left: 22px;
	margin-bottom: 18px;
}
.awrcua2y > section ul li,
.awrcua2y > section ol li {
	margin-bottom: 6px;
}
.awrcua2y > section dl dt {
	font-weight: 700;
	margin-top: 14px;
}
.awrcua2y > section dl dd {
	margin: 0 0 12px;
	color: #5a6b72;
}
/* Geo maillage block sections */
.awrcua2y > .znw75gigx {
	padding-top: 32px;
	padding-bottom: 32px;
}
.awrcua2y > .znw75gigx + .znw75gigx {
	border-top: 1px solid rgba(0,0,0,.08);
}
.awrcua2y > .znw75gigx .im8mi3twj {
	max-width: 1180px;
	margin: 0 auto;
	padding: 0 24px;
}
.awrcua2y > .znw75gigx h2 {
	font-size: 1.4rem;
	margin-bottom: 16px;
}
.awrcua2y > .znw75gigx .t86qtl5z {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: 6px 22px;
	list-style: none;
	padding: 0;
	margin: 0;
}
.awrcua2y > .znw75gigx .t86qtl5z li {
	padding: 5px 0;
	border-bottom: 1px solid rgba(0,0,0,.06);
}
.awrcua2y > .znw75gigx .t86qtl5z a {
	color: inherit;
	text-decoration: none;
}
.awrcua2y > .znw75gigx .t86qtl5z .u9075zst {
	color: #5a6b72;
	font-size: .85em;
	margin-left: 6px;
}

/* spacing */
body.home .awrcua2y > *:first-child {
	margin-top: 24px;
}

/* === AW palette dark gray #1f2937 + CTA orange #f97316 === */

/* === Header fix: cap logo, force horizontal nav === */
header.hdr7cq { padding: 12px 0 !important; }
header.hdr7cq .hdr7cq-inner { display: flex !important; align-items: center !important; justify-content: space-between !important; max-width: 1200px; margin: 0 auto; padding: 0 24px; gap: 24px; }
header.hdr7cq .hdr7cq-logo img { max-height: 42px !important; width: auto !important; max-width: 240px !important; height: auto !important; }
header.hdr7cq .nav7md { display: flex !important; align-items: center !important; }
header.hdr7cq .nav7md ul, header.hdr7cq .nav-list { display: flex !important; gap: 22px !important; list-style: none !important; margin: 0 !important; padding: 0 !important; align-items: center !important; }
header.hdr7cq .nav7md a, header.hdr7cq .nav-list a { display: inline-block !important; text-decoration: none; color: #1f2937; font-weight: 500; padding: 6px 0; }
header.hdr7cq .ham7btn { display: none !important; }

/* === Enriched sections === */
.awrcua2y > .aw-sec {
  position: relative !important;
  width: 100vw !important;
  max-width: 100vw !important;
  margin-left: calc(-50vw + 50%) !important;
  margin-right: calc(-50vw + 50%) !important;
  padding: 72px 0 !important;
  border-top: 0 !important;
}
.awrcua2y > .aw-sec:nth-of-type(odd) { background: #f7f6f3; }
.awrcua2y > .aw-sec:nth-of-type(even) { background: #fff; }
.aw-wpr { max-width: 1180px; margin: 0 auto; padding: 0 24px; }
.aw-hd { text-align: center; margin: 0 auto 44px; max-width: 780px; }
.aw-hd h2 { font-size: 2rem; color: #1f2937; margin: 0 0 12px; }
.aw-hd p { font-size: 1.05rem; color: #4a5568; margin: 0; }

.aw-types-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 28px; }
.aw-tc { background: #fff; border: 1px solid #e5e5e5; border-radius: 10px; overflow: hidden; display: flex; flex-direction: column; box-shadow: 0 1px 3px rgba(0,0,0,.04); }
.aw-tc:hover { transform: translateY(-3px); box-shadow: 0 12px 28px rgba(31,41,55,.13); }
.aw-tc-img { height: 220px; background-size: cover; background-position: center; }
.aw-tc-bd { padding: 22px 24px 26px; flex: 1; }
.aw-tc-bd h3 { margin: 0 0 10px; font-size: 1.3rem; color: #1f2937; }
.aw-tc-bd p { margin: 0 0 16px; color: #4a5568; line-height: 1.6; }
.aw-tc-px { border-top: 1px solid #e5e5e5; padding-top: 12px; font-size: .95rem; color: #1f2937; }
.aw-tc-px strong { color: #f97316; font-size: 1.15rem; }

.aw-rail-list { list-style: none; margin: 0 auto; padding: 0; position: relative; max-width: 880px; }
.aw-rail-list::before { content: ''; position: absolute; left: 24px; top: 20px; bottom: 20px; width: 4px; background: linear-gradient(180deg, #f97316, #1f2937); border-radius: 2px; }
.aw-rail-list > li { position: relative; padding: 0 0 30px 70px; margin: 0; }
.aw-rail-num { position: absolute; left: 0; top: 0; width: 52px; height: 52px; border-radius: 50%; background: #fff; border: 3px solid #f97316; color: #1f2937; font-weight: 700; font-size: 1.4rem; display: flex; align-items: center; justify-content: center; }
.aw-rail-bd h3 { margin: 6px 0 8px; font-size: 1.18rem; color: #1f2937; }
.aw-rail-bd p { margin: 0; color: #4a5568; line-height: 1.6; }

.aw-mason-grid { display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: 180px; gap: 12px; }
.aw-mz { background-size: cover; background-position: center; border-radius: 8px; }
.aw-mz.wide { grid-column: span 2; }
.aw-mz.tall { grid-row: span 2; }

.aw-prijs-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 14px; }
.aw-pr-it { display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 28px; padding: 18px 24px; background: #fff; border: 1px solid #e5e5e5; border-radius: 8px; }
.aw-pr-lbl { font-weight: 600; color: #1f2937; font-size: 1.02rem; }
.aw-pr-dsc { color: #6b7280; font-size: .9rem; margin: 4px 0 10px; }
.aw-pr-bar { height: 8px; background: #f3f4f6; border-radius: 4px; overflow: hidden; }
.aw-pr-fill { height: 100%; background: linear-gradient(90deg, #f97316, #1f2937); }
.aw-pr-px { font-size: 1.55rem; font-weight: 700; color: #1f2937; text-align: right; display: flex; flex-direction: column; align-items: flex-end; line-height: 1.1; }
.aw-pr-px small { font-size: .68rem; color: #6b7280; font-weight: 400; margin-top: 2px; }
.aw-pr-note { margin: 24px auto 0; max-width: 820px; text-align: center; color: #6b7280; font-size: .92rem; }

.aw-split-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; }
.aw-split-img { height: 460px; background-size: cover; background-position: center; border-radius: 12px; box-shadow: 0 12px 32px rgba(31,41,55,.16); }
.aw-split-bd h2 { font-size: 2rem; color: #1f2937; margin: 0 0 22px; }
.aw-split-checks { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 14px; }
.aw-split-checks li { display: flex; align-items: flex-start; gap: 12px; color: #1f2937; line-height: 1.55; }
.aw-split-checks li svg { color: #f97316; flex-shrink: 0; margin-top: 2px; }
.aw-split-checks li strong { color: #1f2937; }

.aw-faq-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.aw-fq { background: #fff; border: 1px solid #e5e5e5; border-radius: 8px; padding: 22px 24px; }
.aw-fq h3 { margin: 0 0 10px; font-size: 1.08rem; color: #1f2937; }
.aw-fq p { margin: 0; color: #4a5568; line-height: 1.6; }

.awrcua2y > .aw-sec.aw-cta { background: #1f2937 !important; color: #fff !important; padding: 64px 0 !important; }
.aw-cta-in { display: grid; grid-template-columns: 1fr auto; gap: 32px; align-items: center; }
.aw-cta-in h2 { margin: 0 0 8px; color: #fff !important; font-size: 1.7rem; }
.aw-cta-in p { margin: 0; color: rgba(255,255,255,.92) !important; font-size: 1.02rem; }
.aw-cta-btn { display: inline-block; background: #f97316 !important; color: #fff !important; font-weight: 700; padding: 16px 28px; border-radius: 8px; text-decoration: none; }
.aw-cta-btn:hover { background: #fff !important; color: #f97316 !important; }

.aw-sec h2::before, .aw-sec h2::after, .aw-sec h3::before, .aw-sec h3::after,
.aw-sec p::before, .aw-sec p::after { content: none !important; display: none !important; }

@media (max-width: 900px) {
  .aw-types-grid, .aw-faq-grid, .aw-split-grid, .aw-cta-in { grid-template-columns: 1fr; }
  .aw-mason-grid { grid-template-columns: 1fr 1fr; }
  .aw-mz.wide, .aw-mz.tall { grid-column: auto; grid-row: auto; }
  .aw-split-img { height: 280px; }
  .aw-pr-it { grid-template-columns: 1fr; gap: 10px; }
}
/* AFB v40 "steel-rust" — slate steel #1F2937 + safety orange #EA580C */
:root{
  --afb-steel:#1F2937;
  --afb-rust:#EA580C;
  --afb-rust-dim:#C2410C;
  --afb-paper:#FAFAF9;
  --afb-line:#E7E5E4;
  --afb-mute:#57534E;
}
.awrcua2y{
  font-feature-settings:"ss01","cv11";
  color:#1C1917;
  line-height:1.72;
}
.awrcua2y > h2{
  position:relative;
  font-weight:800;
  letter-spacing:-.018em;
  color:var(--afb-steel);
  font-size:clamp(1.55rem,2.2vw,2rem);
  margin:3.2rem 0 1.2rem;
  padding-left:1.05rem;
  border-left:5px solid var(--afb-rust);
}
.awrcua2y > h3{
  font-weight:700;
  color:var(--afb-steel);
  font-size:1.22rem;
  margin:2.1rem 0 .7rem;
  padding-bottom:.32rem;
  border-bottom:1px dashed var(--afb-line);
}
.awrcua2y > p{
  margin:0 0 1.15rem;
  color:#292524;
  font-size:1.025rem;
}
.awrcua2y > p > strong{
  color:var(--afb-rust-dim);
  font-weight:700;
  background:linear-gradient(transparent 60%,rgba(234,88,12,.12) 60%);
  padding:0 .12em;
}
.awrcua2y > ul, .awrcua2y > ol{
  margin:0 0 1.4rem;
  padding:0 0 0 0;
  list-style:none;
}
.awrcua2y > ul > li, .awrcua2y > ol > li{
  position:relative;
  padding:.5rem 0 .5rem 2rem;
  border-bottom:1px solid var(--afb-line);
}
.awrcua2y > ul > li:last-child, .awrcua2y > ol > li:last-child{border-bottom:none}
.awrcua2y > ul > li::before{
  content:"";
  position:absolute;
  left:.35rem; top:1.05rem;
  width:9px; height:9px;
  background:var(--afb-rust);
  transform:rotate(45deg);
}
.awrcua2y > ol{counter-reset:afbn}
.awrcua2y > ol > li{counter-increment:afbn}
.awrcua2y > ol > li::before{
  content:counter(afbn,decimal-leading-zero);
  position:absolute;
  left:0; top:.55rem;
  font-weight:800;
  font-size:.85rem;
  color:var(--afb-rust);
  font-feature-settings:"tnum";
  letter-spacing:.04em;
}
.awrcua2y > table{
  width:100%;
  margin:1.6rem 0 2.1rem;
  border-collapse:collapse;
  background:var(--afb-paper);
  border:1px solid var(--afb-line);
  font-size:.96rem;
}
.awrcua2y > table thead{
  background:var(--afb-steel);
}
.awrcua2y > table thead th{
  color:#FAFAF9;
  font-weight:700;
  text-align:left;
  padding:.85rem 1rem;
  text-transform:uppercase;
  letter-spacing:.04em;
  font-size:.82rem;
}
.awrcua2y > table tbody td{
  padding:.85rem 1rem;
  border-top:1px solid var(--afb-line);
  vertical-align:top;
  color:#292524;
}
.awrcua2y > table tbody tr:nth-child(even){background:#F5F5F4}
.awrcua2y > table tbody td:first-child{
  font-weight:700;
  color:var(--afb-steel);
}
.awrcua2y blockquote{
  margin:1.6rem 0;
  padding:1.05rem 1.3rem;
  background:#FFF7ED;
  border-left:4px solid var(--afb-rust);
  color:#1C1917;
  font-style:italic;
}
.awrcua2y a:not([class]){
  color:var(--afb-rust-dim);
  text-decoration:none;
  border-bottom:2px solid rgba(234,88,12,.35);
  transition:border-color .2s;
}
.awrcua2y a:not([class]):hover{
  border-bottom-color:var(--afb-rust);
}
