:root{
  --ink:#1F2430; --slate:#2F5D80; --slate-d:#244a66; --tuile:#C75D33; --tuile-d:#a94c25;
  --cream:#F5F1E9; --bg:#ffffff; --soft:#f6f5f2; --gray:#5b6470; --line:#e7e3da;
  --maxw:1180px; --r:14px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg);line-height:1.65;font-size:17px;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
h1,h2,h3{line-height:1.18;font-weight:800;letter-spacing:-.01em}
h2{font-size:2rem;margin-bottom:.4em}
h2 .accent{color:var(--tuile)}
.sub{color:var(--gray);font-size:1.06rem;max-width:680px}
section{padding:72px 0}
.btn{display:inline-flex;align-items:center;gap:.5em;font-weight:700;border-radius:999px;padding:15px 26px;font-size:1rem;transition:.15s;border:2px solid transparent;cursor:pointer}
.btn-primary{background:var(--tuile);color:#fff}
.btn-primary:hover{background:var(--tuile-d)}
.btn-ghost{background:transparent;border-color:rgba(255,255,255,.6);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.12)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#000}
/* TOPBAR */
.topbar{background:var(--ink);color:#cfd6de;font-size:.9rem}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:14px;padding-top:9px;padding-bottom:9px;flex-wrap:wrap}
.topbar a{color:#fff;font-weight:700}
.topbar .pill{color:var(--cream)}
/* HEADER */
header.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.96);backdrop-filter:blur(6px);border-bottom:1px solid var(--line)}
header.nav .wrap{display:flex;align-items:center;justify-content:space-between;gap:18px;padding-top:12px;padding-bottom:12px}
.logo{height:46px;width:auto}
nav.menu{display:flex;gap:22px;align-items:center;font-weight:600;font-size:.98rem}
nav.menu a:hover{color:var(--tuile)}
.nav-cta{display:flex;align-items:center;gap:14px}
.tel-strong{font-weight:800;color:var(--slate);white-space:nowrap}
.burger{display:none;font-size:1.7rem;background:none;border:none;color:var(--ink)}
/* HERO */
.hero{position:relative;color:#fff;background:var(--ink);padding:0}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.42}
.hero-grad{position:absolute;inset:0;background:linear-gradient(120deg,rgba(31,36,48,.92) 0%,rgba(31,36,48,.6) 60%,rgba(31,36,48,.35) 100%)}
.hero .wrap{position:relative;padding:92px 22px}
.hero h1{font-size:3rem;max-width:760px}
.hero p.lead{margin:20px 0 28px;font-size:1.25rem;max-width:620px;color:#e8edf2}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.badges{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
.badge{display:flex;align-items:center;gap:9px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);padding:10px 16px;border-radius:12px;font-weight:600;font-size:.95rem}
.badge b{color:var(--cream)}
.tick{color:var(--tuile);font-weight:900}
/* PAGE HERO (pages internes) */
.page-hero{position:relative;background:var(--ink);color:#fff}
.page-hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.34}
.page-hero .hero-grad{background:linear-gradient(120deg,rgba(31,36,48,.93),rgba(31,36,48,.6))}
.page-hero .wrap{position:relative;padding:62px 22px}
.page-hero h1{font-size:2.4rem;max-width:820px}
.page-hero p.lead{margin:16px 0 24px;font-size:1.15rem;max-width:660px;color:#e8edf2}
/* BREADCRUMB */
.breadcrumb{font-size:.86rem;color:var(--gray);padding:14px 0}
.breadcrumb a:hover{color:var(--tuile)}
.breadcrumb span{margin:0 6px;opacity:.5}
/* PROSE */
.prose{max-width:760px;font-size:1.06rem}
.prose p{margin-bottom:1.05em}
.prose h2{font-size:1.7rem;margin:1.3em 0 .5em}
.prose h3{font-size:1.25rem;margin:1.1em 0 .4em}
.prose ul{margin:0 0 1.1em 0;list-style:none}
.prose ul li{position:relative;padding-left:30px;margin-bottom:.55em}
.prose ul li::before{content:"✔";position:absolute;left:0;color:var(--tuile);font-weight:900}
.split{display:grid;grid-template-columns:1.1fr .9fr;gap:44px;align-items:center}
.split img{border-radius:var(--r);height:100%;object-fit:cover}
/* TRUST */
.trust{background:var(--cream)}
.trust .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.trust .it{display:flex;gap:14px;align-items:flex-start}
.trust .ic{font-size:1.6rem;line-height:1}
.trust h3{font-size:1.05rem;margin-bottom:2px}
.trust p{font-size:.95rem;color:var(--gray)}
/* SERVICES */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:36px}
.card{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:#fff;transition:.18s;display:flex;flex-direction:column}
.card:hover{box-shadow:0 12px 30px rgba(31,36,48,.1);transform:translateY(-3px)}
.card img{height:190px;object-fit:cover;width:100%}
.card .bd{padding:22px;display:flex;flex-direction:column;flex:1}
.card h3{font-size:1.22rem;margin-bottom:8px}
.card p{color:var(--gray);font-size:.97rem;flex:1}
.card .more{margin-top:14px;color:var(--tuile);font-weight:700;font-size:.95rem}
/* WHY */
.why{background:var(--ink);color:#fff}
.why h2{color:#fff}
.why .sub{color:#b9c2cd}
.why .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;margin-top:38px}
.why .it{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--r);padding:24px}
.why .n{font-size:2rem;font-weight:800;color:var(--tuile)}
.why h3{font-size:1.1rem;margin:8px 0 6px}
.why p{color:#b9c2cd;font-size:.95rem}
/* GALLERY */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:34px}
.gallery img{border-radius:10px;height:230px;object-fit:cover;width:100%}
/* ZONES */
.zones{background:var(--soft)}
.zonewrap{display:grid;grid-template-columns:1.1fr 1fr;gap:40px;align-items:center}
.citylist{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.citylist a{background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 16px;font-weight:600;font-size:.94rem}
.citylist a:hover{border-color:var(--slate);color:var(--slate)}
.zonewrap img{border-radius:var(--r);height:100%;object-fit:cover}
/* PROCESS */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:36px}
.step{text-align:center;padding:10px}
.step .circ{width:54px;height:54px;border-radius:50%;background:var(--cream);color:var(--tuile);font-weight:800;font-size:1.3rem;display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.step h3{font-size:1.05rem;margin-bottom:5px}
.step p{color:var(--gray);font-size:.93rem}
/* AVIS */
.avis{background:var(--cream)}
.avis .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:30px}
.review{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:24px}
.stars{color:#f5a623;font-size:1.1rem;letter-spacing:2px}
.review p{margin:12px 0;color:#3a4049;font-size:.97rem}
.review .who{font-weight:700;font-size:.95rem}
.gnote{display:inline-flex;align-items:center;gap:8px;margin-top:18px;font-size:.9rem;color:var(--gray)}
/* FAQ */
.faq details{border:1px solid var(--line);border-radius:12px;padding:4px 20px;margin-bottom:12px;background:#fff}
.faq summary{font-weight:700;cursor:pointer;padding:16px 0;list-style:none;display:flex;justify-content:space-between;gap:14px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--tuile);font-weight:800;font-size:1.3rem}
.faq details[open] summary::after{content:"–"}
.faq p{padding:0 0 16px;color:var(--gray)}
/* CTA BAND */
.ctaband{background:var(--tuile);color:#fff;text-align:center}
.ctaband h2{color:#fff}
.ctaband p{font-size:1.1rem;margin:6px 0 24px;color:#fff;opacity:.95}
/* CONTACT */
.contact .grid{display:grid;grid-template-columns:1fr 1fr;gap:44px}
.contact form{display:grid;gap:14px}
.contact label{font-weight:600;font-size:.92rem;margin-bottom:-8px}
.contact input,.contact textarea,.contact select{padding:13px 15px;border:1px solid var(--line);border-radius:10px;font:inherit;font-size:1rem;background:#fff;color:inherit;width:100%}
.contact textarea{min-height:120px;resize:vertical}
.contact .opt{font-weight:400;color:var(--gray);font-size:.85em}
.form-msg{margin-top:6px;padding:22px 20px;border:1px solid #cfe6d4;background:#eef8f0;border-radius:12px}
.form-msg[hidden]{display:none}
.form-msg strong{display:block;font-size:1.05rem;color:#1d7a3a;margin-bottom:4px}
.form-msg span{color:#3a4a3d}
.blog-meta{color:var(--gray);font-size:.9rem;margin-bottom:18px}
.prose h2{scroll-margin-top:90px}
.coord{display:flex;gap:14px;align-items:flex-start;margin-bottom:18px}
.coord .ic{font-size:1.4rem}
.coord b{display:block}
.coord span{color:var(--gray)}
.map{width:100%;height:260px;border:0;border-radius:var(--r);margin-top:18px}
.fdec{display:inline-block;margin-top:12px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:8px;padding:6px 12px;color:var(--cream);font-weight:600;font-size:.85rem}
/* FOOTER */
footer{background:var(--ink);color:#aab3bf;font-size:.94rem}
footer .grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px;padding:60px 0 30px}
footer h4{color:#fff;font-size:1.02rem;margin-bottom:14px}
footer a:hover{color:#fff}
footer ul{list-style:none;display:grid;gap:8px}
footer .legal{border-top:1px solid rgba(255,255,255,.12);padding:18px 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.85rem}
@media(max-width:920px){
  .trust .grid,.why .grid,.steps{grid-template-columns:repeat(2,1fr)}
  .cards,.avis .grid{grid-template-columns:1fr 1fr}
  .gallery{grid-template-columns:1fr 1fr}
  .zonewrap,.contact .grid,footer .grid,.split{grid-template-columns:1fr}
  .hero h1{font-size:2.2rem}
  header.nav .wrap{gap:10px}
  .nav-cta{gap:10px}
  .nav-cta .tel-strong{display:none}
  nav.menu{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;background:#fff;padding:6px 22px 14px;border-bottom:1px solid var(--line);box-shadow:0 10px 24px rgba(31,36,48,.1)}
  nav.menu a{padding:13px 2px;border-top:1px solid var(--line)}
  .burger{display:block}
}
@media(max-width:560px){
  section{padding:54px 0}
  .cards,.avis .grid,.trust .grid,.why .grid,.steps,.gallery{grid-template-columns:1fr}
  .hero h1{font-size:1.9rem}
  .page-hero h1{font-size:1.8rem}
}
