/* =====================================================================
   MAS FERMETURE — Feuille de style globale
   Thème clair, lisible, orienté confiance & conversion
   ===================================================================== */
:root{
  --brand:#0077B6;          /* bleu principal */
  --brand-dark:#024E78;     /* bleu foncé (texte/hover) */
  --brand-light:#E6F4FB;    /* fond bleu très clair */
  --accent:#F59E0B;         /* orange/ambre — urgence, CTA secondaire */
  --danger:#DC2626;
  --success:#16A34A;

  --bg:#FFFFFF;
  --bg-alt:#F5F8FB;         /* sections alternées */
  --text:#0B1B2B;
  --muted:#5B6B7B;
  --line:#E2E8F0;

  --radius:16px;
  --radius-sm:10px;
  --shadow:0 10px 30px rgba(2,40,70,.08);
  --shadow-lg:0 18px 50px rgba(2,40,70,.14);
  --maxw:1160px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth; scroll-padding-top:90px}
body{
  margin:0; background:var(--bg); color:var(--text);
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,Ubuntu,Cantarell,"Noto Sans",sans-serif;
  line-height:1.65; font-size:17px;
}
img{max-width:100%; height:auto; display:block}
a{color:var(--brand); text-decoration:none}
a:hover{color:var(--brand-dark)}
.container{max-width:var(--maxw); margin:0 auto; padding:0 20px}
.muted{color:var(--muted)}
.center{text-align:center}

h1,h2,h3{line-height:1.2; color:var(--text); margin:0 0 .5em}
h1{font-size:clamp(28px,4.5vw,44px); font-weight:800; letter-spacing:-.02em}
h2{font-size:clamp(23px,3vw,32px); font-weight:800; letter-spacing:-.01em}
h3{font-size:20px; font-weight:700}
section{padding:clamp(48px,7vw,80px) 0}
section.alt{background:var(--bg-alt)}
.lead{font-size:19px; color:var(--muted); max-width:62ch}

/* ---------- Boutons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  border:2px solid transparent; border-radius:var(--radius-sm);
  padding:14px 22px; font-weight:700; font-size:16px; cursor:pointer;
  transition:transform .15s, box-shadow .15s, background .15s, color .15s;
  min-height:52px; line-height:1;
}
.btn-primary{ background:var(--brand); color:#fff; box-shadow:var(--shadow) }
.btn-primary:hover{ background:var(--brand-dark); color:#fff; transform:translateY(-2px); box-shadow:var(--shadow-lg) }
.btn-call{ background:var(--accent); color:#3a2a00; box-shadow:0 8px 22px rgba(245,158,11,.35) }
.btn-call:hover{ background:#e08e00; color:#3a2a00; transform:translateY(-2px) }
.btn-ghost{ background:#fff; color:var(--brand-dark); border-color:var(--line) }
.btn-ghost:hover{ border-color:var(--brand); background:var(--brand-light) }
.btn-block{ width:100% }

/* ---------- Header ---------- */
header.site{
  position:sticky; top:0; z-index:50; background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex; align-items:center; justify-content:space-between; gap:16px; padding:12px 0}
.brand{display:flex; align-items:center; gap:12px}
.brand img{width:48px; height:48px; border-radius:10px}
.brand .name{font-weight:800; font-size:16px; color:var(--text); line-height:1.1}
.brand .name span{display:block; font-weight:600; font-size:12px; color:var(--muted)}
.nav-links{display:flex; align-items:center; gap:22px}
.nav-links a{color:var(--text); font-weight:600; font-size:15px}
.nav-links a:hover{color:var(--brand)}
.nav-actions{display:flex; align-items:center; gap:10px}
.nav-phone{font-weight:800; color:var(--brand-dark); white-space:nowrap}
.burger{display:none; background:none; border:0; font-size:26px; cursor:pointer; color:var(--text)}

/* ---------- Hero ---------- */
.hero{background:linear-gradient(180deg,var(--brand-light),#fff); padding-top:clamp(40px,6vw,64px)}
.hero-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:40px; align-items:center}
.eyebrow{
  display:inline-flex; align-items:center; gap:8px; font-weight:700; font-size:14px;
  color:var(--brand-dark); background:#fff; border:1px solid var(--line);
  padding:7px 14px; border-radius:999px; box-shadow:var(--shadow)
}
.hero h1{margin-top:16px}
.hero .lead{margin:0 0 24px}
.hero-cta{display:flex; flex-wrap:wrap; gap:12px; margin-bottom:20px}
.trust-row{display:flex; flex-wrap:wrap; gap:10px}
.chip{
  display:inline-flex; align-items:center; gap:7px; font-size:14px; font-weight:600;
  color:var(--brand-dark); background:#fff; border:1px solid var(--line);
  padding:8px 13px; border-radius:999px
}

/* ---------- Carte formulaire ---------- */
.card{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:24px; box-shadow:var(--shadow)}
.form-card h2{font-size:22px; margin-bottom:4px}
form label{display:block; font-weight:600; font-size:14px; margin:12px 0 5px}
form input, form textarea, form select{
  width:100%; padding:13px 14px; border:1px solid var(--line); border-radius:var(--radius-sm);
  font-size:16px; font-family:inherit; background:#fff; color:var(--text)
}
form input:focus, form textarea:focus, form select:focus{
  outline:none; border-color:var(--brand); box-shadow:0 0 0 3px rgba(0,119,182,.15)
}
.hint{font-size:13px; color:var(--muted); margin:8px 0 0}
.hp{position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden}

/* ---------- Grilles ---------- */
.grid{display:grid; gap:20px}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}

.feature{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:22px}
.feature .ico{font-size:28px; margin-bottom:8px}
.feature h3{font-size:18px; margin-bottom:6px}
.feature p{margin:0; color:var(--muted); font-size:15px}

/* ---------- Cartes services ---------- */
.service{
  display:flex; flex-direction:column; background:#fff; border:1px solid var(--line);
  border-radius:var(--radius); padding:24px; box-shadow:var(--shadow);
  transition:transform .2s, box-shadow .2s
}
.service:hover{transform:translateY(-4px); box-shadow:var(--shadow-lg)}
.service .ico{
  width:54px; height:54px; display:flex; align-items:center; justify-content:center;
  font-size:26px; border-radius:14px; background:var(--brand-light); margin-bottom:14px
}
.service h3{margin-bottom:8px}
.service p{color:var(--muted); margin:0 0 16px; flex:1}
.service .price{font-weight:600; color:var(--brand-dark); margin-bottom:14px}
.service .price strong{font-size:20px; color:var(--text)}
.service .actions{display:flex; gap:10px; flex-wrap:wrap}

/* ---------- Avis ---------- */
.reviews-track{display:flex; gap:18px; overflow-x:auto; scroll-snap-type:x mandatory; padding-bottom:8px}
.review{
  flex:0 0 320px; max-width:340px; scroll-snap-align:start; background:#fff;
  border:1px solid var(--line); border-radius:var(--radius); padding:22px; box-shadow:var(--shadow)
}
.review .stars{color:var(--accent); font-size:18px; letter-spacing:2px}
.review p{margin:10px 0; font-style:italic}
.review .who{font-weight:700; color:var(--brand-dark); font-style:normal}

/* ---------- Zones ---------- */
.zones-grid{display:grid; grid-template-columns:1.3fr .7fr; gap:28px; align-items:start}
.zones-grid ul{columns:2; gap:24px; margin:14px 0 0; padding-left:18px}
.zones-grid li{margin-bottom:6px; color:var(--muted)}

/* ---------- FAQ ---------- */
.faq details{background:#fff; border:1px solid var(--line); border-radius:var(--radius-sm); padding:16px 18px; margin-bottom:12px}
.faq details[open]{box-shadow:var(--shadow)}
.faq summary{cursor:pointer; font-weight:700; list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+"; float:right; color:var(--brand); font-weight:800}
.faq details[open] summary::after{content:"–"}
.faq p{margin:12px 0 0; color:var(--muted)}

/* ---------- Bande CTA ---------- */
.cta-band{background:var(--brand-dark); color:#fff; text-align:center}
.cta-band h2{color:#fff}
.cta-band p{color:#cfe6f6; margin:0 auto 22px; max-width:55ch}

/* ---------- Contact ---------- */
.contact-grid{display:grid; grid-template-columns:1.1fr .9fr; gap:28px}
.info-list{list-style:none; padding:0; margin:0}
.info-list li{display:flex; gap:12px; padding:12px 0; border-bottom:1px solid var(--line)}
.info-list .ico{font-size:20px}
.info-list b{display:block}

/* ---------- Footer ---------- */
footer.site{background:#0B1B2B; color:#C9D7E3; padding:46px 0 28px}
footer.site a{color:#9FC9E6}
footer.site a:hover{color:#fff}
.footer-grid{display:grid; grid-template-columns:2fr 1fr 1fr; gap:30px}
.footer-grid h4{color:#fff; margin:0 0 12px; font-size:16px}
.footer-grid ul{list-style:none; padding:0; margin:0}
.footer-grid li{margin-bottom:8px}
.legal{font-size:12.5px; color:#8AA0B4; margin-top:14px; line-height:1.6}

/* ---------- Barre d'appel mobile ---------- */
.callbar{
  position:fixed; left:0; right:0; bottom:0; z-index:60; display:none;
  grid-template-columns:1fr 1fr; gap:10px; padding:10px 14px;
  background:rgba(255,255,255,.96); backdrop-filter:blur(8px);
  border-top:1px solid var(--line); box-shadow:0 -6px 20px rgba(2,40,70,.10)
}
.callbar .btn{min-height:48px; padding:12px}

/* ---------- Fil d'ariane ---------- */
.breadcrumb{font-size:14px; color:var(--muted); padding:14px 0 0}
.breadcrumb a{color:var(--muted)} .breadcrumb a:hover{color:var(--brand)}

/* ---------- Consentement cookies ---------- */
.cookie{
  position:fixed; left:16px; right:16px; bottom:16px; z-index:80; max-width:560px;
  margin:0 auto; background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  box-shadow:var(--shadow-lg); padding:18px 20px; display:none
}
.cookie.show{display:block}
.cookie p{margin:0 0 12px; font-size:14px}
.cookie .row{display:flex; gap:10px; flex-wrap:wrap}
.cookie .btn{padding:10px 16px; min-height:44px; font-size:14px}

/* ---------- Responsive ---------- */
@media (max-width:960px){
  .hero-grid{grid-template-columns:1fr; gap:28px}
  .grid-4{grid-template-columns:1fr 1fr}
  .grid-3{grid-template-columns:1fr 1fr}
  .zones-grid, .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .nav-links{display:none}
  .nav-links.open{
    display:flex; position:absolute; top:100%; left:0; right:0; flex-direction:column;
    align-items:flex-start; gap:0; background:#fff; border-bottom:1px solid var(--line); padding:8px 20px
  }
  .nav-links.open a{padding:12px 0; width:100%; border-bottom:1px solid var(--line)}
  .burger{display:block}
  .callbar{display:grid}
  body{padding-bottom:72px}
}
@media (max-width:560px){
  .grid-4, .grid-3, .grid-2{grid-template-columns:1fr}
  .zones-grid ul{columns:1}
  .nav-phone{display:none}
}

/* ---------- Accessibilité ---------- */
:focus-visible{outline:3px solid var(--accent); outline-offset:2px}
.sr-only{position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0}
@media (prefers-reduced-motion:reduce){*{transition:none!important; scroll-behavior:auto!important}}
