
:root{--navy:#06345f;--navy2:#0b4775;--teal:#08a7b7;--blue:#0878c9;--muted:#617d91;--line:#d9e8f0;--soft:#f5f9fc;--white:#fff;--shadow:0 18px 50px rgba(6,52,95,.10)}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Arial,sans-serif;color:var(--navy);background:#fff}img{max-width:100%;display:block}a{color:inherit}.wrap{width:min(1240px,calc(100% - 32px));margin:auto}.skip{position:absolute;left:-999px}.skip:focus{left:16px;top:12px;z-index:99;background:#fff;padding:10px}.header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.97);border-bottom:1px solid #edf2f5;backdrop-filter:blur(10px)}.header-row{height:76px;display:flex;align-items:center;gap:30px}.brand img{width:150px}.nav{margin:auto;display:flex;gap:30px}.nav a,.mobile-nav a{text-decoration:none;font-weight:800;font-size:14px}.phone{background:linear-gradient(135deg,var(--navy2),var(--blue));color:#fff;text-decoration:none;border-radius:999px;padding:13px 20px;font-weight:900}.menu-button{display:none;width:44px;border:0;background:none}.menu-button span{display:block;height:2px;background:var(--navy);margin:6px}.mobile-nav{display:none;flex-direction:column;gap:15px;padding:12px 22px 20px}
.hero{min-height:600px;position:relative;overflow:hidden;background:#fff}.hero-photo{position:absolute;right:0;top:0;width:65%;height:100%}.hero-photo img{width:100%;height:100%;object-fit:cover;object-position:center}.hero-fade{position:absolute;inset:0;background:linear-gradient(90deg,#fff 0%,#fff 35%,rgba(255,255,255,.94) 45%,rgba(255,255,255,.40) 64%,rgba(255,255,255,0) 80%)}.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:55% 45%;min-height:600px;align-items:center}.hero-content{max-width:650px;padding:50px 0}.eyebrow{display:inline-flex;border:1.5px solid var(--teal);color:#057d98;background:#f7ffff;border-radius:999px;padding:6px 14px;font-size:12px;font-weight:900;letter-spacing:.04em}.hero h1{font-size:clamp(46px,5.4vw,68px);line-height:1.02;letter-spacing:-.04em;margin:18px 0}.hero p{font-size:18px;line-height:1.65;color:#4e6f87;max-width:590px}.hero-points{display:flex;gap:9px;flex-wrap:wrap;margin-top:20px}.hero-points span{font-size:12px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 12px;font-weight:800;color:#315873}.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:25px}.btn{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;font-weight:950;border-radius:12px;padding:16px 22px;border:0}.btn.primary{background:linear-gradient(135deg,var(--teal),var(--blue));color:#fff;box-shadow:0 10px 25px rgba(8,119,200,.18)}.btn.outline{background:#fff;color:var(--navy);border:1px solid #a9c2d3}
.section{padding:82px 0}.soft{background:var(--soft)}.story-grid,.method-grid,.local-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center}.story-copy h2,.section-head h2,.method h2,.local-grid h2{font-size:clamp(34px,4vw,52px);line-height:1.08;margin:14px 0}.story-copy p,.section-head p,.local-grid p{font-size:16px;line-height:1.75;color:#58768b}.timeline{display:grid;gap:14px}.timeline article{display:flex;gap:16px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:20px;box-shadow:0 10px 30px rgba(6,52,95,.06)}.timeline b{flex:0 0 42px;height:42px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,var(--teal),var(--blue));color:#fff;font-size:18px}.timeline strong,.timeline span{display:block}.timeline strong{font-size:18px}.timeline span{color:#657f92;line-height:1.55;margin-top:5px}.section-head{max-width:840px}.section-head.center{text-align:center;margin:0 auto 38px}.commitments{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.commitments article{background:#fff;border:1px solid var(--line);border-radius:20px;padding:24px;box-shadow:0 10px 30px rgba(6,52,95,.05)}.commitments span{color:var(--teal);font-weight:950;font-size:13px}.commitments h3{font-size:21px;margin:13px 0 10px}.commitments p{color:#607b8f;line-height:1.6;margin:0}.method-card,.service-showcase{border:1px solid var(--line);border-radius:22px;padding:30px;background:#fff;box-shadow:var(--shadow)}.method-card ol{list-style:none;padding:0;margin:25px 0 0;display:grid;gap:16px}.method-card li{display:flex;gap:15px}.method-card li>b{flex:0 0 38px;height:38px;border-radius:50%;display:grid;place-items:center;background:#e9f9fb;color:var(--teal)}.method-card strong,.method-card span{display:block}.method-card span{color:#647f92;line-height:1.5;margin-top:4px}.service-showcase h3{font-size:28px;margin-top:0}.service-mini-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.service-mini-grid a{text-decoration:none;border:1px solid var(--line);border-radius:16px;padding:12px;text-align:center;background:#fbfdff}.service-mini-grid img{height:120px;width:100%;object-fit:contain}.service-mini-grid span{display:block;font-weight:900;margin-top:7px}.local-section{padding:72px 0;background:linear-gradient(135deg,#eefbfc,#edf6fd)}.city-tags{display:flex;gap:10px;flex-wrap:wrap}.city-tags span{background:#fff;border:1px solid var(--line);border-radius:999px;padding:10px 14px;font-weight:800;color:#40677f}.final-cta{background:linear-gradient(100deg,#0397a7,#0873c8);color:#fff}.cta-row{min-height:160px;display:flex;align-items:center;justify-content:space-between;gap:25px}.cta-row span{font-size:29px;font-weight:950}.cta-row p{margin:6px 0 0;color:#def3f8}.cta-button{background:#fff;color:var(--navy);box-shadow:0 12px 28px rgba(6,52,95,.18);min-width:260px}footer{background:#052f5a;color:#fff;padding:45px 0 16px}.footer-grid{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:32px}.footer-grid img{width:165px;filter:brightness(0) invert(1)}.footer-grid p{color:#c7d9e5;line-height:1.6}.footer-grid strong,.footer-grid a,.footer-grid span{display:block}.footer-grid strong{margin-bottom:12px}.footer-grid a,.footer-grid span{color:#d8e6ef;text-decoration:none;margin:8px 0;font-size:13px}.copyright{border-top:1px solid rgba(255,255,255,.15);padding-top:14px;margin-top:28px;color:#c7d8e4;font-size:12px}
@media(max-width:950px){.nav{display:none}.menu-button{display:block;margin-left:auto}.mobile-nav.open{display:flex}.hero{min-height:auto}.hero-photo{position:relative;width:100%;height:420px}.hero-fade{display:none}.hero-grid{display:block;min-height:0}.hero-content{padding:38px 0}.story-grid,.method-grid,.local-grid{grid-template-columns:1fr}.commitments{grid-template-columns:1fr 1fr}.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:620px){.wrap{width:min(100% - 20px,1240px)}.header-row{height:66px}.brand img{width:125px}.phone{padding:10px 12px;font-size:0}.phone:after{content:'☎';font-size:20px}.hero-photo{height:310px}.hero h1{font-size:42px}.hero p{font-size:16px}.hero-actions{display:grid}.hero-actions .btn{width:100%}.section{padding:58px 0}.commitments,.service-mini-grid{grid-template-columns:1fr}.cta-row{display:block;padding:30px 0}.cta-button{width:100%;margin-top:22px}.footer-grid{grid-template-columns:1fr}}


.cta-visible{min-width:260px;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;font-weight:900;letter-spacing:.01em}
.final-cta .cta-visible{background:#fff!important;color:#06345f!important;border:1px solid rgba(255,255,255,.92)!important;box-shadow:0 12px 28px rgba(6,52,95,.18)!important;padding:18px 28px!important;border-radius:16px!important}
.final-cta .cta-visible:hover{opacity:.97}

/* V33 logo normalization */
.header .brand{display:flex!important;align-items:center!important;flex:0 0 auto!important}
.header .brand img,.brand img{width:150px!important;height:auto!important;max-height:64px!important;object-fit:contain!important}
@media(max-width:620px){.header .brand img,.brand img{width:132px!important;max-height:58px!important}}


/* V34 - correction definitive logo header/footer */
.header{min-height:82px;overflow:visible!important}
.header-row{height:82px!important;min-height:82px!important;align-items:center!important}
.header .brand,.brand{display:flex!important;align-items:center!important;justify-content:flex-start!important;width:210px!important;min-width:210px!important;max-width:210px!important;flex:0 0 210px!important;height:82px!important;overflow:visible!important}
.header .brand img,.brand img{display:block!important;width:180px!important;max-width:180px!important;height:auto!important;max-height:58px!important;object-fit:contain!important;object-position:left center!important;filter:none!important;transform:none!important;background:transparent!important;padding:0!important;border-radius:0!important}
footer .footer-brand img,footer .footer-grid img,.footer .footer-grid img,.footer img{width:170px!important;max-width:170px!important;height:auto!important;max-height:64px!important;object-fit:contain!important;object-position:left center!important;filter:none!important;background:#fff!important;border-radius:12px!important;padding:7px!important;box-sizing:border-box!important}
@media(max-width:760px){.header{min-height:68px}.header-row{height:68px!important;min-height:68px!important}.header .brand,.brand{width:155px!important;min-width:155px!important;max-width:155px!important;flex:0 0 155px!important;height:68px!important}.header .brand img,.brand img{width:138px!important;max-width:138px!important;max-height:50px!important}}


/* V35 correction globale : logo header/footer et boutons CTA visibles */
body > header .brand, .header .brand{
  display:flex!important;
  align-items:center!important;
  justify-content:flex-start!important;
  width:190px!important;
  min-width:190px!important;
  max-width:190px!important;
  flex:0 0 190px!important;
  height:76px!important;
  overflow:hidden!important;
}
body > header .brand img, .header .brand img, a.brand > img{
  display:block!important;
  width:170px!important;
  max-width:170px!important;
  height:auto!important;
  max-height:54px!important;
  object-fit:contain!important;
  object-position:left center!important;
  aspect-ratio:540/150!important;
  filter:none!important;
  transform:none!important;
  background:transparent!important;
  padding:0!important;
  border-radius:0!important;
}
.cta-band .btn,
.cta-band a.btn,
.cta-band .btn.outline,
.cta-band a.btn.outline,
.cta-row .btn,
.final-cta .btn{
  color:#06345f!important;
  background:#fff!important;
  border:2px solid rgba(255,255,255,.88)!important;
  text-shadow:none!important;
  opacity:1!important;
  visibility:visible!important;
}
.cta-band .btn:hover,
.cta-row .btn:hover,
.final-cta .btn:hover{filter:brightness(.98)}
@media(max-width:760px){
  body > header .brand, .header .brand{width:155px!important;min-width:155px!important;max-width:155px!important;flex-basis:155px!important;height:68px!important;}
  body > header .brand img, .header .brand img, a.brand > img{width:138px!important;max-width:138px!important;max-height:48px!important;}
}
