:root{
  --night:#071a2a; --night2:#0c2437; --gold:#d4a45c; --gold2:#efc77f; --cream:#fcfaf5; --sand:#f5efe4; --ink:#122033; --muted:#67707b; --line:#e5dbcc; --white:#fff;
  --serif:'Cormorant Garamond', Georgia, serif; --sans:'Inter', system-ui, sans-serif; --max:1240px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);background:var(--cream);color:var(--ink);line-height:1.55}
a{text-decoration:none;color:inherit}img{max-width:100%;display:block}
.container{max-width:var(--max);margin:0 auto;padding:0 28px}
.section{padding:88px 0}.dark{background:linear-gradient(135deg,var(--night),#04111a);color:var(--white)}
h1,h2,h3{font-family:var(--serif);font-weight:600;letter-spacing:-.02em;margin:0}p{margin:0}
.site-header{position:absolute;left:0;top:0;width:100%;z-index:20;color:#fff}
.header-inner{height:96px;display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:14px}
.brand-mark{width:52px;height:52px;border:1px solid rgba(255,255,255,.35);border-radius:50%;display:grid;place-items:center;color:var(--gold)}
.brand-mark svg{width:34px;height:34px;fill:none;stroke:currentColor;stroke-width:2}
.brand-text strong{display:block;font-family:var(--serif);font-size:2rem;line-height:.9;letter-spacing:.06em;text-transform:uppercase}
.brand-text small{display:block;margin-top:4px;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase}
.main-nav{display:flex;align-items:center;gap:28px;font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;font-weight:700}
.main-nav a:hover{color:var(--gold)}
.nav-cta{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#fff!important;padding:14px 20px;border-radius:2px}
.menu-toggle{display:none;background:transparent;border:0;flex-direction:column;gap:6px}.menu-toggle span{display:block;width:26px;height:2px;background:#fff}
.hero{position:relative;min-height:780px;display:flex;align-items:center;overflow:hidden;background:var(--night)}
.hero-bg{position:absolute;inset:0;background:linear-gradient(90deg,rgba(5,19,31,.95) 0%,rgba(6,27,43,.86) 28%,rgba(6,27,43,.42) 58%,rgba(6,27,43,.15) 100%),url('assets/hero-piscine.jpg') center right / cover no-repeat;}
.hero-inner{position:relative;z-index:1;width:100%;padding-top:82px;padding-bottom:52px}
.hero-copy{max-width:620px;color:#fff}
.eyebrow,.section-kicker{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;font-weight:800;color:var(--gold);margin-bottom:18px}
.hero h1{font-size:clamp(4rem,6.6vw,6.6rem);line-height:.92;color:#fff;margin-bottom:24px}.hero h1 em{display:block;color:var(--gold);font-style:italic;font-weight:500}
.hero-subtitle{font-size:1.12rem;max-width:560px;color:rgba(255,255,255,.92);margin-bottom:28px}
.hero-actions{display:flex;gap:18px;flex-wrap:wrap;margin-bottom:22px}.zones-line{font-size:.82rem;color:rgba(255,255,255,.86)}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:16px 28px;border:1px solid transparent;border-radius:2px;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;font-weight:800;cursor:pointer}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#fff}.btn-ghost{background:rgba(255,255,255,.04);color:#fff;border-color:rgba(255,255,255,.45)}
.trust-strip{background:#fff;border-bottom:1px solid var(--line)}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);padding:34px 0}
.trust-item{text-align:center;padding:0 26px;border-right:1px solid var(--line)}.trust-item:last-child{border-right:0}
.trust-item svg,.service-card svg{width:44px;height:44px;fill:none;stroke:currentColor;stroke-width:1.55;color:var(--gold);margin-bottom:16px}
.trust-item h3,.service-card h3{font-family:var(--sans);font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;font-weight:800}.trust-item p{font-size:.9rem;color:var(--muted);max-width:200px;margin:9px auto 0}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:42px}.section-head.wide{display:block;max-width:760px}
.section h2{font-size:clamp(2.5rem,4vw,4rem);line-height:.98;color:var(--ink)}.dark h2{color:#fff}
.service-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}.service-card{background:#fff;border:1px solid var(--line);border-radius:10px;padding:34px 26px;min-height:288px;display:flex;flex-direction:column;box-shadow:0 8px 26px rgba(16,32,51,.04)}.service-card svg{color:#1258b0}.service-card p{font-size:.9rem;color:var(--muted);margin-top:14px}
.proof{padding:78px 0}.gold{color:var(--gold)!important}.proof-head h2{font-size:3.3rem}.link-arrow{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;font-weight:800;color:var(--gold)}
.before-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.before-card img{width:100%;height:285px;object-fit:cover;border-radius:10px;border:1px solid rgba(255,255,255,.15);box-shadow:0 12px 40px rgba(0,0,0,.18)}.before-card span{display:block;text-align:center;margin-top:14px;font-size:.8rem;text-transform:uppercase;letter-spacing:.18em;color:rgba(255,255,255,.84)}
.approach{border-top:1px solid rgba(212,164,92,.36);border-bottom:1px solid rgba(212,164,92,.36);padding:48px 0}.approach-grid{display:grid;grid-template-columns:.8fr 1.1fr 1fr;gap:48px;align-items:center}
.star{font-size:2.25rem;color:var(--gold);margin:0 0 6px}.approach-title h2{font-size:3.3rem;line-height:.95}.approach-copy{font-size:1rem;color:rgba(255,255,255,.84);max-width:440px}.approach-points{list-style:none;margin:0;padding:0}.approach-points li{position:relative;padding-left:24px;margin:10px 0;color:rgba(255,255,255,.88)}.approach-points li:before{content:'•';position:absolute;left:0;top:-1px;color:var(--gold);font-size:1.25rem}
.contact{padding:68px 0 74px}.contact-grid{display:grid;grid-template-columns:.9fr 1.2fr;gap:60px;align-items:start}.contact-copy h2{font-size:3.7rem;line-height:.94}.contact-copy>p{margin-top:20px;color:rgba(255,255,255,.84);max-width:360px}.contact-lines{display:grid;gap:10px;margin-top:26px;color:rgba(255,255,255,.88);font-size:.95rem}.contact-form{display:grid;gap:14px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.contact-form input,.contact-form select,.contact-form textarea{width:100%;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.22);border-radius:2px;color:#fff;padding:14px 14px;font:inherit}.contact-form input::placeholder,.contact-form textarea::placeholder{color:rgba(255,255,255,.68)}.contact-form select{color:rgba(255,255,255,.8)}.contact-form option{color:var(--ink)}.file-label{font-size:.82rem;color:rgba(255,255,255,.72);border:1px dashed rgba(255,255,255,.22);padding:12px 14px;cursor:pointer}.file-label input{display:none}.contact-form .btn{justify-self:start;min-width:300px;margin-top:4px}.privacy{font-size:.74rem;color:rgba(255,255,255,.58)}
.site-footer{background:#fbf8f1;border-top:1px solid var(--line);padding:28px 0}.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;font-size:.8rem;color:var(--muted)}.footer-inner strong{display:block;font-family:var(--serif);font-size:1.2rem;color:var(--ink)}.footer-inner span{display:block;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase}
@media (max-width: 1024px){.menu-toggle{display:flex}.main-nav{display:none;position:absolute;top:86px;left:28px;right:28px;flex-direction:column;align-items:flex-start;background:rgba(7,26,42,.96);padding:24px;border:1px solid rgba(255,255,255,.08)}.main-nav.active{display:flex}.trust-grid,.service-grid,.before-grid,.approach-grid,.contact-grid{grid-template-columns:1fr}.trust-item{border-right:0;border-bottom:1px solid var(--line);padding:26px}.trust-item:last-child{border-bottom:0}.contact-copy h2,.approach-title h2{font-size:3rem}}
@media (max-width: 640px){.container{padding:0 20px}.hero{min-height:820px}.hero-bg{background:linear-gradient(90deg,rgba(5,19,31,.93),rgba(6,27,43,.78)), url('assets/hero-piscine.jpg') center/cover no-repeat}.hero h1{font-size:3.4rem}.hero-actions,.form-row{display:grid;grid-template-columns:1fr}.btn,.contact-form .btn{width:100%;min-width:0}.section{padding:64px 0}.proof-head h2,.section h2{font-size:2.45rem}.before-card img{height:220px}.footer-inner{flex-direction:column;align-items:flex-start}}


/* Ajustement V4 : liens téléphone dans le bloc contact */
.contact-lines a {
  color: inherit;
  text-decoration: none;
}
.contact-lines a:hover {
  color: var(--gold);
}


/* V5 : mention Hérault / partenaires de confiance */
.herault-mention {
  display: block;
  margin-top: 14px;
  padding-left: 16px;
  border-left: 1px solid rgba(212, 164, 92, .42);
  color: rgba(255,255,255,.72);
  font-size: .92rem;
  line-height: 1.65;
}

.geo-status-list {
  list-style: none;
  margin: 22px 0 0;
  padding: 0;
  display: grid;
  gap: 9px;
}

.geo-status-list li {
  display: flex;
  gap: 9px;
  align-items: flex-start;
  color: rgba(255,255,255,.82);
  font-size: .92rem;
  line-height: 1.5;
}

.geo-status-list li span {
  color: var(--gold);
  line-height: 1.4;
}


/* V6 : zone élargie sans mention de partenaire */
.zone-mention {
  display: block;
  margin-top: 14px;
  padding-left: 16px;
  border-left: 1px solid rgba(212, 164, 92, .42);
  color: rgba(255,255,255,.72);
  font-size: .92rem;
  line-height: 1.65;
}

/* Logo officiel en footer */
.footer-logo-wrap {
  display: flex;
  align-items: center;
}

.footer-logo {
  width: 180px;
  max-width: 100%;
  height: auto;
  display: block;
}


/* V7 : logo texte seul dans le header */
.brand-image {
  display: inline-flex;
  align-items: center;
}

.header-logo {
  width: 215px;
  max-height: 58px;
  object-fit: contain;
  display: block;
  filter: drop-shadow(0 8px 18px rgba(0,0,0,.18));
}

/* Page Conseils */
.articles-page {
  background: var(--cream);
}

.articles-header {
  background: linear-gradient(135deg, var(--night), #04111a);
  color: var(--white);
  border-bottom: 1px solid rgba(212,164,92,.25);
}

.articles-header .header-inner {
  height: 92px;
}

.articles-nav {
  display: flex;
}

.articles-hero {
  padding: 92px 0 58px;
  background: linear-gradient(135deg, var(--night), #071a2a);
  color: var(--white);
}

.articles-hero h1 {
  font-size: clamp(3.4rem, 6vw, 5.8rem);
  line-height: .95;
  color: var(--white);
}

.articles-hero p:not(.section-kicker) {
  margin-top: 18px;
  max-width: 720px;
  color: rgba(255,255,255,.84);
  font-size: 1.08rem;
}

.articles-list-section {
  padding: 78px 0;
}

.articles-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}

.article-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 30px 28px;
  min-height: 260px;
  display: flex;
  flex-direction: column;
  box-shadow: 0 10px 28px rgba(16,32,51,.045);
}

.article-tag {
  color: var(--gold);
  font-size: .76rem;
  text-transform: uppercase;
  letter-spacing: .16em;
  font-weight: 800;
  margin-bottom: 18px;
}

.article-card h2 {
  font-size: 2rem;
  line-height: 1.05;
  color: var(--ink);
}

.article-card p:not(.article-tag) {
  margin-top: 14px;
  color: var(--muted);
  font-size: .94rem;
}

.article-card a {
  margin-top: auto;
  color: var(--gold);
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: .75rem;
}

.articles-cta {
  margin-top: 42px;
  background: linear-gradient(135deg, var(--night), #06131f);
  color: #fff;
  border-radius: 10px;
  padding: 38px;
  display: flex;
  gap: 28px;
  align-items: center;
  justify-content: space-between;
}

.articles-cta h2 {
  color: #fff;
  font-size: 2.6rem;
}

.articles-cta p {
  color: rgba(255,255,255,.78);
  max-width: 520px;
  margin-top: 8px;
}

.site-footer a {
  color: inherit;
}

@media (max-width: 1024px) {
  .header-logo {
    width: 180px;
    max-height: 52px;
  }

  .articles-grid {
    grid-template-columns: 1fr;
  }

  .articles-cta {
    display: block;
  }

  .articles-cta .btn {
    margin-top: 22px;
  }
}

@media (max-width: 640px) {
  .header-logo {
    width: 158px;
    max-height: 46px;
  }

  .articles-hero {
    padding: 72px 0 46px;
  }

  .article-card h2 {
    font-size: 1.7rem;
  }
}


/* V8 refinements */
.header-logo {
  width: 250px;
  max-height: 50px;
  object-fit: contain;
  display: block;
  filter: none;
}
.footer-logo {
  width: 190px;
  max-width: 100%;
  height: auto;
}
.footer-inner {
  grid-template-columns: auto 1fr auto;
}
@media (max-width: 1024px) {
  .header-logo { width: 210px; max-height: 44px; }
}
@media (max-width: 640px) {
  .header-logo { width: 170px; max-height: 38px; }
}


/* V9 refinements */
.header-logo {
  width: 250px;
  max-height: 50px;
  object-fit: contain;
  display: block;
  filter: drop-shadow(0 6px 16px rgba(0,0,0,.18));
}
.hero-microline {
  margin-top: 18px;
  color: rgba(255,255,255,.78);
  font-size: .96rem;
  line-height: 1.55;
  max-width: 540px;
}
@media (max-width: 1024px) {
  .header-logo { width: 210px; max-height: 44px; }
}
@media (max-width: 640px) {
  .header-logo { width: 170px; max-height: 38px; }
  .hero-microline { font-size: .9rem; }
}

/* V10 : Article SEO page */
.article-page {
  background: var(--cream);
}

.article-hero {
  background:
    linear-gradient(90deg, rgba(5,19,31,.94), rgba(6,27,43,.75)),
    url('../../assets/hero-piscine.jpg') center right / cover no-repeat;
  color: #fff;
  padding: 138px 0 86px;
}

.article-hero-inner {
  max-width: 900px;
}

.article-hero h1 {
  color: #fff;
  font-size: clamp(3.1rem, 6vw, 5.7rem);
  line-height: .95;
  max-width: 920px;
}

.article-hero p:not(.section-kicker) {
  margin-top: 24px;
  max-width: 720px;
  color: rgba(255,255,255,.86);
  font-size: 1.12rem;
}

.article-hero .btn {
  margin-top: 32px;
}

.article-body-section {
  padding: 78px 0 90px;
}

.article-layout {
  display: grid;
  grid-template-columns: 260px minmax(0, 820px);
  gap: 70px;
  align-items: start;
}

.article-sidebar {
  position: sticky;
  top: 110px;
  border-left: 1px solid var(--line);
  padding-left: 22px;
}

.article-sidebar-title {
  font-size: .76rem;
  color: var(--gold);
  text-transform: uppercase;
  letter-spacing: .16em;
  font-weight: 800;
  margin-bottom: 18px;
}

.article-sidebar a {
  display: block;
  color: var(--muted);
  font-size: .88rem;
  margin: 12px 0;
}

.article-sidebar a:hover {
  color: var(--ink);
}

.article-content {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 54px;
  box-shadow: 0 14px 38px rgba(16,32,51,.05);
}

.article-content h2 {
  font-size: 2.45rem;
  line-height: 1.05;
  margin: 44px 0 18px;
  color: var(--ink);
}

.article-content h3 {
  font-family: var(--sans);
  font-size: 1.05rem;
  line-height: 1.35;
  margin: 28px 0 10px;
  font-weight: 800;
  color: var(--ink);
}

.article-content p {
  color: #435061;
  font-size: 1rem;
  line-height: 1.85;
  margin: 0 0 18px;
}

.article-intro {
  font-size: 1.16rem !important;
  color: var(--ink) !important;
}

.article-callout {
  margin: 34px 0;
  padding: 26px 28px;
  border-left: 2px solid var(--gold);
  background: var(--sand);
}

.article-callout p {
  margin: 0;
  color: var(--ink);
  font-family: var(--serif);
  font-size: 1.45rem;
  line-height: 1.3;
}

.article-cta-box {
  margin: 46px 0;
  padding: 36px;
  background: linear-gradient(135deg, var(--night), #06131f);
  color: #fff;
  border-radius: 10px;
}

.article-cta-box h2 {
  color: #fff;
  margin: 0 0 16px;
}

.article-cta-box p {
  color: rgba(255,255,255,.82);
}

.article-cta-box .btn {
  margin-top: 14px;
}

@media (max-width: 980px) {
  .article-layout {
    grid-template-columns: 1fr;
    gap: 28px;
  }
  .article-sidebar {
    display: none;
  }
  .article-content {
    padding: 34px 24px;
  }
  .article-content h2 {
    font-size: 2rem;
  }
  .article-hero {
    padding: 120px 0 70px;
  }
}


/* V11 : Pages SEO locales */
.local-page {
  background: var(--cream);
}

.local-hero {
  background:
    linear-gradient(90deg, rgba(5,19,31,.95), rgba(6,27,43,.77)),
    url('assets/hero-piscine.jpg') center right / cover no-repeat;
  color: #fff;
  padding: 142px 0 88px;
}

.local-page .local-hero {
  background:
    linear-gradient(90deg, rgba(5,19,31,.95), rgba(6,27,43,.77)),
    url('../assets/hero-piscine.jpg') center right / cover no-repeat;
}

.local-hero h1 {
  color: #fff;
  font-size: clamp(3.1rem, 6vw, 5.8rem);
  line-height: .95;
  max-width: 960px;
}

.local-hero p:not(.section-kicker) {
  margin-top: 22px;
  max-width: 760px;
  color: rgba(255,255,255,.86);
  font-size: 1.1rem;
}

.local-hero .btn,
.local-hero-actions {
  margin-top: 28px;
}

.local-hero-actions {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}

.local-content-section,
.zones-section {
  padding: 78px 0 92px;
}

.local-layout {
  display: grid;
  grid-template-columns: minmax(0, 820px) 300px;
  gap: 64px;
  align-items: start;
}

.local-main {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 50px;
  box-shadow: 0 14px 38px rgba(16,32,51,.05);
}

.local-main h2 {
  font-size: 2.4rem;
  line-height: 1.05;
  margin: 0 0 18px;
  color: var(--ink);
}

.local-main h2:not(:first-child) {
  margin-top: 44px;
}

.local-main p {
  color: #435061;
  font-size: 1rem;
  line-height: 1.85;
  margin-bottom: 18px;
}

.local-service-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}

.local-service-list article {
  background: var(--cream);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 22px;
}

.local-service-list h3 {
  font-family: var(--sans);
  font-size: .92rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-weight: 800;
  margin-bottom: 10px;
}

.local-service-list p {
  margin: 0;
  font-size: .92rem;
}

.area-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.area-tags span {
  border: 1px solid var(--line);
  background: var(--sand);
  border-radius: 999px;
  padding: 9px 14px;
  font-size: .85rem;
  color: var(--ink);
}

.local-cta {
  margin-bottom: 0;
}

.local-aside {
  display: grid;
  gap: 18px;
  position: sticky;
  top: 112px;
}

.aside-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 24px;
}

.aside-card a {
  display: block;
  color: var(--muted);
  margin: 12px 0;
  font-size: .92rem;
}

.aside-card a:hover {
  color: var(--ink);
}

.zones-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}

.zone-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 30px;
  min-height: 210px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  box-shadow: 0 10px 28px rgba(16,32,51,.045);
}

.zone-card h2 {
  font-size: 2.35rem;
  color: var(--ink);
}

.zone-card p {
  color: var(--muted);
  margin-top: 16px;
}

.article-cta-box a {
  color: var(--gold);
  font-weight: 700;
}

@media (max-width: 980px) {
  .local-layout,
  .zones-grid,
  .local-service-list {
    grid-template-columns: 1fr;
  }

  .local-aside {
    position: static;
  }

  .local-main {
    padding: 34px 24px;
  }

  .local-main h2 {
    font-size: 2rem;
  }
}


/* V12 : images article SEO */
.article-figure {
  margin: 34px 0 36px;
}

.article-figure img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 10px;
  border: 1px solid var(--line);
  box-shadow: 0 14px 38px rgba(16,32,51,.08);
}

.article-figure figcaption {
  margin-top: 12px;
  font-size: .88rem;
  line-height: 1.6;
  color: var(--muted);
}

.article-figure-wide img {
  max-height: 560px;
  object-fit: cover;
}


/* V13 : Article premium, plus aéré et plus conversion */
.article-hero-premium {
  background:
    linear-gradient(90deg, rgba(5,19,31,.96), rgba(6,27,43,.78)),
    url('../../assets/article-piscine-claire.jpg') center right / cover no-repeat;
}

.breadcrumb {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: 28px;
  color: rgba(255,255,255,.72);
  font-size: .82rem;
}

.breadcrumb a {
  color: rgba(255,255,255,.82);
}

.breadcrumb a:hover {
  color: var(--gold);
}

.article-meta {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 24px;
  color: rgba(255,255,255,.72);
  font-size: .84rem;
}

.article-meta span {
  border-right: 1px solid rgba(255,255,255,.22);
  padding-right: 14px;
}

.article-meta span:last-child {
  border-right: 0;
  padding-right: 0;
}

.article-content-premium {
  padding: 62px;
}

.article-content-premium p {
  max-width: 720px;
}

.article-content-premium h2 {
  max-width: 760px;
}

.premium-callout {
  background: #f8f1e5;
}

.premium-callout p {
  max-width: none;
}

.premium-cta p {
  max-width: 760px;
}

.local-links-inline {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 26px 0 42px;
}

.local-links-inline a {
  display: inline-flex;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 9px 14px;
  color: var(--ink);
  background: var(--sand);
  font-size: .86rem;
  font-weight: 700;
}

.local-links-inline a:hover {
  border-color: var(--gold);
  color: var(--gold);
}

@media (max-width: 980px) {
  .article-content-premium {
    padding: 36px 24px;
  }
}


/* V14 : finitions article premium */
.article-opening-title {
  font-size: clamp(2.4rem, 4vw, 3.25rem) !important;
  line-height: 1.02 !important;
  margin: 0 0 22px !important;
  max-width: 760px;
  color: var(--ink);
}

.article-content-premium .article-intro {
  max-width: 760px;
  margin-bottom: 30px;
}

.article-content-premium .article-figure {
  max-width: 86%;
  margin-left: auto;
  margin-right: auto;
}

.article-content-premium .article-figure-wide {
  max-width: 88%;
}

.article-content-premium .article-figure img {
  max-height: 520px;
  object-fit: cover;
}

.article-content-premium .article-figure:not(.article-figure-wide) {
  max-width: 76%;
}

.article-content-premium .article-figure:not(.article-figure-wide) img {
  max-height: 430px;
}

@media (max-width: 980px) {
  .article-content-premium .article-figure,
  .article-content-premium .article-figure-wide,
  .article-content-premium .article-figure:not(.article-figure-wide) {
    max-width: 100%;
  }

  .article-content-premium .article-figure img,
  .article-content-premium .article-figure:not(.article-figure-wide) img {
    max-height: none;
  }
}


/* V15 : signature et finition éditoriale */
.article-author-note {
  max-width: 760px;
  margin: 26px 0 34px;
  padding: 22px 24px;
  border: 1px solid var(--line);
  border-left: 2px solid var(--gold);
  border-radius: 8px;
  background: #fbf8f1;
}

.article-author-note p {
  margin: 0 0 8px !important;
  line-height: 1.6 !important;
  color: #435061;
}

.article-author-note p:last-child {
  margin-bottom: 0 !important;
}

.article-author-note strong {
  color: var(--ink);
}

.pro-note {
  max-width: 720px;
  padding-left: 18px;
  border-left: 1px solid rgba(212,164,92,.55);
  color: var(--ink) !important;
  font-weight: 600;
}



/* V16 : état menu mobile */
body.menu-open {
  overflow: hidden;
}

.menu-toggle.active span:first-child {
  transform: translateY(5px) rotate(45deg);
}

.menu-toggle.active span:last-child {
  transform: translateY(-5px) rotate(-45deg);
}

/* Signature discrète article */
.article-signature {
  margin-top: 42px;
  padding-top: 22px;
  border-top: 1px solid var(--line);
  color: var(--muted);
}

.article-signature span {
  display: block;
  font-family: var(--serif);
  font-size: 1.35rem;
  color: var(--ink);
}

.article-signature small {
  display: block;
  margin-top: 4px;
  font-size: .82rem;
  letter-spacing: .02em;
}



/* V17 : fin article allégée */
.local-links-compact {
  margin: 36px 0 42px;
  padding-top: 24px;
  border-top: 1px solid var(--line);
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
}

.local-links-compact p {
  margin: 0 8px 0 0 !important;
  color: var(--muted);
  font-size: .9rem !important;
  line-height: 1.4 !important;
}

.local-links-compact a {
  display: inline-flex;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 8px 13px;
  color: var(--ink);
  background: var(--sand);
  font-size: .82rem;
  font-weight: 700;
}

.local-links-compact a:hover {
  border-color: var(--gold);
  color: var(--gold);
}


/* V18 : CTA doré avec texte foncé */
.btn-gold,
.btn.btn-gold,
a.btn-gold,
button.btn-gold {
  color: #14233b !important;
}

.btn-gold:hover,
.btn.btn-gold:hover,
a.btn-gold:hover,
button.btn-gold:hover {
  color: #0d1b30 !important;
}

/* Cards on articles index */
.article-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 26px;
  margin-top: 40px;
}
.article-card {
  border: 1px solid var(--line);
  border-radius: 14px;
  overflow: hidden;
  background: #fff;
}
.article-card img {
  width: 100%;
  height: 240px;
  object-fit: cover;
  display: block;
}
.article-card-body {
  padding: 22px 22px 24px;
}
.article-card-body h2,
.article-card-body h3 {
  margin: 0 0 12px;
  font-size: 1.45rem;
}
.article-card-body p {
  margin: 0 0 16px;
  color: var(--muted);
}
.article-kicker {
  display: inline-block;
  margin-bottom: 12px;
  color: var(--gold);
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-weight: 700;
}
@media (max-width: 900px) {
  .article-grid {
    grid-template-columns: 1fr;
  }
  .article-card img {
    height: 220px;
  }
}



/* V19 : hero article filtration harmonisé */
.article-hero-filtration {
  background:
    linear-gradient(90deg, rgba(5,19,31,.96), rgba(6,27,43,.76)),
    url('assets/articles/filtration-ete-hero.jpg') center right / cover no-repeat;
}

.article-page-filtration .article-hero-filtration {
  background:
    linear-gradient(90deg, rgba(5,19,31,.96), rgba(6,27,43,.76)),
    url('../../assets/articles/filtration-ete-hero.jpg') center right / cover no-repeat;
}



/* V20 : correction définitive menu mobile + hero mobile */
.btn-gold,
.btn.btn-gold,
a.btn-gold,
button.btn-gold,
.nav-cta {
  color: #071a2a !important;
}

@media (max-width: 1024px) {
  .menu-toggle {
    position: relative;
    z-index: 1002;
  }

  .main-nav {
    display: none;
  }

  .main-nav.active,
  .main-nav.open {
    display: flex !important;
    position: fixed !important;
    top: 118px !important;
    left: 22px !important;
    right: 22px !important;
    z-index: 1001 !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 24px !important;
    padding: 30px 28px !important;
    background: rgba(7, 26, 42, .985) !important;
    border: 1px solid rgba(255,255,255,.12) !important;
    box-shadow: 0 24px 80px rgba(0,0,0,.35) !important;
  }

  .main-nav.active a,
  .main-nav.open a {
    width: 100%;
  }

  .main-nav.active .nav-cta,
  .main-nav.open .nav-cta {
    text-align: center;
    width: 100%;
  }
}

@media (max-width: 640px) {
  .site-header,
  .articles-header {
    min-height: 92px;
  }

  .hero {
    min-height: 740px !important;
  }

  .hero-inner {
    padding-top: 108px !important;
    padding-bottom: 42px !important;
  }

  .hero h1 {
    font-size: clamp(3rem, 14vw, 3.85rem) !important;
    line-height: .96 !important;
    margin-bottom: 22px !important;
  }

  .hero-subtitle {
    font-size: 1rem !important;
    line-height: 1.62 !important;
    margin-bottom: 24px !important;
  }

  .hero-actions {
    gap: 14px !important;
    margin-bottom: 20px !important;
  }

  .hero-actions .btn {
    padding: 15px 20px !important;
    font-size: .72rem !important;
    letter-spacing: .1em !important;
  }

  .zones-line {
    font-size: .78rem !important;
    line-height: 1.55 !important;
  }

  .article-hero h1,
  .local-hero h1 {
    font-size: clamp(3rem, 14vw, 4.05rem) !important;
    line-height: .96 !important;
  }

  .article-hero p,
  .local-hero p:not(.section-kicker) {
    font-size: 1rem !important;
    line-height: 1.62 !important;
  }

  .breadcrumb,
  .article-meta {
    font-size: .75rem !important;
  }
}



/* V21 : logo officiel blanc + header mobile raffiné */
.header-logo {
  width: auto !important;
  height: 52px !important;
  max-width: 250px !important;
  object-fit: contain !important;
}

.brand-image {
  display: inline-flex;
  align-items: center;
}

@media (max-width: 640px) {
  .site-header,
  .articles-header {
    min-height: 84px !important;
    padding: 0 !important;
  }

  .header-inner,
  .nav-container {
    min-height: 84px !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    align-items: center !important;
  }

  .header-logo,
  .logo-header {
    height: 44px !important;
    max-width: 235px !important;
    width: auto !important;
    object-fit: contain !important;
  }

  .menu-toggle {
    width: 42px !important;
    height: 42px !important;
  }

  .main-nav.active,
  .main-nav.open {
    top: 96px !important;
    left: 18px !important;
    right: 18px !important;
    padding: 26px 24px !important;
  }

  .hero-inner {
    padding-top: 94px !important;
  }

  .hero .section-kicker,
  .hero .eyebrow,
  .hero-kicker {
    display: none !important;
  }
}

@media (max-width: 390px) {
  .header-logo,
  .logo-header {
    height: 39px !important;
    max-width: 210px !important;
  }
}



/* V22 : mobile-first + SEO local */
.local-issue-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px 18px;
  margin: 18px 0 32px;
  padding: 0;
  list-style: none;
}

.local-issue-list li {
  position: relative;
  padding-left: 22px;
  color: #435061;
  line-height: 1.6;
}

.local-issue-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .72em;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--gold);
}

@media (max-width: 640px) {
  .hero {
    min-height: 650px !important;
  }

  .hero-inner {
    padding-top: 86px !important;
    padding-bottom: 34px !important;
  }

  .hero h1 {
    font-size: clamp(2.75rem, 12.5vw, 3.35rem) !important;
    line-height: .98 !important;
  }

  .hero-subtitle {
    font-size: .96rem !important;
    line-height: 1.52 !important;
    margin-bottom: 20px !important;
  }

  .hero-actions .btn-ghost,
  .hero-actions .btn-outline,
  .hero-actions a[href*="#services"] {
    display: none !important;
  }

  .hero-actions .btn-gold {
    width: 100% !important;
    justify-content: center !important;
    text-align: center !important;
  }

  .zones-line {
    margin-top: 18px !important;
    max-width: 95% !important;
  }

  .local-issue-list {
    grid-template-columns: 1fr;
  }

  .local-hero-actions .btn-ghost {
    display: none !important;
  }
}



/* V23 : pages locales plus sobres */
.local-hero-clean .local-hero-inner {
  max-width: 1180px;
}

.local-hero-clean h1 {
  max-width: 1180px;
}

.local-hero-clean p:not(.section-kicker) {
  max-width: 920px;
}

.local-content-clean {
  padding: 68px 0 86px;
}

.local-clean-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}

.local-clean-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 34px;
  box-shadow: 0 14px 36px rgba(16,32,51,.045);
}

.local-clean-card-wide {
  grid-column: 1 / -1;
}

.local-clean-card h2 {
  font-size: clamp(2.1rem, 3.6vw, 3.2rem);
  line-height: 1.04;
  margin-bottom: 18px;
}

.local-clean-card p {
  color: var(--muted);
  line-height: 1.75;
}

.clean-tags {
  margin-top: 14px;
}

.zone-card-city-only {
  min-height: 150px;
  justify-content: center;
}

.zone-card-city-only h2 {
  margin: 0;
}

.zones-grid-city-only {
  grid-auto-rows: 1fr;
}

/* Correction contraste blocs CTA sombres */
.article-cta-box,
.premium-cta,
.local-cta {
  color: #fff;
}

.article-cta-box h2,
.premium-cta h2,
.local-cta h2 {
  color: #fff !important;
  opacity: 1 !important;
}

.article-cta-box p,
.premium-cta p,
.local-cta p {
  color: rgba(255,255,255,.82) !important;
  opacity: 1 !important;
}

@media (max-width: 900px) {
  .local-clean-grid,
  .zones-grid-city-only {
    grid-template-columns: 1fr;
  }

  .local-clean-card {
    padding: 28px 22px;
  }
}



/* V24 : hero accueil minimaliste */
.hero .hero-inner {
  max-width: 760px;
}

.hero h1 {
  margin-bottom: 0 !important;
}

.hero h1 .highlight,
.hero h1 em,
.hero h1 i {
  display: block;
}

@media (min-width: 1025px) {
  .hero {
    min-height: 760px;
  }

  .hero .hero-inner {
    padding-top: 180px;
  }
}

@media (max-width: 640px) {
  .hero {
    min-height: 610px !important;
  }

  .hero-inner {
    padding-top: 112px !important;
    padding-bottom: 34px !important;
  }

  .hero h1 {
    font-size: clamp(3.05rem, 13vw, 3.65rem) !important;
    line-height: .98 !important;
  }
}



/* V25 : finition premium, hero mobile et protocole */
.hero .hero-inner {
  text-align: left !important;
  align-items: flex-start !important;
}

.hero h1 {
  text-align: left !important;
}

.hero-microcopy {
  margin-top: 26px;
  max-width: 520px;
  color: rgba(255,255,255,.88);
}

.hero-microcopy p {
  margin: 0 0 12px;
  font-size: 1.05rem;
  line-height: 1.55;
}

.hero-microcopy .hero-area {
  color: var(--gold);
  font-size: .92rem;
  font-weight: 700;
  letter-spacing: .02em;
}

.hero-mobile-cta {
  margin-top: 12px;
  display: none;
}

.protocol-section {
  background: #fbfaf6;
  padding: 86px 0 92px;
  border-bottom: 1px solid var(--line);
}

.section-heading.centered {
  text-align: center;
  margin-bottom: 42px;
}

.section-heading.centered h2 {
  font-size: clamp(2.8rem, 5vw, 4.8rem);
  line-height: 1;
  color: var(--ink);
}

.protocol-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 26px;
}

.protocol-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 34px 28px 36px;
  text-align: center;
  box-shadow: 0 14px 34px rgba(16,32,51,.045);
}

.protocol-icon {
  width: 88px;
  height: 88px;
  border: 1px solid rgba(212,164,92,.75);
  border-radius: 50%;
  display: grid;
  place-items: center;
  margin: 8px auto 26px;
  color: var(--gold);
}

.protocol-icon svg {
  width: 40px;
  height: 40px;
  stroke: var(--gold);
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.protocol-card h3 {
  font-size: 2rem;
  margin-bottom: 12px;
  color: var(--ink);
}

.protocol-card p {
  color: var(--muted);
  line-height: 1.65;
  margin: 0;
}

.founder-note {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  margin: 40px auto 0;
  padding-top: 26px;
  max-width: 680px;
  border-top: 1px solid var(--line);
  color: var(--muted);
  text-align: center;
}

.founder-note strong {
  color: var(--gold);
  font-weight: 700;
}

.founder-icon {
  color: var(--gold);
  font-size: 1.6rem;
}

@media (max-width: 900px) {
  .protocol-grid {
    grid-template-columns: 1fr;
  }

  .protocol-icon {
    width: 78px;
    height: 78px;
    margin-bottom: 22px;
  }

  .protocol-icon svg {
    width: 34px;
    height: 34px;
  }
}

@media (max-width: 640px) {
  .header-logo,
  .logo-header {
    height: 35px !important;
    max-width: 195px !important;
  }

  .hero {
    min-height: 720px !important;
    background-position: 65% center !important;
  }

  .hero::before {
    opacity: .78 !important;
  }

  .hero-inner {
    padding-top: 94px !important;
  }

  .hero h1 {
    font-size: clamp(2.75rem, 11.7vw, 3.35rem) !important;
    line-height: .98 !important;
    max-width: 88vw !important;
  }

  .hero-microcopy {
    margin-top: 22px;
    max-width: 84vw;
  }

  .hero-microcopy p {
    font-size: .98rem;
    line-height: 1.48;
  }

  .hero-microcopy .hero-area {
    font-size: .82rem;
    color: var(--gold);
  }

  .hero-mobile-cta {
    display: inline-flex !important;
    padding: 14px 22px !important;
    font-size: .72rem !important;
    letter-spacing: .08em !important;
  }

  .protocol-section {
    padding: 58px 0 64px;
  }

  .section-heading.centered h2 {
    font-size: 2.45rem;
  }

  .protocol-card {
    display: grid;
    grid-template-columns: 62px 1fr;
    column-gap: 18px;
    text-align: left;
    align-items: center;
    padding: 24px 22px;
  }

  .protocol-number {
    display: none;
  }

  .protocol-icon {
    grid-row: span 2;
    width: 54px;
    height: 54px;
    margin: 0;
    font-size: 1.45rem;
  }

  .protocol-card h3 {
    font-size: 1.45rem;
    margin: 0 0 4px;
  }

  .protocol-card p {
    font-size: .92rem;
  }

  .founder-note {
    font-size: .9rem;
    line-height: 1.55;
  }
}

/* V25 : FAQ discrète zones */
.zone-faq-section {
  padding: 0 0 82px;
  background: #fbfaf6;
}

.zone-faq-box {
  max-width: 920px;
  margin: 0 auto;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 34px;
}

.zone-faq-box h2 {
  font-size: 2.4rem;
  margin-bottom: 20px;
}

.zone-faq-box details {
  border-top: 1px solid var(--line);
  padding: 16px 0;
}

.zone-faq-box details:first-of-type {
  border-top: 0;
}

.zone-faq-box summary {
  cursor: pointer;
  font-weight: 700;
  color: var(--ink);
}

.zone-faq-box p {
  color: var(--muted);
  margin: 12px 0 0;
  line-height: 1.65;
}



/* V26 : alignement homogène + hero plus lumineux */
.hero::before {
  opacity: .70 !important;
}

.hero {
  background-position: 62% center !important;
}

.hero .hero-inner {
  margin-left: 0 !important;
  margin-right: auto !important;
}

.protocol-section .section-heading.centered {
  text-align: left !important;
  max-width: 1180px;
  margin-left: auto;
  margin-right: auto;
}

.protocol-section .section-heading.centered h2 {
  text-align: left !important;
}

.protocol-grid {
  align-items: stretch;
}

.protocol-card {
  text-align: left !important;
}

.protocol-card .protocol-icon {
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.protocol-card h3,
.protocol-card p {
  text-align: left !important;
}

.founder-note {
  display: none !important;
}

/* uniformisation des grands blocs */
.services .section-heading,
.section-heading,
.content-block,
.form-section .section-heading {
  text-align: left;
}

@media (min-width: 1025px) {
  .hero .hero-inner {
    max-width: 760px !important;
  }

  .protocol-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .hero {
    background-position: 68% center !important;
  }

  .hero::before {
    opacity: .62 !important;
  }

  .hero::after {
    opacity: .55 !important;
  }

  .hero h1 {
    max-width: 92vw !important;
  }

  .hero-microcopy {
    max-width: 90vw !important;
  }

  .protocol-section .section-heading.centered {
    text-align: left !important;
  }

  .protocol-section .section-heading.centered h2 {
    text-align: left !important;
  }
}



/* V27 : alignement hero + dégradé mobile chirurgical */
@media (min-width: 1025px) {
  .hero .hero-inner {
    max-width: 1180px !important;
    width: min(1180px, calc(100% - 48px)) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .hero h1,
  .hero-microcopy {
    max-width: 760px !important;
  }

  .protocol-section .container,
  .protocol-section .section-heading.centered {
    max-width: 1180px !important;
    width: min(1180px, calc(100% - 48px)) !important;
  }
}

/* Hero : overlay plus subtil sur desktop aussi */
.hero::before {
  background: linear-gradient(
    90deg,
    rgba(5, 19, 31, 0.88) 0%,
    rgba(5, 19, 31, 0.64) 42%,
    rgba(5, 19, 31, 0.30) 100%
  ) !important;
  opacity: 1 !important;
}

.hero::after {
  background: linear-gradient(
    to bottom,
    rgba(5, 19, 31, 0.12) 0%,
    rgba(5, 19, 31, 0.10) 45%,
    rgba(5, 19, 31, 0.28) 100%
  ) !important;
}

/* Mobile : garder le texte lisible, libérer la piscine en bas */
@media (max-width: 768px) {
  .hero {
    min-height: 92vh !important;
    background-position: 78% bottom !important;
    background-size: cover !important;
  }

  .hero::before {
    background: linear-gradient(
      to bottom,
      rgba(5, 19, 31, 0.86) 0%,
      rgba(5, 19, 31, 0.64) 42%,
      rgba(5, 19, 31, 0.22) 100%
    ) !important;
    opacity: 1 !important;
  }

  .hero::after {
    background: linear-gradient(
      to bottom,
      rgba(5, 19, 31, 0.00) 0%,
      rgba(5, 19, 31, 0.06) 48%,
      rgba(5, 19, 31, 0.16) 100%
    ) !important;
    opacity: 1 !important;
  }

  .hero .hero-inner {
    width: calc(100% - 44px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-top: 96px !important;
    padding-bottom: 42px !important;
  }

  .hero h1 {
    font-size: clamp(2.45rem, 10.6vw, 3.05rem) !important;
    line-height: 1.04 !important;
    max-width: 84vw !important;
  }

  .hero-microcopy {
    max-width: 82vw !important;
    margin-top: 20px !important;
  }

  .hero-microcopy p {
    font-size: .95rem !important;
    line-height: 1.48 !important;
  }

  .hero-microcopy .hero-area {
    font-size: .78rem !important;
  }

  .hero-mobile-cta {
    width: auto !important;
    min-width: 230px !important;
    justify-content: center !important;
    color: #071a2a !important;
  }
}

@media (max-width: 390px) {
  .hero .hero-inner {
    width: calc(100% - 34px) !important;
  }

  .hero h1 {
    font-size: clamp(2.32rem, 10vw, 2.82rem) !important;
  }
}



/* V28 : grille desktop unique pour hero / protocole / prestations */
:root {
  --content-rail: 960px;
  --content-rail-wide: 1180px;
}

/* On centre le rail global, puis tous les gros contenus partent du même bord gauche */
@media (min-width: 1025px) {
  .hero .hero-inner,
  .protocol-section > .container,
  #services > .container,
  .services > .container,
  .section-services > .container {
    width: min(var(--content-rail), calc(100% - 48px)) !important;
    max-width: var(--content-rail) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .hero h1,
  .hero-microcopy {
    max-width: 760px !important;
    margin-left: 0 !important;
    margin-right: auto !important;
    text-align: left !important;
  }

  .protocol-section .section-heading,
  .protocol-section .section-heading.centered,
  #services .section-heading,
  .services .section-heading,
  .section-services .section-heading {
    width: 100% !important;
    max-width: 760px !important;
    margin-left: 0 !important;
    margin-right: auto !important;
    text-align: left !important;
  }

  .protocol-section .section-heading h2,
  .protocol-section .section-heading.centered h2,
  #services .section-heading h2,
  .services .section-heading h2,
  .section-services .section-heading h2 {
    text-align: left !important;
  }

  .protocol-grid,
  .services-grid,
  .service-grid,
  .cards-grid {
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: auto !important;
  }

  /* Le bandeau d'icônes juste après le protocole reste centré car c'est une frise de réassurance */
  .features-strip .container,
  .trust-strip .container,
  .reassurance-strip .container {
    width: min(var(--content-rail), calc(100% - 48px)) !important;
    max-width: var(--content-rail) !important;
  }
}

/* Desktop large : éviter que le hero paraisse collé au centre quand l'écran est très large */
@media (min-width: 1440px) {
  .hero .hero-inner,
  .protocol-section > .container,
  #services > .container,
  .services > .container,
  .section-services > .container {
    width: min(var(--content-rail), 100%) !important;
  }
}



/* V29 : alignement bas de page + pages locales texte naturel */
@media (min-width: 1025px) {
  .split-section > .container,
  .dark-section > .container,
  .contact-section > .container,
  .form-section > .container,
  #contact > .container,
  #devis > .container,
  .site-footer > .container,
  .footer-inner,
  .footer-container {
    width: min(var(--content-rail), calc(100% - 48px)) !important;
    max-width: var(--content-rail) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .split-section h2,
  .dark-section h2,
  .contact-section h2,
  .form-section h2,
  #contact h2,
  #devis h2 {
    text-align: left !important;
  }
}

.local-clean-text {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  max-width: 960px;
}

.local-clean-text .local-clean-card {
  padding: 42px;
}

.local-clean-text .local-clean-card h2 {
  max-width: 760px;
}

.local-clean-text .local-clean-card p {
  max-width: 820px;
  font-size: 1rem;
  line-height: 1.8;
}

@media (max-width: 900px) {
  .local-clean-text .local-clean-card {
    padding: 28px 22px;
  }
}



/* V30 : bloc “L’esprit libre” recadré et aligné */
@media (min-width: 1025px) {
  .split-section,
  .dark-section,
  .intro-dark,
  .reassurance-dark {
    padding-top: 84px !important;
    padding-bottom: 84px !important;
  }

  .split-section > .container,
  .dark-section > .container,
  .intro-dark > .container,
  .reassurance-dark > .container {
    width: min(var(--content-rail), calc(100% - 48px)) !important;
    max-width: var(--content-rail) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    display: block !important;
  }

  .split-section h2,
  .dark-section h2,
  .intro-dark h2,
  .reassurance-dark h2 {
    max-width: 640px !important;
    margin: 0 0 34px 0 !important;
    text-align: left !important;
  }

  .split-section .split-grid,
  .dark-section .split-grid,
  .intro-dark .split-grid,
  .reassurance-dark .split-grid,
  .split-section .content-grid,
  .dark-section .content-grid,
  .intro-dark .content-grid,
  .reassurance-dark .content-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 64px !important;
    align-items: start !important;
    width: 100% !important;
  }

  .split-section .content-block,
  .dark-section .content-block,
  .intro-dark .content-block,
  .reassurance-dark .content-block {
    max-width: none !important;
    margin: 0 !important;
  }
}

/* Fallback ciblé sur les sections sombres qui contiennent ce titre */
@media (min-width: 1025px) {
  section:has(h2) h2 {
    text-wrap: balance;
  }

  section:has(h2) .section-kicker {
    text-align: left !important;
  }
}

@media (max-width: 1024px) {
  .split-section > .container,
  .dark-section > .container,
  .intro-dark > .container,
  .reassurance-dark > .container {
    display: block !important;
  }

  .split-section h2,
  .dark-section h2,
  .intro-dark h2,
  .reassurance-dark h2 {
    margin-bottom: 26px !important;
  }
}



/* V30 : hook dédié si présent dans le HTML */
@media (min-width: 1025px) {
  .free-water-section > .container {
    width: min(var(--content-rail), calc(100% - 48px)) !important;
    max-width: var(--content-rail) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    display: block !important;
  }

  .free-water-section h2 {
    max-width: 620px !important;
    margin-bottom: 34px !important;
  }

  .free-water-section .split-grid,
  .free-water-section .content-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 64px !important;
    align-items: start !important;
  }
}



/* V32 : bloc “L’esprit libre, l’eau parfaite.” simplifié et aligné */
.free-water-section-clean {
  background: #061927;
  color: #fff;
  padding: 86px 0;
  border-top: 1px solid rgba(212,164,92,.35);
  border-bottom: 1px solid rgba(212,164,92,.35);
}

.free-water-section-clean .container {
  width: min(var(--content-rail, 960px), calc(100% - 48px));
  max-width: var(--content-rail, 960px);
  margin-left: auto;
  margin-right: auto;
}

.free-water-block {
  max-width: 980px;
}

.free-water-heading {
  max-width: 880px;
}

.free-water-heading h2 {
  color: #fff;
  font-size: clamp(3.1rem, 5vw, 4.9rem);
  line-height: 1.02;
  letter-spacing: -0.02em;
  margin: 0;
}

.free-water-divider {
  display: block;
  width: 76px;
  height: 2px;
  background: var(--gold);
  margin: 28px 0 34px;
}

.free-water-text-stack {
  max-width: 880px;
}

.free-water-lead {
  color: rgba(255,255,255,.9);
  font-size: 1.18rem;
  line-height: 1.6;
  margin: 0 0 34px;
  max-width: 860px;
}

.free-water-list {
  display: grid;
  gap: 20px;
  margin: 0;
  padding: 0;
  list-style: none;
  max-width: 860px;
}

.free-water-list li {
  position: relative;
  padding-left: 34px;
  color: rgba(255,255,255,.92);
  font-size: 1.04rem;
  line-height: 1.55;
}

.free-water-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .58em;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--gold);
}

@media (max-width: 900px) {
  .free-water-section-clean {
    padding: 64px 0;
  }

  .free-water-section-clean .container {
    width: calc(100% - 44px);
  }

  .free-water-heading h2 {
    font-size: clamp(2.6rem, 9.5vw, 3.8rem);
    line-height: 1.05;
  }

  .free-water-divider {
    width: 64px;
    margin: 22px 0 26px;
  }

  .free-water-lead {
    font-size: 1.03rem;
    margin-bottom: 26px;
  }

  .free-water-list {
    gap: 16px;
  }

  .free-water-list li {
    font-size: .98rem;
    padding-left: 28px;
  }

  .free-water-list li::before {
    width: 9px;
    height: 9px;
  }
}




/* V33 : version complète — ancien bloc approche supprimé */
.free-water-section-clean {
  scroll-margin-top: 100px;
}

/* Le nouveau bloc devient l'unique section Notre approche */
.free-water-section-clean + #devis,
.free-water-section-clean + section#devis {
  margin-top: 0;
}

/* Sécurité : si l'ancien bloc approche reste dans un cache CSS/HTML, on ne l'affiche pas */
section.section.approach.dark:not(.free-water-section-clean) {
  display: none !important;
}

/* Ajustement final desktop */
@media (min-width: 1025px) {
  .free-water-section-clean .container,
  #devis > .container {
    width: min(var(--content-rail, 960px), calc(100% - 48px)) !important;
    max-width: var(--content-rail, 960px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
}

/* Ajustement final mobile */
@media (max-width: 640px) {
  .free-water-section-clean {
    padding: 58px 0 62px;
  }

  .free-water-heading h2 {
    font-size: clamp(2.45rem, 10vw, 3.35rem) !important;
  }
}



/* V34 : restauration du bloc contact comme avant */
#devis {
  background: #061927 !important;
  color: #fff !important;
  padding: 84px 0 88px !important;
  border-top: 1px solid rgba(212,164,92,.35) !important;
}

#devis .contact-grid {
  display: grid !important;
  grid-template-columns: .9fr 1.2fr !important;
  gap: 60px !important;
  align-items: start !important;
}

#devis .contact-copy h2 {
  color: #fff !important;
  font-size: clamp(3rem, 5vw, 4.8rem) !important;
  line-height: .94 !important;
}

#devis .contact-copy p,
#devis .contact-lines,
#devis .geo-status-list,
#devis .privacy {
  color: rgba(255,255,255,.78) !important;
}

#devis .contact-lines a {
  color: rgba(255,255,255,.9) !important;
}

#devis .geo-status-list li {
  color: rgba(255,255,255,.78) !important;
}

#devis .geo-status-list li span {
  color: var(--gold) !important;
}

#devis .contact-form input,
#devis .contact-form textarea,
#devis .contact-form select {
  background: rgba(255,255,255,.04) !important;
  border: 1px solid rgba(255,255,255,.24) !important;
  color: #fff !important;
}

#devis .contact-form input::placeholder,
#devis .contact-form textarea::placeholder {
  color: rgba(255,255,255,.62) !important;
}

#devis .file-label {
  color: rgba(255,255,255,.74) !important;
  border: 1px dashed rgba(255,255,255,.26) !important;
  background: rgba(255,255,255,.02) !important;
}

#devis .btn-gold {
  color: #071a2a !important;
}

@media (max-width: 900px) {
  #devis {
    padding: 64px 0 72px !important;
  }

  #devis .contact-grid {
    grid-template-columns: 1fr !important;
    gap: 42px !important;
  }

  #devis .contact-copy h2 {
    font-size: clamp(2.8rem, 12vw, 4rem) !important;
  }
}


/* V36 : protocole simplifié */
.protocol-grid-minimal {
  max-width: 1080px;
  margin: 0 auto;
  gap: 22px;
}

.protocol-card-minimal {
  padding: 28px 28px 30px;
  text-align: left;
  min-height: 260px;
}

.protocol-step {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(212, 164, 92, .75);
  color: var(--gold);
  font-weight: 800;
  font-size: 1rem;
  margin-bottom: 28px;
}

.protocol-grid-minimal .protocol-card h3,
.protocol-grid-minimal .protocol-card p {
  text-align: left;
}

.protocol-grid-minimal .protocol-card p {
  max-width: 26ch;
}

.article-hero-chemie {
  background:
    linear-gradient(90deg, rgba(5,19,31,.95), rgba(6,27,43,.76)),
    url('assets/article-analyse-eau.jpg') center center / cover no-repeat;
}

.article-page-chemie .article-hero-chemie {
  background:
    linear-gradient(90deg, rgba(5,19,31,.95), rgba(6,27,43,.76)),
    url('../../assets/article-analyse-eau.jpg') center center / cover no-repeat;
}

@media (max-width: 900px) {
  .protocol-grid-minimal {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .protocol-card-minimal {
    min-height: auto;
    padding: 24px 24px 26px;
  }

  .protocol-step {
    width: 38px;
    height: 38px;
    margin-bottom: 20px;
  }
}



/* V37 : article préparation voyageurs */
.article-hero-voyageurs {
  background:
    linear-gradient(90deg, rgba(5,19,31,.95), rgba(6,27,43,.74)),
    url('assets/article-piscine-claire.jpg') center center / cover no-repeat;
}

.article-page-voyageurs .article-hero-voyageurs {
  background:
    linear-gradient(90deg, rgba(5,19,31,.95), rgba(6,27,43,.74)),
    url('../../assets/article-piscine-claire.jpg') center center / cover no-repeat;
}



/* V38 : zones premium + pages locales premium */
.zones-hero-premium,
.local-hero-premium {
  min-height: 420px;
  color: #fff;
  display: flex;
  align-items: center;
  background:
    linear-gradient(90deg, rgba(5,19,31,.94), rgba(5,19,31,.62), rgba(5,19,31,.22)),
    url('assets/hero-piscine.jpg') center right / cover no-repeat;
  padding: 135px 0 78px;
}

.local-hero-premium {
  background:
    linear-gradient(90deg, rgba(5,19,31,.94), rgba(5,19,31,.62), rgba(5,19,31,.24)),
    var(--local-hero-img) center right / cover no-repeat;
}

.zones-hero-inner,
.local-hero-inner {
  max-width: 820px;
}

.zones-hero-premium h1,
.local-hero-premium h1 {
  color: #fff;
  font-size: clamp(3.6rem, 6.8vw, 6.4rem);
  line-height: .9;
  max-width: 900px;
}

.zones-hero-premium p:not(.section-kicker),
.local-hero-premium p:not(.section-kicker) {
  color: rgba(255,255,255,.88);
  font-size: 1.05rem;
  line-height: 1.65;
  max-width: 680px;
}

.local-hero-premium .btn {
  margin-top: 28px;
}

.zones-photo-section,
.local-premium-content {
  background: #fbfaf6;
  padding: 58px 0 80px;
}

.section-heading-left h2 {
  font-size: 2.3rem;
  margin-bottom: 22px;
  color: var(--ink);
}

.zones-photo-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 16px;
  margin-bottom: 34px;
}

.zone-photo-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 10px;
  overflow: hidden;
  color: var(--ink);
  transition: transform .25s ease, box-shadow .25s ease;
}

.zone-photo-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 18px 42px rgba(16,32,51,.09);
}

.zone-photo-card img {
  width: 100%;
  height: 126px;
  object-fit: cover;
  display: block;
}

.zone-photo-body {
  padding: 18px;
}

.zone-photo-body h2 {
  font-size: 1.65rem;
  margin: 0 0 8px;
}

.zone-photo-body span {
  color: var(--muted);
  font-size: .82rem;
}

.communes-panel,
.zone-info-panel {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 26px;
  margin-top: 22px;
}

.communes-panel h2,
.zone-info-panel h2 {
  font-size: 2rem;
  margin-bottom: 18px;
}

.communes-chip-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.commune-chip,
.near-buttons span,
.local-other-sectors a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.75);
  color: var(--ink);
  border-radius: 999px;
  padding: 10px 14px;
  font-size: .86rem;
  font-weight: 700;
}

.communes-panel p {
  color: var(--muted);
  margin-top: 16px;
  font-size: .9rem;
}

.zone-info-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}

.zone-info-grid article {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 16px;
  border-right: 1px solid var(--line);
  padding-right: 20px;
}

.zone-info-grid article:last-child {
  border-right: 0;
}

.zone-info-grid span,
.local-card-icon,
.local-detail-card span {
  color: var(--gold);
  font-size: 1.8rem;
}

.zone-info-grid h3,
.local-detail-card h3 {
  font-family: var(--sans);
  font-size: 1rem;
  margin: 0 0 6px;
}

.zone-info-grid p,
.local-premium-card p,
.local-detail-card p,
.local-bottom-cta p {
  color: var(--muted);
  line-height: 1.65;
}

.zones-final-cta,
.local-bottom-cta {
  background: #061927;
  color: #fff;
  border-radius: 12px;
  padding: 28px 34px;
  margin-top: 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
}

.zones-final-cta h2,
.local-bottom-cta h2 {
  color: #fff;
  font-size: 2rem;
  margin: 0 0 6px;
}

.zones-final-cta p {
  color: rgba(255,255,255,.74);
  margin: 0;
}

.local-top-grid {
  display: grid;
  grid-template-columns: 1fr 1fr .92fr;
  gap: 22px;
}

.local-premium-card,
.local-detail-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 30px;
  box-shadow: 0 12px 32px rgba(16,32,51,.045);
}

.local-premium-card h2 {
  font-size: 2rem;
  margin: 14px 0 14px;
}

.near-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.local-detail-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-top: 22px;
}

.local-detail-card {
  min-height: 160px;
}

.local-other-sectors {
  margin-top: 22px;
  padding: 18px 20px;
  border: 1px solid var(--line);
  border-radius: 12px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  background: #fff;
}

.local-other-sectors span {
  color: var(--muted);
  font-size: .82rem;
  text-transform: uppercase;
  letter-spacing: .12em;
  font-weight: 800;
  margin-right: 8px;
}

@media (max-width: 1180px) {
  .zones-photo-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .local-top-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .zones-hero-premium,
  .local-hero-premium {
    min-height: 560px;
    padding: 128px 0 64px;
    background-position: 68% center;
  }

  .zones-hero-premium h1,
  .local-hero-premium h1 {
    font-size: clamp(3rem, 12vw, 4.2rem);
  }

  .zones-photo-grid,
  .zone-info-grid,
  .local-detail-grid {
    grid-template-columns: 1fr;
  }

  .zone-info-grid article {
    border-right: 0;
    border-bottom: 1px solid var(--line);
    padding-bottom: 18px;
  }

  .zones-final-cta,
  .local-bottom-cta {
    align-items: flex-start;
    flex-direction: column;
  }

  .zone-photo-card img {
    height: 180px;
  }
}



/* V39 : photos locales + pages locales moins répétitives */
.local-premium-layout-v39 {
  max-width: 960px;
  margin: 0 auto;
}

.local-wide-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 34px 38px;
  display: grid;
  grid-template-columns: 70px 1fr;
  gap: 28px;
  box-shadow: 0 16px 36px rgba(16,32,51,.045);
}

.local-wide-icon {
  width: 58px;
  height: 58px;
  border-radius: 999px;
  background: rgba(212,164,92,.12);
  color: var(--gold);
  display: grid;
  place-items: center;
  font-size: 1.6rem;
}

.local-wide-card h2,
.local-soft-block h2,
.local-near-lines h2 {
  font-size: 2.15rem;
  margin: 8px 0 14px;
}

.local-wide-card p,
.local-soft-block p,
.local-near-lines p {
  color: var(--muted);
  line-height: 1.75;
}

.local-two-columns-v39 {
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 22px;
  margin-top: 22px;
}

.local-soft-block,
.local-near-lines {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 32px;
  box-shadow: 0 16px 36px rgba(16,32,51,.04);
}

.local-near-lines ul {
  list-style: none;
  padding: 0;
  margin: 18px 0 0;
}

.local-near-lines li {
  padding: 13px 0;
  border-top: 1px solid var(--line);
  color: var(--ink);
  font-weight: 700;
}

.local-near-lines li:first-child {
  border-top: 0;
}

.communes-panel-premium {
  padding: 30px;
}

.communes-intro {
  max-width: 760px;
}

.communes-columns {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  margin-top: 22px;
}

.communes-columns div {
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 20px;
  background: rgba(255,255,255,.72);
}

.communes-columns h3 {
  font-family: var(--sans);
  font-size: .9rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--ink);
  margin: 0 0 10px;
}

.communes-columns p {
  margin: 0;
  color: var(--muted);
  line-height: 1.6;
}

.communes-note {
  font-style: italic;
}

@media (max-width: 900px) {
  .local-wide-card,
  .local-two-columns-v39 {
    grid-template-columns: 1fr;
  }

  .communes-columns {
    grid-template-columns: 1fr;
  }
}


/* V40 : crédits photos */
.image-credit-link { display:block; margin-top:10px; font-size:.72rem; opacity:.55; }
.image-credit-link a { color: inherit; text-decoration:none; }
.image-credit-link a:hover { opacity:1; }



/* V41 : FAQ discrète + suppression bloc interventions visible */
.zone-info-panel {
  display: none !important;
}

.zones-faq-accordion,
.local-faq-accordion {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 28px 32px;
  margin-top: 24px;
  box-shadow: 0 16px 36px rgba(16,32,51,.035);
}

.zones-faq-accordion h2,
.local-faq-accordion h2 {
  font-size: 2rem;
  margin: 0 0 16px;
  color: var(--ink);
}

.zones-faq-accordion details,
.local-faq-accordion details {
  border-top: 1px solid var(--line);
  padding: 16px 0;
}

.zones-faq-accordion details:first-of-type,
.local-faq-accordion details:first-of-type {
  border-top: 0;
}

.zones-faq-accordion summary,
.local-faq-accordion summary {
  cursor: pointer;
  font-weight: 800;
  color: var(--ink);
  list-style: none;
}

.zones-faq-accordion summary::-webkit-details-marker,
.local-faq-accordion summary::-webkit-details-marker {
  display: none;
}

.zones-faq-accordion summary::after,
.local-faq-accordion summary::after {
  content: "+";
  float: right;
  color: var(--gold);
  font-weight: 800;
}

.zones-faq-accordion details[open] summary::after,
.local-faq-accordion details[open] summary::after {
  content: "–";
}

.zones-faq-accordion p,
.local-faq-accordion p {
  color: var(--muted);
  line-height: 1.7;
  margin: 12px 0 0;
  max-width: 760px;
}

@media (max-width: 760px) {
  .zones-faq-accordion,
  .local-faq-accordion {
    padding: 24px 20px;
  }
}


/* V44 : finition mobile protocole + footer centré */
@media (max-width: 640px) {
  .protocol-section {
    padding: 68px 0 72px;
  }

  .protocol-section .section-heading {
    text-align: left;
    margin-bottom: 30px;
  }

  .protocol-section .section-heading h2 {
    font-size: clamp(2.7rem, 12vw, 3.65rem);
    line-height: .94;
    max-width: 100%;
  }

  .protocol-grid-minimal {
    display: grid;
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .protocol-card-minimal {
    display: grid;
    grid-template-columns: 48px minmax(0, 1fr);
    column-gap: 18px;
    row-gap: 14px;
    align-items: center;
    min-height: 0 !important;
    padding: 24px 22px 25px !important;
    border-radius: 14px;
  }

  .protocol-card-minimal .protocol-step {
    grid-column: 1;
    grid-row: 1;
    width: 46px;
    height: 46px;
    margin: 0 !important;
    font-size: 1rem;
  }

  .protocol-card-minimal h3 {
    grid-column: 2;
    grid-row: 1;
    margin: 0 !important;
    font-size: 2rem;
    line-height: 1;
  }

  .protocol-card-minimal p {
    grid-column: 1 / -1;
    grid-row: 2;
    max-width: none !important;
    margin: 0 !important;
    font-size: 1rem;
    line-height: 1.62;
    color: var(--muted);
  }

  .site-footer {
    padding: 46px 0 34px;
  }

  .site-footer .footer-inner {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center;
    gap: 18px;
  }

  .site-footer .footer-logo-wrap {
    width: 100%;
    justify-content: center;
  }

  .site-footer .footer-logo {
    width: min(245px, 78vw);
    margin: 0 auto;
  }

  .site-footer .footer-inner > p {
    max-width: 320px;
    margin: 0 auto;
    font-size: .92rem;
    line-height: 1.65;
  }

  .site-footer .image-credit-link {
    display: block;
    margin-top: 4px;
    font-size: .72rem;
    opacity: .62;
  }
}


/* Formulaire Hostinger */
.hp-field{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;overflow:hidden!important}

/* V46 — champ anti-spam invisible */
.hp-field,
.hp-field[hidden] {
  display: none !important;
  visibility: hidden !important;
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  pointer-events: none !important;
}


/* V56 — aide simple pour plusieurs photos */
.photo-help {
  margin: -6px 0 4px;
  font-size: .88rem;
  line-height: 1.5;
  color: rgba(222, 229, 235, .72);
}

@media (max-width: 720px) {
  .photo-help {
    font-size: .84rem;
    margin-top: -4px;
  }
}


/* V57 — aide téléphone facultatif */
.phone-help {
  margin: -6px 0 8px;
  font-size: .78rem;
  line-height: 1.45;
  color: rgba(255,255,255,.58);
}

@media (max-width: 760px) {
  .phone-help {
    margin-top: -2px;
  }
}
