/* =========================================================================
   Clairlieu — Le Diagnostic
   Esthétique clinique : papier crème · encre noire · accent phosphor lab
   Inter (corps, titres condensés UPPERCASE) · IBM Plex Mono (codes, données)
   ========================================================================= */

:root {
	/* Encre & papier */
	--c-paper:       #F2EFE6;
	--c-paper-soft:  #F8F6EE;
	--c-paper-warm:  #ECE8DC;
	--c-ink:         #0A0A0B;
	--c-ink-soft:    #2A2A2D;
	--c-ink-mute:    #6E6E73;
	--c-rule:        #0A0A0B;
	--c-rule-soft:   #C9C5B7;

	/* Signal — usage parcimonieux */
	--c-signal:      #D8FF3A;
	--c-signal-deep: #B6D81F;
	--c-alarm:       #FF3D1F;

	/* Typographie */
	--ff-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	--ff-mono: "IBM Plex Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;

	/* Géométrie */
	--container: 1380px;
	--container-narrow: 820px;
	--container-service: 1120px;
	--container-service-faq: 980px;
	--container-page: 1120px;
	--gutter: clamp(20px, 2.4vw, 32px);
	--rule-w: 1px;
	--rule-w-strong: 1.5px;

	--mono-xs: .68rem;
	--mono-sm: .76rem;
	--mono-md: .84rem;
}

:root[data-theme="dark"] {
	color-scheme: dark;

	--c-paper:       #10100D;
	--c-paper-soft:  #151510;
	--c-paper-warm:  #202016;
	--c-ink:         #F2EFE6;
	--c-ink-soft:    #D7D1C2;
	--c-ink-mute:    #9B9587;
	--c-rule:        #F2EFE6;
	--c-rule-soft:   #3E3A31;
	--c-signal:      #D8FF3A;
	--c-signal-deep: #B6D81F;
	--c-alarm:       #FF684F;
}

/* ---------- Reset léger ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
	margin: 0;
	font-family: var(--ff-sans);
	font-size: 16px;
	line-height: 1.55;
	color: var(--c-ink);
	background: var(--c-paper);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	font-feature-settings: "ss01", "cv11";
	transition: background .18s ease, color .18s ease;
}
img, svg { max-width: 100%; height: auto; display: block; }
.svc-icon path:not([fill]) { fill: currentColor; }
button { font: inherit; }
ul, ol { padding-left: 0; list-style: none; margin: 0; }
a { color: inherit; text-decoration: none; transition: color .18s ease, opacity .18s ease; }

/* ---------- Sélection ---------- */
::selection { background: var(--c-signal); color: var(--c-ink); }
:root[data-theme="dark"] ::selection { background: var(--c-signal); color: #0A0A0B; }

/* ---------- Headings ---------- */
h1, h2, h3, h4, h5 {
	font-family: var(--ff-sans);
	font-weight: 600;
	color: var(--c-ink);
	line-height: 1;
	letter-spacing: -0.025em;
	margin: 0;
	text-wrap: balance;
}
h1 {
	font-size: clamp(2.8rem, 8.4vw, 7.2rem);
	font-weight: 700;
	letter-spacing: -0.045em;
	line-height: .92;
	text-transform: uppercase;
}
h2 {
	font-size: clamp(1.6rem, 3.2vw, 2.6rem);
	font-weight: 600;
	letter-spacing: -0.03em;
	line-height: 1.02;
	text-transform: uppercase;
}
h3 {
	font-size: 1.05rem;
	font-weight: 600;
	letter-spacing: -0.01em;
	text-transform: uppercase;
}

p { margin: 0 0 1rem; max-width: 62ch; }
strong { font-weight: 600; }
em { font-style: normal; color: var(--c-ink-mute); border-bottom: 1px dotted var(--c-ink-mute); padding-bottom: 1px; }

/* ---------- Mono primitives ---------- */
.mono {
	font-family: var(--ff-mono);
	font-size: var(--mono-sm);
	letter-spacing: .02em;
	text-transform: uppercase;
}
.mono--xs { font-size: var(--mono-xs); }
.mono--md { font-size: var(--mono-md); }

.label {
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	font-weight: 500;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--c-ink);
}
.label--mute { color: var(--c-ink-mute); }
.label--signal { color: var(--c-ink); background: var(--c-signal); padding: 2px 6px; }

.numeral {
	font-family: var(--ff-mono);
	font-feature-settings: "tnum";
	letter-spacing: -.02em;
}

/* ---------- Layout ---------- */
.container {
	width: 100%;
	max-width: var(--container);
	margin: 0 auto;
	padding: 0 var(--gutter);
}
.container--narrow { max-width: var(--container-narrow); }
.container--service { max-width: var(--container-service); }
.container--service-faq { max-width: var(--container-service-faq); }
.container--page { max-width: var(--container-page); }

.section { padding: clamp(56px, 8vw, 120px) 0; position: relative; }
.section--service-body { padding-top: 0; }
.section--page-body { padding-top: 0; }
.section--ink {
	background: var(--c-ink);
	color: var(--c-paper);
}
.section--ink h1, .section--ink h2, .section--ink h3 { color: var(--c-paper); }
.section--ink .label { color: var(--c-paper); }
.section--ink .label--mute { color: rgba(242,239,230,.55); }

/* ---------- Règles horizontales (signature) ---------- */
.rule       { height: 0; border: 0; border-top: var(--rule-w-strong) solid var(--c-rule); margin: 0; }
.rule--soft { border-top-color: var(--c-rule-soft); border-top-width: var(--rule-w); }
.rule--ink  { border-top-color: var(--c-paper); }
.rule--dot  { border-top-style: dotted; border-top-width: 1.5px; }

/* ---------- Section header (numéroté §) ---------- */
.section-head {
	display: grid;
	grid-template-columns: 1fr auto;
	align-items: end;
	gap: 24px;
	padding: 16px 0 22px;
}
.section-head__chapter {
	font-family: var(--ff-mono);
	font-size: var(--mono-sm);
	letter-spacing: .14em;
	color: var(--c-ink-mute);
	text-transform: uppercase;
}
.section-head__chapter b { color: var(--c-ink); font-weight: 600; }
.section-head__title {
	max-width: 18ch;
}
.section-head__meta {
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .14em;
	color: var(--c-ink-mute);
	text-transform: uppercase;
	text-align: right;
	white-space: nowrap;
}
.section--ink .section-head__chapter,
.section--ink .section-head__meta { color: rgba(242,239,230,.6); }
.section--ink .section-head__chapter b { color: var(--c-paper); }

/* ---------- Boutons ---------- */
.btn {
	display: inline-flex;
	align-items: center;
	gap: .7rem;
	padding: 14px 22px;
	font-family: var(--ff-mono);
	font-size: var(--mono-md);
	font-weight: 500;
	letter-spacing: .12em;
	text-transform: uppercase;
	border: var(--rule-w-strong) solid var(--c-ink);
	background: transparent;
	color: var(--c-ink);
	cursor: pointer;
	transition: background .18s ease, color .18s ease, transform .18s ease;
	white-space: nowrap;
	border-radius: 0;
}
.btn:hover { background: var(--c-ink); color: var(--c-paper); }
.btn--signal { background: var(--c-signal); border-color: var(--c-ink); color: var(--c-ink); }
.btn--signal:hover { background: var(--c-ink); color: var(--c-signal); }
.btn--ink { background: var(--c-ink); color: var(--c-paper); }
.btn--ink:hover { background: var(--c-signal); color: var(--c-ink); border-color: var(--c-ink); }
.btn--ghost-on-ink { border-color: var(--c-paper); color: var(--c-paper); }
.btn--ghost-on-ink:hover { background: var(--c-paper); color: var(--c-ink); }
.btn::after {
	content: "→";
	font-family: var(--ff-sans);
	letter-spacing: 0;
	transition: transform .18s ease;
}
.btn:hover::after { transform: translateX(4px); }
.btn--lg { padding: 18px 28px; font-size: var(--mono-md); }
.btn--no-arrow::after { display: none; }

/* ---------- Skip / a11y ---------- */
.skip-link { position: absolute; left: -9999px; top: -9999px; }
.skip-link:focus {
	left: 16px; top: 16px; z-index: 1000;
	background: var(--c-ink); color: var(--c-paper);
	padding: 10px 14px; font-family: var(--ff-mono); font-size: var(--mono-sm);
}
.screen-reader-text { position: absolute !important; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); }

/* =========================================================================
   STATUS BAR — ticker permanent
   ========================================================================= */
.status-bar {
	background: var(--c-ink);
	color: var(--c-paper);
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .12em;
	text-transform: uppercase;
	border-bottom: 1px solid rgba(242,239,230,.15);
	overflow: hidden;
}
.status-bar__inner {
	display: flex;
	align-items: center;
	gap: 28px;
	padding: 9px 0;
	white-space: nowrap;
}
.status-bar__dot {
	width: 8px; height: 8px; border-radius: 50%;
	background: var(--c-signal);
	flex-shrink: 0;
}
.status-bar__item { display: inline-flex; align-items: center; gap: 10px; }
.status-bar__item b { color: var(--c-signal); font-weight: 500; }
.status-bar__sep { opacity: .25; }
.status-bar__contact {
	margin-left: auto;
	display: inline-flex;
	gap: 22px;
	flex-shrink: 0;
}
.status-bar__contact a:hover { color: var(--c-signal); }

/* =========================================================================
   HEADER / NAV
   ========================================================================= */
.site-header {
	position: sticky;
	top: 0; z-index: 60;
	background: var(--c-paper);
	border-bottom: var(--rule-w-strong) solid var(--c-ink);
}
.navbar__inner {
	display: grid;
	grid-template-columns: auto 1fr auto auto;
	align-items: center;
	gap: 14px 28px;
	padding: 18px 0;
}
.brand {
	display: inline-flex; align-items: center; gap: 12px;
	color: var(--c-ink);
}
.brand__mark {
	width: 38px; height: 38px;
	display: inline-flex; align-items: center; justify-content: center;
	border: var(--rule-w-strong) solid var(--c-ink);
	font-family: var(--ff-mono);
	font-size: 1.15rem; font-weight: 600;
	letter-spacing: -.04em;
}
.brand__mark--logo {
	width: auto;
	height: auto;
	border: 0;
	padding: 0;
	color: var(--c-ink);
}
.brand__mark--logo svg { display: block; }
.brand-logo__spark { fill: var(--c-ink); }
:root[data-theme="dark"] .brand-logo__spark { fill: var(--c-signal); }
.brand--footer .brand__mark--logo { color: var(--c-paper); }
.brand__name {
	font-family: var(--ff-sans);
	font-weight: 700;
	font-size: 1.15rem;
	letter-spacing: -.02em;
	text-transform: uppercase;
	line-height: 1;
	display: flex; flex-direction: column; gap: 4px;
}
.brand__name small {
	font-family: var(--ff-mono);
	font-weight: 400;
	font-size: var(--mono-xs);
	letter-spacing: .12em;
	color: var(--c-ink-mute);
	text-transform: uppercase;
}
.primary-nav { display: flex; align-items: center; justify-content: center; gap: 28px; }
.primary-nav ul {
	display: flex; gap: 28px; padding: 0; margin: 0;
	font-family: var(--ff-mono);
	font-size: var(--mono-sm);
	text-transform: uppercase;
	letter-spacing: .1em;
}
.primary-nav a {
	display: inline-flex; align-items: center; gap: 6px;
	padding: 6px 0;
	color: var(--c-ink);
	position: relative;
}
.primary-nav a::before {
	content: counter(navidx, decimal-leading-zero) "/";
	color: var(--c-ink-mute);
	font-weight: 400;
}
.primary-nav ul { counter-reset: navidx; }
.primary-nav li { counter-increment: navidx; }
.primary-nav a::after {
	content: ""; position: absolute; left: 0; right: 0; bottom: -2px;
	height: 1.5px; background: var(--c-ink);
	transform: scaleX(0); transform-origin: left;
	transition: transform .22s ease;
}
.primary-nav a:hover::after,
.primary-nav .current-menu-item > a::after { transform: scaleX(1); }
.nav-cta {
	background: var(--c-signal);
	border: var(--rule-w-strong) solid var(--c-ink);
	padding: 10px 16px;
	font-family: var(--ff-mono);
	font-size: var(--mono-sm);
	text-transform: uppercase;
	letter-spacing: .12em;
	color: var(--c-ink);
	white-space: nowrap;
	transition: background .18s ease, color .18s ease;
}
.nav-cta::before { display: none; }
.nav-cta::after  { display: none !important; }
.nav-cta:hover { background: var(--c-ink); color: var(--c-signal); }

.theme-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	padding: 0;
	border: var(--rule-w-strong) solid var(--c-ink);
	background: transparent;
	color: var(--c-ink);
	cursor: pointer;
	transition: background .18s ease, color .18s ease, border-color .18s ease;
}
.theme-toggle:hover {
	background: var(--c-ink);
	color: var(--c-paper);
}
.theme-toggle__icon {
	display: block;
	width: 20px;
	height: 20px;
	fill: none;
	stroke: currentColor;
	stroke-width: 2;
	stroke-linecap: round;
	stroke-linejoin: round;
	transform-origin: center;
	transition: transform .34s cubic-bezier(.16, 1, .3, 1);
}
.theme-toggle.is-switching .theme-toggle__icon {
	transform: scale(.86) rotate(-90deg);
}
.theme-toggle__moon,
.theme-toggle__sun {
	transform-box: fill-box;
	transform-origin: center;
	transition: opacity .24s ease, transform .36s cubic-bezier(.16, 1, .3, 1);
}
.theme-toggle__moon {
	opacity: 1;
	transform: rotate(0deg) scale(1);
}
.theme-toggle__sun {
	opacity: 0;
	transform: rotate(-90deg) scale(.55);
}
:root[data-theme="dark"] .theme-toggle {
	background: var(--c-signal);
	color: #0A0A0B;
	border-color: var(--c-signal);
}
:root[data-theme="dark"] .theme-toggle:hover {
	background: transparent;
	color: var(--c-ink);
	border-color: var(--c-ink);
}
:root[data-theme="dark"] .theme-toggle__moon {
	opacity: 0;
	transform: rotate(90deg) scale(.55);
}
:root[data-theme="dark"] .theme-toggle__sun {
	opacity: 1;
	transform: rotate(0deg) scale(1);
}

@supports (view-transition-name: root) {
	::view-transition-old(root),
	::view-transition-new(root) {
		animation: none;
		mix-blend-mode: normal;
	}
	::view-transition-old(root) { z-index: 0; }
	::view-transition-new(root) { z-index: 1; }
}

/* Mobile toggle */
.nav-toggle {
	display: none;
	background: transparent;
	border: var(--rule-w-strong) solid var(--c-ink);
	width: 44px; height: 44px;
	padding: 0;
	cursor: pointer;
	flex-direction: column; align-items: center; justify-content: center; gap: 5px;
}
.nav-toggle span {
	display: block; width: 18px; height: 1.5px; background: var(--c-ink);
	transition: transform .25s ease, opacity .25s ease;
}
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* =========================================================================
   IMAGES — traitement Diagnostic forcé sur toute image uploadée
   N&B + contraste + cadre + grain léger pour cohérence brand
   ========================================================================= */
.diagnostic-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	filter: grayscale(1) contrast(1.08) brightness(0.96);
}
.site-main img:not(.diagnostic-img):not(.no-filter) {
	filter: grayscale(1) contrast(1.05) brightness(0.97);
}

/* =========================================================================
   HERO
   ========================================================================= */
.hero {
	border-bottom: var(--rule-w-strong) solid var(--c-ink);
	padding: clamp(40px, 6vw, 72px) 0 clamp(40px, 6vw, 72px);
	position: relative;
	overflow: hidden;
}
.hero__meta {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 0;
	padding-bottom: 24px;
	border-bottom: 1px solid var(--c-rule-soft);
	margin-bottom: clamp(40px, 6vw, 72px);
}
.hero__meta-cell {
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
	padding-right: 16px;
}
.hero__meta-cell b {
	display: block;
	color: var(--c-ink);
	font-weight: 500;
	margin-top: 4px;
	font-size: var(--mono-sm);
}
.hero__main {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(22px, 3.2vw, 36px);
	align-items: end;
}
.hero__headline {
	display: grid;
	grid-template-columns: minmax(0, 1.18fr) minmax(340px, .82fr);
	gap: clamp(24px, 3.8vw, 54px);
	align-items: center;
}
.hero__title {
	font-size: clamp(3rem, 6.35vw, 5.65rem);
	line-height: .9;
	margin-bottom: 0;
}
.hero__title em {
	border: 0;
	color: var(--c-ink);
	background: var(--c-signal);
	display: inline-block;
	padding: 0 .12em .02em;
	line-height: .94;
}
.hero__row {
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: clamp(32px, 5vw, 80px);
	align-items: end;
	padding-top: clamp(32px, 4vw, 48px);
	padding-bottom: clamp(10px, 2vw, 24px);
	border-top: 1px solid var(--c-rule-soft);
}
.hero__lede {
	font-size: 1.12rem;
	color: var(--c-ink-soft);
	max-width: 56ch;
	margin: 0;
	line-height: 1.5;
}
.hero__lede strong { color: var(--c-ink); font-weight: 600; }
.hero__actions {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
	margin-top: clamp(14px, 1.8vw, 22px);
}
.hero__sigs {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 12px 24px;
	margin-top: 28px;
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
}
.hero__sigs li::before {
	content: "[✓]";
	color: var(--c-ink);
	margin-right: 8px;
}

/* Hero plate — bande image éditoriale */
.hero__plate {
	margin: 0;
	padding: 0;
}
.hero__plate-frame {
	position: relative;
	border: 1.5px solid var(--c-ink);
	background: var(--c-ink);
	aspect-ratio: 4 / 3;
	overflow: hidden;
}
.hero__plate-frame::before,
.hero__plate-frame::after {
	content: "";
	position: absolute;
	width: 14px;
	height: 14px;
	pointer-events: none;
	z-index: 2;
}
.hero__plate-frame::before {
	top: 8px; left: 8px;
	border-top: 1.5px solid var(--c-signal);
	border-left: 1.5px solid var(--c-signal);
}
.hero__plate-frame::after {
	bottom: 8px; right: 8px;
	border-bottom: 1.5px solid var(--c-signal);
	border-right: 1.5px solid var(--c-signal);
}
.hero__plate-empty {
	position: absolute; inset: 0;
	display: flex; flex-direction: column; align-items: center; justify-content: center;
	gap: 16px;
	background:
		repeating-linear-gradient(0deg,  transparent 0 39px, rgba(242,239,230,.06) 39px 40px),
		repeating-linear-gradient(90deg, transparent 0 39px, rgba(242,239,230,.06) 39px 40px),
		var(--c-ink);
	color: var(--c-paper);
	font-family: var(--ff-mono);
}
.hero__plate-empty-mark {
	font-size: clamp(2rem, 6vw, 4rem);
	font-weight: 600;
	letter-spacing: -0.02em;
	color: var(--c-signal);
}
.hero__plate-empty-label {
	font-size: var(--mono-xs);
	letter-spacing: .14em;
	text-transform: uppercase;
	color: rgba(242,239,230,.55);
	border: 1px dashed rgba(242,239,230,.4);
	padding: 6px 12px;
}
.hero__plate-caption {
	display: flex;
	justify-content: space-between;
	gap: 24px;
	flex-wrap: wrap;
	margin-top: 12px;
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
}

.hero::after {
	content: "";
	position: absolute;
	left: 0; right: 0; top: 0;
	height: 2px;
	background: var(--c-signal);
	pointer-events: none;
	opacity: .9;
}

/* =========================================================================
   RÉFÉRENTIEL (services) — table
   ========================================================================= */
.referentiel {
	border-top: var(--rule-w-strong) solid var(--c-ink);
	border-bottom: var(--rule-w-strong) solid var(--c-ink);
}
.ref-table { width: 100%; border-collapse: collapse; }
.ref-table thead th {
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	font-weight: 500;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
	text-align: left;
	padding: 14px 16px;
	border-bottom: 1px solid var(--c-rule-soft);
}
.ref-table thead th:last-child { text-align: right; }
.ref-row { border-bottom: 1px solid var(--c-rule-soft); transition: background .2s ease; }
.ref-row:hover { background: var(--c-paper-warm); }
.ref-row > td {
	padding: 26px 16px;
	vertical-align: top;
}
.ref-row__code {
	font-family: var(--ff-mono);
	font-size: var(--mono-sm);
	letter-spacing: .08em;
	color: var(--c-ink-mute);
	width: 90px;
}
.ref-row__icon {
	width: 68px;
	color: var(--c-ink);
	transition: color .2s ease, transform .25s ease;
}
.ref-row__icon .svc-icon {
	display: block;
	margin-top: -4px;
}
.ref-row:hover .ref-row__icon {
	color: var(--c-accent-deep, var(--c-ink));
	transform: translateX(2px);
}
.ref-row__title {
	font-size: clamp(1.4rem, 2vw, 1.85rem);
	font-weight: 700;
	letter-spacing: -.02em;
	text-transform: uppercase;
	line-height: 1;
	color: var(--c-ink);
	width: 28%;
}
.ref-row__desc {
	color: var(--c-ink-soft);
	font-size: .95rem;
	line-height: 1.45;
	max-width: 52ch;
}
.ref-row__delay {
	font-family: var(--ff-mono);
	font-size: var(--mono-sm);
	letter-spacing: .08em;
	color: var(--c-ink);
	text-align: right;
	white-space: nowrap;
	width: 1%;
}
.ref-row__delay b {
	display: inline-block;
	background: var(--c-signal);
	padding: 2px 8px;
	font-weight: 500;
}
.ref-row__link {
	display: inline-flex; align-items: center; gap: 6px;
	margin-top: 14px;
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--c-ink);
	border-bottom: 1.5px solid var(--c-ink);
	padding-bottom: 2px;
}
.ref-row__link::after { content: "→"; transition: transform .18s ease; font-family: var(--ff-sans); }
.ref-row:hover .ref-row__link::after { transform: translateX(4px); }

/* =========================================================================
   EDITORIAL — journal SEO
   ========================================================================= */
.editorial-section {
	border-bottom: var(--rule-w-strong) solid var(--c-ink);
}
.editorial-home {
	border-bottom: var(--rule-w-strong) solid var(--c-ink);
}
.editorial-cats {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: clamp(28px, 4vw, 48px);
}
.editorial-cat {
	display: inline-flex;
	align-items: center;
	min-height: 38px;
	padding: 8px 12px;
	border: 1px solid var(--c-rule-soft);
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--c-ink);
	background: transparent;
}
.editorial-cat:hover,
.editorial-cat--current,
.editorial-cat--cta {
	border-color: var(--c-ink);
	background: var(--c-signal);
}
.editorial-grid,
.editorial-intent-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	border-top: var(--rule-w-strong) solid var(--c-ink);
	border-left: 1px solid var(--c-rule-soft);
}
.editorial-card {
	min-height: 330px;
	padding: clamp(22px, 3vw, 30px);
	border-right: 1px solid var(--c-rule-soft);
	border-bottom: 1px solid var(--c-rule-soft);
	background: var(--c-paper);
	display: flex;
	flex-direction: column;
	align-items: flex-start;
}
.editorial-card:hover {
	background: var(--c-paper-warm);
}
.editorial-card__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 8px 14px;
	margin-bottom: 24px;
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
}
.editorial-card__meta a {
	color: var(--c-ink);
	border-bottom: 1px solid currentColor;
}
.editorial-card__title {
	font-size: clamp(1.35rem, 2vw, 1.95rem);
	line-height: 1;
	max-width: 16ch;
	margin-bottom: 18px;
}
.editorial-card__title a {
	color: inherit;
}
.editorial-card p {
	color: var(--c-ink-soft);
	line-height: 1.55;
	margin-bottom: 0;
}
.editorial-card .ref-row__link {
	margin-top: auto;
}
.editorial-home__link {
	margin: 28px 0 0;
}
.editorial-hero {
	padding-bottom: clamp(30px, 4vw, 48px);
}
.editorial-hero h1 {
	font-size: clamp(2.8rem, 5vw, 4.7rem);
	line-height: .96;
	max-width: min(1120px, calc(100vw - (var(--gutter) * 2)));
	margin: 0 auto 18px;
}
.editorial-hero .page-hero__meta {
	margin-bottom: 26px;
}
.editorial-hero .page-hero__lede {
	max-width: min(1120px, calc(100vw - (var(--gutter) * 2)));
	margin-left: auto;
	margin-right: auto;
	font-size: 1.04rem;
}
.editorial-single {
	padding-top: clamp(34px, 4.5vw, 68px);
}
.editorial-featured {
	max-width: min(1120px, calc(100vw - (var(--gutter) * 2)));
	margin: 0 auto clamp(26px, 3.8vw, 46px);
	border: var(--rule-w-strong) solid var(--c-ink);
	background: var(--c-paper);
}
.editorial-featured__img {
	display: block;
	width: 100%;
	aspect-ratio: 16 / 6;
	object-fit: cover;
	filter: grayscale(1) contrast(1.08);
}
.editorial-featured figcaption {
	display: flex;
	justify-content: space-between;
	gap: 16px;
	padding: 12px 14px;
	border-top: var(--rule-w-strong) solid var(--c-ink);
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
}
.editorial-body {
	display: grid;
	grid-template-columns: minmax(190px, 240px) minmax(0, 800px);
	gap: clamp(40px, 5vw, 80px);
	max-width: min(1120px, calc(100vw - (var(--gutter) * 2)));
	justify-content: space-between;
	align-items: start;
}
.editorial-copy {
	min-width: 0;
}
.editorial-rail {
	position: sticky;
	top: 120px;
	padding-top: 16px;
	border-top: var(--rule-w-strong) solid var(--c-ink);
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
}
.editorial-rail__label {
	color: var(--c-ink);
	margin-bottom: 18px;
}
.editorial-rail dl {
	display: grid;
	gap: 14px;
	margin: 0 0 24px;
}
.editorial-rail dt {
	margin-bottom: 4px;
	color: var(--c-ink-mute);
}
.editorial-rail dd {
	margin: 0;
	color: var(--c-ink);
	line-height: 1.35;
}
.editorial-rail__toc {
	display: grid;
	gap: 10px;
	padding-top: 18px;
	border-top: 1px solid var(--c-rule-soft);
}
.editorial-rail__toc div {
	color: var(--c-ink-mute);
}
.editorial-rail__toc a {
	color: var(--c-ink);
	line-height: 1.35;
}
.editorial-rail__toc a:hover {
	color: var(--c-ink);
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
}
.editorial-single .prose {
	font-size: 1.1rem;
	line-height: 1.74;
}
.editorial-cta {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 22px;
	align-items: center;
	margin-top: clamp(30px, 4vw, 44px);
	padding: clamp(20px, 3vw, 28px);
	border: 1px solid var(--c-rule-soft);
	background: color-mix(in srgb, var(--c-ink) 4%, transparent);
	color: var(--c-ink);
}
.editorial-cta h2 {
	color: var(--c-ink);
	font-size: clamp(1.25rem, 2vw, 1.65rem);
	margin-bottom: 8px;
}
.editorial-cta p {
	color: var(--c-ink-soft);
	font-size: .98rem;
	line-height: 1.5;
	margin: 0;
}
.editorial-cta__label {
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
	margin-bottom: 10px;
}

/* =========================================================================
   DATA PLATE — indicateurs sur fond noir
   ========================================================================= */
.data-plate { background: var(--c-ink); color: var(--c-paper); }
.data-plate__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	border-top: 1px solid rgba(242,239,230,.18);
	border-bottom: 1px solid rgba(242,239,230,.18);
}
.data-cell {
	padding: 56px 24px 48px;
	border-right: 1px solid rgba(242,239,230,.18);
	position: relative;
}
.data-cell:last-child { border-right: 0; }
.data-cell__num {
	font-family: var(--ff-mono);
	font-size: clamp(2.8rem, 6vw, 4.6rem);
	font-weight: 500;
	letter-spacing: -.04em;
	line-height: .9;
	color: var(--c-paper);
	margin-bottom: 18px;
	font-feature-settings: "tnum";
}
.data-cell__num em {
	color: var(--c-signal);
	border: 0;
	font-style: normal;
}
.data-cell__label {
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .14em;
	text-transform: uppercase;
	color: rgba(242,239,230,.6);
	max-width: 22ch;
	line-height: 1.4;
}
.data-cell__index {
	position: absolute;
	top: 16px; right: 16px;
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	color: rgba(242,239,230,.35);
	letter-spacing: .12em;
}

/* =========================================================================
   PROTOCOLE — timeline
   ========================================================================= */
.protocol-list {
	display: grid;
	grid-template-columns: 1fr;
	border-top: var(--rule-w-strong) solid var(--c-ink);
}
.protocol-row {
	display: grid;
	grid-template-columns: 110px 200px 1fr auto;
	gap: 32px;
	align-items: start;
	padding: 32px 0;
	border-bottom: 1px solid var(--c-rule-soft);
}
.protocol-row__t {
	font-family: var(--ff-mono);
	font-size: 1.4rem;
	letter-spacing: -.02em;
	color: var(--c-ink);
	font-weight: 500;
}
.protocol-row__title {
	font-size: 1.05rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: -.01em;
	color: var(--c-ink);
}
.protocol-row__desc {
	color: var(--c-ink-soft);
	font-size: .95rem;
	margin: 0;
	max-width: 56ch;
	line-height: 1.5;
}
.protocol-row__index {
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .12em;
	color: var(--c-ink-mute);
	white-space: nowrap;
}

/* =========================================================================
   PILIERS / RÉASSURANCE
   ========================================================================= */
.pillars {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	border-top: var(--rule-w-strong) solid var(--c-ink);
	border-bottom: var(--rule-w-strong) solid var(--c-ink);
}
.pillar {
	padding: 36px 32px 36px 0;
	border-right: 1px solid var(--c-rule-soft);
	border-bottom: 1px solid var(--c-rule-soft);
}
.pillar:nth-child(2n) { border-right: 0; padding-left: 32px; padding-right: 0; }
.pillar:nth-last-child(-n+2) { border-bottom: 0; }
.pillar__index {
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .14em;
	color: var(--c-ink-mute);
	text-transform: uppercase;
	margin-bottom: 12px;
	display: block;
}
.pillar h3 { margin: 0 0 8px; font-size: 1.1rem; }
.pillar p  { color: var(--c-ink-soft); font-size: .96rem; margin: 0; max-width: 50ch; }

/* =========================================================================
   ZONE — référentiel territorial
   ========================================================================= */
.zone-grid {
	display: grid;
	grid-template-columns: 1.1fr 1fr;
	gap: clamp(40px, 6vw, 96px);
	align-items: start;
}
.zone-list {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0;
	border-top: 1px solid rgba(242,239,230,.2);
}
.zone-list li {
	font-family: var(--ff-mono);
	font-size: var(--mono-md);
	letter-spacing: .06em;
	text-transform: uppercase;
	color: var(--c-paper);
	padding: 14px 16px;
	border-bottom: 1px solid rgba(242,239,230,.2);
	border-right: 1px solid rgba(242,239,230,.2);
	display: flex; justify-content: space-between; align-items: center;
}
.zone-list li:nth-child(2n) { border-right: 0; }
.zone-list li b { color: var(--c-signal); font-weight: 500; }
.zone-list li::after {
	content: "ACTIF";
	font-size: var(--mono-xs);
	letter-spacing: .14em;
	color: var(--c-signal);
}

/* =========================================================================
   REGISTRE — témoignages dossiers
   ========================================================================= */
.registre {
	border-top: var(--rule-w-strong) solid var(--c-ink);
}
.registre-list {
	display: grid;
	grid-template-columns: 1fr;
	border-bottom: var(--rule-w-strong) solid var(--c-ink);
}
.registre-entry {
	display: grid;
	grid-template-columns: 220px 1fr auto;
	gap: 32px;
	padding: 36px 0;
	border-bottom: 1px solid var(--c-rule-soft);
	align-items: start;
}
.registre-entry:last-child { border-bottom: 0; }
.registre-entry__head {
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .12em;
	color: var(--c-ink-mute);
	text-transform: uppercase;
	line-height: 1.6;
}
.registre-entry__head b { display: block; color: var(--c-ink); font-weight: 500; font-size: var(--mono-sm); margin-bottom: 4px; }
.registre-entry blockquote {
	margin: 0;
	font-size: 1.18rem;
	line-height: 1.4;
	color: var(--c-ink);
	letter-spacing: -.01em;
	max-width: 60ch;
	font-weight: 500;
}
.registre-entry blockquote::before { content: "« "; color: var(--c-ink-mute); }
.registre-entry blockquote::after  { content: " »"; color: var(--c-ink-mute); }
.registre-entry figcaption {
	margin-top: 14px;
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .12em;
	color: var(--c-ink-mute);
	text-transform: uppercase;
}
.registre-entry__status {
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .14em;
	background: var(--c-signal);
	color: var(--c-ink);
	padding: 4px 8px;
	white-space: nowrap;
	height: max-content;
}

/* =========================================================================
   CTA BAND — ouverture de dossier
   ========================================================================= */
.cta-band {
	background: var(--c-ink);
	color: var(--c-paper);
	border-top: var(--rule-w-strong) solid var(--c-ink);
	border-bottom: var(--rule-w-strong) solid var(--c-ink);
}
.cta-band__inner {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 48px;
	align-items: center;
	padding-top: clamp(48px, 6vw, 80px);
	padding-bottom: clamp(48px, 6vw, 80px);
}
.cta-band__head {
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .14em;
	color: var(--c-signal);
	text-transform: uppercase;
	margin-bottom: 18px;
}
.cta-band h2 {
	color: var(--c-paper);
	font-size: clamp(1.8rem, 4vw, 3.2rem);
	margin: 0 0 16px;
	max-width: 24ch;
	letter-spacing: -.03em;
}
.cta-band p { color: rgba(242,239,230,.7); margin: 0; max-width: 56ch; }
.cta-band__actions { display: flex; gap: 12px; flex-direction: column; }

/* =========================================================================
   FOOTER — imprimerie
   ========================================================================= */
.site-footer {
	background: var(--c-paper);
	color: var(--c-ink);
	padding-top: 64px;
	border-top: var(--rule-w-strong) solid var(--c-ink);
}
.site-footer__top {
	display: grid;
	grid-template-columns: 1.4fr repeat(3, 1fr);
	gap: 40px;
	padding-bottom: 56px;
	border-bottom: 1px solid var(--c-rule-soft);
}
.site-footer h4 {
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	font-weight: 500;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
	margin: 0 0 16px;
}
.footer-list { display: grid; gap: 8px; }
.footer-list a {
	font-family: var(--ff-mono);
	font-size: var(--mono-sm);
	letter-spacing: .04em;
	text-transform: uppercase;
	color: var(--c-ink);
	border-bottom: 1px solid transparent;
	padding-bottom: 1px;
	display: inline-block;
	width: max-content;
}
.footer-list a:hover { border-bottom-color: var(--c-ink); }
.footer-list--icons a {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	width: max-content;
}
.footer-list--icons .svc-icon {
	color: var(--c-ink-mute);
	flex-shrink: 0;
	transition: color .18s ease;
}
.footer-list--icons a:hover .svc-icon { color: var(--c-ink); }
.site-footer__bottom {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 24px;
	padding: 28px 0;
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
}
.site-footer__bottom b { color: var(--c-ink); font-weight: 500; }
.site-footer__mark {
	font-family: var(--ff-mono);
	font-weight: 600;
	letter-spacing: -.02em;
	font-size: 4rem;
	color: var(--c-ink);
	line-height: 1;
	padding: 32px 0 0;
	border-top: var(--rule-w-strong) solid var(--c-ink);
	display: flex; align-items: baseline; justify-content: space-between;
	flex-wrap: wrap; gap: 24px;
}
.site-footer__mark small {
	font-family: var(--ff-mono); font-size: var(--mono-xs);
	font-weight: 400;
	letter-spacing: .14em; text-transform: uppercase;
	color: var(--c-ink-mute);
}
.site-footer__logotype {
	display: inline-flex;
	align-items: center;
	gap: 18px;
	color: var(--c-ink);
}
.site-footer__logotype svg { flex-shrink: 0; }

/* =========================================================================
   PAGE HERO (intérieur)
   ========================================================================= */
.page-hero {
	padding: clamp(60px, 8vw, 110px) 0 clamp(40px, 5vw, 64px);
	border-bottom: var(--rule-w-strong) solid var(--c-ink);
}
.page-hero__meta {
	display: flex; gap: 48px; flex-wrap: wrap;
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
	margin-bottom: 32px;
	padding-bottom: 16px;
	border-bottom: 1px solid var(--c-rule-soft);
}
.page-hero__meta b { color: var(--c-ink); font-weight: 500; }
.page-hero h1 {
	font-size: clamp(2.4rem, 6vw, 5.4rem);
	margin-bottom: 24px;
}
.page-hero__lede {
	font-size: 1.18rem;
	color: var(--c-ink-soft);
	max-width: 64ch;
	line-height: 1.5;
}
.page-hero--service .page-hero__inner {
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: 64px;
	align-items: end;
}
.page-hero__media {
	margin: 0;
}
.page-hero__media-frame {
	position: relative;
	border: 1.5px solid var(--c-ink);
	aspect-ratio: 5 / 3;
	overflow: hidden;
	background: var(--c-paper-soft);
}
.page-hero__media-frame::before,
.page-hero__media-frame::after {
	content: "";
	position: absolute;
	width: 12px; height: 12px;
	pointer-events: none;
	z-index: 2;
}
.page-hero__media-frame::before {
	top: 8px; left: 8px;
	border-top: 1.5px solid var(--c-signal);
	border-left: 1.5px solid var(--c-signal);
}
.page-hero__media-frame::after {
	bottom: 8px; right: 8px;
	border-bottom: 1.5px solid var(--c-signal);
	border-right: 1.5px solid var(--c-signal);
}
.page-hero__media-caption {
	display: flex;
	justify-content: space-between;
	gap: 16px;
	flex-wrap: wrap;
	margin-top: 10px;
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
}
.page-hero__media img {
	width: 100%;
	height: 100%;
}
.page-hero__actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 32px; }

/* Planche schématique — gros pictogramme service en hero quand pas de thumbnail */
.page-hero__schema {
	margin: 0;
	border: 1.5px solid var(--c-ink);
	background:
		repeating-linear-gradient(0deg,  transparent 0 23px, var(--c-rule-soft) 23px 24px),
		repeating-linear-gradient(90deg, transparent 0 23px, var(--c-rule-soft) 23px 24px),
		var(--c-paper-soft);
	padding: 32px 24px;
	display: grid;
	place-items: center;
	min-height: 260px;
	position: relative;
	color: var(--c-ink);
}
.page-hero__schema .svc-icon {
	color: var(--c-ink);
	width: clamp(140px, 28vw, 240px);
	height: auto;
}
.page-hero__schema-caption {
	position: absolute;
	bottom: 12px; left: 16px; right: 16px;
	display: flex; justify-content: space-between;
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
	pointer-events: none;
}
.page-hero__schema::before {
	content: "";
	position: absolute;
	top: 12px; left: 12px;
	width: 12px; height: 12px;
	border-top: 1.5px solid var(--c-ink);
	border-left: 1.5px solid var(--c-ink);
}
.page-hero__schema::after {
	content: "";
	position: absolute;
	top: 12px; right: 12px;
	width: 12px; height: 12px;
	border-top: 1.5px solid var(--c-ink);
	border-right: 1.5px solid var(--c-ink);
}

/* =========================================================================
   PROSE
   ========================================================================= */
.prose {
	font-size: 1.02rem;
	line-height: 1.7;
	color: var(--c-ink);
}
.prose > * + * { margin-top: 1rem; }
.prose h2 { margin-top: 2.4rem; font-size: 1.8rem; }
.prose h3 { margin-top: 1.8rem; font-size: 1.15rem; }
.prose ul, .prose ol { padding-left: 1.4rem; list-style: disc; }
.prose ol { list-style: decimal; }
.prose li { margin-bottom: .35rem; }
.prose blockquote {
	border-left: 3px solid var(--c-ink);
	padding: .4rem 0 .4rem 1.4rem;
	color: var(--c-ink-soft);
	font-size: 1.15rem;
	font-style: italic;
}
.prose img {
	display: block;
	width: 100%;
	height: auto;
	border: var(--rule-w-strong) solid var(--c-ink);
	filter: grayscale(1) contrast(1.05);
}
.prose figure,
.prose .wp-caption {
	width: 100% !important;
	max-width: 100%;
	margin: 2rem 0;
}
.prose figcaption,
.prose .wp-caption-text {
	margin-top: 10px;
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
}
.prose .btn {
	max-width: 100%;
	white-space: normal;
	overflow-wrap: anywhere;
	text-align: left;
}
.prose strong { background: var(--c-signal); padding: 0 .15em; font-weight: 600; color: var(--c-ink); }

.checklist {
	display: grid; gap: 0;
	border-top: 1px solid var(--c-rule-soft);
	margin: 1.5rem 0;
}
.checklist li {
	font-family: var(--ff-mono);
	font-size: var(--mono-md);
	letter-spacing: .04em;
	text-transform: uppercase;
	padding: 14px 16px 14px 44px;
	border-bottom: 1px solid var(--c-rule-soft);
	position: relative;
	color: var(--c-ink);
}
.checklist li::before {
	content: "[✓]";
	position: absolute; left: 0; top: 14px;
	font-size: var(--mono-sm);
	color: var(--c-ink);
}
.price-hint {
	border: 1.5px solid var(--c-ink);
	padding: 18px 22px;
	font-family: var(--ff-mono);
	font-size: var(--mono-md);
	letter-spacing: .04em;
	text-transform: uppercase;
}
.price-hint strong { background: var(--c-signal); padding: 2px 6px; }

/* =========================================================================
   SERVICE — composants éditoriaux ACF
   ========================================================================= */
.service-editorial {
	border-bottom: var(--rule-w-strong) solid var(--c-ink);
}
.service-block {
	display: grid;
	grid-template-columns: 190px minmax(0, 1fr);
	gap: clamp(24px, 4vw, 56px);
	padding: clamp(30px, 5vw, 58px) 0;
	border-top: 1px solid var(--c-rule-soft);
}
.service-block:first-child { border-top: 0; }
.service-block__meta {
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
	padding-top: .28em;
}
.service-block__title {
	font-size: clamp(1.65rem, 3.2vw, 2.45rem);
	line-height: .98;
	margin-bottom: 18px;
	max-width: 15ch;
}
.service-block__intro {
	color: var(--c-ink-soft);
	font-size: 1.06rem;
	line-height: 1.55;
	margin-bottom: 22px;
	max-width: 62ch;
}
.service-block__body {
	font-size: 1.04rem;
	line-height: 1.72;
	color: var(--c-ink-soft);
	max-width: 76ch;
}
.service-block__body > * + * { margin-top: 1rem; }
.service-block__body strong,
.prose-lite strong {
	background: var(--c-signal);
	color: var(--c-ink);
	font-weight: 600;
	padding: 0 .16em;
}
.service-block__body--lead {
	font-size: clamp(1.16rem, 1.45vw, 1.38rem);
	line-height: 1.5;
	color: var(--c-ink);
	max-width: 60ch;
}
.service-block--lead {
	align-items: start;
	padding-top: clamp(36px, 5vw, 64px);
	padding-bottom: clamp(36px, 5vw, 64px);
}
.service-lead-card {
	position: relative;
	border: var(--rule-w-strong) solid var(--c-ink);
	background: var(--c-paper-soft);
	padding: clamp(24px, 3.5vw, 38px);
}
.service-lead-card::before {
	content: "";
	position: absolute;
	top: -1.5px;
	left: -1.5px;
	width: 72px;
	height: 6px;
	background: var(--c-signal);
	border-right: var(--rule-w-strong) solid var(--c-ink);
	border-bottom: var(--rule-w-strong) solid var(--c-ink);
}
.service-lead-card__label {
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
	margin-bottom: 16px;
}
.service-block--warning {
	background: var(--c-ink);
	color: var(--c-paper);
	margin-left: calc(-1 * clamp(22px, 4vw, 44px));
	margin-right: calc(-1 * clamp(22px, 4vw, 44px));
	padding-left: clamp(22px, 4vw, 44px);
	padding-right: clamp(22px, 4vw, 44px);
	border-top: 0;
}
.service-block--warning .service-block__meta,
.service-block--warning .service-block__body { color: rgba(242,239,230,.76); }
.service-block--warning .service-block__title { color: var(--c-paper); max-width: 15ch; }
.service-block--warning strong {
	background: var(--c-signal);
	color: var(--c-ink);
}
.service-steps {
	list-style: none;
	padding: 0;
	margin: 24px 0 0;
	border-top: 1.5px solid var(--c-ink);
}
.service-step {
	display: grid;
	grid-template-columns: 88px minmax(0, 1fr);
	gap: 22px;
	padding: 20px 0;
	border-bottom: 1px solid var(--c-rule-soft);
}
.service-step__num {
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--c-ink);
}
.service-step h3 {
	font-size: 1.1rem;
	margin-bottom: 5px;
}
.service-step p {
	color: var(--c-ink-soft);
	line-height: 1.58;
}
.service-audience-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 0;
	margin-top: 26px;
	border: 1.5px solid var(--c-ink);
}
.service-audience-card {
	padding: 20px;
	border-right: 1px solid var(--c-rule-soft);
	min-height: 160px;
}
.service-audience-card:last-child { border-right: 0; }
.service-audience-card h3 {
	font-size: 1rem;
	margin-bottom: 10px;
}
.service-audience-card p {
	color: var(--c-ink-soft);
	font-size: .95rem;
	line-height: 1.55;
}
.service-pricing-panel {
	border: var(--rule-w-strong) solid var(--c-ink);
	background: var(--c-signal);
	color: var(--c-ink);
	padding: clamp(22px, 4vw, 36px);
}
.service-pricing-panel .service-block__title { max-width: none; }
.service-pricing-panel .service-block__body {
	color: var(--c-ink);
	max-width: 62ch;
}
.service-pricing-panel strong {
	background: var(--c-ink);
	color: var(--c-signal);
	padding: 0 .16em;
}

/* =========================================================================
   PAGES — composants éditoriaux ACF
   ========================================================================= */
.page-editorial {
	border-bottom: var(--rule-w-strong) solid var(--c-ink);
}
.page-block {
	display: grid;
	grid-template-columns: 190px minmax(0, 1fr);
	gap: clamp(24px, 4vw, 56px);
	padding: clamp(36px, 5vw, 64px) 0;
	border-top: 1px solid var(--c-rule-soft);
}
.page-block:first-child { border-top: 0; }
.page-block__meta {
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
	padding-top: .28em;
}
.page-block__title {
	font-size: clamp(1.65rem, 3.2vw, 2.45rem);
	line-height: .98;
	margin-bottom: 18px;
	max-width: 16ch;
}
.page-block__body {
	font-size: 1.04rem;
	line-height: 1.72;
	color: var(--c-ink-soft);
	max-width: 76ch;
}
.page-block__body > * + * { margin-top: 1rem; }
.page-block__body strong {
	background: var(--c-signal);
	color: var(--c-ink);
	font-weight: 600;
	padding: 0 .16em;
}
.page-block__body--lead {
	font-size: clamp(1.16rem, 1.45vw, 1.38rem);
	line-height: 1.5;
	color: var(--c-ink);
	max-width: 60ch;
}
.page-lead-card {
	position: relative;
	border: var(--rule-w-strong) solid var(--c-ink);
	background: var(--c-paper-soft);
	padding: clamp(24px, 3.5vw, 38px);
}
.page-lead-card::before {
	content: "";
	position: absolute;
	top: -1.5px;
	left: -1.5px;
	width: 72px;
	height: 6px;
	background: var(--c-signal);
	border-right: var(--rule-w-strong) solid var(--c-ink);
	border-bottom: var(--rule-w-strong) solid var(--c-ink);
}
.page-lead-card__label {
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
	margin-bottom: 16px;
}
.page-map-panel {
	margin-top: 26px;
}
.page-card-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 0;
	margin-top: 26px;
	border: var(--rule-w-strong) solid var(--c-ink);
}
.page-card {
	padding: 24px;
	min-height: 170px;
	border-right: 1px solid var(--c-rule-soft);
	border-bottom: 1px solid var(--c-rule-soft);
}
.page-card:nth-child(2n) { border-right: 0; }
.page-card:nth-last-child(-n+2) { border-bottom: 0; }
.page-card h3 {
	font-size: 1.05rem;
	margin-bottom: 10px;
}
.page-card p {
	color: var(--c-ink-soft);
	font-size: .96rem;
	line-height: 1.58;
	margin: 0;
}

/* =========================================================================
   CONTACT
   ========================================================================= */
.contact-grid {
	display: grid;
	grid-template-columns: minmax(280px, .9fr) minmax(0, 1.6fr);
	gap: clamp(32px, 4vw, 64px);
	align-items: start;
}
.contact-aside {
	font-family: var(--ff-mono);
	font-size: var(--mono-md);
	letter-spacing: .04em;
	text-transform: uppercase;
}
.contact-aside h2 {
	font-family: var(--ff-sans);
	font-size: clamp(1.25rem, 2vw, 1.6rem);
	line-height: 1.05;
	margin: 0 0 24px;
	text-transform: uppercase;
}
.contact-aside dl { display: grid; gap: 28px; margin: 0; }
.contact-aside dt {
	font-size: var(--mono-xs);
	letter-spacing: .14em;
	color: var(--c-ink-mute);
	margin-bottom: 6px;
}
.contact-aside dd {
	margin: 0;
	color: var(--c-ink);
	font-weight: 500;
}
.contact-aside dd a { border-bottom: 1.5px solid var(--c-ink); padding-bottom: 1px; }
.contact-aside dd a:hover { color: var(--c-ink-mute); border-bottom-color: var(--c-ink-mute); }
.contact-aside__phone { font-size: 1.45rem; letter-spacing: -.01em; }
.contact-steps {
	margin-top: 44px;
	border-top: var(--rule-w-strong) solid var(--c-ink);
	padding-top: 22px;
}
.contact-steps h3 {
	font-family: var(--ff-sans);
	font-size: 1.05rem;
	margin: 0 0 18px;
	text-transform: uppercase;
}
.contact-steps ol {
	display: grid;
	gap: 0;
	margin: 0;
	padding: 0;
	list-style: none;
	counter-reset: contact-step;
	border-top: 1px solid var(--c-rule-soft);
}
.contact-steps li {
	counter-increment: contact-step;
	display: grid;
	grid-template-columns: 42px minmax(0, 1fr);
	column-gap: 12px;
	row-gap: 4px;
	padding: 16px 0;
	border-bottom: 1px solid var(--c-rule-soft);
}
.contact-steps li::before {
	content: counter(contact-step, decimal-leading-zero);
	grid-row: 1 / span 2;
	color: var(--c-ink-mute);
	font-size: var(--mono-xs);
	letter-spacing: .14em;
}
.contact-steps b {
	display: block;
	grid-column: 2;
	color: var(--c-ink);
	font-weight: 600;
	min-width: 0;
}
.contact-steps span {
	display: block;
	grid-column: 2;
	color: var(--c-ink-soft);
	font-family: var(--ff-sans);
	font-size: .92rem;
	line-height: 1.5;
	letter-spacing: 0;
	text-transform: none;
	min-width: 0;
}

.contact-main { display: grid; gap: 16px; }
.contact-form {
	display: grid;
	gap: 0;
}
.field {
	display: grid;
	grid-template-columns: minmax(170px, 200px) minmax(0, 1fr);
	align-items: stretch;
	gap: 0;
	border-bottom: 1px solid var(--c-rule-soft);
}
.field > span {
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
	padding: 18px 16px 18px 0;
	display: flex; align-items: center;
	border-right: 1px solid var(--c-rule-soft);
	line-height: 1.35;
}
.field > input, .field > select, .field > textarea {
	font-family: var(--ff-sans);
	font-size: 1rem;
	padding: 16px 18px;
	border: 0;
	background: transparent;
	color: var(--c-ink);
	width: 100%;
	min-width: 0;
	transition: background .15s ease;
}
.field > input:focus, .field > select:focus, .field > textarea:focus {
	outline: none;
	background: var(--c-paper-warm);
}
.field > textarea { min-height: 140px; resize: vertical; line-height: 1.5; }
.field:has(textarea) > span { align-items: flex-start; padding-top: 18px; }
.field--honey { position: absolute !important; left: -9999px; top: -9999px; }

.legal {
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .04em;
	color: var(--c-ink-mute);
	margin-top: 16px;
	max-width: 64ch;
}
.legal a { color: var(--c-ink); border-bottom: 1px solid var(--c-ink); }

.alert {
	padding: 18px 22px;
	margin-bottom: 24px;
	font-family: var(--ff-mono);
	font-size: var(--mono-sm);
	letter-spacing: .04em;
	text-transform: uppercase;
	border: 1.5px solid var(--c-ink);
}
.alert--ok  { border-color: var(--c-ink); background: var(--c-signal); }
.alert--err { border-color: var(--c-alarm); color: var(--c-alarm); }
.alert ul { margin: 8px 0 0; padding-left: 1.2rem; list-style: none; }
.alert ul li::before { content: "[ ! ] "; color: var(--c-alarm); }

/* =========================================================================
   IDF MAP — carte SVG des 8 départements
   ========================================================================= */
.idf-map {
	width: 100%;
	color: var(--c-ink);
}
.section--ink .idf-map { color: var(--c-paper); }

.idf-map__head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 24px;
	padding-bottom: 16px;
	margin-bottom: 16px;
	border-bottom: 1px solid currentColor;
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .14em;
	text-transform: uppercase;
	flex-wrap: wrap;
}
.section--ink .idf-map__head { border-bottom-color: rgba(242,239,230,.4); }
.idf-map__title { opacity: .7; }
.idf-map__legend-status { display: inline-flex; align-items: center; gap: 10px; }
.idf-map__dot {
	width: 8px; height: 8px; border-radius: 50%;
	background: var(--c-signal);
	display: inline-block;
}

.idf-map__svg {
	width: 100%;
	height: auto;
	display: block;
	border: 1px solid currentColor;
	background: transparent;
}

.idf-dept__shape {
	fill: transparent;
	stroke: currentColor;
	stroke-width: 0.5;
	stroke-linejoin: round;
	transition: fill .25s ease, stroke .25s ease, stroke-width .25s ease;
	cursor: pointer;
}
.idf-dept {
	outline: none;
}
.idf-dept:hover .idf-dept__shape,
.idf-dept.is-active .idf-dept__shape,
.idf-dept:focus-visible .idf-dept__shape {
	fill: var(--c-signal);
	stroke: var(--c-ink);
	stroke-width: 0.7;
}
.section--ink .idf-dept:hover .idf-dept__shape,
.section--ink .idf-dept.is-active .idf-dept__shape,
.section--ink .idf-dept:focus-visible .idf-dept__shape {
	fill: var(--c-signal);
	stroke: var(--c-ink);
}

.idf-label__code {
	font-weight: 600;
	letter-spacing: -0.02em;
	fill: currentColor;
	transition: fill .2s ease, opacity .2s ease;
}
.idf-label__delay {
	fill: currentColor;
	opacity: .55;
	text-transform: uppercase;
	transition: fill .2s ease, opacity .2s ease;
}
.idf-dept:hover .idf-label__code,
.idf-dept:hover .idf-label__delay,
.idf-dept.is-active .idf-label__code,
.idf-dept.is-active .idf-label__delay,
.idf-dept:focus-visible .idf-label__code,
.idf-dept:focus-visible .idf-label__delay {
	fill: var(--c-ink);
	opacity: 1;
}

/* Légende sous la carte */
.idf-map__legend {
	margin: 24px 0 0;
	padding: 0;
	list-style: none;
	border-top: var(--rule-w-strong) solid currentColor;
	border-bottom: var(--rule-w-strong) solid currentColor;
}
.idf-legend-item {
	display: grid;
	grid-template-columns: 60px 1.4fr 2fr 80px 70px;
	gap: 16px;
	align-items: center;
	padding: 14px 0;
	border-bottom: 1px solid currentColor;
	font-family: var(--ff-mono);
	font-size: var(--mono-sm);
	letter-spacing: .04em;
	text-transform: uppercase;
}
.section--ink .idf-legend-item { border-bottom-color: rgba(242,239,230,.2); }
.idf-legend-item:last-child { border-bottom: 0; }
.idf-legend-item.is-active {
	background: var(--c-signal);
	color: #0A0A0B;
	padding-left: 12px;
	padding-right: 12px;
}
.idf-legend-item__code {
	background: var(--c-signal);
	color: var(--c-ink);
	padding: 4px 8px;
	font-weight: 600;
	width: max-content;
}
.idf-legend-item.is-active .idf-legend-item__code {
	background: #0A0A0B;
	color: var(--c-signal);
}
.idf-legend-item.is-active .idf-legend-item__cities,
.idf-legend-item.is-active .idf-legend-item__status {
	opacity: 1;
	color: #0A0A0B;
}
.idf-legend-item__name { font-weight: 500; }
.idf-legend-item__cities { opacity: .65; font-size: var(--mono-xs); letter-spacing: .06em; }
.idf-legend-item__delay { text-align: right; }
.idf-legend-item__status {
	font-size: var(--mono-xs);
	letter-spacing: .14em;
	color: var(--c-signal);
	text-align: right;
}
.section--ink .idf-legend-item__status { color: var(--c-signal); }

@media (max-width: 880px) {
	.idf-legend-item {
		grid-template-columns: 50px 1fr 60px;
		gap: 12px;
	}
	.idf-legend-item__cities,
	.idf-legend-item__status { display: none; }
}

/* =========================================================================
   ZONE MAP — pavage de cartes département (page Zone d'intervention)
   ========================================================================= */
.zone-map {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	border-top: var(--rule-w-strong) solid var(--c-ink);
	border-bottom: var(--rule-w-strong) solid var(--c-ink);
	margin: 2.4rem 0;
}
.zone-card {
	padding: 28px 28px;
	border-bottom: 1px solid var(--c-rule-soft);
	border-right: 1px solid var(--c-rule-soft);
	position: relative;
	cursor: pointer;
	transition: background .2s ease, color .2s ease, box-shadow .2s ease;
}
.zone-card:hover,
.zone-card:focus-visible {
	background: var(--c-paper-warm);
	outline: 0;
	box-shadow: inset 0 0 0 var(--rule-w-strong) var(--c-ink);
}
.zone-card.is-active {
	background: var(--c-signal);
	color: #0A0A0B;
	box-shadow: inset 0 0 0 var(--rule-w-strong) #0A0A0B;
}
.zone-card:nth-child(2n)        { border-right: 0; }
.zone-card:nth-last-child(-n+2) { border-bottom: 0; }
.zone-card__head {
	font-family: var(--ff-sans);
	font-weight: 700;
	font-size: 1.4rem;
	letter-spacing: -.02em;
	text-transform: uppercase;
	color: var(--c-ink);
	margin-bottom: 4px;
}
.zone-card__head b {
	font-family: var(--ff-mono);
	background: var(--c-signal);
	padding: 0 8px;
	margin-right: 6px;
	font-weight: 500;
}
.zone-card.is-active .zone-card__head,
.zone-card.is-active .zone-card__delay,
.zone-card.is-active .zone-card__delay b,
.zone-card.is-active p {
	color: #0A0A0B;
}
.zone-card.is-active .zone-card__head b {
	background: #0A0A0B;
	color: var(--c-paper-soft);
}
.zone-card.is-active p strong {
	background: transparent;
	color: #0A0A0B;
	padding: 0;
}
.zone-card__delay {
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
	margin-bottom: 14px;
}
.zone-card__delay b { color: var(--c-ink); font-weight: 500; }
.zone-card p {
	font-size: .95rem;
	line-height: 1.55;
	color: var(--c-ink-soft);
	margin: 0;
	max-width: 56ch;
}
.zone-card__link {
	display: inline-flex;
	margin-top: 18px;
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .12em;
	text-transform: uppercase;
	border-bottom: 1px solid currentColor;
	color: var(--c-ink);
}
.zone-card.is-active .zone-card__link {
	color: #0A0A0B;
}
.zone-detail {
	margin-top: -1px;
	border: var(--rule-w-strong) solid var(--c-ink);
	padding: clamp(22px, 3vw, 34px);
	background: var(--c-paper-soft);
}
.zone-detail__meta {
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
	margin-bottom: 18px;
}
.zone-detail__grid {
	display: grid;
	grid-template-columns: 160px minmax(0, 1fr);
	gap: 14px 28px;
	align-items: start;
}
.zone-detail__grid > div:first-child {
	grid-row: 1 / span 3;
}
.zone-detail__code {
	display: inline-block;
	background: var(--c-signal);
	color: #0A0A0B;
	font-family: var(--ff-mono);
	font-size: 1.7rem;
	line-height: 1;
	padding: 6px 10px;
	margin-bottom: 10px;
}
.zone-detail__title {
	font-size: clamp(1.25rem, 2vw, 1.8rem);
	margin: 0;
}
.zone-detail__delay {
	grid-column: 2;
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
}
.zone-detail__delay b {
	display: block;
	margin-top: 8px;
	color: var(--c-ink);
	font-size: 1.35rem;
	letter-spacing: 0;
}
.zone-detail__body {
	grid-column: 2;
	color: var(--c-ink-soft);
	font-size: .98rem;
	line-height: 1.6;
	max-width: 72ch;
}
.zone-detail__body p {
	margin: 0;
}
.zone-detail__body strong {
	background: var(--c-signal);
	color: #0A0A0B;
	padding: 0 .16em;
}
.zone-detail__actions {
	grid-column: 2;
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	align-self: start;
	justify-self: start;
}
.zone-detail__actions .btn {
	white-space: normal;
}
@media (max-width: 760px) {
	.zone-map { grid-template-columns: 1fr; }
	.zone-card { border-right: 0 !important; border-bottom: 1px solid var(--c-rule-soft) !important; }
	.zone-card:last-child { border-bottom: 0 !important; }
	.zone-detail__grid { grid-template-columns: 1fr; }
	.zone-detail__grid > div:first-child,
	.zone-detail__delay,
	.zone-detail__body,
	.zone-detail__actions {
		grid-column: auto;
		grid-row: auto;
	}
	.zone-detail__actions { justify-self: stretch; }
	.zone-detail__actions .btn { justify-content: center; width: 100%; }
}

/* =========================================================================
   ZONE LOCAL — pages départementales SEO
   ========================================================================= */
.zone-local-hero__actions {
	margin-top: 28px;
}
.zone-local__cities {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 18px;
}
.zone-local__cities li {
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .1em;
	text-transform: uppercase;
	border: 1px solid var(--c-rule-soft);
	padding: 8px 10px;
}
.zone-local__cities a {
	color: inherit;
	text-decoration: none;
}
.zone-local__cities a:hover,
.zone-local__cities a.is-active {
	color: var(--c-ink);
	background: var(--c-signal);
	box-shadow: 0 0 0 8px var(--c-signal);
}
.zone-local__intent-list {
	display: grid;
	gap: 10px;
	margin-top: 20px;
	max-width: 760px;
	font-family: var(--ff-mono);
	font-size: var(--mono-sm);
	letter-spacing: .08em;
	text-transform: uppercase;
}
.zone-local__intent-list li {
	border-top: 1px solid var(--c-rule-soft);
	padding-top: 10px;
}
.zone-local__services .page-card a {
	display: inline-flex;
	margin-top: 18px;
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .12em;
	text-transform: uppercase;
	border-bottom: 1px solid currentColor;
}
.zone-local__steps {
	max-width: 720px;
}

/* =========================================================================
   FAQ — accordéon dossier
   ========================================================================= */
.faq-list {
	border-top: var(--rule-w-strong) solid var(--c-ink);
	border-bottom: var(--rule-w-strong) solid var(--c-ink);
}
.faq-item {
	border-bottom: 1px solid var(--c-rule-soft);
}
.faq-item:last-child { border-bottom: 0; }
.faq-item summary {
	display: grid;
	grid-template-columns: 80px 1fr 28px;
	align-items: center;
	gap: 16px;
	padding: 22px 0;
	cursor: pointer;
	list-style: none;
	font-weight: 500;
	color: var(--c-ink);
	transition: background .15s ease;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary:hover { background: var(--c-paper-warm); padding-left: 12px; padding-right: 12px; }
.faq-item__num {
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .14em;
	color: var(--c-ink-mute);
	text-transform: uppercase;
}
.faq-item__q {
	font-size: 1.08rem;
	letter-spacing: -.01em;
	line-height: 1.35;
}
.faq-item__chev {
	font-family: var(--ff-mono);
	font-size: 1.4rem;
	color: var(--c-ink);
	text-align: right;
	transition: transform .25s ease;
	line-height: 1;
}
.faq-item[open] .faq-item__chev { transform: rotate(45deg); }
.faq-item[open] summary { background: var(--c-paper-warm); padding-left: 12px; padding-right: 12px; }
.faq-item__a {
	padding: 0 12px 28px 96px;
	color: var(--c-ink-soft);
	font-size: 1rem;
	line-height: 1.65;
	max-width: 70ch;
	background: var(--c-paper-warm);
}
@media (max-width: 660px) {
	.faq-item summary { grid-template-columns: 60px 1fr 24px; gap: 12px; }
	.faq-item__a { padding-left: 12px; }
}

/* =========================================================================
   PAGINATION + EMPTY
   ========================================================================= */
.pagination {
	display: flex; gap: 0; justify-content: center; margin-top: 48px;
	border-top: 1px solid var(--c-rule-soft);
	border-bottom: 1px solid var(--c-rule-soft);
	padding: 16px 0;
	font-family: var(--ff-mono);
	font-size: var(--mono-sm);
	letter-spacing: .12em;
	text-transform: uppercase;
}
.pagination .page-numbers {
	padding: 8px 16px;
	color: var(--c-ink);
	border-right: 1px solid var(--c-rule-soft);
}
.pagination .page-numbers:last-child { border-right: 0; }
.pagination .current { background: var(--c-ink); color: var(--c-paper); }

.empty {
	text-align: center; padding: 80px 0;
	font-family: var(--ff-mono);
	letter-spacing: .12em;
	text-transform: uppercase;
}

/* =========================================================================
   DARK MODE — grands aplats conservés en contraste fort
   ========================================================================= */
:root[data-theme="dark"] .status-bar,
:root[data-theme="dark"] .section--ink,
:root[data-theme="dark"] .data-plate,
:root[data-theme="dark"] .cta-band,
:root[data-theme="dark"] .service-block--warning {
	--c-paper: #F2EFE6;
	--c-paper-soft: #F8F6EE;
	--c-paper-warm: #ECE8DC;
	--c-ink: #070708;
	--c-ink-soft: #2A2A2D;
	--c-ink-mute: #8D897F;
	--c-rule-soft: rgba(242,239,230,.2);
	background: var(--c-ink);
	color: var(--c-paper);
}
:root[data-theme="dark"] .editorial-single .editorial-cta {
	background: rgba(248,246,238,.04);
	border-color: rgba(248,246,238,.18);
	color: #F8F6EE;
}
:root[data-theme="dark"] .editorial-single .editorial-cta__label,
:root[data-theme="dark"] .editorial-single .editorial-cta h2 {
	color: #F8F6EE;
}
:root[data-theme="dark"] .editorial-single .editorial-cta p {
	color: rgba(248,246,238,.7);
}
:root[data-theme="dark"] .editorial-rail__label,
:root[data-theme="dark"] .editorial-rail__toc a.is-active {
	color: #F8F6EE !important;
}
:root[data-theme="dark"] .site-header,
:root[data-theme="dark"] .navbar,
:root[data-theme="dark"] .primary-nav {
	background: var(--c-paper);
}
:root[data-theme="dark"] .site-footer {
	background: #0D0D0A;
}
:root[data-theme="dark"] .editorial-card {
	background: var(--c-paper-soft);
}
:root[data-theme="dark"] .editorial-card:hover,
:root[data-theme="dark"] .ref-row:hover,
:root[data-theme="dark"] .faq-item summary:hover,
:root[data-theme="dark"] .faq-item[open] summary,
:root[data-theme="dark"] .faq-item[open] .faq-item__a {
	background: var(--c-paper-warm);
}
:root[data-theme="dark"] .checklist li::before,
:root[data-theme="dark"] .hero__sigs li::before,
:root[data-theme="dark"] .page-hero__meta b,
:root[data-theme="dark"] .primary-nav a::before,
:root[data-theme="dark"] .protocol-row__index,
:root[data-theme="dark"] .pillar__index,
:root[data-theme="dark"] .registre-entry__head b,
:root[data-theme="dark"] .site-footer h4 {
	color: var(--c-signal);
}
:root[data-theme="dark"] .zone-local__cities a:hover,
:root[data-theme="dark"] .zone-local__cities a.is-active {
	color: var(--c-ink);
}
:root[data-theme="dark"] .btn--signal,
:root[data-theme="dark"] .nav-cta,
:root[data-theme="dark"] .hero__title em,
:root[data-theme="dark"] .label--signal,
:root[data-theme="dark"] .prose strong,
:root[data-theme="dark"] .prose-lite strong,
:root[data-theme="dark"] .page-block__body strong,
:root[data-theme="dark"] .service-block__body strong,
:root[data-theme="dark"] .service-block--warning strong,
:root[data-theme="dark"] .price-hint strong,
:root[data-theme="dark"] .ref-row__delay b,
:root[data-theme="dark"] .registre-entry__status,
:root[data-theme="dark"] .editorial-cat:hover,
:root[data-theme="dark"] .editorial-cat--current,
:root[data-theme="dark"] .editorial-cat--cta,
:root[data-theme="dark"] .zone-card__head b,
:root[data-theme="dark"] .service-pricing-panel {
	color: #0A0A0B;
}
:root[data-theme="dark"] .service-pricing-panel {
	--c-ink: #0A0A0B;
	--c-ink-soft: #2A2A2D;
	--c-rule: #0A0A0B;
}
:root[data-theme="dark"] .service-pricing-panel strong {
	background: transparent;
	color: #0A0A0B;
	padding: 0;
}
:root[data-theme="dark"] .zone-card.is-active .zone-card__head b {
	color: #F8F6EE;
}
:root[data-theme="dark"] .idf-dept:hover .idf-dept__shape,
:root[data-theme="dark"] .idf-dept.is-active .idf-dept__shape,
:root[data-theme="dark"] .idf-dept:focus-visible .idf-dept__shape {
	stroke: #0A0A0B;
}
:root[data-theme="dark"] .idf-dept:hover .idf-label__code,
:root[data-theme="dark"] .idf-dept:hover .idf-label__delay,
:root[data-theme="dark"] .idf-dept.is-active .idf-label__code,
:root[data-theme="dark"] .idf-dept.is-active .idf-label__delay,
:root[data-theme="dark"] .idf-dept:focus-visible .idf-label__code,
:root[data-theme="dark"] .idf-dept:focus-visible .idf-label__delay {
	fill: #0A0A0B;
}
:root[data-theme="dark"] .btn--ink:hover {
	background: var(--c-signal);
	color: #0A0A0B;
	border-color: var(--c-signal);
}
:root[data-theme="dark"] .btn--signal:hover,
:root[data-theme="dark"] .nav-cta:hover {
	background: var(--c-signal-deep);
	color: #0A0A0B;
	border-color: var(--c-signal-deep);
}
:root[data-theme="dark"] .diagnostic-img {
	filter: grayscale(1) contrast(1.12) brightness(.86);
}
:root[data-theme="dark"] .site-main img:not(.diagnostic-img):not(.no-filter) {
	filter: grayscale(1) contrast(1.08) brightness(.9);
}

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width: 1080px) {
	.hero__meta { grid-template-columns: repeat(2, 1fr); gap: 16px 0; }
	.hero__headline { grid-template-columns: 1fr; }
	.hero__plate-frame { aspect-ratio: 21 / 9; }
	.editorial-grid,
	.editorial-intent-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.editorial-body {
		grid-template-columns: minmax(150px, 200px) minmax(0, 720px);
		gap: 32px;
	}
	.editorial-cta { grid-template-columns: 1fr; }
	.data-plate__grid { grid-template-columns: repeat(2, 1fr); }
	.data-cell { border-bottom: 1px solid rgba(242,239,230,.18); }
	.data-cell:nth-child(2n) { border-right: 0; }
	.data-cell:nth-last-child(-n+2) { border-bottom: 0; }
	.status-bar__contact { display: none; }
	.service-block--warning {
		margin-left: 0;
		margin-right: 0;
	}
	.site-footer__top { grid-template-columns: 1fr 1fr; }
	.site-footer__bottom { grid-template-columns: repeat(2, 1fr); }
	.page-hero--service .page-hero__inner { grid-template-columns: 1fr; }
}

@media (max-width: 880px) {
	.status-bar__contact { display: none; }
	.status-bar__inner { gap: 16px; }
	.editorial-body {
		grid-template-columns: 1fr;
	}
	.editorial-rail {
		position: static;
		display: grid;
		grid-template-columns: 1fr 1.4fr;
		gap: 18px;
		top: auto;
	}
	.editorial-rail__label {
		grid-column: 1 / -1;
		margin-bottom: 0;
	}
	.editorial-rail dl {
		margin-bottom: 0;
	}
	.nav-toggle { display: inline-flex; }
	.primary-nav {
		position: absolute; top: 100%; left: 0; right: 0;
		background: var(--c-paper);
		border-bottom: var(--rule-w-strong) solid var(--c-ink);
		padding: 16px 24px 24px;
		flex-direction: column; align-items: stretch;
		display: none;
	}
	.primary-nav.is-open { display: flex; }
	.primary-nav ul { flex-direction: column; gap: 0; }
	.primary-nav li { border-bottom: 1px solid var(--c-rule-soft); }
	.primary-nav li:last-child { border-bottom: 0; }
	.primary-nav a { padding: 16px 0; }
	.nav-cta { margin-top: 14px; text-align: center; justify-content: center; }
	.navbar__inner { grid-template-columns: 1fr auto auto; }
	.navbar__inner .nav-cta { display: none; }

	.hero__row { grid-template-columns: 1fr; }
	.hero__meta { grid-template-columns: 1fr 1fr; }

	/* Tables → stacked cards */
	.ref-table thead { display: none; }
	.ref-table, .ref-table tbody, .ref-table tr, .ref-table td { display: block; width: 100%; }
	.ref-row { padding: 24px 0; }
	.ref-row > td { padding: 6px 0; width: 100% !important; }
	.ref-row__title { font-size: 1.5rem; margin: 4px 0; }
	.ref-row__delay { text-align: left; }

	.protocol-row { grid-template-columns: 80px 1fr; gap: 16px; }
	.protocol-row__title { grid-column: 2; }
	.protocol-row__desc  { grid-column: 2; }
	.protocol-row__index { grid-column: 1 / -1; padding-top: 4px; color: var(--c-ink-mute); }

	.pillars { grid-template-columns: 1fr; }
	.pillar { padding: 28px 0 !important; border-right: 0 !important; }
	.pillar:not(:last-child) { border-bottom: 1px solid var(--c-rule-soft); }

	.zone-grid { grid-template-columns: 1fr; }
	.zone-list { grid-template-columns: 1fr; }
	.zone-list li { border-right: 0 !important; }

	.registre-entry { grid-template-columns: 1fr; gap: 12px; }
	.registre-entry__status { width: max-content; }

	.cta-band__inner { grid-template-columns: 1fr; }
	.cta-band__actions { flex-direction: row; flex-wrap: wrap; }
	.editorial-grid,
	.editorial-intent-grid {
		grid-template-columns: 1fr;
		border-left: 0;
	}
	.editorial-card { border-right: 0; min-height: 0; }

	.contact-grid { grid-template-columns: 1fr; }
	.field { grid-template-columns: 1fr; }
	.field > span { padding: 14px 16px 0; border-right: 0; }

	.service-block {
		grid-template-columns: 1fr;
		gap: 14px;
	}
	.service-block__title { max-width: 18ch; }
	.service-block--warning {
		margin-left: 0;
		margin-right: 0;
	}
	.service-step { grid-template-columns: 74px 1fr; gap: 14px; }
	.service-audience-grid { grid-template-columns: 1fr; }
	.service-audience-card {
		min-height: 0;
		border-right: 0;
		border-bottom: 1px solid var(--c-rule-soft);
	}
	.service-audience-card:last-child { border-bottom: 0; }
	.page-block {
		grid-template-columns: 1fr;
		gap: 14px;
	}
	.page-block__title { max-width: 18ch; }
	.page-card-grid { grid-template-columns: 1fr; }
	.page-card {
		min-height: 0;
		border-right: 0;
		border-bottom: 1px solid var(--c-rule-soft);
	}
	.page-card:last-child { border-bottom: 0; }

	.site-footer__top { grid-template-columns: 1fr; }
	.site-footer__bottom { grid-template-columns: 1fr; }
	.site-footer__mark { font-size: 2.6rem; }
}

@media (max-width: 480px) {
	body { font-size: 15px; }
	.btn { width: 100%; justify-content: space-between; }
	.hero__sigs { grid-template-columns: 1fr; }
	.editorial-hero h1 { font-size: clamp(2.35rem, 15vw, 3.4rem); }
	.editorial-featured__img { aspect-ratio: 4 / 3; }
	.editorial-featured figcaption,
	.editorial-rail {
		font-size: 9px;
	}
	.editorial-rail {
		grid-template-columns: 1fr;
	}
}

@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after { animation: none !important; transition: none !important; }
	.hero::after, .status-bar__dot { animation: none !important; }
}

/* =========================================================================
   SINGLE.PHP ENHANCEMENTS
   ========================================================================= */

/* 1. Progress Bar */
.reading-progress-bar {
	position: fixed;
	top: 0;
	left: 0;
	height: 4px;
	background: var(--c-signal);
	width: 0%;
	z-index: 9999;
	transition: width 0.1s;
}

/* 2. Adjust gap between Hero and Image */
.page-hero.editorial-hero.has-thumbnail {
	border-bottom: 0;
	padding-bottom: clamp(16px, 2.5vw, 32px);
}
.section.editorial-single.has-thumbnail {
	padding-top: 0;
}

/* 3. TOC Active Item */
.editorial-rail__toc a {
	transition: color 0.2s;
}
.editorial-rail__toc a.is-active {
	color: var(--c-ink) !important;
	font-weight: 600;
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
}

/* 4. Related Posts */
.editorial-related {
	margin-top: clamp(40px, 6vw, 64px);
	padding-top: 32px;
	border-top: var(--rule-w-strong) solid var(--c-ink);
}
.editorial-related h3 {
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
	margin-bottom: 24px;
}
.editorial-related__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 24px;
}
.related-card {
	display: block;
	padding: 24px;
	border: 1px solid var(--c-rule-soft);
	transition: border-color 0.2s, transform 0.2s;
	text-decoration: none;
	background: color-mix(in srgb, var(--c-paper-soft) 72%, transparent);
}
.related-card:hover {
	border-color: var(--c-signal);
	transform: translateY(-2px);
}
.related-card__meta {
	font-family: var(--ff-mono);
	font-size: var(--mono-xs);
	color: var(--c-ink-mute);
	display: block;
	margin-bottom: 12px;
}
.related-card h4 {
	color: var(--c-ink);
	font-size: 1.1rem;
	line-height: 1.4;
	margin: 0;
}
:root[data-theme="dark"] .related-card {
	background: var(--c-paper-soft);
	border-color: var(--c-rule-soft);
}
:root[data-theme="dark"] .related-card:hover {
	background: var(--c-paper-warm);
	border-color: var(--c-signal);
}
:root[data-theme="dark"] .related-card h4 {
	color: var(--c-ink);
}
:root[data-theme="dark"] .related-card__meta {
	color: var(--c-ink-mute);
}
