/* ==========================================================================
   PRO-DEM — Thème ÉDITORIAL (sans cartes, descriptions texte, blanc/gris)
   Anthracite + accent ambre · Aucune couleur verte
   ========================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Hanken+Grotesk:wght@400;500;600;700;800&display=swap');

:root{
  --bg:#FFFFFF;
  --bg-2:#F5F5F2;
  --line:#E6E5E1;
  --line-2:#D7D6D1;
  --ink:#161719;
  --soft:#383A3D;
  --muted:#6C7075;
  --dark:#0E1F16;
  --accent:#1E8A54;        /* vert (palette vert + blanc) */
  --accent-d:#15683F;
  --radius:12px;
  --radius-sm:9px;
  --maxw:1080px;
  --read:760px;            /* largeur de lecture confortable */
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Hanken Grotesk',system-ui,sans-serif;color:var(--ink);background:var(--bg);line-height:1.62;font-size:16px;-webkit-font-smoothing:antialiased;overflow-x:hidden}
html{overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-weight:800;line-height:1.14;letter-spacing:-.025em;color:var(--ink)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:54px 0}
.eyebrow{font-weight:700;text-transform:uppercase;letter-spacing:.18em;font-size:.74rem;color:var(--accent)}
/*l*/.lead{font-size:1.06rem;color:var(--soft);max-width:62ch;line-height:1.7}
.muted{color:var(--muted)}
.center{text-align:center}

/* boutons */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-weight:700;font-size:.97rem;
  padding:13px 26px;border-radius:7px;border:1.5px solid transparent;cursor:pointer;transition:.16s}
.btn--primary{background:var(--accent);color:#fff}
.btn--primary:hover{background:var(--accent-d);transform:translateY(-1px)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn--ghost:hover{border-color:var(--ink)}
.btn--accent{background:var(--accent);color:#fff}
.btn--accent:hover{background:var(--accent-d);transform:translateY(-1px)}
.btn--white{background:#fff;color:var(--ink);border-color:var(--line-2)}
.btn--white:hover{border-color:var(--ink)}
.btn--lg{padding:15px 30px;font-size:1.04rem}

/* header */
.hdr{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.93);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.hdr__bar{display:flex;align-items:center;justify-content:space-between;height:72px}
.logo{display:flex;align-items:center;gap:11px;font-weight:800;font-size:1.28rem;letter-spacing:-.03em;color:var(--ink)}
.logo__mark{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,#43C281 0%,#1E8A54 52%,#136A41 100%);display:grid;place-items:center;flex:0 0 auto;color:#fff;font-weight:800;font-size:1.08rem;line-height:1;box-shadow:0 5px 14px -5px rgba(24,120,74,.55);letter-spacing:-.02em}
.logo__mark svg{width:19px;height:19px;fill:none;stroke:#fff;stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round}
.logo__mark .a{stroke:rgba(255,255,255,.55)}
.logo b{font-weight:800}
.nav{display:flex;align-items:center;gap:30px}
.nav a{font-weight:600;font-size:.96rem;color:var(--ink);opacity:.76;transition:.15s}
.nav a:hover,.nav a.active{opacity:1;color:var(--accent)}
.hdr__cta{display:flex;align-items:center;gap:16px}
.hdr__tel{font-weight:800;white-space:nowrap;color:var(--ink)}
.burger{display:none;background:none;border:0;cursor:pointer;width:42px;height:42px}
.burger span{display:block;height:2px;width:22px;margin:5px auto;background:var(--ink)}

/* hero */
.hero{background:var(--bg);border-bottom:1px solid var(--line)}
.hero__in{padding:60px 0 48px;max-width:var(--read);margin:0 auto}
/*b*/.hero .badge{margin-bottom:18px;display:inline-flex;align-items:center;gap:9px;background:var(--bg-2);color:var(--ink);font-weight:700;font-size:.82rem;padding:7px 14px;border-radius:999px;margin-bottom:26px;border:1px solid var(--line)}
.hero .badge::before{content:"";width:8px;height:8px;border-radius:2px;background:var(--accent)}
.hero h1{font-size:clamp(2rem,4.4vw,3rem);letter-spacing:-.03em}
.hero h1 em{font-style:normal;color:var(--accent)}
.hero p{font-size:1.1rem;color:var(--muted);margin:16px 0 24px;max-width:58ch}
.hero__actions{display:flex;gap:14px;flex-wrap:wrap}
/* bandeau de réassurance : texte simple, pas de cases */
/*f*/.facts{margin-top:28px;padding-top:20px;border-top:1px solid var(--line);color:var(--muted);font-size:1rem;display:flex;flex-wrap:wrap;gap:10px 26px}
.facts span{display:inline-flex;align-items:center;gap:9px}
.facts span::before{content:"";width:7px;height:7px;border-radius:2px;background:var(--accent);flex:0 0 auto}
.facts b{color:var(--ink);font-weight:800}

/* section heads */
.sec-head{max-width:var(--read);margin:0 auto 8px}
.sec-head h2{font-size:clamp(1.5rem,3vw,2rem);margin:6px 0}
.sec-head .lead{margin-top:8px}

/* SERVICES — liste éditoriale, descriptions seules (pas de cartes) */
.svc-list{max-width:var(--read);margin:18px auto 0}
/*s*/.svc-item{padding:18px 0;border-top:1px solid var(--line);display:grid;grid-template-columns:auto 1fr;gap:26px;align-items:start}
.svc-item:last-child{border-bottom:1px solid var(--line)}
.svc-item .no{font-weight:800;font-size:1.05rem;color:var(--accent);padding-top:3px;font-variant-numeric:tabular-nums}
.svc-item h3{font-size:1.15rem;margin-bottom:4px}
.svc-item p{color:var(--muted);font-size:.98rem}
.svc-item ul{list-style:none;margin-top:12px;display:grid;gap:8px 26px;grid-template-columns:1fr 1fr}
.svc-item li{padding-left:20px;position:relative;color:var(--soft);font-size:.98rem}
.svc-item li::before{content:"•";position:absolute;left:2px;top:-1px;color:var(--accent);font-weight:800;font-size:1.05rem}
@media(max-width:680px){.svc-item ul{grid-template-columns:1fr}}

/* approche : points texte alignés */
.points{display:grid;gap:11px;margin:8px auto 0;max-width:var(--read)}
/*pt*/.points li{list-style:none;padding-left:32px;position:relative;font-size:1rem;color:var(--soft)}
.points li::before{content:"";position:absolute;left:0;top:3px;width:22px;height:22px;border-radius:5px;background:var(--accent);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:12px}

/* déroulement : étapes en texte numéroté, sans cases */
.proc{max-width:var(--read);margin:10px auto 0;counter-reset:s}
/*p*/.proc li{list-style:none;padding:14px 0 14px 48px;border-top:1px solid var(--line);position:relative}
/*pb*/.proc li::before{counter-increment:s;content:counter(s,decimal-leading-zero);position:absolute;left:0;top:14px;font-weight:800;color:var(--accent);font-size:1.1rem}
.proc h4{font-size:1.04rem;margin-bottom:2px}
.proc p{color:var(--muted)}

/* bandes */
.band{background:var(--bg-2)}

/* zones : liens texte en ligne, pas de pastilles */
/*z*/.zones-text{max-width:var(--read);margin:18px auto 0;overflow-wrap:anywhere;font-size:1.12rem;line-height:2.1;color:var(--muted)}
.zones-text a{color:var(--ink);font-weight:700;border-bottom:2px solid var(--line);padding-bottom:1px;transition:.15s}
.zones-text a:hover{border-color:var(--accent);color:var(--accent)}
.zones-text .sep{color:var(--line-2);margin:0 4px}

/* testimonial */
.testi{background:var(--bg-2)}
.testi .wrap{max-width:900px}
.testi .mark{font-size:3rem;line-height:.6;color:var(--accent);font-weight:800;display:block;margin-bottom:14px}
.testi blockquote{font-size:clamp(1.5rem,3.4vw,2.3rem);font-weight:800;line-height:1.28;letter-spacing:-.02em;margin:0}
.testi figcaption{margin-top:20px;color:var(--muted);font-weight:600}
.testi figcaption b{color:var(--ink)}

/* note + pricing */
/*n*/.note{max-width:var(--read);margin-left:auto;margin-right:auto;border-left:3px solid var(--accent);padding:6px 0 6px 18px;font-size:1rem;color:var(--muted)}
.note b{font-weight:800;color:var(--ink)}
.ptable{width:100%;max-width:var(--read);border-collapse:collapse;margin:20px auto 0}
.ptable th,.ptable td{padding:15px 4px;text-align:left;border-bottom:1px solid var(--line)}
.ptable th{font-weight:800;font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.ptable td{color:var(--muted)}
.ptable td:first-child{color:var(--ink);font-weight:600}
.ptable td:last-child{font-weight:800;color:var(--ink);white-space:nowrap;text-align:right}
.ptable th:last-child{text-align:right}

/* hero interne */
.phero{background:var(--bg-2);border-bottom:1px solid var(--line)}
.phero__in{padding:46px 0 38px}
.crumb{font-size:.88rem;color:var(--muted);margin-bottom:12px}
.crumb a:hover{color:var(--accent)}
.phero h1{font-size:clamp(2rem,4.6vw,3.1rem)}
.phero p{color:var(--muted);margin-top:12px;max-width:62ch;font-size:1.14rem}

/* faq — texte avec filets, sans cases */
.faq{max-width:var(--read);margin:20px auto 0}
.faq details{border-top:1px solid var(--line);padding:4px 0}
.faq details:last-child{border-bottom:1px solid var(--line)}
.faq summary{padding:18px 0;font-weight:700;font-size:1.1rem;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:14px;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--accent);font-size:1.5rem;font-weight:600;transition:.2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq p{padding:0 0 20px;color:var(--muted);max-width:60ch}

/* DEVIS — formulaire clair et lisible, une colonne */
.devis-band{background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.devis-wrap{max-width:680px;margin:0 auto}
.devis-title{text-align:center;font-weight:800;letter-spacing:-.025em;font-size:clamp(1.8rem,4vw,2.5rem);line-height:1.14;margin-bottom:12px}
.devis-sub{text-align:center;color:var(--muted);max-width:52ch;margin:0 auto 14px}
/*dp*/.devis-prep{text-align:center;color:var(--muted);font-size:.92rem;margin:0 auto 24px;max-width:56ch}
.devis-prep b{color:var(--ink)}
.form{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px 24px 26px}
.field{margin-bottom:15px}
.field>label{display:block;font-weight:700;font-size:.95rem;margin-bottom:9px;color:var(--ink)}
.req{color:var(--accent)}
.field input,.field select,.field textarea{width:100%;padding:14px 15px;border:1.5px solid var(--line-2);border-radius:var(--radius-sm);
  font-family:inherit;font-size:1.02rem;background:#fff;color:var(--ink);transition:.15s}
.field input::placeholder,.field textarea::placeholder{color:#9C9E9F}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 3px rgba(22,23,25,.08)}
.field textarea{min-height:120px;resize:vertical}
.fgrid{display:grid;gap:0 18px;grid-template-columns:1fr 1fr}
.chips{display:flex;flex-wrap:wrap;gap:9px}
.chip{position:relative}
.chip input{position:absolute;opacity:0;inset:0;cursor:pointer}
.chip span{display:inline-block;padding:10px 16px;border:1.5px solid var(--line-2);border-radius:999px;font-size:.94rem;font-weight:600;cursor:pointer;background:#fff;color:var(--soft);transition:.15s}
.chip input:checked+span{background:var(--accent);color:#fff;border-color:var(--accent)}
.hint{font-size:.86rem;color:var(--muted);font-weight:500}
.estimate{margin:4px 0 20px;padding:20px;border:1.5px dashed var(--accent);border-radius:var(--radius-sm);background:#EEF6F0;text-align:center}
.estimate .eyebrow{color:var(--accent)}
.estimate .val{font-weight:800;font-size:2rem;color:var(--ink);margin-top:2px}
.estimate small{display:block;color:var(--muted);font-size:.82rem;margin-top:4px}
.formmsg{padding:14px 16px;border-radius:var(--radius-sm);font-weight:600;margin-top:12px;display:none}
.formmsg.ok{display:block;background:#F2F5EF;color:#3A5A2E;border:1px solid #D2E0CA}
.formmsg.err{display:block;background:#FBEDEA;color:#8A2B20;border:1px solid #E6BCB4}

/* PRÉ-CONTACT */
/*pc*/.precontact{background:var(--bg);text-align:center;padding:52px 0 48px;border-top:1px solid var(--line)}
.precontact .lbl{font-size:clamp(1.3rem,2.6vw,1.8rem);font-weight:800;margin-bottom:4px}
.precontact .phone{display:block;font-size:clamp(2rem,4.6vw,2.9rem);font-weight:800;color:var(--accent);margin-bottom:18px}
.precontact p{color:var(--muted);max-width:54ch;margin:0 auto 26px}

/* footer — sombre, texte (colonnes simples) */
.ft{background:var(--dark);color:#A6AAAF;padding:0 0 28px;font-size:.95rem}
.ft__top{padding:56px 0 40px}
.ft__grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1.2fr;gap:32px}
.ft__brand .ft__logo{display:flex;align-items:center;gap:11px;color:#fff;font-weight:800;font-size:1.45rem;margin-bottom:14px}
.ft__brand .ft__logo .logo__mark{background:linear-gradient(135deg,#43C281,#136A41);box-shadow:none}
.ft__brand p{color:#979BA1;max-width:34ch}
.ft__brand .tagline{color:var(--accent);font-weight:700;margin-top:10px}
.ft h4{color:#fff;font-size:.82rem;text-transform:uppercase;letter-spacing:.12em;margin-bottom:16px}
.ft a{display:block;color:#A6AAAF;margin:10px 0;transition:.15s}
.ft a:hover{color:#fff}
.ft .plain{color:#A6AAAF;margin:10px 0;line-height:1.5}
.ft__bottom{border-top:1px solid #2A2C31;padding-top:22px;display:flex;justify-content:center;gap:22px;flex-wrap:wrap;font-size:.84rem;color:#797D82}
.ft__bottom a:hover{color:#fff}
.ft__copy{text-align:center;color:#62666B;font-size:.82rem;margin-top:14px}

/* reveal */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

@media(max-width:820px){.ft__grid{grid-template-columns:1fr 1fr}}
@media(max-width:680px){
  body{font-size:16px}
  .nav,.hdr__tel{display:none}
  .burger{display:block}
  .nav.open{display:flex;position:absolute;top:72px;left:0;right:0;flex-direction:column;background:var(--bg);border-bottom:1px solid var(--line);padding:18px 24px;gap:16px}
  .fgrid,.ft__grid{grid-template-columns:1fr}
  .svc-item{grid-template-columns:1fr;gap:6px}
  .section{padding:60px 0}
  .hero__in{padding:66px 0 56px}
  .form{padding:22px 18px 24px}
}

/* bloc compact 2 colonnes */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:46px;max-width:1000px;margin:0 auto}
.duo .h-sm{font-size:1.2rem;margin-bottom:6px}
.duo .eyebrow{margin-bottom:4px}
@media(max-width:760px){.duo{grid-template-columns:1fr;gap:30px}}

/* champ photos */
.field input[type=file]{padding:11px 14px;background:var(--bg-2);cursor:pointer;font-size:.94rem;color:var(--muted)}
.field input[type=file]::file-selector-button{margin-right:12px;border:0;background:linear-gradient(135deg,#2EA968,#15683F);color:#fff;padding:9px 15px;border-radius:7px;font-weight:700;cursor:pointer;font-family:inherit;font-size:.9rem}
.field input[type=file]:hover{border-color:var(--accent)}
.photo-note{font-size:.84rem;color:var(--accent);font-weight:600;margin-top:7px}

@media(max-width:540px){ .hdr__cta .btn{display:none} }
