/* =========================================================================
   ÉLECTRICIEN ÎLE MAURICE — Site vitrine artisan
   Préfixe : --carnet- / .carnet-
   ========================================================================= */

:root {
	--c-marine:        #1c3a5e;
	--c-marine-2:      #2c5380;
	--c-marine-foncé:  #122a44;
	--c-blanc:         #ffffff;
	--c-blanc-casse:   #fafaf7;
	--c-gris-tres-clair:#f1f3f5;
	--c-gris-clair:    #e6e8ec;
	--c-gris:          #cfd3d9;
	--c-gris-acier:    #5a6470;
	--c-texte:         #1f2937;
	--c-texte-2:       #4b5563;
	--c-ambre:         #d99a2b;
	--c-ambre-foncé:   #b87f1f;
	--c-ambre-clair:   #fdf3df;
	--c-vert-ok:       #2f7d52;

	--font-base: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;

	--rad-s: 4px;
	--rad-m: 6px;
	--rad-l: 10px;

	--sh-s: 0 1px 2px rgba(28,58,94,.06), 0 2px 6px rgba(28,58,94,.04);
	--sh-m: 0 2px 4px rgba(28,58,94,.06), 0 8px 24px rgba(28,58,94,.08);
	--sh-l: 0 4px 8px rgba(28,58,94,.08), 0 16px 40px rgba(28,58,94,.10);
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
	margin: 0;
	font-family: var(--font-base);
	font-size: 16px;
	line-height: 1.65;
	color: var(--c-texte);
	background: var(--c-blanc-casse);
	-webkit-font-smoothing: antialiased;
}

img, svg { max-width: 100%; height: auto; display: block; }
a { color: var(--c-marine); text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1px; }
a:hover { color: var(--c-ambre-foncé); }
button { font: inherit; cursor: pointer; }

.screen-reader-text { position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.carnet-skip { position: absolute; top: -100px; left: 1rem; background: var(--c-marine); color: var(--c-blanc); padding: 8px 14px; z-index: 9999; }
.carnet-skip:focus { top: 1rem; }

/* Conteneurs */
.carnet-container { width: min(1180px, 92%); margin-inline: auto; }
.carnet-container--narrow { width: min(820px, 92%); }
.carnet-container--prose { width: min(720px, 92%); }
.carnet-container--large { width: min(1280px, 94%); }

.carnet-section { padding: 80px 0; }
.carnet-section--gris { background: var(--c-gris-tres-clair); }
@media (max-width: 720px) { .carnet-section { padding: 56px 0; } }

/* =================== TYPO ====================== */

.carnet-h1, .carnet-h2, .carnet-h3 {
	font-family: var(--font-base);
	color: var(--c-marine);
	font-weight: 700;
	line-height: 1.2;
	margin: 0 0 .5em;
	letter-spacing: -.018em;
}
.carnet-h1 { font-size: clamp(2rem, 4vw + .4rem, 3.2rem); }
.carnet-h2 { font-size: clamp(1.6rem, 2.4vw + .3rem, 2.2rem); }
.carnet-h3 { font-size: clamp(1.15rem, 1.2vw + .4rem, 1.4rem); font-weight: 600; }

.carnet-kicker {
	display: inline-block;
	font-family: var(--font-base);
	font-size: .82rem;
	font-weight: 600;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--c-ambre-foncé);
	margin-bottom: 14px;
}

.carnet-lead {
	font-size: clamp(1.05rem, .6vw + .9rem, 1.18rem);
	color: var(--c-texte-2);
	line-height: 1.6;
}

/* =================== ENTÊTE ==================== */

.carnet-entete {
	position: sticky; top: 0; z-index: 80;
	background: var(--c-blanc);
	border-bottom: 1px solid var(--c-gris-clair);
}
.carnet-entete__rail {
	display: flex; align-items: center; justify-content: space-between;
	gap: 1.5rem; padding: 14px 4%;
}

.carnet-marque { display: flex; align-items: center; gap: 12px; text-decoration: none; }
.carnet-marque__logo {
	width: 40px; height: 40px; flex-shrink: 0;
	background: var(--c-marine);
	border-radius: var(--rad-s);
	display: flex; align-items: center; justify-content: center;
	color: var(--c-ambre); font-weight: 700;
}
.carnet-marque__nom {
	display: flex; flex-direction: column; line-height: 1.15;
}
.carnet-marque__main {
	font-family: var(--font-base);
	font-size: 1.1rem; font-weight: 700;
	color: var(--c-marine);
	letter-spacing: -.01em;
}
.carnet-marque__sous {
	font-size: .8rem; color: var(--c-texte-2);
	font-weight: 500;
}

/* Nav */
.carnet-nav { display: flex; align-items: center; }
.carnet-burger {
	background: transparent; border: 1px solid var(--c-gris);
	border-radius: var(--rad-s);
	padding: 10px 12px; min-height: 44px; min-width: 44px;
}
.carnet-burger__lignes { display: inline-flex; flex-direction: column; gap: 5px; width: 22px; }
.carnet-burger__lignes span { display: block; height: 2px; background: var(--c-marine); }

.carnet-menu { list-style: none; margin: 0; padding: 0; display: flex; gap: 1.6rem; align-items: center; }
.carnet-menu li a {
	text-decoration: none;
	font-family: var(--font-base);
	font-size: .98rem; font-weight: 500;
	color: var(--c-texte);
	padding: 10px 0; min-height: 44px;
	display: inline-flex; align-items: center;
	transition: color .15s ease;
}
.carnet-menu li a:hover { color: var(--c-marine); }
.carnet-menu__cta {
	background: var(--c-marine); color: var(--c-blanc) !important;
	padding: 10px 18px !important; border-radius: var(--rad-s);
	font-weight: 600 !important;
	transition: background-color .15s ease;
}
.carnet-menu__cta:hover { background: var(--c-marine-foncé); color: var(--c-blanc) !important; }

@media (max-width: 980px) {
	.carnet-burger { display: inline-flex; }
	.carnet-menu {
		position: absolute; top: 100%; left: 0; right: 0;
		flex-direction: column; gap: 0; align-items: stretch;
		background: var(--c-blanc); border-bottom: 1px solid var(--c-gris-clair);
		max-height: 0; overflow: hidden; transition: max-height .3s ease;
		box-shadow: var(--sh-m);
	}
	.carnet-menu li { border-bottom: 1px solid var(--c-gris-clair); }
	.carnet-menu li:last-child { border-bottom: 0; }
	.carnet-menu li a { padding: 16px 6%; display: block; }
	.carnet-menu__cta { margin: 12px 6%; text-align: center; border-radius: var(--rad-s); }
	.carnet-nav.is-open .carnet-menu { max-height: 80vh; }
}
@media (min-width: 981px) {
	.carnet-burger { display: none; }
}

/* =================== BOUTONS =================== */

.carnet-btn {
	display: inline-flex; align-items: center; justify-content: center; gap: 8px;
	font-family: var(--font-base);
	font-weight: 600; font-size: 1rem;
	min-height: 50px; padding: 14px 24px; border-radius: var(--rad-s);
	text-decoration: none; border: 1px solid transparent;
	transition: background-color .15s ease, border-color .15s ease, color .15s ease, transform .1s ease;
	cursor: pointer;
}
.carnet-btn--primary {
	background: var(--c-marine); color: var(--c-blanc); border-color: var(--c-marine);
}
.carnet-btn--primary:hover { background: var(--c-marine-foncé); border-color: var(--c-marine-foncé); color: var(--c-blanc); }

.carnet-btn--ambre {
	background: var(--c-ambre); color: var(--c-marine); border-color: var(--c-ambre);
	font-weight: 700;
}
.carnet-btn--ambre:hover { background: var(--c-ambre-foncé); border-color: var(--c-ambre-foncé); color: var(--c-blanc); }

.carnet-btn--ghost {
	background: transparent; color: var(--c-marine); border-color: var(--c-gris);
}
.carnet-btn--ghost:hover { background: var(--c-marine); border-color: var(--c-marine); color: var(--c-blanc); }

.carnet-btn--rouge { /* legacy compat */
	background: var(--c-marine); color: var(--c-blanc); border-color: var(--c-marine);
}
.carnet-btn--rouge:hover { background: var(--c-marine-foncé); border-color: var(--c-marine-foncé); color: var(--c-blanc); }

.carnet-cta-row { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 24px; }

/* =================== HERO HOME ==================== */

.carnet-hero {
	padding: 64px 0 80px;
	background: var(--c-blanc);
	border-bottom: 1px solid var(--c-gris-clair);
}
.carnet-hero__rail {
	display: grid; grid-template-columns: 1fr; gap: 40px;
	align-items: center;
}
@media (min-width: 980px) {
	.carnet-hero__rail { grid-template-columns: 1.05fr 1fr; gap: 56px; }
}
.carnet-hero__texte { }
.carnet-hero__h1 em { font-style: normal; color: var(--c-ambre-foncé); }
.carnet-hero__lead { max-width: 56ch; margin: 18px 0 0; }

.carnet-hero__visu {
	position: relative;
	border-radius: var(--rad-l);
	overflow: hidden;
	box-shadow: var(--sh-l);
	aspect-ratio: 4 / 3;
	background: var(--c-gris-clair);
}
.carnet-hero__visu img {
	width: 100%; height: 100%;
	object-fit: cover;
	object-position: center 35%;
}

.carnet-hero__bandeau {
	background: var(--c-marine);
	color: var(--c-blanc);
	padding: 14px 22px;
	border-radius: var(--rad-s);
	display: inline-flex; align-items: center; gap: 14px;
	margin-top: 32px;
	font-size: .94rem;
}
.carnet-hero__bandeau strong { color: var(--c-ambre); font-weight: 700; }

/* =================== BANDEAU CHIFFRES ============= */

.carnet-stats {
	background: var(--c-marine);
	color: var(--c-blanc);
	padding: 36px 0;
}
.carnet-stats__grille {
	display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px 12px;
}
@media (min-width: 720px) { .carnet-stats__grille { grid-template-columns: repeat(4, 1fr); } }
.carnet-stat { text-align: center; padding: 0 8px; }
.carnet-stat__valeur {
	font-size: clamp(1.8rem, 2.6vw + .4rem, 2.4rem);
	font-weight: 800; color: var(--c-ambre);
	line-height: 1; letter-spacing: -.02em;
}
.carnet-stat__label {
	font-size: .85rem;
	color: rgba(255,255,255,.85);
	margin-top: 8px;
	font-weight: 500;
}

/* =================== 3 PUBLICS ==================== */

.carnet-publics__head {
	display: grid; grid-template-columns: 1fr; gap: 24px; margin-bottom: 40px;
}
@media (min-width: 980px) {
	.carnet-publics__head { grid-template-columns: 1.4fr 1fr; gap: 56px; align-items: end; }
}

.carnet-publics__grille {
	display: grid; grid-template-columns: 1fr; gap: 20px;
}
@media (min-width: 720px) { .carnet-publics__grille { grid-template-columns: repeat(3, 1fr); } }

.carnet-public {
	background: var(--c-blanc);
	border: 1px solid var(--c-gris-clair);
	border-radius: var(--rad-m);
	padding: 28px 26px 24px;
	text-decoration: none; color: var(--c-texte);
	transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
	display: flex; flex-direction: column;
	position: relative;
	border-top: 3px solid var(--c-marine);
}
.carnet-public:hover {
	transform: translateY(-3px);
	box-shadow: var(--sh-m);
	border-color: var(--c-gris);
	color: var(--c-texte);
}
.carnet-public--entreprise { border-top-color: var(--c-marine-2); }
.carnet-public--chantier   { border-top-color: var(--c-ambre-foncé); }
.carnet-public__icone { color: var(--c-marine); margin-bottom: 16px; }
.carnet-public__cible {
	font-size: .78rem; color: var(--c-ambre-foncé);
	letter-spacing: .12em; text-transform: uppercase; font-weight: 600;
}
.carnet-public__titre { margin: 4px 0 10px; font-size: 1.3rem; font-weight: 700; color: var(--c-marine); }
.carnet-public__txt { color: var(--c-texte-2); margin: 0 0 18px; flex-grow: 1; font-size: .96rem; }
.carnet-public__lien {
	font-weight: 600; color: var(--c-marine);
	display: inline-flex; align-items: center; gap: 6px;
}
.carnet-public__lien::after { content: "→"; transition: transform .15s ease; }
.carnet-public:hover .carnet-public__lien::after { transform: translateX(3px); }

/* =================== PRESTATIONS ==================== */

.carnet-services__head {
	display: grid; grid-template-columns: 1fr; gap: 24px; margin-bottom: 40px;
}
@media (min-width: 980px) {
	.carnet-services__head { grid-template-columns: 1.4fr 1fr; gap: 56px; align-items: end; }
}

.carnet-services__grille {
	display: grid; grid-template-columns: 1fr; gap: 16px;
}
@media (min-width: 540px) { .carnet-services__grille { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 980px) { .carnet-services__grille { grid-template-columns: repeat(4, 1fr); } }

.carnet-service-card {
	background: var(--c-blanc);
	border: 1px solid var(--c-gris-clair);
	border-radius: var(--rad-m);
	padding: 24px 22px;
	text-decoration: none; color: var(--c-texte);
	transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
	display: flex; flex-direction: column;
}
.carnet-service-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--sh-m);
	border-color: var(--c-gris);
	color: var(--c-texte);
}
.carnet-service-card__icone {
	width: 44px; height: 44px;
	background: var(--c-ambre-clair);
	border-radius: var(--rad-s);
	display: inline-flex; align-items: center; justify-content: center;
	color: var(--c-ambre-foncé);
	margin-bottom: 14px;
}
.carnet-service-card__titre { font-size: 1.05rem; font-weight: 700; color: var(--c-marine); margin: 0 0 8px; }
.carnet-service-card__txt { color: var(--c-texte-2); font-size: .92rem; margin: 0 0 14px; flex-grow: 1; }
.carnet-service-card__lien { font-size: .9rem; font-weight: 600; color: var(--c-marine); }

/* =================== RÉALISATIONS ==================== */

.carnet-realisations__grille {
	display: grid; grid-template-columns: 1fr; gap: 20px;
}
@media (min-width: 720px) { .carnet-realisations__grille { grid-template-columns: repeat(3, 1fr); } }

.carnet-realisation {
	background: var(--c-blanc);
	border: 1px solid var(--c-gris-clair);
	border-radius: var(--rad-m);
	overflow: hidden;
	transition: transform .15s ease, box-shadow .15s ease;
}
.carnet-realisation:hover { transform: translateY(-2px); box-shadow: var(--sh-m); }
.carnet-realisation__photo {
	aspect-ratio: 4 / 3;
	background-size: cover; background-position: center 40%;
	background-color: var(--c-gris-clair);
}
.carnet-realisation__corps { padding: 18px 20px 20px; }
.carnet-realisation__meta {
	display: flex; gap: 12px; align-items: center;
	font-size: .8rem; color: var(--c-texte-2);
	margin-bottom: 6px;
}
.carnet-realisation__lieu { color: var(--c-ambre-foncé); font-weight: 600; text-transform: uppercase; letter-spacing: .04em; }
.carnet-realisation__sep { color: var(--c-gris); }
.carnet-realisation__titre { font-size: 1.1rem; font-weight: 700; color: var(--c-marine); margin: 0 0 6px; }
.carnet-realisation__nature { font-size: .92rem; color: var(--c-texte-2); margin: 0; }

/* =================== ZONES ============= */

.carnet-zones__head {
	display: grid; grid-template-columns: 1fr; gap: 24px; margin-bottom: 32px;
}
@media (min-width: 980px) { .carnet-zones__head { grid-template-columns: 1.3fr 1fr; gap: 56px; align-items: end; } }

.carnet-zones__bandeau {
	display: grid; grid-template-columns: 1fr; gap: 20px; margin-bottom: 32px;
}
@media (min-width: 720px) { .carnet-zones__bandeau { grid-template-columns: 1fr 1fr; } }
.carnet-zones__cote {
	padding: 22px 24px;
	background: var(--c-blanc);
	border: 1px solid var(--c-gris-clair);
	border-left: 4px solid var(--c-marine);
	border-radius: var(--rad-s);
}
.carnet-zones__cote--nord { border-left-color: var(--c-ambre-foncé); }
.carnet-zones__cote h3 { margin: 0 0 6px; color: var(--c-marine); font-size: 1.1rem; font-weight: 700; }
.carnet-zones__cote p { margin: 0; color: var(--c-texte-2); font-size: .94rem; }

.carnet-zones__grille {
	display: grid; grid-template-columns: 1fr; gap: 12px;
}
@media (min-width: 540px) { .carnet-zones__grille { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 980px) { .carnet-zones__grille { grid-template-columns: repeat(5, 1fr); } }

.carnet-zone-pin {
	display: block; padding: 18px 16px;
	background: var(--c-blanc);
	border: 1px solid var(--c-gris-clair);
	border-radius: var(--rad-s);
	text-decoration: none; color: var(--c-texte);
	transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.carnet-zone-pin:hover { transform: translateY(-2px); box-shadow: var(--sh-s); border-color: var(--c-gris); color: var(--c-texte); }
.carnet-zone-pin__cote {
	font-size: .72rem; color: var(--c-ambre-foncé);
	letter-spacing: .08em; text-transform: uppercase; font-weight: 600;
}
.carnet-zone-pin__nom { font-weight: 700; color: var(--c-marine); margin: 4px 0 4px; font-size: 1.02rem; }
.carnet-zone-pin__det { font-size: .8rem; color: var(--c-texte-2); }

/* =================== MÉTHODE TIMELINE ============= */

.carnet-methode {
	background: var(--c-marine);
	color: var(--c-blanc);
}
.carnet-methode .carnet-h2 { color: var(--c-blanc); }
.carnet-methode .carnet-kicker { color: var(--c-ambre-clair); }
.carnet-methode .carnet-lead { color: rgba(255,255,255,.85); }

.carnet-methode__head {
	display: grid; grid-template-columns: 1fr; gap: 24px; margin-bottom: 48px;
}
@media (min-width: 980px) { .carnet-methode__head { grid-template-columns: 1.3fr 1fr; gap: 56px; align-items: end; } }

.carnet-methode__etapes {
	display: grid; grid-template-columns: 1fr; gap: 20px;
}
@media (min-width: 720px) { .carnet-methode__etapes { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1080px) { .carnet-methode__etapes { grid-template-columns: repeat(5, 1fr); } }

.carnet-etape {
	background: rgba(255,255,255,.04);
	border: 1px solid rgba(255,255,255,.12);
	border-radius: var(--rad-s);
	padding: 22px 18px;
}
.carnet-etape__num {
	font-size: .85rem; color: var(--c-ambre);
	font-weight: 700; letter-spacing: .04em;
	margin-bottom: 6px;
}
.carnet-etape__titre { font-size: 1.05rem; font-weight: 700; color: var(--c-blanc); margin: 0 0 10px; }
.carnet-etape__txt { font-size: .9rem; color: rgba(255,255,255,.78); margin: 0; line-height: 1.55; }

/* =================== TÉMOIGNAGES ============ */

.carnet-temoins__grille {
	display: grid; grid-template-columns: 1fr; gap: 20px;
}
@media (min-width: 720px) { .carnet-temoins__grille { grid-template-columns: repeat(2, 1fr); } }

.carnet-temoin {
	background: var(--c-blanc);
	border: 1px solid var(--c-gris-clair);
	border-radius: var(--rad-m);
	padding: 26px 24px 22px;
}
.carnet-temoin__txt {
	font-size: 1rem; color: var(--c-texte);
	margin: 0 0 16px; line-height: 1.65;
}
.carnet-temoin__txt::before { content: "« "; color: var(--c-ambre-foncé); }
.carnet-temoin__txt::after  { content: " »"; color: var(--c-ambre-foncé); }
.carnet-temoin__auteur { font-weight: 700; color: var(--c-marine); font-size: .98rem; }
.carnet-temoin__role  { font-size: .85rem; color: var(--c-texte-2); margin-top: 2px; }

/* =================== FAQ =================== */

.carnet-faq__liste { display: grid; gap: 14px; }
.carnet-faq__item {
	background: var(--c-blanc);
	border: 1px solid var(--c-gris-clair);
	border-radius: var(--rad-s);
	padding: 18px 22px;
}
.carnet-faq__item summary {
	font-weight: 600; color: var(--c-marine);
	cursor: pointer; list-style: none;
	display: flex; justify-content: space-between; align-items: center;
	padding-right: 8px;
}
.carnet-faq__item summary::-webkit-details-marker { display: none; }
.carnet-faq__item summary::after {
	content: "+"; color: var(--c-ambre-foncé); font-size: 1.4rem;
	transition: transform .15s ease;
}
.carnet-faq__item[open] summary::after { content: "−"; }
.carnet-faq__item p { margin: 12px 0 0; color: var(--c-texte-2); font-size: .96rem; }

/* =================== CTA FINAL =================== */

.carnet-cta-final {
	padding: 80px 0;
	background: var(--c-marine);
	color: var(--c-blanc);
}
.carnet-cta-final__rail {
	display: grid; grid-template-columns: 1fr; gap: 28px; align-items: center;
}
@media (min-width: 980px) { .carnet-cta-final__rail { grid-template-columns: 1.5fr 1fr; gap: 56px; } }
.carnet-cta-final h2 { color: var(--c-blanc); }
.carnet-cta-final .carnet-kicker { color: var(--c-ambre-clair); }
.carnet-cta-final p { color: rgba(255,255,255,.82); }
.carnet-cta-final .carnet-btn--primary { background: var(--c-ambre); border-color: var(--c-ambre); color: var(--c-marine); }
.carnet-cta-final .carnet-btn--primary:hover { background: var(--c-ambre-foncé); border-color: var(--c-ambre-foncé); color: var(--c-blanc); }
.carnet-cta-final .carnet-btn--ghost { color: var(--c-blanc); border-color: rgba(255,255,255,.4); }
.carnet-cta-final .carnet-btn--ghost:hover { background: rgba(255,255,255,.1); border-color: var(--c-blanc); color: var(--c-blanc); }

/* =================== FORMULAIRES =================== */

.carnet-form {
	background: var(--c-blanc);
	border: 1px solid var(--c-gris-clair);
	border-radius: var(--rad-m);
	padding: 32px 28px;
	box-shadow: var(--sh-s);
}
.carnet-form__head { margin-bottom: 18px; }
.carnet-form__head h2 { margin: 0 0 6px; }
.carnet-form__row { display: grid; grid-template-columns: 1fr; gap: 16px; margin-bottom: 16px; }
@media (min-width: 720px) { .carnet-form__row--2 { grid-template-columns: 1fr 1fr; } }
.carnet-form__field label {
	display: block; font-size: .85rem; color: var(--c-texte);
	font-weight: 600; margin-bottom: 6px;
}
.carnet-form__field input,
.carnet-form__field select,
.carnet-form__field textarea {
	width: 100%; font: inherit; font-size: 16px;
	padding: 12px 14px; border-radius: var(--rad-s);
	border: 1px solid var(--c-gris); background: var(--c-blanc);
	color: var(--c-texte); transition: border-color .15s ease, box-shadow .15s ease;
}
.carnet-form__field input:focus,
.carnet-form__field select:focus,
.carnet-form__field textarea:focus {
	outline: none; border-color: var(--c-marine);
	box-shadow: 0 0 0 3px rgba(28,58,94,.12);
}
.carnet-form__field textarea { min-height: 140px; resize: vertical; }
.carnet-form__sub { font-size: .85rem; color: var(--c-texte-2); margin-top: 8px; }
.carnet-form__alerte {
	padding: 14px 18px; border-radius: var(--rad-s);
	background: var(--c-ambre-clair);
	border-left: 4px solid var(--c-ambre);
	margin-bottom: 18px;
}
.carnet-form__alerte--ok {
	background: #e7f5ec;
	border-left-color: var(--c-vert-ok);
}

/* =================== WIZARD =================== */

.carnet-wizard {
	background: var(--c-blanc);
	border: 1px solid var(--c-gris-clair);
	border-radius: var(--rad-m);
	padding: 32px 28px;
	box-shadow: var(--sh-s);
}
.carnet-wizard__head {
	display: flex; justify-content: space-between; align-items: center;
	gap: 16px; margin-bottom: 24px; flex-wrap: wrap;
}
.carnet-wizard__progress { display: flex; gap: 6px; }
.carnet-wizard__progress span {
	width: 28px; height: 4px;
	background: var(--c-gris-clair);
	border-radius: 2px;
}
.carnet-wizard__progress span.is-active { background: var(--c-ambre); }
.carnet-wizard__step { display: none; }
.carnet-wizard__step.is-active { display: block; }
.carnet-wizard__step h2 { font-size: 1.4rem; margin: 0 0 6px; color: var(--c-marine); }
.carnet-wizard__step p.intro { color: var(--c-texte-2); margin: 0 0 18px; }
.carnet-wizard__choices {
	display: grid; grid-template-columns: 1fr; gap: 10px; margin-bottom: 24px;
}
@media (min-width: 540px) { .carnet-wizard__choices { grid-template-columns: 1fr 1fr; } }
.carnet-wizard__choice {
	cursor: pointer; padding: 16px 18px; min-height: 56px;
	border: 1px solid var(--c-gris); border-radius: var(--rad-s);
	background: var(--c-blanc); color: var(--c-texte);
	font-size: .96rem; font-weight: 500;
	display: flex; align-items: center; justify-content: space-between; gap: 12px;
	transition: border-color .15s ease, background-color .15s ease;
	text-align: left;
}
.carnet-wizard__choice:hover { border-color: var(--c-marine); background: var(--c-gris-tres-clair); }
.carnet-wizard__choice.is-selected {
	border-color: var(--c-ambre);
	background: var(--c-ambre-clair);
	color: var(--c-marine); font-weight: 600;
}
.carnet-wizard__nav {
	display: flex; justify-content: space-between; gap: 12px;
	margin-top: 16px; padding-top: 18px;
	border-top: 1px solid var(--c-gris-clair);
}

/* =================== PROSE / CONTENU =================== */

.carnet-prose { font-size: 1.04rem; line-height: 1.75; color: var(--c-texte); }
.carnet-prose h2 { font-size: clamp(1.4rem, 1.8vw + .4rem, 1.8rem); color: var(--c-marine); margin: 2.2em 0 .6em; font-weight: 700; }
.carnet-prose h3 { font-size: clamp(1.15rem, 1.2vw + .4rem, 1.35rem); color: var(--c-marine); margin: 1.6em 0 .5em; font-weight: 600; }
.carnet-prose p { margin: 0 0 1.1em; }
.carnet-prose ul, .carnet-prose ol { margin: 0 0 1.4em; padding-left: 1.4em; }
.carnet-prose li { margin-bottom: .5em; }
.carnet-prose a { color: var(--c-marine); }
.carnet-prose-head { margin-bottom: 28px; }

/* =================== FICHE DETAIL ============= */

.carnet-fiche-detail {
	display: grid; grid-template-columns: 1fr; gap: 32px;
	margin: 28px 0 40px;
}
@media (min-width: 980px) { .carnet-fiche-detail { grid-template-columns: 1.4fr 1fr; gap: 48px; } }

.carnet-info-bloc {
	background: var(--c-blanc);
	border: 1px solid var(--c-gris-clair);
	border-radius: var(--rad-m);
	padding: 22px 24px;
}
.carnet-info-bloc h3 {
	font-size: .82rem;
	color: var(--c-ambre-foncé);
	letter-spacing: .12em;
	text-transform: uppercase;
	font-weight: 700;
	margin: 0 0 14px;
}
.carnet-info-bloc dl { margin: 0; display: grid; gap: 10px; }
.carnet-info-bloc dl > div {
	display: grid; grid-template-columns: 1fr 1.2fr;
	gap: 12px;
	padding-bottom: 10px;
	border-bottom: 1px solid var(--c-gris-clair);
}
.carnet-info-bloc dl > div:last-child { border-bottom: 0; padding-bottom: 0; }
.carnet-info-bloc dt { font-size: .85rem; color: var(--c-texte-2); font-weight: 500; }
.carnet-info-bloc dd { margin: 0; color: var(--c-marine); font-weight: 600; font-size: .94rem; }

/* Listes */
.carnet-liste {
	list-style: none; padding: 0; margin: 0;
	display: grid; grid-template-columns: 1fr; gap: 8px;
}
.carnet-liste li {
	padding: 14px 16px 14px 50px;
	background: var(--c-blanc);
	border: 1px solid var(--c-gris-clair);
	border-radius: var(--rad-s);
	position: relative;
	font-size: .98rem;
	counter-increment: liste;
}
.carnet-liste--num { counter-reset: liste; }
.carnet-liste--num li::before {
	content: counter(liste, decimal-leading-zero);
	position: absolute; left: 16px; top: 50%; transform: translateY(-50%);
	font-weight: 700; font-size: .9rem;
	color: var(--c-ambre-foncé);
}
.carnet-liste--check li { padding-left: 50px; }
.carnet-liste--check li::before {
	content: "";
	position: absolute; left: 18px; top: 50%; transform: translateY(-50%);
	width: 18px; height: 18px;
	background: var(--c-marine);
	border-radius: 50%;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath d='M3 8l3 3 6-7' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: center;
}

/* =================== FIL D'ARIANE =================== */

.carnet-fil { font-size: .85rem; color: var(--c-texte-2); margin-bottom: 20px; }
.carnet-fil ol { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; gap: 6px; }
.carnet-fil li { display: flex; align-items: center; }
.carnet-fil li:not(:last-child)::after { content: "/"; margin-left: 6px; color: var(--c-gris); }
.carnet-fil a { color: var(--c-texte-2); text-decoration: none; }
.carnet-fil a:hover { color: var(--c-marine); text-decoration: underline; }

/* =================== HEADER PAGE INTERNE =================== */

.carnet-page-head {
	padding: 56px 0 36px;
	background: var(--c-blanc);
	border-bottom: 1px solid var(--c-gris-clair);
}
.carnet-page-head__rail {
	display: grid; grid-template-columns: 1fr; gap: 24px; align-items: end;
}
@media (min-width: 980px) { .carnet-page-head__rail { grid-template-columns: 1.6fr 1fr; gap: 56px; } }
.carnet-page-head h1 { margin: 8px 0 14px; }

/* =================== PIED =================== */

.carnet-pied {
	background: var(--c-marine-foncé);
	color: rgba(255,255,255,.78);
	padding: 56px 0 24px;
}
.carnet-pied__rail {
	width: min(1280px, 92%); margin-inline: auto;
	display: grid; grid-template-columns: 1fr; gap: 36px;
}
@media (min-width: 720px) { .carnet-pied__rail { grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 32px; } }
.carnet-pied__col { font-size: .94rem; }
.carnet-pied__nom { color: var(--c-blanc); font-weight: 700; font-size: 1.1rem; margin: 12px 0 8px; }
.carnet-pied__petit { font-size: .85rem; opacity: .8; }
.carnet-pied__titre { font-size: .98rem; color: var(--c-blanc); font-weight: 700; margin: 0 0 14px; }
.carnet-pied__titre--bis { margin-top: 24px; }
.carnet-pied__col ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 8px; }
.carnet-pied__col a { color: rgba(255,255,255,.78); text-decoration: none; transition: color .15s ease; }
.carnet-pied__col a:hover { color: var(--c-ambre); }
.carnet-pied__bas {
	width: min(1280px, 92%); margin: 40px auto 0;
	padding-top: 18px; border-top: 1px solid rgba(255,255,255,.15);
	display: flex; justify-content: space-between; gap: 14px; flex-wrap: wrap;
	font-size: .85rem;
}
.carnet-pied__bas p { margin: 0; }

/* =================== 404 =================== */

.carnet-404__inner { text-align: center; padding: 80px 0; }
.carnet-404__inner .carnet-h1 { margin-top: 14px; }

/* =================== Recherche =================== */

.carnet-search { display: flex; gap: 8px; }
.carnet-search input { flex: 1; padding: 12px 14px; font-size: 16px; border: 1px solid var(--c-gris); border-radius: var(--rad-s); }

/* =================== UTILS =================== */

.carnet-eyebrow {
	display: inline-block; padding: 5px 10px;
	background: var(--c-gris-tres-clair);
	border: 1px solid var(--c-gris-clair);
	border-radius: var(--rad-s);
	font-size: .78rem; color: var(--c-texte-2);
	font-weight: 500;
}

.carnet-divider {
	height: 1px; border: 0;
	background: var(--c-gris-clair);
	margin: 48px 0;
}

/* Compat anciens noms (sécurisation au cas où) */
.carnet-tampon { display: none; }
.carnet-polaroid { display: none; }
.carnet-annotation { display: none; }
.carnet-marque__numero { display: none; }
.carnet-marque__amp { display: none; }
.carnet-hero__signature { display: none; }
.carnet-hero__date { display: none; }
.carnet-meta-bande { display: none; }
.carnet-fiche-grille { display: grid; grid-template-columns: 1fr; gap: 16px; }
@media (min-width: 540px) { .carnet-fiche-grille { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 980px) { .carnet-fiche-grille { grid-template-columns: repeat(4, 1fr); } }
.carnet-fiche {
	background: var(--c-blanc); border: 1px solid var(--c-gris-clair);
	border-radius: var(--rad-m); padding: 22px 22px;
	text-decoration: none; color: var(--c-texte);
	transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
	display: flex; flex-direction: column;
}
.carnet-fiche:hover { transform: translateY(-2px); box-shadow: var(--sh-m); border-color: var(--c-gris); color: var(--c-texte); }
.carnet-fiche__head { padding: 0; }
.carnet-fiche__cote { font-size: .72rem; color: var(--c-ambre-foncé); letter-spacing: .1em; text-transform: uppercase; font-weight: 600; margin-bottom: 6px; }
.carnet-fiche__titre { font-size: 1.05rem; font-weight: 700; color: var(--c-marine); margin: 0 0 8px; }
.carnet-fiche__base { font-size: .9rem; color: var(--c-texte-2); margin: 0 0 14px; flex-grow: 1; padding: 0; }
.carnet-fiche__pied { display: flex; justify-content: space-between; align-items: center; padding: 0; }
.carnet-fiche__lien { font-size: .9rem; font-weight: 600; color: var(--c-marine); }
.carnet-fiche__icone { color: var(--c-ambre-foncé); }
.carnet-fiche::before { display: none !important; content: none !important; }

@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
	html { scroll-behavior: auto; }
}

/* Compat popup rental-notice */
body.sbr-banner-open { padding-bottom: 96px; }

/* Cartouche legacy → restyle sobre */
.carnet-cartouche {
	background: var(--c-blanc);
	border: 1px solid var(--c-gris-clair);
	border-radius: var(--rad-m);
	padding: 22px 24px;
}
.carnet-cartouche::before { display: none; }
.carnet-cartouche dl { margin: 0; display: grid; grid-template-columns: 1fr; gap: 10px; }
.carnet-cartouche dl > div {
	display: grid; grid-template-columns: 1fr 1.2fr;
	gap: 12px;
	padding-bottom: 10px;
	border-bottom: 1px solid var(--c-gris-clair);
}
.carnet-cartouche dl > div:last-child { border-bottom: 0; padding-bottom: 0; }
.carnet-cartouche dl > div.full { grid-template-columns: 1fr; }
.carnet-cartouche dt { font-size: .82rem; color: var(--c-texte-2); font-weight: 500; }
.carnet-cartouche dd { margin: 0; color: var(--c-marine); font-weight: 600; font-size: .94rem; }
