/* ETS Leroy Père & Fils — feuille de style */
:root{
  --brand:#0b3d6b;          /* bleu artisan */
  --brand-dark:#082c4e;
  --brand-700:#0a345c;
  --brand-light:#e9f1fa;
  --accent:#d62828;         /* rouge CTA (couronne du logo) */
  --accent-dark:#b01e1e;
  --ink:#1f2933;
  --muted:#5b6b7b;
  --line:#e3e9f0;
  --bg:#ffffff;
  --bg-alt:#f4f7fb;
  --ok:#1ba56b;
  --radius:14px;
  --radius-sm:9px;
  --shadow:0 10px 30px rgba(11,61,107,.10);
  --shadow-sm:0 4px 14px rgba(11,61,107,.08);
  --container:1140px;
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,"Noto Sans",sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;font-family:var(--font);color:var(--ink);background:var(--bg);
  font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;
}
h1,h2,h3{line-height:1.2;color:var(--brand-dark);font-weight:800;letter-spacing:-.01em}
h2{font-size:clamp(1.5rem,1rem + 2vw,2.1rem);margin:0 0 .6em}
h3{font-size:1.2rem;margin:0 0 .4em}
p{margin:0 0 1rem}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
img,svg{max-width:100%}
ul{margin:0;padding:0;list-style:none}

.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:20px}
.container--narrow{max-width:780px}

.icon{width:1.2em;height:1.2em;flex:0 0 auto;vertical-align:-.15em}

.skip-link{position:absolute;left:-9999px;top:0;background:var(--brand);color:#fff;padding:.6rem 1rem;z-index:200}
.skip-link:focus{left:8px;top:8px;border-radius:6px}

/* ---------- Boutons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5em;justify-content:center;
  padding:.72em 1.25em;border-radius:999px;font-weight:700;font-size:.97rem;
  border:2px solid transparent;cursor:pointer;transition:.18s ease;text-align:center;
  line-height:1.1;
}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn--call{background:var(--accent);color:#fff;box-shadow:0 6px 16px rgba(214,40,40,.35)}
.btn--call:hover{background:var(--accent-dark);color:#fff}
.btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
.btn--ghost:hover{background:rgba(255,255,255,.12);color:#fff}
.btn--light{background:#fff;color:var(--brand-dark)}
.btn--light:hover{background:#f0f4f9;color:var(--brand-dark)}
.btn--lg{padding:.92em 1.6em;font-size:1.05rem}

/* ---------- Topbar ---------- */
.topbar{background:var(--brand-dark);color:#dce8f4;font-size:.86rem}
.topbar__inner{display:flex;gap:1.4rem;align-items:center;justify-content:center;min-height:38px;flex-wrap:wrap}
.topbar__item{display:inline-flex;align-items:center;gap:.4em}
.topbar__item .icon{color:var(--accent)}

/* ---------- Header ---------- */
.header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.96);
  backdrop-filter:saturate(160%) blur(8px);border-bottom:1px solid var(--line)}
.header.is-scrolled{box-shadow:var(--shadow-sm)}
.header__inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:70px}
.brand{display:inline-flex;align-items:center;gap:.65rem;color:var(--brand-dark)}
.brand:hover{text-decoration:none}
.brand__mark{
  width:54px;height:54px;flex:0 0 auto;display:block;line-height:0
}
.brand__mark .emblem{width:100%;height:100%;display:block}
.brand__text{display:flex;flex-direction:column;line-height:1}
.brand__name{font-weight:800;font-size:1.18rem;color:var(--brand-dark)}
.brand__sub{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-weight:700}

.nav{display:flex;align-items:center;gap:.3rem}
.nav__link{padding:.5rem .7rem;border-radius:8px;color:var(--ink);font-weight:600;font-size:.95rem}
.nav__link:hover{background:var(--brand-light);color:var(--brand-dark);text-decoration:none}
.nav__cta{margin-left:.4rem}

.menu-toggle{display:none;flex-direction:column;gap:5px;width:44px;height:44px;
  border:1px solid var(--line);border-radius:10px;background:#fff;cursor:pointer;align-items:center;justify-content:center}
.menu-toggle span{width:22px;height:2px;background:var(--brand-dark);border-radius:2px;transition:.2s}
.menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{
  position:relative;color:#fff;
  background:radial-gradient(1200px 500px at 80% -10%,rgba(214,40,40,.28),transparent 60%),
             linear-gradient(160deg,var(--brand) 0%,var(--brand-dark) 100%);
  padding:clamp(2.4rem,2rem + 4vw,4.6rem) 0;
}
.hero--home{padding:clamp(3rem,2rem + 6vw,6rem) 0}
.hero__inner{max-width:780px}
.hero__kicker{display:inline-block;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);
  padding:.35em .85em;border-radius:999px;font-size:.82rem;font-weight:700;letter-spacing:.03em;margin:0 0 1rem}
.hero__title{color:#fff;font-size:clamp(1.9rem,1.2rem + 3.4vw,3.1rem);margin:0 0 .5em}
.hero__subtitle{font-size:clamp(1.02rem,.95rem + .5vw,1.22rem);color:#dbe7f4;max-width:680px;margin:0 0 1.6rem}
.hero__cta{display:flex;gap:.8rem;flex-wrap:wrap}
.badges{display:flex;gap:1.2rem;flex-wrap:wrap;margin:1.8rem 0 0}
.badge{display:inline-flex;align-items:center;gap:.45em;font-weight:600;font-size:.92rem;color:#eaf2fb}
.badge .icon{color:#7ee0b0}

/* ---------- Sections ---------- */
.section{padding:clamp(2.4rem,2rem + 3vw,4rem) 0}
.section--alt{background:var(--bg-alt);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.section__title{text-align:center;margin-bottom:.4em}
.section__lead{text-align:center;color:var(--muted);max-width:680px;margin:0 auto 2rem}
.page-title{font-size:clamp(1.8rem,1.2rem + 2.5vw,2.5rem);margin-bottom:1rem}

.prose{color:#36424e}
.prose h2{text-align:left;margin-top:1.6em;font-size:1.35rem}
.prose p{margin-bottom:1rem}
.prose strong{color:var(--brand-dark)}

/* ---------- Cartes services ---------- */
.grid{display:grid;gap:1.1rem}
.grid--services{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.card{
  display:flex;flex-direction:column;gap:.45rem;padding:1.5rem;background:#fff;
  border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);
  transition:.2s ease;color:var(--ink)
}
.card:hover{text-decoration:none;transform:translateY(-4px);box-shadow:var(--shadow);border-color:#cdd9e6}
.card__icon{width:54px;height:54px;border-radius:13px;display:grid;place-items:center;
  background:var(--brand-light);color:var(--brand);margin-bottom:.3rem}
.card__icon .icon{width:28px;height:28px}
.card__title{font-weight:800;font-size:1.15rem;color:var(--brand-dark)}
.card__text{color:var(--muted);font-size:.95rem;flex:1}
.card__link{display:inline-flex;align-items:center;gap:.3em;color:var(--accent);font-weight:700;font-size:.92rem;margin-top:.3rem}
.card:hover .card__link .icon{transform:translateX(3px);transition:.2s}

/* ---------- Atouts ---------- */
.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}
.feature{display:flex;align-items:center;gap:.9rem;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius-sm);padding:1rem 1.1rem;font-weight:600;box-shadow:var(--shadow-sm)}
.feature__icon{width:44px;height:44px;border-radius:11px;display:grid;place-items:center;
  background:var(--brand-light);color:var(--brand);flex:0 0 auto}
.feature__icon .icon{width:22px;height:22px}

/* ---------- Listes / checklist ---------- */
.cols2{columns:2;column-gap:2.4rem}
.checklist li{display:flex;gap:.6rem;align-items:flex-start;margin-bottom:.7rem;break-inside:avoid}
.checklist .icon{color:var(--ok);width:1.3em;height:1.3em;margin-top:.12em}
.linklist{display:grid;gap:.5rem}
.linklist li a{display:inline-flex;align-items:center;gap:.4em;font-weight:600}
.linklist li a::before{content:"›";color:var(--accent);font-weight:800}
.linklist--cols{grid-template-columns:repeat(auto-fit,minmax(230px,1fr))}

/* ---------- Urgences ---------- */
.urgences{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center}
.tag{background:#fff;border:1px solid #f2c2c2;color:var(--accent-dark);font-weight:700;
  padding:.5em 1em;border-radius:999px;font-size:.92rem}
.tag::before{content:"⚡";margin-right:.35em}

/* ---------- Zones ---------- */
.zones{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.zones__title{display:flex;align-items:center;gap:.45em;color:var(--brand-dark);font-size:1.1rem;
  padding-bottom:.6rem;border-bottom:2px solid var(--brand-light)}
.zones__title .icon{color:var(--accent)}
.citylist{display:grid;grid-template-columns:1fr 1fr;gap:.35rem .8rem;margin-top:1rem}
.citylist a{display:inline-flex;align-items:center;gap:.35em;color:var(--ink);font-weight:600;font-size:.95rem}
.citylist a::before{content:"›";color:var(--accent);font-weight:800}
.citylist a:hover{color:var(--brand)}
.citylist--inline{grid-template-columns:repeat(auto-fit,minmax(150px,auto))}

/* ---------- Étapes ---------- */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.2rem;list-style:none;margin:0;padding:0}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem 1.3rem;
  box-shadow:var(--shadow-sm);position:relative}
.step__num{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;font-weight:800;
  background:var(--accent);color:#fff;margin-bottom:.7rem}
.step__title{font-size:1.08rem}
.step p{margin:0;color:var(--muted);font-size:.95rem}

/* ---------- Bande CTA ---------- */
.ctaband{background:linear-gradient(160deg,var(--brand) 0%,var(--brand-dark) 100%);color:#fff}
.ctaband__inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
  padding-block:clamp(1.8rem,1.4rem + 2vw,2.8rem);flex-wrap:wrap}
.ctaband__title{color:#fff;margin:0 0 .25em;font-size:clamp(1.3rem,1rem + 1.5vw,1.8rem)}
.ctaband__text{color:#d7e5f3;margin:0;max-width:540px}
.ctaband__actions{display:flex;gap:.7rem;flex-wrap:wrap}

/* ---------- FAQ ---------- */
.faq{display:grid;gap:.7rem}
.faq__item{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);
  box-shadow:var(--shadow-sm);overflow:hidden}
.faq__q{cursor:pointer;font-weight:700;color:var(--brand-dark);padding:1rem 1.2rem;list-style:none;
  display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq__q::-webkit-details-marker{display:none}
.faq__q::after{content:"+";font-size:1.4rem;color:var(--accent);font-weight:700;flex:0 0 auto}
.faq__item[open] .faq__q::after{content:"–"}
.faq__a{padding:0 1.2rem 1.1rem;color:var(--muted)}
.faq__a p{margin:0}

/* ---------- Fil d'Ariane ---------- */
.breadcrumb{background:var(--bg-alt);border-bottom:1px solid var(--line);font-size:.88rem}
.breadcrumb .container{padding-block:.7rem;display:flex;flex-wrap:wrap;gap:.4rem;align-items:center}
.breadcrumb a{color:var(--muted);font-weight:600}
.breadcrumb span[aria-current]{color:var(--brand-dark);font-weight:700}
.breadcrumb__sep{color:#b6c2cf}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem}
.contact-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:1.6rem;box-shadow:var(--shadow-sm)}
.contact-card .section__title{text-align:left}
.contact-card__lead{color:var(--muted)}
.contact-phone{font-size:1.5rem;font-weight:800;color:var(--brand-dark);display:flex;align-items:center;gap:.5rem}
.contact-phone .icon{color:var(--accent)}
.contact-phone a{color:var(--brand-dark)}
.form{display:grid;gap:.8rem}
.form label{display:grid;gap:.3rem;font-weight:600;font-size:.92rem;color:var(--brand-dark)}
.form input,.form select,.form textarea{
  font:inherit;padding:.7em .8em;border:1px solid var(--line);border-radius:9px;background:#fff;color:var(--ink)}
.form input:focus,.form select:focus,.form textarea:focus{outline:2px solid var(--brand);border-color:var(--brand)}
.form__note{background:#fef2f2;border:1px solid #f2c2c2;color:var(--accent-dark);padding:.6rem .8rem;
  border-radius:8px;font-size:.85rem;font-weight:600}

/* ---------- Carte Google Maps ---------- */
.map-embed{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-sm);line-height:0;background:#e9eef3}
.map-embed iframe{display:block;width:100%;height:420px;border:0}
.map-actions{margin-top:1.1rem}
.map-links__intro{margin-top:1.4rem;margin-bottom:.2rem;font-weight:600;color:var(--brand-dark)}
.map-links{margin-top:.7rem}
@media (max-width:640px){.map-embed iframe{height:300px}}

/* ---------- Fiches en ligne (Retrouvez-nous) ---------- */
.listings{display:grid;grid-template-columns:repeat(2,1fr);gap:1.6rem;margin-top:1.6rem}
.listings__dep{margin:0 0 .85rem;font-size:1.05rem;color:var(--brand-dark)}
.listings__list{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.55rem}
.listings__list a,.listings__list .listings__plain{display:inline-flex;align-items:center;gap:.35rem;padding:.5rem .85rem;
  border:1px solid var(--line);border-radius:var(--radius-sm);background:#fff;color:var(--ink);
  text-decoration:none;font-weight:600;font-size:.95rem;box-shadow:var(--shadow-sm);
  transition:border-color .15s,color .15s,transform .15s}
.listings__list a:hover,.listings__list a:focus-visible,
.listings__list .listings__plain:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}
.listings__list .listings__plain{cursor:pointer}
.listings__list a svg,.listings__list .listings__plain svg{width:1em;height:1em;flex:none}
@media (max-width:640px){.listings{grid-template-columns:1fr;gap:1.2rem}}

/* ---------- Footer ---------- */
.footer{background:var(--brand-dark);color:#c6d6e6;margin-top:0}
.footer__cols{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2rem;padding:clamp(2.2rem,2rem + 2vw,3.2rem) 20px}
.brand--footer .brand__name{color:#fff}
.footer__about{color:#a9bdd1;font-size:.92rem;margin-top:.9rem}
.footer__contact{font-size:.92rem;color:#c6d6e6}
.footer__contact a{color:#fff}
.footer__contact .icon{color:var(--accent)}
.footer__title{color:#fff;font-size:1rem;margin-bottom:.9rem;letter-spacing:.02em}
.footer__list li{margin-bottom:.45rem}
.footer__list a{color:#bcd0e3;font-size:.92rem}
.footer__list a:hover{color:#fff}
.footer__list--cities{display:grid;grid-template-columns:1fr 1fr;gap:.3rem .8rem}
.footer__bottom{background:#061f38}
.footer__bottom-inner{display:flex;justify-content:space-between;align-items:center;gap:1rem;
  padding-block:1.1rem;flex-wrap:wrap;font-size:.85rem;color:#8fa6bc}
.footer__legal{display:flex;gap:1.1rem;flex-wrap:wrap}
.footer__legal a{color:#bcd0e3}

/* ---------- Bouton d'appel flottant (mobile) ---------- */
.callfab{display:none;position:fixed;right:16px;bottom:16px;z-index:120;
  width:60px;height:60px;border-radius:50%;background:var(--accent);color:#fff;
  align-items:center;justify-content:center;box-shadow:0 8px 22px rgba(214,40,40,.5);
  animation:pulse 2.2s infinite}
.callfab .icon{width:26px;height:26px}
@keyframes pulse{0%{box-shadow:0 8px 22px rgba(214,40,40,.5),0 0 0 0 rgba(214,40,40,.45)}
  70%{box-shadow:0 8px 22px rgba(214,40,40,.5),0 0 0 16px rgba(214,40,40,0)}
  100%{box-shadow:0 8px 22px rgba(214,40,40,.5),0 0 0 0 rgba(214,40,40,0)}}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .footer__cols{grid-template-columns:1fr 1fr}
  .zones{grid-template-columns:1fr}
}
@media (max-width:760px){
  .topbar__item--hide{display:none}
  .menu-toggle{display:flex;position:relative;z-index:2}
  .header{backdrop-filter:none;-webkit-backdrop-filter:none;background:#fff}
  .nav{position:fixed;inset:0 0 0 auto;width:min(80vw,320px);transform:translateX(100%);
    flex-direction:column;align-items:stretch;gap:.2rem;background:#fff;padding:5rem 1.2rem 2rem;
    box-shadow:-12px 0 40px rgba(0,0,0,.18);transition:transform .25s ease;overflow-y:auto;z-index:1}
  .nav.is-open{transform:translateX(0)}
  .nav__link{padding:.85rem .7rem;border-bottom:1px solid var(--line);border-radius:0}
  .nav__cta{margin:1rem 0 0;justify-content:center}
  body.nav-open{overflow:hidden}
  .cols2{columns:1}
  .contact-grid{grid-template-columns:1fr}
  .citylist{grid-template-columns:1fr}
  .footer__cols{grid-template-columns:1fr}
  .footer__list--cities{grid-template-columns:1fr 1fr}
  .callfab{display:flex}
  .footer__bottom-inner{flex-direction:column;text-align:center}
}
@media (max-width:560px){
  .hero__cta,.ctaband__actions{flex-direction:column;align-items:stretch;width:100%}
  .hero__cta .btn,.ctaband__actions .btn{width:100%}
}
@media (max-width:420px){
  .badges{gap:.6rem}
  .badge{font-size:.85rem}
}

/* Accessibilité : focus visible */
a:focus-visible,button:focus-visible,summary:focus-visible,input:focus-visible,
select:focus-visible,textarea:focus-visible{outline:3px solid var(--accent);outline-offset:2px;border-radius:4px}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}
