/*
Theme Name: Notal Bâtiment
Theme URI: https://www.notal-batiment.fr/
Description: Child theme GeneratePress pour Notal Bâtiment — design Direction B (bleu nuit + jaune solaire + ivoire chaud).
Author: Antoine
Author URI: https://www.notal-batiment.fr/
Template: generatepress
Version: 1.0.1
Text Domain: notal-batiment-child
*/

/* =========================================================================
   1. DESIGN TOKENS (Direction B — Claude Design)
   ========================================================================= */
:root {
	/* Colors */
	--notal-c-bg:           #FAF7EF;
	--notal-c-paper:        #FFFFFF;
	--notal-c-bg-alt:       #F1ECDE;
	--notal-c-ink:          #0E0E10;
	--notal-c-primary:      #11254A;
	--notal-c-primary-deep: #0A1830;
	--notal-c-accent:       #FFC233;
	--notal-c-accent-soft:  #FFE9A8;
	--notal-c-urgence:      #D63F1F;
	--notal-c-urgence-deep: #A82E12;
	--notal-c-stone:        #6B6660;
	--notal-c-stone-soft:   #B3ACA2;
	--notal-c-rule:         rgba(14, 14, 16, 0.10);
	--notal-c-rule-strong:  rgba(14, 14, 16, 0.18);

	/* Typography stacks */
	--notal-ff-sans:  'DM Sans', system-ui, -apple-system, sans-serif;
	--notal-ff-serif: 'Fraunces', Georgia, serif;
	--notal-ff-mono:  'JetBrains Mono', ui-monospace, monospace;

	/* Radii */
	--notal-radius-xs:   4px;
	--notal-radius-sm:   6px;
	--notal-radius-md:   8px;
	--notal-radius-pill: 999px;

	/* Spacing scale */
	--notal-space-1:  4px;
	--notal-space-2:  8px;
	--notal-space-3:  12px;
	--notal-space-4:  16px;
	--notal-space-5:  20px;
	--notal-space-6:  24px;
	--notal-space-8:  32px;
	--notal-space-10: 40px;
	--notal-space-12: 48px;
	--notal-space-16: 64px;

	/* Container max-width (étendu à 1440px sur grands écrans) */
	--notal-container-max: 1440px;
}

/* =========================================================================
   2. BASE — Override GeneratePress defaults
   ========================================================================= */
body {
	font-family: var(--notal-ff-sans);
	background: var(--notal-c-bg);
	color: var(--notal-c-ink);
	letter-spacing: -0.005em;
}

h1, h2, h3, h4, h5, h6,
.entry-title,
.site-title {
	font-family: var(--notal-ff-sans);
	font-weight: 700;
	letter-spacing: -0.03em;
	color: var(--notal-c-ink);
}

h1 { letter-spacing: -0.04em; }

em, .notal-italic-serif {
	font-family: var(--notal-ff-serif);
	font-style: italic;
}

a {
	color: var(--notal-c-primary);
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
}
a:hover {
	color: var(--notal-c-primary-deep);
}

/* Lead paragraph (intros, sous H1) */
.is-style-lead,
p.is-style-lead {
	font-family: var(--notal-ff-sans);
	font-size: 1.15rem;
	line-height: 1.55;
	color: var(--notal-c-ink);
	letter-spacing: -0.01em;
}

/* =========================================================================
   3. BUTTONS (override Gutenberg + classes utilitaires Notal)
   ========================================================================= */
.wp-block-button__link {
	font-family: var(--notal-ff-sans);
	font-weight: 700;
	letter-spacing: -0.01em;
	border-radius: var(--notal-radius-pill);
	padding: 14px 22px;
	border: 1.5px solid var(--notal-c-primary);
	background: var(--notal-c-primary);
	color: var(--notal-c-paper);
	transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
	display: inline-flex;
	align-items: center;
	gap: 10px;
}
.wp-block-button__link:hover {
	background: var(--notal-c-primary-deep);
	border-color: var(--notal-c-primary-deep);
	color: var(--notal-c-paper);
}

/* Outline button */
.wp-block-button.is-style-outline .wp-block-button__link,
.wp-block-button .wp-block-button__link.is-style-outline {
	background: transparent;
	color: var(--notal-c-ink);
	border: 1.5px solid var(--notal-c-ink);
}
.wp-block-button.is-style-outline .wp-block-button__link:hover {
	background: var(--notal-c-ink);
	color: var(--notal-c-paper);
}

/* Style "Accent" (jaune) — utilisé via classes additionnelles */
.wp-block-button .wp-block-button__link.has-accent-background,
.notal-btn--accent {
	background: var(--notal-c-accent);
	color: var(--notal-c-primary);
	border-color: var(--notal-c-accent);
}
.wp-block-button .wp-block-button__link.has-accent-background:hover {
	background: #f0b520;
	border-color: #f0b520;
}

/* Style "Urgence" (rouge vermeil) */
.notal-btn--urgence,
.wp-block-button .wp-block-button__link.has-urgence-background {
	background: var(--notal-c-urgence);
	color: var(--notal-c-paper);
	border-color: var(--notal-c-urgence);
}
.notal-btn--urgence:hover,
.wp-block-button .wp-block-button__link.has-urgence-background:hover {
	background: var(--notal-c-urgence-deep);
	border-color: var(--notal-c-urgence-deep);
	color: var(--notal-c-paper);
}

/* =========================================================================
   4. NOTAL COMPONENTS
   ========================================================================= */

/* --- Section label (petite barre + texte uppercase letter-spaced) --- */
.notal-section-label {
	font-family: var(--notal-ff-sans);
	font-weight: 700;
	font-size: 0.75rem;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--notal-c-primary);
	display: inline-flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 16px;
}
.notal-section-label::before {
	content: "";
	display: inline-block;
	width: 28px;
	height: 1.5px;
	background: currentColor;
}
.notal-section-label--dark { color: var(--notal-c-accent); }

/* Label responsive — éviter débordement sur mobile (texte uppercase + letter-spacing) */
@media (max-width: 768px) {
	.notal-section-label {
		letter-spacing: 0.14em;
		font-size: 0.6875rem;
		max-width: 100%;
		flex-wrap: wrap;
		gap: 8px;
		line-height: 1.4;
	}
	.notal-section-label::before {
		width: 20px;
	}
	/* Force align-items: flex-start sur les sections crosssell en mobile
	   pour empêcher le label de se retrouver à droite via align-items: flex-end */
	.notal-crosssell-section__head {
		flex-direction: column !important;
		align-items: flex-start !important;
		text-align: left !important;
	}
	.notal-crosssell-section__head > * {
		align-self: flex-start !important;
	}
}
@media (max-width: 480px) {
	.notal-section-label {
		letter-spacing: 0.1em;
		font-size: 0.625rem;
	}
}

/* --- Pill (badge uppercase) --- */
.notal-pill {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 5px 12px;
	border-radius: var(--notal-radius-pill);
	background: var(--notal-c-accent);
	color: var(--notal-c-primary);
	font-family: var(--notal-ff-sans);
	font-weight: 700;
	font-size: 0.6875rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
}
.notal-pill--urgence { background: var(--notal-c-urgence); color: var(--notal-c-paper); }
.notal-pill--ghost   { background: transparent; color: var(--notal-c-stone); border: 1px solid var(--notal-c-rule-strong); }

/* --- Pulse dot (animation urgence) --- */
.notal-pulse-dot {
	position: relative;
	display: inline-block;
	width: 8px;
	height: 8px;
	flex-shrink: 0;
}
.notal-pulse-dot::before,
.notal-pulse-dot::after {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: 50%;
	background: var(--notal-c-urgence);
}
.notal-pulse-dot::before {
	animation: notal-pulse 1.6s ease-out infinite;
}
@keyframes notal-pulse {
	0%   { transform: scale(1);   opacity: 0.7; }
	70%  { transform: scale(2.4); opacity: 0; }
	100% { opacity: 0; }
}

/* --- Card générique --- */
.notal-card {
	background: var(--notal-c-paper);
	border: 1px solid var(--notal-c-rule);
	border-radius: var(--notal-radius-sm);
	padding: 28px 30px;
	display: flex;
	flex-direction: column;
	gap: 18px;
}

/* --- Service card --- */
.notal-service-card { /* hérite de .notal-card */ }
.notal-service-card__head {
	display: flex;
	align-items: flex-start;
	gap: 16px;
}
.notal-service-card__icon {
	width: 56px;
	height: 56px;
	border-radius: var(--notal-radius-xs);
	background: var(--notal-c-primary);
	color: var(--notal-c-accent);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.notal-service-card__title {
	font-family: var(--notal-ff-sans);
	font-weight: 700;
	font-size: 1.625rem;
	margin: 0;
	letter-spacing: -0.03em;
	line-height: 1;
}
.notal-service-card__sub {
	font-family: var(--notal-ff-serif);
	font-style: italic;
	font-size: 1rem;
	color: var(--notal-c-stone);
	margin-top: 6px;
}
.notal-service-card__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 8px 14px;
}
.notal-service-card__list li {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 0.875rem;
	color: var(--notal-c-ink);
}
.notal-service-card__list li::before {
	content: "";
	display: inline-block;
	width: 14px;
	height: 14px;
	flex-shrink: 0;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2311254A' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
	background-size: contain;
	background-repeat: no-repeat;
}

/* --- USP block (icon + titre + description) --- */
.notal-usp {
	display: flex;
	flex-direction: column;
	gap: 12px;
	padding: 26px 0;
	border-top: 1px solid var(--notal-c-rule);
}
.notal-usp__icon {
	width: 44px;
	height: 44px;
	border-radius: var(--notal-radius-xs);
	background: var(--notal-c-accent);
	color: var(--notal-c-primary);
	display: flex;
	align-items: center;
	justify-content: center;
}
.notal-usp__title {
	font-family: var(--notal-ff-sans);
	font-weight: 700;
	font-size: 1.125rem;
	letter-spacing: -0.02em;
	margin: 0;
}
.notal-usp__body {
	font-size: 0.875rem;
	line-height: 1.55;
	color: var(--notal-c-stone);
}

/* --- Review card --- */
.notal-review {
	background: var(--notal-c-paper);
	border: 1px solid var(--notal-c-rule);
	border-radius: var(--notal-radius-sm);
	padding: 26px 28px;
	display: flex;
	flex-direction: column;
	gap: 14px;
}
.notal-review__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.notal-review__stars {
	display: inline-flex;
	gap: 2px;
	color: var(--notal-c-accent);
}
.notal-review__stars svg { width: 14px; height: 14px; fill: currentColor; }
.notal-review__google {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 0.6875rem;
	color: var(--notal-c-stone);
}
.notal-review__text {
	margin: 0;
	font-family: var(--notal-ff-serif);
	font-style: italic;
	font-size: 0.975rem;
	line-height: 1.5;
	color: var(--notal-c-ink);
}
.notal-review__footer {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-top: auto;
	padding-top: 8px;
	border-top: 1px solid var(--notal-c-rule);
}
.notal-review__avatar {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: var(--notal-c-bg-alt);
	color: var(--notal-c-primary);
	font-family: var(--notal-ff-sans);
	font-weight: 700;
	font-size: 0.8125rem;
	display: flex;
	align-items: center;
	justify-content: center;
	letter-spacing: -0.02em;
}
.notal-review__name {
	font-family: var(--notal-ff-sans);
	font-weight: 700;
	font-size: 0.8125rem;
	letter-spacing: -0.01em;
	color: var(--notal-c-ink);
}
.notal-review__date {
	font-size: 0.6875rem;
	color: var(--notal-c-stone);
}

/* --- Badge RGE --- */
.notal-badge-rge {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 8px 14px;
	border-radius: var(--notal-radius-xs);
	border: 1px solid var(--notal-c-rule-strong);
	background: var(--notal-c-paper);
	font-family: var(--notal-ff-sans);
	color: var(--notal-c-ink);
}
.notal-badge-rge__chip {
	width: 28px;
	height: 28px;
	border-radius: var(--notal-radius-xs);
	background: var(--notal-c-primary);
	color: var(--notal-c-accent);
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 800;
	font-size: 0.6875rem;
	letter-spacing: 0.04em;
}
.notal-badge-rge__title {
	font-weight: 700;
	font-size: 1rem;
	letter-spacing: -0.02em;
	line-height: 1;
}
.notal-badge-rge__sub {
	font-size: 0.75rem;
	color: var(--notal-c-stone);
	margin-top: 2px;
}

/* --- Stat (trust strip) --- */
.notal-stat__value {
	font-family: var(--notal-ff-sans);
	font-weight: 700;
	font-size: 1.375rem;
	color: var(--notal-c-ink);
	line-height: 1;
	letter-spacing: -0.03em;
}
.notal-stat__label {
	font-family: var(--notal-ff-sans);
	font-weight: 600;
	font-size: 0.625rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--notal-c-stone);
	margin-top: 4px;
}

/* --- Photo placeholder (rayé) --- */
.notal-photo-placeholder {
	position: relative;
	background: repeating-linear-gradient(
		135deg,
		var(--notal-c-paper) 0 14px,
		rgba(17, 37, 74, 0.06) 14px 16px
	);
	border: 1px dashed var(--notal-c-primary);
	border-radius: var(--notal-radius-xs);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 6px;
	color: var(--notal-c-primary);
	padding: 14px;
	min-height: 220px;
	font-family: var(--notal-ff-mono);
	font-size: 0.6875rem;
	letter-spacing: 0.18em;
	text-align: center;
	text-transform: uppercase;
}

/* --- FAQ (override <details>) --- */
.notal-faq details {
	border-top: 1px solid var(--notal-c-rule);
}
.notal-faq details:last-of-type {
	border-bottom: 1px solid var(--notal-c-rule);
}
.notal-faq summary {
	list-style: none;
	padding: 20px 0;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: space-between;
	font-family: var(--notal-ff-sans);
	font-weight: 600;
	font-size: 1.125rem;
	letter-spacing: -0.02em;
	color: var(--notal-c-ink);
}
.notal-faq summary::-webkit-details-marker { display: none; }
.notal-faq summary::after {
	content: "+";
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: var(--notal-c-bg-alt);
	color: var(--notal-c-primary);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-left: 16px;
	flex-shrink: 0;
	font-weight: 700;
	font-size: 1.125rem;
}
.notal-faq details[open] summary::after { content: "−"; }
.notal-faq details > *:not(summary) {
	font-size: 0.9375rem;
	line-height: 1.6;
	color: var(--notal-c-stone);
	padding: 0 0 22px;
	max-width: 720px;
}

/* --- Top urgency bar (avant header) --- */
.notal-topbar {
	background: var(--notal-c-ink);
	color: var(--notal-c-paper);
	font-family: var(--notal-ff-sans);
	font-size: 0.8125rem;
}
.notal-topbar__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	max-width: var(--notal-container-max);
	margin: 0 auto;
	padding: 10px 24px;
	gap: 16px;
}
.notal-topbar__left {
	display: flex;
	align-items: center;
	gap: 12px;
	min-width: 0;
}
.notal-topbar__label {
	font-weight: 700;
	font-size: 0.6875rem;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--notal-c-urgence);
	white-space: nowrap;
}
.notal-topbar__sep {
	width: 1px;
	height: 14px;
	background: rgba(255, 255, 255, 0.2);
	flex-shrink: 0;
}
.notal-topbar__msg {
	opacity: 0.85;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.notal-topbar__cta {
	color: var(--notal-c-accent);
	text-decoration: none;
	font-weight: 700;
	font-size: 0.875rem;
	letter-spacing: -0.01em;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	white-space: nowrap;
	flex-shrink: 0;
}
.notal-topbar__cta:hover { color: var(--notal-c-accent-soft); }
@media (max-width: 720px) {
	.notal-topbar__msg { display: none; }
	.notal-topbar__sep { display: none; }
}

/* --- Footer custom --- */
.notal-footer {
	background: var(--notal-c-primary);
	color: var(--notal-c-paper);
	padding: 56px 0 24px;
	font-family: var(--notal-ff-sans);
}
.notal-footer__inner {
	max-width: var(--notal-container-max);
	margin: 0 auto;
	padding: 0 24px;
}
.notal-footer__grid {
	display: grid;
	grid-template-columns: 1.3fr 1fr 1fr 1.2fr;
	gap: 40px;
	align-items: flex-start;
}
@media (max-width: 880px) {
	.notal-footer__grid { grid-template-columns: 1fr 1fr; gap: 32px; }
}
@media (max-width: 480px) {
	.notal-footer__grid { grid-template-columns: 1fr; }
}
.notal-footer__title {
	font-weight: 700;
	font-size: 0.75rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--notal-c-accent);
	margin: 0 0 14px;
}
.notal-footer__link {
	display: block;
	padding: 4px 0;
	font-size: 0.875rem;
	color: rgba(255, 255, 255, 0.75);
	text-decoration: none;
}
.notal-footer__link:hover {
	color: var(--notal-c-paper);
}
.notal-footer__desc {
	margin: 22px 0 0;
	font-size: 0.875rem;
	line-height: 1.55;
	color: rgba(255, 255, 255, 0.7);
	max-width: 320px;
}
.notal-footer__contact {
	font-size: 0.875rem;
	line-height: 1.6;
	color: rgba(255, 255, 255, 0.75);
}
.notal-footer__phone {
	color: var(--notal-c-accent);
	text-decoration: none;
	font-weight: 700;
	letter-spacing: -0.01em;
	display: block;
}
.notal-footer__phone:hover { color: var(--notal-c-accent-soft); }
.notal-footer__hours {
	font-size: 0.78125rem;
	line-height: 1.55;
	color: rgba(255, 255, 255, 0.75);
	margin-top: 12px;
}
.notal-footer__hours-row {
	display: flex;
	justify-content: space-between;
	gap: 10px;
	padding: 2px 0;
}
.notal-footer__hours-row--urgence { color: var(--notal-c-accent); font-weight: 700; }
.notal-footer__legal {
	margin-top: 40px;
	padding-top: 18px;
	border-top: 1px solid rgba(255, 255, 255, 0.15);
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: 14px;
	font-size: 0.75rem;
	color: rgba(255, 255, 255, 0.6);
}
.notal-footer__legal a {
	color: rgba(255, 255, 255, 0.6);
	text-decoration: none;
	margin-left: 22px;
}
.notal-footer__legal a:hover { color: var(--notal-c-paper); }
.notal-footer__brand-mark {
	display: inline-flex;
	align-items: center;
	gap: 14px;
	color: var(--notal-c-paper);
	text-decoration: none;
}
.notal-footer__brand-name {
	font-weight: 700;
	font-size: 1.375rem;
	letter-spacing: -0.035em;
	line-height: 0.95;
}
.notal-footer__brand-name .accent { color: var(--notal-c-accent); }
.notal-footer__brand-sign {
	margin-top: 4px;
	font-family: var(--notal-ff-serif);
	font-style: italic;
	font-weight: 400;
	font-size: 0.75rem;
	color: rgba(255, 255, 255, 0.65);
}

/* --- Site lockup (header logo + wordmark) --- */
.notal-lockup {
	display: inline-flex;
	align-items: center;
	gap: 14px;
	text-decoration: none;
}
.notal-lockup__mark img,
.notal-lockup__mark svg {
	display: block;
	width: 72px;
	height: 72px;
	background: transparent;
}
@media (max-width: 768px) {
	.notal-lockup__mark img,
	.notal-lockup__mark svg {
		width: 56px;
		height: 56px;
	}
}
.notal-lockup__words {
	display: flex;
	flex-direction: column;
	line-height: 0.88;
}
.notal-lockup__name {
	font-family: var(--notal-ff-sans);
	font-weight: 700;
	font-size: 1.375rem;
	color: var(--notal-c-ink);
	letter-spacing: -0.035em;
	line-height: 0.88;
}
.notal-lockup__name .accent { color: var(--notal-c-accent); }
.notal-lockup__sign {
	margin-top: 7px;
	font-family: var(--notal-ff-serif);
	font-style: italic;
	font-weight: 400;
	font-size: 0.78rem;
	color: var(--notal-c-stone);
	letter-spacing: 0.02em;
}

/* --- Sticky call mobile (CTA téléphone fixe en bas écran) --- */
.notal-sticky-call {
	display: none;
}
@media (max-width: 768px) {
	.notal-sticky-call {
		position: fixed;
		left: 12px;
		right: 12px;
		bottom: 12px;
		z-index: 999;
		display: flex;
		align-items: center;
		justify-content: center;
		gap: 10px;
		padding: 14px 18px;
		background: var(--notal-c-urgence);
		color: var(--notal-c-paper);
		font-family: var(--notal-ff-sans);
		font-weight: 700;
		font-size: 1rem;
		letter-spacing: -0.01em;
		text-decoration: none;
		border-radius: var(--notal-radius-pill);
		box-shadow: 0 8px 24px rgba(214, 63, 31, 0.35);
	}
	body.admin-bar .notal-sticky-call { /* admin-bar offset si admin loggé */ }
}

/* --- Tables (overrides pour les pages tarifs) --- */
.wp-block-table {
	font-family: var(--notal-ff-sans);
}
.wp-block-table table {
	border-collapse: collapse;
	width: 100%;
	background: var(--notal-c-paper);
	border: 1px solid var(--notal-c-rule);
	border-radius: var(--notal-radius-sm);
	overflow: hidden;
}
.wp-block-table thead {
	background: var(--notal-c-bg-alt);
}
.wp-block-table thead th {
	font-weight: 700;
	font-size: 0.8125rem;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--notal-c-primary);
	padding: 14px 18px;
	text-align: left;
}
.wp-block-table tbody td {
	padding: 14px 18px;
	font-size: 0.9375rem;
	color: var(--notal-c-ink);
	border-top: 1px solid var(--notal-c-rule);
}
.wp-block-table tbody tr:hover td { background: rgba(255, 194, 51, 0.05); }

/* --- Listes : check icons --- */
.entry-content ul:not(.wp-block-gallery):not(.wp-block-social-links) {
	list-style: none;
	padding-left: 0;
}
.entry-content ul:not(.wp-block-gallery):not(.wp-block-social-links) > li {
	position: relative;
	padding-left: 28px;
	margin-bottom: 8px;
	line-height: 1.6;
}
.entry-content ul:not(.wp-block-gallery):not(.wp-block-social-links) > li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 7px;
	width: 16px;
	height: 16px;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2311254A' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
	background-size: contain;
	background-repeat: no-repeat;
}

/* --- Headings spacing --- */
.entry-content h2 {
	font-size: 2rem;
	margin: 48px 0 20px;
	letter-spacing: -0.035em;
}
.entry-content h3 {
	font-size: 1.375rem;
	margin: 32px 0 12px;
	letter-spacing: -0.025em;
}

/* --- Galerie WP : grille propre --- */
.wp-block-gallery {
	gap: 16px !important;
}
.wp-block-gallery .wp-block-image img {
	border-radius: var(--notal-radius-sm);
	transition: transform 0.25s ease;
}
.wp-block-gallery .wp-block-image:hover img {
	transform: scale(1.02);
}

/* =========================================================================
   5. PAGES DESIGNÉES — full-width override (Direction B)
   La classe body.notal-fullwidth est ajoutée via functions.php pour les pages
   qui contiennent du contenu design (.notal-home, .notal-page).
   On force l'ensemble de la chain de containers GP en pleine largeur.
   ========================================================================= */
body.notal-fullwidth .site.grid-container,
body.notal-fullwidth .site.container,
body.notal-fullwidth #page.site,
body.notal-fullwidth .site-content,
body.notal-fullwidth #content,
body.notal-fullwidth .content-area,
body.notal-fullwidth #primary,
body.notal-fullwidth .site-main,
body.notal-fullwidth #main,
body.notal-fullwidth .site-main > article,
body.notal-fullwidth .inside-article,
body.notal-fullwidth .entry-content {
	max-width: none !important;
	width: 100% !important;
	padding: 0 !important;
	margin: 0 !important;
}

/* Mais on garde un container interne pour le HEADER (max 1280px). */
body.notal-fullwidth .inside-header.grid-container,
body.notal-fullwidth .inside-navigation.grid-container {
	max-width: var(--notal-container-max) !important;
}

/* Et un container interne pour les SECTIONS notal — limite la lecture. */
body.notal-fullwidth .notal-home > section > *:not(.notal-trust__inner):not(.notal-zones__grid):not(.notal-cta-finale),
body.notal-fullwidth .notal-page > section > *:not(.notal-service-trust__inner):not(.notal-service-zones__grid):not(.notal-service-cta):not(.notal-faq-section__grid):not(.notal-realisations-section__head):not(.notal-services-section__head):not(.notal-prestations-section__head) {
	max-width: var(--notal-container-max);
	margin-left: auto;
	margin-right: auto;
}

/* Alignement gauche cohérent : ciblé uniquement sur les sections boostées
   (celles avec style="background:..." inline injectées par les scripts SEO),
   pour ne pas casser les sections natives du design (crosssell, hero, usps, etc.). */
.notal-page > section[style*="background"] > p,
.notal-page > section[style*="background"] > .notal-section-label,
.notal-page > section[style*="background"] > h1,
.notal-page > section[style*="background"] > h2,
.notal-page > section[style*="background"] > h3,
.notal-page > section[style*="background"] > table,
.notal-page > section[style*="background"] > ul,
.notal-page > section[style*="background"] > ol {
	margin-left: 0;
	margin-right: auto;
}
.notal-page > section[style*="background"] > div:not([class]) {
	margin-left: 0;
	margin-right: auto;
}
/* Le label inline-flex doit être block-level pour respecter la marge gauche
   uniquement dans les sections boostées */
.notal-page > section[style*="background"] > .notal-section-label {
	display: flex;
	width: max-content;
	max-width: 100%;
}

/* Les inner-strips (trust strip, zones bleu nuit, etc.) ont déjà leur propre container. */
.notal-trust__inner,
.notal-service-trust__inner,
.notal-cta-finale,
.notal-zones__grid,
.notal-service-zones__grid,
.notal-faq-section__grid,
.notal-realisations-section__head,
.notal-services-section__head,
.notal-prestations-section__head,
.notal-avis__head,
.notal-avis-grid,
.notal-usps-grid,
.notal-realisations-grid,
.notal-services-grid,
.notal-prestations-grid,
.notal-crosssell-grid,
.notal-crosssell-section__head,
.notal-service-pourquoi__grid,
.notal-timeline-grid,
.notal-valeurs-section__head,
.notal-valeurs-grid,
.notal-certifs-grid,
.notal-apropos-cta__card,
.notal-contact-hero-grid,
.notal-contact-grid,
.notal-manifesto__grid,
.notal-hero,
.notal-hero-page,
.notal-service-hero {
	max-width: var(--notal-container-max);
	margin-left: auto;
	margin-right: auto;
}

/* CTA finale a sa propre marge horizontale */
.notal-cta-finale-section .notal-cta-finale,
.notal-service-cta-section .notal-service-cta,
.notal-contact-map__box {
	max-width: var(--notal-container-max);
	margin-left: auto;
	margin-right: auto;
}

.notal-home > section {
	padding: 100px 80px;
}
@media (max-width: 1024px) {
	.notal-home > section { padding: 72px 32px; }
}
@media (max-width: 640px) {
	.notal-home > section { padding: 48px 20px; }
}

/* Hero accueil */
.notal-hero {
	display: grid;
	grid-template-columns: 1.1fr 0.9fr;
	gap: 64px;
	align-items: center;
	padding-top: 72px !important;
	padding-bottom: 80px !important;
}
@media (max-width: 960px) {
	.notal-hero { grid-template-columns: 1fr; gap: 48px; }
}
.notal-hero__h1 {
	font-family: var(--notal-ff-sans);
	font-weight: 700;
	font-size: clamp(2.5rem, 6vw, 5.5rem);
	line-height: 0.92;
	margin: 22px 0 18px;
	letter-spacing: -0.045em;
	color: var(--notal-c-ink);
}
.notal-hero__h1 .accent-serif {
	font-family: var(--notal-ff-serif);
	font-style: italic;
	font-weight: 500;
	color: var(--notal-c-primary);
}
.notal-hero__lead {
	font-size: 1.1875rem;
	line-height: 1.5;
	color: var(--notal-c-stone);
	margin: 0 0 32px;
	max-width: 580px;
}
.notal-hero__cta-row {
	display: flex;
	align-items: center;
	gap: 14px;
	flex-wrap: wrap;
}
.notal-btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 14px 22px;
	font-family: var(--notal-ff-sans);
	font-weight: 700;
	font-size: 0.9375rem;
	letter-spacing: -0.01em;
	border-radius: var(--notal-radius-pill);
	text-decoration: none;
	border: 1.5px solid transparent;
	cursor: pointer;
	transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}
.notal-btn--lg { padding: 18px 26px; font-size: 1rem; }
.notal-btn--sm { padding: 10px 16px; font-size: 0.8125rem; }
.notal-btn--primary { background: var(--notal-c-primary); color: var(--notal-c-paper); border-color: var(--notal-c-primary); }
.notal-btn--primary:hover { background: var(--notal-c-primary-deep); border-color: var(--notal-c-primary-deep); color: var(--notal-c-paper); }
.notal-btn--accent { background: var(--notal-c-accent); color: var(--notal-c-primary); border-color: var(--notal-c-accent); }
.notal-btn--accent:hover { background: #f0b520; border-color: #f0b520; color: var(--notal-c-primary); }
.notal-btn--ghost { background: transparent; color: var(--notal-c-ink); border-color: var(--notal-c-ink); }
.notal-btn--ghost:hover { background: var(--notal-c-ink); color: var(--notal-c-paper); }
.notal-btn--ghost-light { background: transparent; color: var(--notal-c-paper); border-color: rgba(255, 255, 255, 0.45); }
.notal-btn--ghost-light:hover { background: rgba(255, 255, 255, 0.1); color: var(--notal-c-paper); }

.notal-hero__reassurance {
	margin-top: 36px;
	display: flex;
	align-items: center;
	gap: 24px;
	flex-wrap: wrap;
	font-family: var(--notal-ff-sans);
	font-size: 0.875rem;
	color: var(--notal-c-stone);
}
.notal-hero__reassurance span {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}
.notal-hero__reassurance span::before {
	content: "";
	width: 16px;
	height: 16px;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2311254A' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
	background-size: contain;
	background-repeat: no-repeat;
}

.notal-hero__visual {
	position: relative;
	min-height: 520px;
}
.notal-hero__photo {
	width: 100%;
	height: 100%;
	min-height: 520px;
	object-fit: cover;
	border-radius: var(--notal-radius-sm);
}
.notal-hero__floating-review {
	position: absolute;
	left: -28px;
	bottom: 24px;
	width: 280px;
	background: var(--notal-c-paper);
	border-radius: var(--notal-radius-sm);
	border: 1px solid var(--notal-c-rule);
	padding: 18px;
	box-shadow: 0 10px 30px -10px rgba(14, 14, 16, 0.18);
	font-family: var(--notal-ff-sans);
}
.notal-hero__floating-review-head {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 8px;
}
.notal-hero__floating-review-rate { font-weight: 700; font-size: 0.8125rem; letter-spacing: -0.01em; }
.notal-hero__floating-review-source { font-size: 0.6875rem; color: var(--notal-c-stone); margin-left: auto; display: inline-flex; align-items: center; gap: 4px; }
.notal-hero__floating-review-text { font-family: var(--notal-ff-serif); font-style: italic; font-size: 0.8125rem; line-height: 1.45; color: var(--notal-c-ink); margin: 0; }
.notal-hero__floating-review-meta { margin-top: 8px; font-size: 0.6875rem; color: var(--notal-c-stone); }
.notal-hero__floating-rge {
	position: absolute;
	right: -16px;
	top: 24px;
	transform: rotate(4deg);
	background: var(--notal-c-primary);
	color: var(--notal-c-paper);
	padding: 12px 14px;
	border-radius: var(--notal-radius-xs);
	font-family: var(--notal-ff-sans);
	display: flex;
	align-items: center;
	gap: 10px;
}
.notal-hero__floating-rge-chip {
	width: 36px;
	height: 36px;
	border-radius: var(--notal-radius-xs);
	background: var(--notal-c-accent);
	color: var(--notal-c-primary);
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 800;
	font-size: 0.75rem;
	letter-spacing: 0.04em;
}
.notal-hero__floating-rge-title { font-weight: 700; font-size: 0.8125rem; line-height: 1; letter-spacing: -0.01em; }
.notal-hero__floating-rge-sub { font-size: 0.6875rem; color: rgba(255, 255, 255, 0.7); margin-top: 3px; }
@media (max-width: 960px) {
	.notal-hero__floating-review { left: 0; }
	.notal-hero__floating-rge { right: 0; }
}

/* Trust strip */
.notal-trust {
	background: var(--notal-c-primary);
	color: var(--notal-c-paper);
	padding: 22px 80px !important;
}
@media (max-width: 1024px) { .notal-trust { padding: 22px 32px !important; } }
.notal-trust__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	flex-wrap: wrap;
}
.notal-trust__stat {
	display: flex;
	flex-direction: column;
}
.notal-trust__value {
	font-weight: 700;
	font-size: 1.375rem;
	color: var(--notal-c-paper);
	line-height: 1;
	letter-spacing: -0.03em;
}
.notal-trust__label {
	font-weight: 600;
	font-size: 0.625rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.7);
	margin-top: 4px;
}
.notal-trust__sep {
	width: 1px;
	height: 26px;
	background: rgba(255, 255, 255, 0.18);
}

/* Heading sections — XL */
.notal-h2-xl {
	font-family: var(--notal-ff-sans);
	font-weight: 700;
	font-size: clamp(2rem, 5vw, 3.5rem);
	margin: 18px 0 0;
	letter-spacing: -0.04em;
	line-height: 1;
	color: var(--notal-c-ink);
}
.notal-h2-xl .accent-serif {
	font-family: var(--notal-ff-serif);
	font-style: italic;
	font-weight: 500;
	color: var(--notal-c-ink);
}
.notal-h2-xl--dark { color: var(--notal-c-paper); }
.notal-h2-xl--dark .accent-serif { color: var(--notal-c-accent); }

/* Services section */
.notal-services-section__head {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 40px;
	margin-bottom: 36px;
}
@media (max-width: 880px) { .notal-services-section__head { flex-direction: column; align-items: flex-start; } }
.notal-services-grid {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 14px;
}
@media (max-width: var(--notal-container-max)) { .notal-services-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 720px)  { .notal-services-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px)  { .notal-services-grid { grid-template-columns: 1fr; } }
.notal-service-compact {
	background: var(--notal-c-paper);
	color: var(--notal-c-ink);
	border: 1px solid var(--notal-c-rule);
	border-radius: var(--notal-radius-sm);
	padding: 22px;
	text-decoration: none;
	display: flex;
	flex-direction: column;
	gap: 14px;
	min-height: 320px;
	transition: transform 0.2s, box-shadow 0.2s;
}
.notal-service-compact:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 24px -8px rgba(14, 14, 16, 0.12);
	color: var(--notal-c-ink);
}
.notal-service-compact--featured {
	background: var(--notal-c-primary);
	color: var(--notal-c-paper);
	border-color: transparent;
}
.notal-service-compact--featured:hover { color: var(--notal-c-paper); }
.notal-service-compact__icon {
	width: 48px;
	height: 48px;
	border-radius: var(--notal-radius-xs);
	background: var(--notal-c-primary);
	color: var(--notal-c-accent);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.notal-service-compact--featured .notal-service-compact__icon {
	background: var(--notal-c-accent);
	color: var(--notal-c-primary);
}
.notal-service-compact__title { font-weight: 700; font-size: 1.375rem; letter-spacing: -0.03em; line-height: 1; margin: 0 0 6px; }
.notal-service-compact__sub { font-family: var(--notal-ff-serif); font-style: italic; font-size: 0.875rem; color: var(--notal-c-stone); }
.notal-service-compact--featured .notal-service-compact__sub { color: rgba(255, 255, 255, 0.75); }
.notal-service-compact__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 6px; }
.notal-service-compact__list li { display: flex; align-items: center; gap: 6px; font-size: 0.8125rem; color: var(--notal-c-ink); padding: 0; margin: 0; }
.notal-service-compact--featured .notal-service-compact__list li { color: rgba(255, 255, 255, 0.85); }
.notal-service-compact__list li::before {
	content: "";
	width: 12px;
	height: 12px;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2311254A' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
	background-size: contain;
	background-repeat: no-repeat;
	flex-shrink: 0;
}
.notal-service-compact--featured .notal-service-compact__list li::before {
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23FFC233' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
}
.notal-service-compact__link { margin-top: auto; display: inline-flex; align-items: center; gap: 8px; font-weight: 700; font-size: 0.8125rem; letter-spacing: -0.01em; color: var(--notal-c-primary); }
.notal-service-compact--featured .notal-service-compact__link { color: var(--notal-c-accent); }

/* USP grid */
.notal-usps-section { background: var(--notal-c-bg-alt); }
.notal-usps-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0 36px;
	margin-top: 56px;
}
@media (max-width: 880px) { .notal-usps-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .notal-usps-grid { grid-template-columns: 1fr; } }

/* Réalisations grid */
.notal-realisations-section__head {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	margin-bottom: 36px;
	gap: 40px;
}
@media (max-width: 720px) { .notal-realisations-section__head { flex-direction: column; align-items: flex-start; } }
.notal-realisations-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 20px;
}
@media (max-width: 1024px) { .notal-realisations-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px)  { .notal-realisations-grid { grid-template-columns: 1fr; } }
.notal-project { display: flex; flex-direction: column; gap: 12px; }
.notal-project__visual { aspect-ratio: 4 / 3; overflow: hidden; border-radius: var(--notal-radius-sm); }
.notal-project__visual img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.3s; }
.notal-project:hover .notal-project__visual img { transform: scale(1.03); }
.notal-project__meta { display: flex; align-items: center; gap: 10px; margin-bottom: 6px; flex-wrap: wrap; }
.notal-project__tag {
	font-family: var(--notal-ff-sans);
	font-weight: 700;
	font-size: 0.6875rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--notal-c-primary);
	padding: 3px 8px;
	border: 1px solid var(--notal-c-primary);
	border-radius: var(--notal-radius-xs);
}
.notal-project__place { font-size: 0.75rem; color: var(--notal-c-stone); display: inline-flex; align-items: center; gap: 4px; }
.notal-project__title { font-weight: 700; font-size: 1.125rem; letter-spacing: -0.02em; margin: 0; }

/* Zones section */
.notal-zones-section { background: var(--notal-c-primary); color: var(--notal-c-paper); }
.notal-zones__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
@media (max-width: 960px) { .notal-zones__grid { grid-template-columns: 1fr; } }
.notal-zones__intro { font-size: 1rem; line-height: 1.55; color: rgba(255, 255, 255, 0.75); max-width: 480px; margin: 0 0 36px; }
.notal-zones__villes { display: grid; grid-template-columns: 1fr 1fr; gap: 10px 14px; margin-bottom: 32px; }
.notal-zones__ville {
	display: flex;
	align-items: center;
	gap: 8px;
	color: var(--notal-c-paper);
	text-decoration: none;
	padding: 10px 14px;
	border-radius: var(--notal-radius-xs);
	border: 1px solid rgba(255, 255, 255, 0.18);
	font-size: 0.875rem;
	font-weight: 500;
	transition: background 0.15s, border-color 0.15s;
}
.notal-zones__ville:hover { background: rgba(255, 255, 255, 0.06); border-color: rgba(255, 255, 255, 0.35); color: var(--notal-c-paper); }
.notal-zones__map {
	position: relative;
	aspect-ratio: 1 / 1;
	max-height: 540px;
	background: #0E1F3F;
	border-radius: var(--notal-radius-md);
	overflow: hidden;
	border: 1px solid rgba(255, 255, 255, 0.18);
	display: flex;
	align-items: center;
	justify-content: center;
	color: rgba(255, 255, 255, 0.45);
	font-family: var(--notal-ff-mono);
	font-size: 0.6875rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	text-align: center;
	padding: 24px;
}

/* Avis section */
.notal-avis-section { background: var(--notal-c-bg); }
.notal-avis__head {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 40px;
	margin-bottom: 40px;
	flex-wrap: wrap;
}
.notal-avis__rating-box {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 16px 22px;
	background: var(--notal-c-paper);
	border: 1px solid var(--notal-c-rule);
	border-radius: var(--notal-radius-sm);
}
.notal-avis__rating-num { font-weight: 700; font-size: 2.25rem; color: var(--notal-c-primary); letter-spacing: -0.04em; line-height: 1; }
.notal-avis__rating-meta { font-size: 0.75rem; color: var(--notal-c-stone); margin-top: 4px; display: inline-flex; align-items: center; gap: 4px; }
.notal-avis-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
@media (max-width: 960px) { .notal-avis-grid { grid-template-columns: 1fr; } }

/* FAQ section */
.notal-faq-section__grid {
	display: grid;
	grid-template-columns: 0.55fr 1.45fr;
	gap: 80px;
	align-items: flex-start;
}
@media (max-width: 960px) { .notal-faq-section__grid { grid-template-columns: 1fr; gap: 32px; } }
.notal-faq-section__intro { position: sticky; top: 40px; }

/* CTA finale */
.notal-cta-finale-section {
	padding: 0 40px 80px !important;
}
@media (max-width: 720px) { .notal-cta-finale-section { padding: 0 20px 48px !important; } }
.notal-cta-finale {
	background: var(--notal-c-ink);
	color: var(--notal-c-paper);
	border-radius: 10px;
	padding: 64px;
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: 64px;
	align-items: center;
	position: relative;
	overflow: hidden;
}
@media (max-width: 880px) { .notal-cta-finale { grid-template-columns: 1fr; padding: 40px; } }
.notal-cta-finale__h2 {
	font-family: var(--notal-ff-sans);
	font-weight: 700;
	font-size: clamp(2rem, 5vw, 4rem);
	margin: 20px 0 12px;
	letter-spacing: -0.045em;
	line-height: 0.95;
	color: var(--notal-c-paper);
}
.notal-cta-finale__h2 .accent-serif {
	font-family: var(--notal-ff-serif);
	font-style: italic;
	font-weight: 500;
	color: var(--notal-c-accent);
}
.notal-cta-finale__lead { font-size: 1.0625rem; color: rgba(255, 255, 255, 0.75); margin: 0 0 28px; max-width: 540px; line-height: 1.5; }
.notal-cta-finale__hours {
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.15);
	border-radius: var(--notal-radius-sm);
	padding: 28px;
}
.notal-cta-finale__hours-title {
	font-family: var(--notal-ff-sans);
	font-size: 0.6875rem;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--notal-c-accent);
	font-weight: 700;
	margin-bottom: 14px;
}
.notal-cta-finale__hours-row {
	display: flex;
	justify-content: space-between;
	padding: 10px 0;
	border-bottom: 1px solid rgba(255, 255, 255, 0.12);
	font-size: 0.875rem;
	color: var(--notal-c-paper);
	font-weight: 500;
}
.notal-cta-finale__hours-row:last-child { border-bottom: none; }
.notal-cta-finale__hours-row--urgence { color: var(--notal-c-accent); font-weight: 700; }
.notal-cta-finale__pill {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 5px 12px;
	border-radius: var(--notal-radius-pill);
	background: rgba(214, 63, 31, 0.2);
	color: var(--notal-c-urgence);
	font-family: var(--notal-ff-sans);
	font-weight: 700;
	font-size: 0.6875rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
}

/* =========================================================================
   6. PAGE À PROPOS — sections spécifiques
   ========================================================================= */
body.page-template-default .entry-content,
body.page .entry-content {
	max-width: none;
	padding: 0;
}
body.page .inside-article { padding: 0; }

.notal-page { width: 100%; }
.notal-page > section { padding: 100px 80px; }
@media (max-width: 1024px) { .notal-page > section { padding: 72px 32px; } }
@media (max-width: 640px)  { .notal-page > section { padding: 48px 20px; } }

/* Images directes enfants de section : limitées au container, alignées gauche */
.notal-page > section > img,
body.notal-fullwidth .notal-page > section > img {
	display: block;
	max-width: var(--notal-container-max);
	margin-left: 0;
	margin-right: auto;
}

.notal-hero-page {
	display: grid;
	grid-template-columns: 1.1fr 0.9fr;
	gap: 56px;
	align-items: center;
	padding: 60px 80px 72px !important;
}
@media (max-width: 960px) {
	.notal-hero-page { grid-template-columns: 1fr; gap: 40px; }
}

.notal-quote-card {
	position: absolute;
	left: -28px;
	bottom: 24px;
	width: 280px;
	background: var(--notal-c-paper);
	border-radius: var(--notal-radius-sm);
	border: 1px solid var(--notal-c-rule);
	padding: 22px 22px 18px;
	box-shadow: 0 10px 30px -10px rgba(14, 14, 16, 0.18);
	font-family: var(--notal-ff-sans);
}
.notal-quote-card__icon { color: var(--notal-c-accent); }
.notal-quote-card__text {
	font-family: var(--notal-ff-serif);
	font-style: italic;
	font-size: 1rem;
	line-height: 1.4;
	color: var(--notal-c-ink);
	margin: 10px 0 0;
}
.notal-quote-card__author {
	margin-top: 12px;
	font-size: 0.6875rem;
	color: var(--notal-c-stone);
	letter-spacing: 0.12em;
	text-transform: uppercase;
	font-weight: 600;
}
@media (max-width: 960px) {
	.notal-quote-card { left: 0; }
}

/* Timeline */
.notal-timeline-section { background: var(--notal-c-bg-alt); }
.notal-timeline-grid {
	display: grid;
	grid-template-columns: 0.7fr 1.3fr;
	gap: 80px;
	align-items: flex-start;
}
@media (max-width: 960px) {
	.notal-timeline-grid { grid-template-columns: 1fr; gap: 40px; }
	.notal-timeline-section__intro { position: relative !important; top: 0 !important; }
}
.notal-timeline-section__intro { position: sticky; top: 40px; }
.notal-timeline__entry {
	display: grid;
	grid-template-columns: 120px 1fr;
	gap: 32px;
	padding: 26px 0;
	border-top: 1px solid var(--notal-c-rule);
}
.notal-timeline__entry:last-child { border-bottom: 1px solid var(--notal-c-rule); }
.notal-timeline__year {
	font-family: var(--notal-ff-serif);
	font-weight: 600;
	font-size: 2rem;
	color: var(--notal-c-primary);
	letter-spacing: -0.02em;
	line-height: 1;
	font-style: italic;
}
.notal-timeline__title {
	font-family: var(--notal-ff-sans);
	font-weight: 700;
	font-size: 1.375rem;
	letter-spacing: -0.02em;
	margin: 0 0 8px;
}
.notal-timeline__body {
	font-size: 0.9375rem;
	line-height: 1.55;
	color: var(--notal-c-stone);
	max-width: 580px;
	margin: 0;
}

/* Manifesto strip */
.notal-manifesto {
	background: var(--notal-c-primary);
	padding: 0 !important;
}
.notal-manifesto__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	min-height: 520px;
}
@media (max-width: 960px) { .notal-manifesto__grid { grid-template-columns: 1fr; } }
.notal-manifesto__visual {
	position: relative;
	min-height: 360px;
	background: #0E1F3F;
	overflow: hidden;
}
.notal-manifesto__visual img { width: 100%; height: 100%; object-fit: cover; display: block; }
.notal-manifesto__body {
	padding: 80px 64px;
	color: var(--notal-c-paper);
	display: flex;
	flex-direction: column;
	justify-content: center;
}
@media (max-width: 720px) { .notal-manifesto__body { padding: 48px 24px; } }
.notal-manifesto__quote {
	font-family: var(--notal-ff-serif);
	font-style: italic;
	font-weight: 500;
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	line-height: 1.2;
	margin: 20px 0 28px;
	color: var(--notal-c-paper);
	letter-spacing: -0.01em;
}
.notal-manifesto__author {
	display: flex;
	align-items: center;
	gap: 14px;
	margin-top: 8px;
}
.notal-manifesto__avatar {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background: var(--notal-c-accent);
	color: var(--notal-c-primary);
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--notal-ff-sans);
	font-weight: 700;
	font-size: 1.125rem;
	letter-spacing: -0.02em;
}
.notal-manifesto__name { font-family: var(--notal-ff-sans); font-weight: 700; font-size: 1rem; color: var(--notal-c-paper); letter-spacing: -0.01em; }
.notal-manifesto__role { font-family: var(--notal-ff-sans); font-size: 0.75rem; color: rgba(255, 255, 255, 0.65); letter-spacing: 0.12em; text-transform: uppercase; margin-top: 4px; }

/* Valeurs (4 cells) */
.notal-valeurs-section__head {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	gap: 40px;
	margin-bottom: 50px;
	flex-wrap: wrap;
}
.notal-valeurs-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0;
}
@media (max-width: 720px) { .notal-valeurs-grid { grid-template-columns: 1fr; } }
.notal-valeurs-grid::after {
	content: "";
	grid-column: 1 / -1;
	border-top: 1px solid var(--notal-c-rule);
}
.notal-valeur {
	padding: 36px 36px 36px 0;
	border-top: 1px solid var(--notal-c-rule);
}
.notal-valeur:nth-child(odd)  { border-right: 1px solid var(--notal-c-rule); padding-left: 0; }
.notal-valeur:nth-child(even) { padding-left: 36px; padding-right: 0; }
@media (max-width: 720px) {
	.notal-valeur, .notal-valeur:nth-child(odd), .notal-valeur:nth-child(even) {
		padding: 28px 0;
		border-right: none;
	}
}
.notal-valeur__head { display: flex; align-items: baseline; gap: 16px; margin-bottom: 14px; }
.notal-valeur__num { font-family: var(--notal-ff-mono); font-size: 0.6875rem; letter-spacing: 0.18em; color: var(--notal-c-primary); font-weight: 600; }
.notal-valeur__title { font-family: var(--notal-ff-sans); font-weight: 700; font-size: 1.75rem; margin: 0; letter-spacing: -0.03em; line-height: 1.05; }
.notal-valeur__body { font-size: 0.96875rem; line-height: 1.6; color: var(--notal-c-stone); margin: 0; max-width: 520px; }

/* Certifications */
.notal-certifs-section { background: var(--notal-c-bg-alt); padding: 80px 80px !important; }
@media (max-width: 1024px) { .notal-certifs-section { padding: 72px 32px !important; } }
.notal-certifs-grid {
	display: grid;
	grid-template-columns: 1.1fr 0.9fr;
	gap: 64px;
	align-items: center;
}
@media (max-width: 880px) { .notal-certifs-grid { grid-template-columns: 1fr; gap: 40px; } }
.notal-certifs-list {
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.notal-certifs-row {
	display: flex;
	justify-content: space-between;
	gap: 16px;
	padding: 12px 0;
	border-bottom: 1px solid var(--notal-c-rule);
}
.notal-certifs-row__k { font-family: var(--notal-ff-sans); font-weight: 600; font-size: 0.875rem; color: var(--notal-c-ink); letter-spacing: -0.01em; }
.notal-certifs-row__v { font-family: var(--notal-ff-sans); font-size: 0.84375rem; color: var(--notal-c-stone); text-align: right; }

.notal-big-rge {
	background: var(--notal-c-paper);
	border-radius: var(--notal-radius-md);
	padding: 36px 32px;
	border: 1px solid var(--notal-c-rule);
	display: flex;
	flex-direction: column;
	gap: 20px;
}
.notal-big-rge__head { display: flex; align-items: center; gap: 16px; }
.notal-big-rge__chip {
	width: 72px;
	height: 72px;
	border-radius: var(--notal-radius-sm);
	background: var(--notal-c-primary);
	color: var(--notal-c-accent);
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 800;
	font-size: 1.375rem;
	letter-spacing: 0.04em;
}
.notal-big-rge__title { font-family: var(--notal-ff-sans); font-weight: 700; font-size: 1.375rem; letter-spacing: -0.02em; line-height: 1.1; }
.notal-big-rge__sub { font-family: var(--notal-ff-serif); font-style: italic; font-size: 0.875rem; color: var(--notal-c-stone); margin-top: 4px; }
.notal-big-rge__aides { display: flex; flex-direction: column; gap: 8px; }
.notal-big-rge__aides span { display: flex; align-items: center; gap: 8px; font-size: 0.875rem; color: var(--notal-c-ink); }
.notal-big-rge__aides span::before {
	content: "";
	width: 14px;
	height: 14px;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2311254A' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
	background-size: contain;
	background-repeat: no-repeat;
	flex-shrink: 0;
}

/* Card CTA "On se parle ?" */
.notal-apropos-cta { padding: 80px 80px 100px !important; }
@media (max-width: 1024px) { .notal-apropos-cta { padding: 72px 32px !important; } }
.notal-apropos-cta__card {
	background: var(--notal-c-paper);
	border-radius: 10px;
	padding: 56px;
	border: 1px solid var(--notal-c-rule);
	display: grid;
	grid-template-columns: 1.3fr 1fr;
	gap: 56px;
	align-items: center;
}
@media (max-width: 880px) {
	.notal-apropos-cta__card { grid-template-columns: 1fr; padding: 40px; gap: 36px; }
}

/* =========================================================================
   7. PAGE CONTACT — sections spécifiques
   ========================================================================= */
.notal-contact-hero-grid {
	display: grid;
	grid-template-columns: 1.2fr 0.8fr;
	gap: 56px;
	align-items: flex-end;
}
@media (max-width: 880px) { .notal-contact-hero-grid { grid-template-columns: 1fr; gap: 24px; align-items: flex-start; } }

.notal-contact-body { padding: 32px 80px 80px !important; }
@media (max-width: 1024px) { .notal-contact-body { padding: 32px 32px 72px !important; } }
@media (max-width: 640px)  { .notal-contact-body { padding: 24px 20px 48px !important; } }
.notal-contact-grid {
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: 56px;
	align-items: flex-start;
}
@media (max-width: 960px) { .notal-contact-grid { grid-template-columns: 1fr; gap: 32px; } }

.notal-form {
	background: var(--notal-c-paper);
	border: 1px solid var(--notal-c-rule);
	border-radius: 10px;
	padding: 40px;
}
@media (max-width: 640px) { .notal-form { padding: 28px 20px; } }
.notal-form__title { font-family: var(--notal-ff-sans); font-weight: 700; font-size: 1.625rem; letter-spacing: -0.03em; margin: 0 0 8px; }
.notal-form__sub   { font-family: var(--notal-ff-serif); font-style: italic; font-size: 0.9375rem; color: var(--notal-c-stone); margin: 0 0 28px; }
.notal-form__chips { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 10px; }
.notal-chip {
	padding: 9px 16px;
	border-radius: var(--notal-radius-pill);
	font-size: 0.8125rem;
	font-family: var(--notal-ff-sans);
	font-weight: 600;
	cursor: pointer;
	border: 1px solid var(--notal-c-rule);
	background: var(--notal-c-paper);
	color: var(--notal-c-ink);
	transition: border 0.15s, background 0.15s, color 0.15s;
}
.notal-chip:hover { border-color: var(--notal-c-primary); }
.notal-chip--active,
.notal-chip[aria-pressed="true"] {
	border: 1.5px solid var(--notal-c-primary);
	background: var(--notal-c-primary);
	color: var(--notal-c-paper);
}
.notal-form__field-label { font-family: var(--notal-ff-sans); font-weight: 600; font-size: 0.8125rem; color: var(--notal-c-ink); letter-spacing: -0.01em; display: block; margin-bottom: 6px; }
.notal-form__field-label--required::after { content: " *"; color: var(--notal-c-urgence); }
.notal-form__field-hint { margin-top: 4px; font-size: 0.75rem; color: var(--notal-c-stone); font-style: italic; font-family: var(--notal-ff-serif); }
.notal-form__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
@media (max-width: 560px) { .notal-form__grid { grid-template-columns: 1fr; } }
.notal-form__field-full { grid-column: 1 / -1; }

.notal-input,
.notal-form input[type="text"],
.notal-form input[type="email"],
.notal-form input[type="tel"],
.notal-form select,
.notal-form textarea {
	width: 100%;
	box-sizing: border-box;
	padding: 12px 14px;
	font-family: var(--notal-ff-sans);
	font-size: 0.90625rem;
	color: var(--notal-c-ink);
	border: 1.5px solid var(--notal-c-rule);
	border-radius: var(--notal-radius-xs);
	background: var(--notal-c-bg);
	outline: none;
	transition: border-color 0.15s;
}
.notal-form input:focus,
.notal-form select:focus,
.notal-form textarea:focus {
	border-color: var(--notal-c-primary);
}
.notal-form textarea { min-height: 110px; resize: vertical; font-family: var(--notal-ff-sans); }
.notal-form__consent { display: flex; align-items: center; gap: 10px; margin-top: 18px; font-size: 0.8125rem; color: var(--notal-c-stone); }
.notal-form__consent input { accent-color: var(--notal-c-primary); }
.notal-form__footer { margin-top: 24px; display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.notal-form__rgpd { font-size: 0.75rem; color: var(--notal-c-stone); max-width: 320px; line-height: 1.5; margin: 0; }

/* Aside contact */
.notal-aside { display: flex; flex-direction: column; gap: 16px; position: sticky; top: 24px; }
@media (max-width: 960px) { .notal-aside { position: relative; top: 0; } }
.notal-aside__card {
	background: var(--notal-c-paper);
	border: 1px solid var(--notal-c-rule);
	padding: 22px 24px;
	border-radius: var(--notal-radius-sm);
}
.notal-aside__card--urgence {
	background: var(--notal-c-urgence);
	color: var(--notal-c-paper);
	border-color: transparent;
}
.notal-aside__title {
	font-family: var(--notal-ff-sans);
	font-weight: 700;
	font-size: 0.6875rem;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--notal-c-primary);
}
.notal-aside__card--urgence .notal-aside__title { color: var(--notal-c-accent); display: inline-flex; align-items: center; gap: 8px; }
.notal-aside__phone {
	font-family: var(--notal-ff-sans);
	font-weight: 700;
	font-size: 1.875rem;
	color: var(--notal-c-paper);
	letter-spacing: -0.03em;
	text-decoration: none;
	display: block;
	margin-top: 4px;
	line-height: 1;
}
.notal-aside__phone--ink { color: var(--notal-c-ink); font-size: 1.375rem; }
.notal-aside__text { font-size: 0.84375rem; margin-top: 10px; color: rgba(255, 255, 255, 0.88); line-height: 1.45; }
.notal-aside__email { font-size: 0.875rem; color: var(--notal-c-stone); text-decoration: underline; display: block; margin-top: 8px; }
.notal-aside__addr { font-size: 0.90625rem; line-height: 1.55; color: var(--notal-c-ink); margin: 4px 0 0; }
.notal-aside__itin { margin-top: 12px; display: inline-flex; align-items: center; gap: 8px; font-family: var(--notal-ff-sans); font-weight: 700; font-size: 0.8125rem; color: var(--notal-c-primary); text-decoration: none; letter-spacing: -0.01em; }
.notal-aside__hours { font-size: 0.875rem; font-family: var(--notal-ff-sans); margin-top: 8px; }
.notal-aside__hours-row { display: flex; justify-content: space-between; gap: 10px; padding: 8px 0; border-bottom: 1px solid var(--notal-c-rule); color: var(--notal-c-ink); font-weight: 500; }
.notal-aside__hours-row:last-child { border-bottom: none; }
.notal-aside__hours-row--urgence { color: var(--notal-c-urgence); font-weight: 700; }
.notal-aside__hours-row--urgence span { color: var(--notal-c-urgence); }
.notal-aside__hours-row span:last-child { color: var(--notal-c-stone); }
.notal-aside__hours-row--urgence span:last-child { color: var(--notal-c-urgence); font-weight: 700; }

/* Map contact */
.notal-contact-map { padding: 0 40px 80px !important; }
@media (max-width: 640px) { .notal-contact-map { padding: 0 20px 48px !important; } }
.notal-contact-map__box {
	position: relative;
	height: 440px;
	border-radius: 10px;
	overflow: hidden;
	border: 1px solid var(--notal-c-rule);
	background: var(--notal-c-primary);
	display: flex;
	align-items: center;
	justify-content: center;
	color: rgba(255, 255, 255, 0.5);
	font-family: var(--notal-ff-mono);
	font-size: 0.8125rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	text-align: center;
	padding: 24px;
}
.notal-contact-map__addr-card {
	position: absolute;
	left: 32px;
	top: 32px;
	background: var(--notal-c-paper);
	padding: 22px 24px;
	border-radius: var(--notal-radius-sm);
	max-width: 320px;
	text-align: left;
	letter-spacing: normal;
	color: var(--notal-c-ink);
	font-family: var(--notal-ff-sans);
	text-transform: none;
	font-size: 0.875rem;
}
@media (max-width: 640px) {
	.notal-contact-map__addr-card { left: 16px; top: 16px; right: 16px; max-width: none; }
}

/* =========================================================================
   8. PAGE SERVICE MÉTIER — sections spécifiques
   ========================================================================= */
.notal-service-hero {
	display: grid;
	grid-template-columns: 1.15fr 0.85fr;
	gap: 56px;
	align-items: center;
	padding: 60px 80px 64px !important;
}
@media (max-width: 960px) { .notal-service-hero { grid-template-columns: 1fr; gap: 40px; } }
.notal-service-hero__h1 {
	font-family: var(--notal-ff-sans);
	font-weight: 700;
	font-size: clamp(2.5rem, 6vw, 5.5rem);
	line-height: 0.92;
	margin: 22px 0 18px;
	letter-spacing: -0.045em;
	color: var(--notal-c-ink);
}
.notal-service-hero__h1 .accent-serif {
	font-family: var(--notal-ff-serif);
	font-style: italic;
	font-weight: 500;
	color: var(--notal-c-primary);
}
.notal-service-hero__lead {
	font-size: 1.1875rem;
	line-height: 1.5;
	color: var(--notal-c-stone);
	margin: 0 0 28px;
	max-width: 560px;
}
.notal-service-hero__stats {
	margin-top: 32px;
	display: flex;
	align-items: center;
	gap: 22px;
	flex-wrap: wrap;
}
.notal-service-hero__stats .notal-trust__sep { background: var(--notal-c-rule); }
.notal-service-hero__stat-value { font-family: var(--notal-ff-sans); font-weight: 700; font-size: 1.375rem; line-height: 1; letter-spacing: -0.03em; color: var(--notal-c-ink); }
.notal-service-hero__stat-label { font-family: var(--notal-ff-sans); font-weight: 600; font-size: 0.625rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--notal-c-stone); margin-top: 4px; }
.notal-service-hero__tag {
	position: absolute;
	left: -20px;
	bottom: 28px;
	background: var(--notal-c-primary);
	color: var(--notal-c-paper);
	padding: 20px 22px;
	border-radius: var(--notal-radius-sm);
	display: flex;
	align-items: center;
	gap: 14px;
	box-shadow: 0 14px 30px -10px rgba(14, 14, 16, 0.25);
}
.notal-service-hero__tag-icon {
	width: 52px;
	height: 52px;
	border-radius: var(--notal-radius-xs);
	background: var(--notal-c-accent);
	color: var(--notal-c-primary);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.notal-service-hero__tag-label { font-family: var(--notal-ff-sans); font-size: 0.6875rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--notal-c-accent); font-weight: 700; }
.notal-service-hero__tag-title { font-family: var(--notal-ff-sans); font-weight: 700; font-size: 1.25rem; letter-spacing: -0.02em; margin-top: 2px; }
@media (max-width: 960px) { .notal-service-hero__tag { left: 0; } }

/* Service trust strip (5 check items) */
.notal-service-trust {
	background: var(--notal-c-primary);
	color: var(--notal-c-paper);
	padding: 20px 80px !important;
}
@media (max-width: 1024px) { .notal-service-trust { padding: 20px 32px !important; } }
.notal-service-trust__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	flex-wrap: wrap;
	font-family: var(--notal-ff-sans);
	font-size: 0.84375rem;
	color: rgba(255, 255, 255, 0.85);
}
.notal-service-trust__item { display: flex; align-items: center; gap: 12px; }
.notal-service-trust__item::before {
	content: "";
	width: 16px;
	height: 16px;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23FFC233' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
	background-size: contain;
	background-repeat: no-repeat;
	flex-shrink: 0;
}

/* Prestations grid 3 col */
.notal-prestations-section__head {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 40px;
	margin-bottom: 36px;
	flex-wrap: wrap;
}
.notal-prestations-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 18px;
}
@media (max-width: 960px) { .notal-prestations-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .notal-prestations-grid { grid-template-columns: 1fr; } }
.notal-prestation {
	background: var(--notal-c-paper);
	border: 1px solid var(--notal-c-rule);
	border-radius: var(--notal-radius-sm);
	padding: 26px;
	display: flex;
	flex-direction: column;
	gap: 14px;
}
.notal-prestation__head {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 14px;
}
.notal-prestation__icon {
	width: 48px;
	height: 48px;
	border-radius: var(--notal-radius-xs);
	background: var(--notal-c-primary);
	color: var(--notal-c-accent);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.notal-prestation__price {
	padding: 5px 10px;
	background: var(--notal-c-bg-alt);
	color: var(--notal-c-primary);
	border-radius: var(--notal-radius-xs);
	font-family: var(--notal-ff-mono);
	font-size: 0.6875rem;
	letter-spacing: 0.08em;
	font-weight: 500;
	white-space: nowrap;
}
.notal-prestation__title { font-family: var(--notal-ff-sans); font-weight: 700; font-size: 1.25rem; letter-spacing: -0.02em; margin: 0; }
.notal-prestation__body { font-size: 0.875rem; line-height: 1.55; color: var(--notal-c-stone); margin: 0; }
.notal-prestation__link { margin-top: auto; display: inline-flex; align-items: center; gap: 6px; font-family: var(--notal-ff-sans); font-weight: 700; font-size: 0.8125rem; color: var(--notal-c-primary); text-decoration: none; letter-spacing: -0.01em; }

/* Pourquoi service (grid 2 col + sub-grid 2x2 cards) */
.notal-service-pourquoi { background: var(--notal-c-bg-alt); padding: 80px 80px !important; }
@media (max-width: 1024px) { .notal-service-pourquoi { padding: 72px 32px !important; } }
.notal-service-pourquoi__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 64px;
	align-items: center;
}
@media (max-width: 880px) { .notal-service-pourquoi__grid { grid-template-columns: 1fr; gap: 40px; } }
.notal-service-pourquoi__cards {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0;
}
.notal-service-pourquoi__card {
	padding: 24px;
	background: var(--notal-c-paper);
	border: 1px solid var(--notal-c-rule);
	margin-right: -1px;
	margin-bottom: -1px;
}
.notal-service-pourquoi__card-icon {
	width: 40px;
	height: 40px;
	border-radius: var(--notal-radius-xs);
	background: var(--notal-c-primary);
	color: var(--notal-c-accent);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 12px;
}
.notal-service-pourquoi__card-title { font-family: var(--notal-ff-sans); font-weight: 700; font-size: 1.0625rem; letter-spacing: -0.02em; margin: 0; }
.notal-service-pourquoi__card-body { font-size: 0.84375rem; line-height: 1.5; color: var(--notal-c-stone); margin: 6px 0 0; }

/* Service zones (grid 3 villes) */
.notal-service-zones { background: var(--notal-c-primary); color: var(--notal-c-paper); padding: 80px 80px !important; }
@media (max-width: 1024px) { .notal-service-zones { padding: 72px 32px !important; } }
.notal-service-zones__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 64px;
	align-items: center;
}
@media (max-width: 960px) { .notal-service-zones__grid { grid-template-columns: 1fr; gap: 40px; } }
.notal-service-zones__villes {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	gap: 8px;
}
@media (max-width: 560px) { .notal-service-zones__villes { grid-template-columns: 1fr 1fr; } }
.notal-service-zones__ville {
	display: flex;
	align-items: center;
	gap: 6px;
	padding: 10px 12px;
	border-radius: var(--notal-radius-xs);
	border: 1px solid rgba(255, 255, 255, 0.18);
	font-size: 0.8125rem;
	color: var(--notal-c-paper);
	text-decoration: none;
	font-family: var(--notal-ff-sans);
	font-weight: 500;
	transition: background 0.15s;
}
.notal-service-zones__ville:hover { background: rgba(255, 255, 255, 0.08); color: var(--notal-c-paper); }

/* Cross-sell autres services (4 cards) */
.notal-crosssell-section { background: var(--notal-c-bg-alt); padding: 80px 80px !important; }
@media (max-width: 1024px) { .notal-crosssell-section { padding: 72px 32px !important; } }
.notal-crosssell-section__head {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	gap: 40px;
	margin-bottom: 28px;
	flex-wrap: wrap;
}
.notal-crosssell-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 14px;
}
@media (max-width: 880px) { .notal-crosssell-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .notal-crosssell-grid { grid-template-columns: 1fr; } }
.notal-crosssell-card {
	background: var(--notal-c-paper);
	border: 1px solid var(--notal-c-rule);
	border-radius: var(--notal-radius-sm);
	padding: 22px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	text-decoration: none;
	color: var(--notal-c-ink);
	min-height: 200px;
	transition: transform 0.2s, box-shadow 0.2s;
}
.notal-crosssell-card:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 24px -8px rgba(14, 14, 16, 0.12);
	color: var(--notal-c-ink);
}
.notal-crosssell-card__icon {
	width: 44px;
	height: 44px;
	border-radius: var(--notal-radius-xs);
	background: var(--notal-c-primary);
	color: var(--notal-c-accent);
	display: flex;
	align-items: center;
	justify-content: center;
}
.notal-crosssell-card__title { font-family: var(--notal-ff-sans); font-weight: 700; font-size: 1.125rem; letter-spacing: -0.02em; }
.notal-crosssell-card__sub { font-family: var(--notal-ff-serif); font-style: italic; font-size: 0.8125rem; color: var(--notal-c-stone); }
.notal-crosssell-card__link { margin-top: auto; display: inline-flex; align-items: center; gap: 6px; font-family: var(--notal-ff-sans); font-weight: 700; font-size: 0.8125rem; color: var(--notal-c-primary); letter-spacing: -0.01em; }

/* Service CTA finale (dark + engagement table) */
.notal-service-cta-section { padding: 0 40px 80px !important; }
@media (max-width: 720px) { .notal-service-cta-section { padding: 0 20px 48px !important; } }
.notal-service-cta {
	background: var(--notal-c-ink);
	color: var(--notal-c-paper);
	border-radius: 10px;
	padding: 56px;
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: 56px;
	align-items: center;
	position: relative;
	overflow: hidden;
}
@media (max-width: 880px) { .notal-service-cta { grid-template-columns: 1fr; padding: 40px; gap: 36px; } }
.notal-service-cta__engagement {
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.15);
	border-radius: var(--notal-radius-sm);
	padding: 24px;
}
.notal-service-cta__engagement-title {
	font-family: var(--notal-ff-sans);
	font-size: 0.6875rem;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--notal-c-accent);
	font-weight: 700;
	margin-bottom: 12px;
}
.notal-service-cta__engagement-row {
	display: flex;
	justify-content: space-between;
	padding: 10px 0;
	border-bottom: 1px solid rgba(255, 255, 255, 0.12);
	font-size: 0.84375rem;
	font-family: var(--notal-ff-sans);
	font-weight: 500;
}
.notal-service-cta__engagement-row:last-child { border-bottom: none; }
.notal-service-cta__engagement-k { color: rgba(255, 255, 255, 0.7); }
.notal-service-cta__engagement-v { font-weight: 700; color: var(--notal-c-accent); }
.notal-service-cta__h2 {
	font-family: var(--notal-ff-sans);
	font-weight: 700;
	font-size: clamp(2rem, 5vw, 3.5rem);
	margin: 16px 0 12px;
	letter-spacing: -0.045em;
	line-height: 0.95;
	color: var(--notal-c-paper);
}
.notal-service-cta__h2 .accent-serif {
	font-family: var(--notal-ff-serif);
	font-style: italic;
	font-weight: 500;
	color: var(--notal-c-accent);
}
.notal-service-cta__lead {
	font-size: 1.0625rem;
	color: rgba(255, 255, 255, 0.75);
	margin: 0 0 28px;
	max-width: 520px;
	line-height: 1.5;
}

/* =========================================================================
   9ter. FORM STATUS (confirmation / erreur formulaire contact)
   ========================================================================= */
.notal-form-status {
	max-width: var(--notal-container-max);
	margin: 32px auto 0;
	padding: 18px 24px;
	border-radius: var(--notal-radius-sm);
	font-family: var(--notal-ff-sans);
	font-size: 0.9375rem;
	line-height: 1.5;
}
.notal-form-status--success {
	background: var(--notal-c-accent-soft);
	color: var(--notal-c-primary);
	border: 1px solid var(--notal-c-accent);
}
.notal-form-status--error {
	background: rgba(214, 63, 31, 0.08);
	color: var(--notal-c-urgence-deep);
	border: 1px solid var(--notal-c-urgence);
}
.notal-form-status a { color: inherit; text-decoration: underline; }

/* =========================================================================
   9bis. MAIN NAVIGATION — style Direction B
   ========================================================================= */

/* Header complet en ivoire pour rester homogène avec le menu */
.site-header,
.site-header .inside-header,
.site-header.grid-container,
.site-header .inside-header.grid-container {
	background: var(--notal-c-bg) !important;
}

/* Navigation principale : fond ivoire continu, bordure bas subtile */
.main-navigation,
.main-navigation ul ul {
	background: transparent !important;
}
.main-navigation,
.main-navigation .inside-navigation {
	background: var(--notal-c-bg) !important;
	border-bottom: 1px solid var(--notal-c-rule);
}
.main-navigation .main-nav > ul > li > a {
	font-family: var(--notal-ff-sans);
	font-weight: 500;
	font-size: 0.9375rem;
	letter-spacing: -0.01em;
	color: var(--notal-c-ink) !important;
	padding: 18px 18px;
	transition: color 0.15s;
}
.main-navigation .main-nav > ul > li:hover > a,
.main-navigation .main-nav > ul > li.sfHover > a,
.main-navigation .main-nav > ul > li.current-menu-item > a,
.main-navigation .main-nav > ul > li.current-menu-parent > a,
.main-navigation .main-nav > ul > li.current-menu-ancestor > a {
	color: var(--notal-c-primary) !important;
	font-weight: 700;
}
.main-navigation .main-nav > ul > li.current-menu-item > a {
	box-shadow: inset 0 -2px 0 var(--notal-c-primary);
}

/* Caret de dropdown : on laisse GeneratePress afficher son icône native
   (.dropdown-menu-toggle). On la stylise juste pour rester cohérent. */
.main-navigation .dropdown-menu-toggle {
	color: var(--notal-c-ink);
}

/* Sous-menu dropdown */
.main-navigation .main-nav ul ul {
	background: var(--notal-c-paper) !important;
	border: 1px solid var(--notal-c-rule);
	border-radius: var(--notal-radius-sm);
	box-shadow: 0 10px 30px -10px rgba(14, 14, 16, 0.15);
	padding: 8px 0;
	min-width: 220px;
}
.main-navigation .main-nav ul ul li a {
	color: var(--notal-c-ink) !important;
	font-family: var(--notal-ff-sans);
	font-weight: 500;
	font-size: 0.875rem;
	padding: 10px 18px;
}
.main-navigation .main-nav ul ul li:hover > a,
.main-navigation .main-nav ul ul li.current-menu-item > a {
	color: var(--notal-c-primary) !important;
	background: var(--notal-c-bg-alt) !important;
	font-weight: 600;
}

/* Mobile menu toggle */
.menu-toggle { color: var(--notal-c-ink) !important; }
.mobile-menu-control-wrapper .menu-toggle { background: transparent !important; }

/* =========================================================================
   9. MOBILE FIXES (≤ 768px)
   ========================================================================= */
@media (max-width: 768px) {

	/* Header : cacher le CTA "Urgence 24/7" — déjà présent dans le top-bar
	   et le sticky-call mobile en bas. Évite la triple redondance. */
	.main-navigation a.notal-btn--urgence,
	.inside-navigation > a.notal-btn--urgence,
	.main-navigation > a[href^="tel:"] {
		display: none !important;
	}

	/* Top bar mobile */
	.notal-topbar__inner { padding: 8px 16px; }
	.notal-topbar__label { font-size: 0.625rem; letter-spacing: 0.18em; }
	.notal-topbar__cta { font-size: 0.8125rem; }

	/* Header : padding réduit */
	body.notal-fullwidth .inside-header.grid-container {
		padding: 12px 16px !important;
	}

	/* Hero accueil / pages : moins de padding, gap réduit */
	.notal-hero,
	.notal-hero-page,
	.notal-service-hero {
		padding: 24px 20px 40px !important;
		gap: 28px !important;
	}
	.notal-hero__h1,
	.notal-service-hero__h1 {
		font-size: clamp(2rem, 8vw, 2.75rem);
		line-height: 0.96;
		margin: 18px 0 14px;
	}
	.notal-hero__lead,
	.notal-service-hero__lead { font-size: 1rem; }
	.notal-hero__cta-row {
		flex-direction: column;
		align-items: stretch;
		gap: 10px;
	}
	.notal-hero__cta-row .notal-btn { justify-content: center; }
	.notal-hero__reassurance {
		flex-wrap: wrap;
		gap: 12px 20px;
		margin-top: 24px;
	}

	/* Pill plus compact */
	.notal-pill {
		font-size: 0.625rem;
		padding: 5px 10px;
		letter-spacing: 0.12em;
		line-height: 1.3;
	}

	/* Floating cards : repositionnées en flow normal sous la photo */
	.notal-hero__visual { min-height: auto; }
	.notal-hero__photo { min-height: auto; aspect-ratio: 4 / 5; height: auto; }
	.notal-hero__floating-review,
	.notal-hero__floating-rge,
	.notal-quote-card,
	.notal-service-hero__tag {
		position: static;
		transform: none;
		left: auto; right: auto; top: auto; bottom: auto;
		margin-top: 14px;
		width: auto;
	}

	/* Trust strip : grid 3 cols */
	.notal-trust { padding: 16px 20px !important; }
	.notal-trust__inner {
		display: grid;
		grid-template-columns: repeat(3, 1fr);
		gap: 16px;
		text-align: center;
	}
	.notal-trust__sep { display: none; }
	.notal-trust__stat { align-items: center; text-align: center; }
	.notal-trust__value { font-size: 1.125rem; }
	.notal-trust__label { font-size: 0.5625rem; letter-spacing: 0.14em; }

	/* Service trust strip : colonne */
	.notal-service-trust { padding: 16px 20px !important; }
	.notal-service-trust__inner {
		flex-direction: column;
		align-items: flex-start;
		gap: 8px;
	}

	/* Sections internes : réduire padding partout */
	.notal-page > section,
	.notal-home > section {
		padding: 56px 20px !important;
	}

	/* Service hero stats : grid 2 cols */
	.notal-service-hero__stats {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		gap: 16px;
	}
	.notal-service-hero__stats .notal-trust__sep { display: none; }

	/* H2 XL plus petit */
	.notal-h2-xl { font-size: clamp(1.625rem, 7vw, 2.25rem); }

	/* Services 5 grid en mono-col compact */
	.notal-services-grid { gap: 12px; }
	.notal-service-compact { min-height: auto; padding: 18px; }

	/* USPs */
	.notal-usps-grid { gap: 0; margin-top: 32px; }
	.notal-usp { padding: 20px 0; }

	/* Réalisations */
	.notal-realisations-grid { gap: 14px; }
	.notal-project__visual { aspect-ratio: 16 / 11; }

	/* Zones / Map */
	.notal-zones__grid,
	.notal-service-zones__grid {
		grid-template-columns: 1fr;
		gap: 32px;
	}
	.notal-zones__villes,
	.notal-service-zones__villes { grid-template-columns: 1fr; }
	.notal-zones__map,
	.notal-contact-map__box {
		aspect-ratio: 4 / 3;
		max-height: 320px;
	}

	/* Avis */
	.notal-avis__head { flex-direction: column; align-items: flex-start; gap: 24px; }
	.notal-avis-grid { gap: 14px; }

	/* FAQ */
	.notal-faq-section__grid { grid-template-columns: 1fr; gap: 24px; }
	.notal-faq-section__intro { position: static !important; top: auto !important; }
	.notal-faq summary { font-size: 1rem; padding: 16px 0; }

	/* CTA finale */
	.notal-cta-finale,
	.notal-service-cta {
		grid-template-columns: 1fr;
		padding: 28px 24px;
		gap: 28px;
	}
	.notal-cta-finale__h2,
	.notal-service-cta__h2 { font-size: clamp(1.5rem, 7vw, 2rem); }

	/* Sticky call : laisser de la place en bas */
	body.notal-fullwidth .notal-footer { padding-bottom: 100px; }

	/* Page À propos */
	.notal-timeline-grid { grid-template-columns: 1fr; gap: 32px; }
	.notal-timeline-section__intro { position: static !important; top: auto !important; }
	.notal-timeline__entry { grid-template-columns: 80px 1fr; gap: 16px; padding: 18px 0; }
	.notal-timeline__year { font-size: 1.5rem; }
	.notal-timeline__title { font-size: 1.125rem; }

	/* Manifesto strip */
	.notal-manifesto__grid { grid-template-columns: 1fr; }
	.notal-manifesto__visual { min-height: 240px; aspect-ratio: 16/10; }
	.notal-manifesto__body { padding: 32px 20px; }
	.notal-manifesto__quote { font-size: 1.25rem; }

	/* Valeurs */
	.notal-valeurs-grid { grid-template-columns: 1fr; }
	.notal-valeurs-section__head { flex-direction: column; align-items: flex-start; gap: 16px; margin-bottom: 28px; }
	.notal-valeur,
	.notal-valeur:nth-child(odd),
	.notal-valeur:nth-child(even) {
		padding: 24px 0;
		border-right: none;
		padding-left: 0;
		padding-right: 0;
	}
	.notal-valeur__title { font-size: 1.375rem; }

	/* Certifs / Apropos CTA */
	.notal-certifs-grid { grid-template-columns: 1fr; gap: 28px; }
	.notal-apropos-cta__card { grid-template-columns: 1fr; padding: 28px 20px; gap: 24px; }

	/* Contact */
	.notal-contact-hero-grid { grid-template-columns: 1fr; gap: 16px; align-items: flex-start; }
	.notal-contact-grid { grid-template-columns: 1fr; gap: 24px; }
	.notal-form { padding: 24px 20px; }
	.notal-form__grid { grid-template-columns: 1fr; }
	.notal-form__chips { gap: 6px; }
	.notal-chip { padding: 7px 12px; font-size: 0.75rem; }
	.notal-aside { position: static !important; top: auto !important; }

	/* Service prestations grid */
	.notal-prestations-grid { grid-template-columns: 1fr; gap: 14px; }
	.notal-prestation { padding: 20px; }

	/* Service pourquoi */
	.notal-service-pourquoi__grid { grid-template-columns: 1fr; gap: 28px; }
	.notal-service-pourquoi__cards { grid-template-columns: 1fr; }

	/* Cross-sell */
	.notal-crosssell-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
	.notal-crosssell-card { padding: 16px; min-height: auto; }
	.notal-crosssell-card__title { font-size: 1rem; }
	.notal-crosssell-section__head { flex-direction: column; align-items: flex-start; gap: 12px; margin-bottom: 20px; }
}

@media (max-width: 480px) {
	.notal-crosssell-grid { grid-template-columns: 1fr; }
	.notal-trust__inner { grid-template-columns: 1fr 1fr; }
}

/* =========================================================================
   10. MOBILE FIXES — overrides agressifs sur les grids inline
   Cible les style="display:grid;grid-template-columns:..." qui contournent
   les media queries CSS classiques.
   ========================================================================= */
@media (max-width: 880px) {
	/* Grids inline 2 colonnes → 1 col en mobile */
	.notal-page section > div[style*="grid-template-columns:1.2fr"],
	.notal-page section > div[style*="grid-template-columns:1.1fr"],
	.notal-page section > div[style*="grid-template-columns:1fr 1fr"],
	.notal-page section > div[style*="grid-template-columns:repeat(2"],
	.notal-page section div[style*="grid-template-columns:1.2fr"],
	.notal-page section div[style*="grid-template-columns:1.1fr"],
	.notal-page section div[style*="grid-template-columns:1fr 1fr"],
	.notal-page section div[style*="grid-template-columns:repeat(2"] {
		grid-template-columns: 1fr !important;
		gap: 20px !important;
	}
}

@media (max-width: 768px) {
	/* Grids 3 cols (glossaire, etc.) → 1 col */
	.notal-page section div[style*="grid-template-columns:repeat(3"] {
		grid-template-columns: 1fr !important;
		gap: 12px !important;
	}
	/* Grids 4 cols (chantiers récents, méthode) → 2 cols */
	.notal-page section div[style*="grid-template-columns:repeat(4"] {
		grid-template-columns: repeat(2, 1fr) !important;
		gap: 14px !important;
	}
	/* Grids 5 cols (assurances) → 2 cols */
	.notal-page section div[style*="grid-template-columns:repeat(5"] {
		grid-template-columns: repeat(2, 1fr) !important;
		gap: 8px !important;
	}

	/* Compactage de tous les paddings inline 100px+ */
	.notal-page section[style*="padding"] {
		padding-left: 20px !important;
		padding-right: 20px !important;
	}

	/* Headers de section avec flex flex-wrap */
	.notal-page section > div[style*="justify-content:space-between"] {
		flex-direction: column !important;
		align-items: flex-start !important;
		gap: 20px !important;
	}

	/* Tableaux : police plus petite + scroll horizontal si besoin */
	.notal-page .wp-block-table {
		overflow-x: auto;
	}
	.notal-page .wp-block-table table {
		min-width: 100%;
		font-size: 0.84375rem;
	}
	.notal-page .wp-block-table th,
	.notal-page .wp-block-table td {
		padding: 10px 12px;
	}

	/* Cards et boxes : padding réduit */
	.notal-page section > div > div[style*="padding:24px"],
	.notal-page section > div > div[style*="padding:28px"] {
		padding: 18px 16px !important;
	}

	/* Hero photo mobile : taille raisonnable */
	.notal-hero__visual img,
	.notal-hero__photo {
		max-height: 400px;
		object-fit: cover;
	}
}

@media (max-width: 560px) {
	/* Chantiers 4 cols → 1 col en très petit écran */
	.notal-page section div[style*="grid-template-columns:repeat(4"] {
		grid-template-columns: 1fr !important;
	}
	/* Assurances 5 cols → 2 cols en très petit écran */
	.notal-page section div[style*="grid-template-columns:repeat(5"] {
		grid-template-columns: repeat(2, 1fr) !important;
	}
}

/* =========================================================================
   11. LANDING PAGES PUB (Google Ads — dépannage) — templates template-lp-*
   Gabarits de conversion autonomes : header réduit, zéro menu, un seul
   objectif = l'appel. Réutilise les tokens + composants Direction B.
   ========================================================================= */
.notal-lp { background: var(--notal-c-bg); }

/* --- Header réduit (logo + appel) --- */
.notal-lp-bar {
	position: sticky;
	top: 0;
	z-index: 1000;
	background: var(--notal-c-bg);
	border-bottom: 1px solid var(--notal-c-rule);
}
.notal-lp-bar__inner {
	max-width: var(--notal-container-max);
	margin: 0 auto;
	padding: 12px 24px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
}
.notal-lp-bar__call {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 11px 20px;
	background: var(--notal-c-urgence);
	color: #fff !important;
	border-radius: var(--notal-radius-pill);
	font-family: var(--notal-ff-sans);
	font-weight: 700;
	font-size: 1rem;
	letter-spacing: -0.01em;
	text-decoration: none;
	white-space: nowrap;
	transition: background 0.15s ease;
}
.notal-lp-bar__call:hover { background: var(--notal-c-urgence-deep); color: #fff !important; }
.notal-lp-bar__call-label { display: inline-flex; flex-direction: column; line-height: 1.05; }
.notal-lp-bar__call-label small { font-size: 0.625rem; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; opacity: 0.85; }
@media (max-width: 560px) {
	.notal-lp-bar__inner { padding: 10px 14px; }
	.notal-lp-bar__call { padding: 9px 14px; font-size: 0.9375rem; }
	.notal-lp-bar .notal-lockup__name { font-size: 1.0625rem; }
	.notal-lp-bar .notal-lockup__sign { display: none; }
	.notal-lp-bar .notal-lockup__mark img { width: 44px; height: 44px; }
}

/* --- Sections génériques --- */
.notal-lp-section { padding: 80px 32px; position: relative; }
@media (max-width: 1024px) { .notal-lp-section { padding: 64px 24px; } }
@media (max-width: 640px)  { .notal-lp-section { padding: 44px 18px; } }
.notal-lp-wrap { max-width: var(--notal-container-max); margin: 0 auto; }
.notal-lp-section--primary { background: var(--notal-c-primary); color: var(--notal-c-paper); }
.notal-lp-section--alt { background: var(--notal-c-bg-alt); }

/* --- Hero --- */
.notal-lp-hero { padding: 44px 32px 64px; }
@media (max-width: 640px) { .notal-lp-hero { padding: 24px 18px 40px; } }
.notal-lp-hero__grid {
	max-width: var(--notal-container-max);
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1.1fr 0.9fr;
	gap: 56px;
	align-items: center;
}
@media (max-width: 960px) { .notal-lp-hero__grid { grid-template-columns: 1fr; gap: 32px; } }
.notal-lp-hero__h1 {
	font-family: var(--notal-ff-sans);
	font-weight: 700;
	font-size: clamp(2.25rem, 5.2vw, 4rem);
	line-height: 0.96;
	letter-spacing: -0.04em;
	margin: 18px 0 16px;
	color: var(--notal-c-ink);
}
.notal-lp-hero__h1 .accent-serif { font-family: var(--notal-ff-serif); font-style: italic; font-weight: 500; color: var(--notal-c-primary); }
.notal-lp-hero__lead { font-size: 1.125rem; line-height: 1.5; color: var(--notal-c-stone); margin: 0 0 26px; max-width: 540px; }
.notal-lp-hero__cta-row { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.notal-lp-hero__reassurance {
	margin-top: 30px;
	display: flex;
	gap: 14px 24px;
	flex-wrap: wrap;
	font-family: var(--notal-ff-sans);
	font-size: 0.875rem;
	color: var(--notal-c-stone);
}
.notal-lp-hero__reassurance span { display: inline-flex; align-items: center; gap: 8px; }
.notal-lp-hero__reassurance span::before {
	content: "";
	width: 16px;
	height: 16px;
	flex-shrink: 0;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2311254A' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
	background-size: contain;
	background-repeat: no-repeat;
}

/* --- Bouton appel géant (conversion principale) --- */
.notal-lp-callbtn {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	padding: 17px 26px;
	background: var(--notal-c-urgence);
	color: #fff !important;
	border: 0;
	border-radius: var(--notal-radius-pill);
	font-family: var(--notal-ff-sans);
	font-weight: 700;
	letter-spacing: -0.01em;
	text-decoration: none;
	cursor: pointer;
	box-shadow: 0 10px 26px -8px rgba(214, 63, 31, 0.45);
	transition: background 0.15s ease, transform 0.15s ease;
}
.notal-lp-callbtn:hover { background: var(--notal-c-urgence-deep); color: #fff !important; transform: translateY(-1px); }
.notal-lp-callbtn small { display: block; font-size: 0.625rem; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; opacity: 0.85; line-height: 1; margin-bottom: 3px; }
.notal-lp-callbtn strong { font-size: 1.0625rem; line-height: 1; }
@media (max-width: 560px) {
	.notal-lp-hero__cta-row { flex-direction: column; align-items: stretch; gap: 10px; }
	.notal-lp-callbtn { justify-content: center; }
}

/* --- Carte formulaire rappel --- */
.notal-lp-formcard {
	background: var(--notal-c-paper);
	border: 1px solid var(--notal-c-rule);
	border-radius: 10px;
	padding: 30px;
	box-shadow: 0 22px 54px -26px rgba(14, 14, 16, 0.28);
	scroll-margin-top: 90px;
}
@media (max-width: 640px) { .notal-lp-formcard { padding: 24px 20px; } }
.notal-lp-formcard__title { font-family: var(--notal-ff-sans); font-weight: 700; font-size: 1.375rem; letter-spacing: -0.03em; margin: 0 0 4px; }
.notal-lp-formcard__sub { font-family: var(--notal-ff-serif); font-style: italic; font-size: 0.9375rem; color: var(--notal-c-stone); margin: 0 0 20px; }
.notal-lp-formcard__row { display: flex; flex-direction: column; gap: 14px; }
.notal-lp-formcard__submit { width: 100%; justify-content: center; margin-top: 6px; }
.notal-lp-formcard__or { text-align: center; margin: 14px 0 0; font-size: 0.8125rem; color: var(--notal-c-stone); }
.notal-lp-formcard__or a { font-weight: 700; color: var(--notal-c-urgence); text-decoration: none; }
.notal-lp-formcard__rgpd { margin: 12px 0 0; font-size: 0.6875rem; line-height: 1.45; color: var(--notal-c-stone); }
.notal-lp-formcard__rgpd a { color: var(--notal-c-primary); text-decoration: underline; }

/* --- Process 3 étapes --- */
.notal-lp-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 40px; }
@media (max-width: 720px) { .notal-lp-steps { grid-template-columns: 1fr; gap: 14px; } }
.notal-lp-step { background: var(--notal-c-paper); border: 1px solid var(--notal-c-rule); border-radius: var(--notal-radius-sm); padding: 26px; }
.notal-lp-step__num {
	width: 40px; height: 40px;
	border-radius: 50%;
	background: var(--notal-c-primary);
	color: var(--notal-c-accent);
	display: flex; align-items: center; justify-content: center;
	font-family: var(--notal-ff-sans); font-weight: 800;
	margin-bottom: 14px;
}
.notal-lp-step__title { font-family: var(--notal-ff-sans); font-weight: 700; font-size: 1.125rem; letter-spacing: -0.02em; margin: 0 0 6px; }
.notal-lp-step__body { font-size: 0.875rem; line-height: 1.55; color: var(--notal-c-stone); margin: 0; }

/* --- Zones 77 (chips non cliquables) --- */
.notal-lp-zones__villes { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; }
@media (max-width: 720px) { .notal-lp-zones__villes { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 420px) { .notal-lp-zones__villes { grid-template-columns: 1fr; } }
.notal-lp-zone {
	display: flex; align-items: center; gap: 6px;
	padding: 10px 12px;
	border-radius: var(--notal-radius-xs);
	border: 1px solid rgba(255, 255, 255, 0.18);
	font-family: var(--notal-ff-sans);
	font-size: 0.8125rem; font-weight: 500;
	color: var(--notal-c-paper);
}
.notal-lp-zone svg { opacity: 0.7; flex-shrink: 0; }

/* --- Footer réduit --- */
.notal-lp-footer { background: var(--notal-c-primary); color: var(--notal-c-paper); padding: 32px 24px; }
.notal-lp-footer__inner {
	max-width: var(--notal-container-max);
	margin: 0 auto;
	display: flex; justify-content: space-between; align-items: center;
	gap: 16px; flex-wrap: wrap;
	font-family: var(--notal-ff-sans);
	font-size: 0.8125rem;
	color: rgba(255, 255, 255, 0.7);
}
.notal-lp-footer__inner a { color: rgba(255, 255, 255, 0.7); text-decoration: none; font-weight: 600; }
.notal-lp-footer__inner a:hover { color: var(--notal-c-paper); }

/* --- Bandeau retour formulaire --- */
.notal-lp-banner {
	margin: 0 0 18px;
	padding: 14px 18px;
	border-radius: var(--notal-radius-sm);
	background: var(--notal-c-accent-soft);
	color: var(--notal-c-primary);
	border: 1px solid var(--notal-c-accent);
	font-family: var(--notal-ff-sans);
	font-size: 0.875rem;
	line-height: 1.5;
}
.notal-lp-banner a { color: inherit; font-weight: 700; }
.notal-lp-banner--error { background: rgba(214, 63, 31, 0.08); color: var(--notal-c-urgence-deep); border-color: var(--notal-c-urgence); }

/* --- Réutilisation .notal-faq-section__grid sans .notal-page wrapper --- */
.notal-lp .notal-faq-section__grid { align-items: flex-start; }

/* --- Sticky-call mobile spécifique LP (numéro de tracking + trackée) --- */
.notal-lp-stickycall { display: none; }
@media (max-width: 768px) {
	.notal-lp-stickycall {
		position: fixed;
		left: 12px; right: 12px; bottom: 12px;
		z-index: 1001;
		display: flex; align-items: center; justify-content: center; gap: 10px;
		padding: 14px 18px;
		background: var(--notal-c-urgence);
		color: #fff !important;
		font-family: var(--notal-ff-sans);
		font-weight: 700; font-size: 1rem; letter-spacing: -0.01em;
		text-decoration: none;
		border-radius: var(--notal-radius-pill);
		box-shadow: 0 8px 24px rgba(214, 63, 31, 0.35);
	}
}

/* --- Bandeau consentement cookies (CMP léger + Consent Mode v2) --- */
.notal-cmp {
	position: fixed;
	left: 12px; right: 12px; bottom: 12px;
	z-index: 1100;
	background: var(--notal-c-ink);
	color: var(--notal-c-paper);
	border-radius: var(--notal-radius-md);
	box-shadow: 0 18px 48px -16px rgba(0, 0, 0, 0.5);
	font-family: var(--notal-ff-sans);
}
.notal-cmp__inner {
	max-width: var(--notal-container-max);
	margin: 0 auto;
	padding: 18px 22px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	flex-wrap: wrap;
}
.notal-cmp__txt { margin: 0; font-size: 0.8125rem; line-height: 1.5; color: rgba(255, 255, 255, 0.85); max-width: 760px; }
.notal-cmp__txt a { color: var(--notal-c-accent); text-decoration: underline; }
.notal-cmp__btns { display: flex; gap: 10px; flex-shrink: 0; }
.notal-cmp__btn {
	padding: 11px 20px;
	border-radius: var(--notal-radius-pill);
	font-family: var(--notal-ff-sans);
	font-weight: 700;
	font-size: 0.875rem;
	letter-spacing: -0.01em;
	cursor: pointer;
	border: 1.5px solid transparent;
	transition: background 0.15s ease, border-color 0.15s ease;
}
.notal-cmp__btn--refuse { background: transparent; color: var(--notal-c-paper); border-color: rgba(255, 255, 255, 0.45); }
.notal-cmp__btn--refuse:hover { background: rgba(255, 255, 255, 0.1); }
.notal-cmp__btn--accept { background: var(--notal-c-accent); color: var(--notal-c-primary); border-color: var(--notal-c-accent); }
.notal-cmp__btn--accept:hover { background: #f0b520; border-color: #f0b520; }
@media (max-width: 600px) {
	.notal-cmp__inner { flex-direction: column; align-items: stretch; gap: 12px; padding: 16px; }
	.notal-cmp__btns { width: 100%; }
	.notal-cmp__btn { flex: 1; }
}
/* "Gérer les cookies" est un lien discret dans le footer (data-notal-consent-reopen) */
.notal-lp-footer__inner [data-notal-consent-reopen] { cursor: pointer; }

/* --- Bande photo métier (mobile uniquement : transition hero → suite) --- */
.notal-lp-photoband { display: none; }
@media (max-width: 768px) {
	.notal-lp-photoband { display: block; }
	.notal-lp-photoband img {
		width: 100%;
		height: 240px;
		object-fit: cover;
		object-position: center 32%;
		display: block;
	}
}

/* --- Mobile : laisser la place à la sticky-call en bas --- */
@media (max-width: 768px) {
	.notal-lp .notal-lp-footer { padding-bottom: 96px; }
	.notal-lp-hero__h1 { font-size: clamp(2rem, 8vw, 2.75rem); }
}
