/* ============================================================
   ELTO — feuille de style partagée (toutes les pages)
   Mobile-first. HTML/CSS statique, simple et propre.
   ============================================================ */

:root{
  --anthracite:#1C1F23;
  --bg:#F6F5F2;
  --blanc:#FFFFFF;
  --bleu:#15455F;
  --bleu-d:#0F3447;
  --orange:#E8722C;
  --orange-d:#cf5f1d;
  --whatsapp:#25D366;
  --gris:#6B7280;
  --bordure:#E5E2DC;
  --serif:"Playfair Display",Georgia,serif;
  --sans:"Plus Jakarta Sans",system-ui,-apple-system,"Segoe UI",sans-serif;
  --r:14px;
  --r-sm:10px;
  --sh:0 10px 30px rgba(28,31,35,.07);
  --sh-sm:0 4px 14px rgba(28,31,35,.06);
  --max:1120px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--anthracite);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
:focus-visible{outline:2.5px solid var(--bleu);outline-offset:3px;border-radius:6px}

.wrap{width:100%;max-width:var(--max);margin:0 auto;padding:0 18px}

/* ---------- titres ---------- */
h1,h2,h3,h4{font-weight:700;line-height:1.18;letter-spacing:-.01em;color:var(--anthracite)}
h1{font-size:clamp(1.9rem,6.4vw,3.1rem)}
h2{font-size:clamp(1.5rem,5vw,2.2rem)}
.eyebrow{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--bleu);font-weight:700;margin-bottom:10px}
.lead{color:var(--gris);font-size:1.05rem}
.section{padding:56px 0}
.section.dark{background:var(--anthracite);color:#EDEDEA}
.section.dark h2,.section.dark h3{color:#fff}
.section.dark .lead{color:#B9BDC2}
.center{text-align:center}
.sec-head{max-width:680px}
.sec-head.center{margin:0 auto 34px}

/* ---------- logo mot « ELTO » ---------- */
.logo{display:inline-flex;align-items:center;gap:9px;font-family:var(--serif);font-weight:800;font-size:1.55rem;letter-spacing:.02em;color:var(--anthracite)}
.logo .mark{width:24px;height:24px;color:var(--bleu);flex:none}
.logo .mark svg{width:100%;height:100%;display:block}

/* ---------- boutons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--sans);font-weight:700;font-size:.98rem;line-height:1.1;
  padding:14px 20px;border-radius:999px;border:2px solid transparent;cursor:pointer;
  transition:transform .15s ease,box-shadow .2s ease,background .2s ease,color .2s ease;
  text-align:center;
}
.btn svg{width:18px;height:18px;flex:none}
.btn-cta{background:var(--orange);color:#fff}
.btn-cta:hover{background:var(--orange-d);transform:translateY(-2px);box-shadow:0 10px 22px rgba(232,114,44,.32)}
.btn-wa{background:var(--whatsapp);color:#fff}
.btn-wa:hover{transform:translateY(-2px);box-shadow:0 10px 22px rgba(37,211,102,.32)}
.btn-call{background:var(--bleu);color:#fff}
.btn-call:hover{background:var(--bleu-d);transform:translateY(-2px);box-shadow:0 10px 22px rgba(21,69,95,.3)}
.btn-ghost{background:transparent;color:var(--anthracite);border-color:var(--bordure)}
.btn-ghost:hover{border-color:var(--bleu);color:var(--bleu)}
.btn-block{width:100%}
.btn-row{display:flex;flex-wrap:wrap;gap:12px}

/* ---------- header sticky + nav ---------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(246,245,242,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--bordure)}
.bar{display:flex;align-items:center;justify-content:space-between;gap:14px;height:66px}
.burger{display:inline-flex;flex-direction:column;justify-content:center;gap:5px;width:46px;height:46px;border:1px solid var(--bordure);background:var(--blanc);border-radius:12px;cursor:pointer}
.burger span{display:block;width:20px;height:2px;background:var(--anthracite);margin:0 auto;border-radius:2px;transition:transform .2s,opacity .2s}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-links{display:none;flex-direction:column;gap:2px;position:absolute;top:66px;left:0;right:0;background:var(--blanc);border-bottom:1px solid var(--bordure);box-shadow:var(--sh);padding:10px 18px 16px}
.nav-links.open{display:flex}
.nav-links a{padding:13px 4px;font-weight:600;color:var(--anthracite);border-bottom:1px solid var(--bordure)}
.nav-links a:last-child{border-bottom:0}
.nav-links a.active{color:var(--bleu)}
.nav-links .nav-cta{margin-top:10px;border-bottom:0;color:#fff;padding:13px 20px}

/* ---------- hero ---------- */
.hero{background:linear-gradient(180deg,#FBFAF8,var(--bg));border-bottom:1px solid var(--bordure)}
.hero .wrap{padding-top:46px;padding-bottom:52px}
.hero .logo{font-size:1.9rem;margin-bottom:18px}
.hero h1{margin-bottom:16px}
.hero h1 .accent{font-family:var(--serif);font-style:italic;font-weight:800;color:var(--bleu)}
.hero .sub{font-size:1.1rem;color:var(--gris);max-width:46ch;margin-bottom:26px}
.hero .btn-row{gap:12px}

/* ---------- bande réassurance ---------- */
.assur{background:var(--blanc);border-top:1px solid var(--bordure);border-bottom:1px solid var(--bordure)}
.assur .grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 16px;padding:22px 0}
.assur .it{display:flex;align-items:center;gap:11px;font-weight:600;font-size:.95rem}
.assur .it .ic{width:38px;height:38px;border-radius:11px;background:rgba(21,69,95,.09);color:var(--bleu);display:grid;place-items:center;flex:none}
.assur .it .ic svg{width:20px;height:20px}

/* ---------- bloc PLACEHOLDER photo (étiqueté) ---------- */
.ph{
  position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  text-align:center;padding:22px;min-height:190px;
  background:repeating-linear-gradient(45deg,#EFEEEA,#EFEEEA 12px,#F4F3EF 12px,#F4F3EF 24px);
  border:2px dashed #C9C5BC;border-radius:var(--r);color:var(--gris);
}
.ph .ph-ic{width:34px;height:34px;color:#A7A299}
.ph .ph-label{font-weight:700;font-size:.9rem;color:#5d5950;max-width:30ch}
.ph .ph-tag{position:absolute;top:10px;left:10px;background:var(--anthracite);color:#fff;font-size:.66rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:4px 9px;border-radius:999px;opacity:.9}
.ph.sq{aspect-ratio:4/3}

/* ---------- services (2 cartes) ---------- */
.services-grid{display:grid;grid-template-columns:1fr;gap:18px}
.svc-card{display:flex;flex-direction:column;background:var(--blanc);border:1px solid var(--bordure);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-sm);transition:transform .2s,box-shadow .2s;color:inherit}
.svc-card:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.svc-card .ph{border:0;border-bottom:2px dashed #C9C5BC;border-radius:0;min-height:170px}
.svc-card .body{padding:22px}
.svc-card h3{font-size:1.3rem;margin-bottom:8px}
.svc-card p{color:var(--gris);font-size:.97rem;margin-bottom:14px}
.svc-card .more{display:inline-flex;align-items:center;gap:7px;font-weight:700;color:var(--orange)}
.svc-card:hover .more{gap:11px}

/* ---------- avant / après ---------- */
.ba-grid{display:grid;grid-template-columns:1fr;gap:16px}

/* ---------- étapes ---------- */
.steps{display:grid;grid-template-columns:1fr;gap:16px;counter-reset:step}
.step{background:var(--blanc);border:1px solid var(--bordure);border-radius:var(--r);padding:22px;box-shadow:var(--sh-sm)}
.step .top{display:flex;align-items:center;gap:13px;margin-bottom:8px}
.step .num{width:42px;height:42px;border-radius:12px;background:var(--bleu);color:#fff;font-weight:800;font-size:1.15rem;display:grid;place-items:center;flex:none}
.step .ic{width:24px;height:24px;color:var(--bleu)}
.step h3{font-size:1.12rem}
.step p{color:var(--gris);font-size:.96rem}

/* ---------- pourquoi ELTO ---------- */
.why-grid{display:grid;grid-template-columns:1fr;gap:24px;align-items:center}
.why-list{list-style:none;display:flex;flex-direction:column;gap:14px}
.why-list li{display:flex;gap:13px;align-items:flex-start;font-weight:600}
.why-list .ck{width:30px;height:30px;border-radius:9px;background:rgba(21,69,95,.1);color:var(--bleu);display:grid;place-items:center;flex:none}
.why-list .ck svg{width:17px;height:17px}

/* ---------- zones ---------- */
.zones-box{background:var(--blanc);border:1px solid var(--bordure);border-radius:var(--r);padding:26px;box-shadow:var(--sh-sm)}
.zones-box .todo{color:var(--gris);margin-top:6px}

/* ---------- CTA finale ---------- */
.cta-final{background:var(--bleu);color:#fff;border-radius:var(--r);padding:34px 24px;text-align:center;box-shadow:var(--sh)}
.cta-final h2{color:#fff;margin-bottom:10px}
.cta-final p{color:#D6E2E8;max-width:44ch;margin:0 auto 22px}
.cta-final .btn-row{justify-content:center}

/* ---------- footer ---------- */
.site-footer{background:var(--anthracite);color:#C4C7CB;padding:42px 0 28px;margin-top:8px}
.site-footer .logo{color:#fff}
.site-footer .logo .mark{color:#5e93ab}
.foot-grid{display:grid;grid-template-columns:1fr;gap:26px}
.foot-grid h4{color:#fff;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:12px}
.foot-grid a{display:block;color:#C4C7CB;padding:5px 0}
.foot-grid a:hover{color:#fff}
.foot-grid .tagline{margin-top:10px;color:#9aa0a6;font-size:.95rem;max-width:34ch}
.foot-contact div{padding:4px 0}
.foot-contact a{display:inline}
.foot-fine{border-top:1px solid rgba(255,255,255,.12);margin-top:26px;padding-top:18px;font-size:.86rem;color:#9aa0a6}

/* ---------- page « shell » (pages en préparation) ---------- */
.page-hero{background:var(--anthracite);color:#fff;padding:52px 0}
.page-hero .eyebrow{color:#7fb0c6}
.page-hero h1{color:#fff;font-size:clamp(1.8rem,5.6vw,2.6rem)}
.soon{max-width:620px;margin:46px auto;text-align:center;background:var(--blanc);border:2px dashed #C9C5BC;border-radius:var(--r);padding:40px 26px;box-shadow:var(--sh-sm)}
.soon .ic{width:46px;height:46px;color:var(--bleu);margin:0 auto 14px}
.soon h2{font-size:1.4rem;margin-bottom:8px}
.soon p{color:var(--gris)}
.soon .btn-row{justify-content:center;margin-top:22px}

/* ============================================================
   Tablette / Desktop (mobile-first → on enrichit)
   ============================================================ */
@media (min-width:680px){
  .wrap{padding:0 24px}
  .section{padding:72px 0}
  .assur .grid{grid-template-columns:repeat(4,1fr);padding:26px 0}
  .services-grid{grid-template-columns:1fr 1fr}
  .ba-grid{grid-template-columns:repeat(3,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .why-grid{grid-template-columns:1.05fr .95fr}
  .foot-grid{grid-template-columns:1.4fr 1fr 1.1fr}
  .cta-final{padding:48px 36px}
}
@media (min-width:860px){
  .burger{display:none}
  .nav-links{display:flex;flex-direction:row;align-items:center;gap:24px;position:static;background:none;border:0;box-shadow:none;padding:0}
  .nav-links a{padding:6px 0;border-bottom:0;font-size:.96rem;color:var(--anthracite);opacity:.85}
  .nav-links a:hover{opacity:1;color:var(--bleu)}
  .nav-links a.active{opacity:1;color:var(--bleu)}
  .nav-links .nav-cta{margin-top:0;color:#fff;padding:11px 20px}
  .steps{grid-template-columns:repeat(4,1fr)}
  .hero .wrap{padding-top:64px;padding-bottom:72px}
  .hero .sub{font-size:1.18rem}
}

@media (prefers-reduced-motion:reduce){
  *{transition:none!important;scroll-behavior:auto!important}
}

/* ============================================================
   AJOUTS lot 2 — page « Débarras & vide-maison »
   (nouveaux composants uniquement ; aucune règle existante modifiée)
   ============================================================ */
/* cartes « situations » : icône + titre + texte */
.cards{display:grid;grid-template-columns:1fr;gap:18px}
.icard{background:var(--blanc);border:1px solid var(--bordure);border-radius:var(--r);padding:24px;box-shadow:var(--sh-sm)}
.icard .ic{width:46px;height:46px;border-radius:12px;background:rgba(21,69,95,.09);color:var(--bleu);display:grid;place-items:center;margin-bottom:13px}
.icard .ic svg{width:24px;height:24px}
.icard h3{font-size:1.18rem;margin-bottom:6px}
.icard p{color:var(--gris);font-size:.96rem}

/* listes à icônes (lieux / ce qu'on évacue) */
.icon-list{list-style:none;display:grid;grid-template-columns:1fr;gap:12px;margin-top:6px}
.icon-list li{display:flex;align-items:center;gap:13px;background:var(--blanc);border:1px solid var(--bordure);border-radius:var(--r-sm);padding:14px 16px;font-weight:600}
.icon-list .ic{width:34px;height:34px;border-radius:9px;background:rgba(21,69,95,.09);color:var(--bleu);display:grid;place-items:center;flex:none}
.icon-list .ic svg{width:18px;height:18px}
.list-note{color:var(--gris);margin-top:14px}

/* enchaînement à 5 étapes (réutilise les cartes .step existantes) */
.flow{display:grid;grid-template-columns:1fr;gap:16px}

@media (min-width:680px){
  .cards{grid-template-columns:1fr 1fr}
  .icon-list{grid-template-columns:1fr 1fr}
  .flow{grid-template-columns:repeat(3,1fr)}
}
@media (min-width:980px){
  .flow{grid-template-columns:repeat(5,1fr)}
}

/* ============================================================
   AJOUTS lot 3 — formulaire de devis (page devis.html)
   (nouveaux composants uniquement ; aucune règle existante modifiée)
   ============================================================ */
.form-card{background:var(--blanc);border:1px solid var(--bordure);border-radius:var(--r);padding:22px;box-shadow:var(--sh-sm);max-width:680px;margin:0 auto}
.qform{display:grid;grid-template-columns:1fr;gap:16px}
.qform .field label{display:block;font-weight:600;font-size:.95rem;margin-bottom:6px}
.qform .req{color:var(--orange)}
/* font-size 16px = pas de zoom auto sur iOS */
.qform input,.qform select,.qform textarea{width:100%;font-family:var(--sans);font-size:16px;color:var(--anthracite);background:var(--bg);border:1px solid var(--bordure);border-radius:var(--r-sm);padding:13px 14px;line-height:1.4;-webkit-appearance:none;appearance:none}
.qform select{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2.4'><path d='m6 9 6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right 12px center;background-size:16px;padding-right:40px}
.qform textarea{min-height:120px;resize:vertical}
.qform input:focus,.qform select:focus,.qform textarea:focus{outline:none;border-color:var(--bleu);box-shadow:0 0 0 3px rgba(21,69,95,.12);background:#fff}
.qform .row2{display:grid;grid-template-columns:1fr;gap:16px}
.qform .submit{width:100%;margin-top:4px}
.qform .note{color:var(--gris);font-size:.9rem;margin-top:-4px}

/* message de confirmation (mode démo) */
.form-ok{display:none;text-align:center;background:#EAF3EE;border:1px solid #BFE0CD;border-radius:var(--r);padding:34px 24px;max-width:680px;margin:0 auto;box-shadow:var(--sh-sm)}
.form-ok.show{display:block}
.form-ok .ic{width:54px;height:54px;border-radius:50%;background:#1F8A4C;color:#fff;display:grid;place-items:center;margin:0 auto 14px}
.form-ok .ic svg{width:28px;height:28px}
.form-ok h3{font-size:1.22rem;line-height:1.4;margin-bottom:6px;max-width:36ch;margin-left:auto;margin-right:auto}
.form-ok .demo{color:var(--gris);font-size:.9rem;margin-top:8px}

/* bande réassurance (3 points) sous le formulaire */
.reassure{display:grid;grid-template-columns:1fr;gap:14px;margin:36px auto 0;max-width:680px}
.reassure .it{display:flex;align-items:center;gap:12px;font-weight:600;font-size:.95rem;background:var(--blanc);border:1px solid var(--bordure);border-radius:var(--r-sm);padding:14px 16px}
.reassure .it .ic{width:38px;height:38px;border-radius:11px;background:rgba(21,69,95,.09);color:var(--bleu);display:grid;place-items:center;flex:none}
.reassure .it .ic svg{width:20px;height:20px}

@media (min-width:560px){
  .qform .row2{grid-template-columns:1fr 1fr}
}
@media (min-width:680px){
  .reassure{grid-template-columns:repeat(3,1fr)}
}

/* ============================================================
   AJOUTS lot 4 — page « Déménagement & transport »
   (nouveaux composants uniquement ; aucune règle existante modifiée)
   ============================================================ */
/* bouton blanc lisible sur le grand CTA bleu (.cta-final) */
.btn-white{background:#fff;color:var(--bleu)}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 10px 22px rgba(0,0,0,.18)}
/* grille à 3 colonnes pour les 3 étapes (réutilise les cartes .step) */
.flow3{display:grid;grid-template-columns:1fr;gap:16px}
@media (min-width:680px){
  .flow3{grid-template-columns:repeat(3,1fr)}
}
