
:root{--ink:#101214;--muted:#5b6363;--line:#e7ecec;--alt:#f7f9f9;--radius:14px;--max:1080px}
body{margin:0;font-family:Arial,Helvetica,sans-serif;color:var(--ink)}
.container{max-width:var(--max);margin:auto;padding:0 22px}
.top{position:sticky;top:0;background:#fff;border-bottom:1px solid var(--line)}
.top__inner{display:flex;justify-content:space-between;align-items:center;padding:14px 0}
.brand__logo{height:42px}
.nav a{margin-left:16px;text-decoration:none;color:var(--ink);font-weight:800;font-size:13px}
.btn{border:1px solid var(--ink);padding:10px 14px;border-radius:999px;text-decoration:none;color:var(--ink);font-weight:900}
.btn--ghost{background:transparent}
.hero-concept{padding:60px 0 0}
.hero-concept__grid{max-width:var(--max);margin:auto}
.hero-banner img{width:100%;max-height:320px;object-fit:cover;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.section{padding:44px 0;border-top:1px solid var(--line)}
.section--alt{background:var(--alt)}
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.card{border:1px solid var(--line);border-radius:var(--radius);padding:16px}
.icon{width:40px;height:40px;border:1px solid var(--line);border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:10px}
.impact__grid{display:grid;grid-template-columns:1.25fr .95fr;gap:26px}
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.kpi{border:1px solid var(--line);border-radius:var(--radius);padding:12px}
.refs--grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.ref--tile{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.ref--tile img{width:100%;height:180px;object-fit:cover}
.footer{border-top:1px solid var(--line);padding:18px 0;color:var(--muted);font-size:12px}
@media(max-width:980px){.cards,.refs--grid3{grid-template-columns:1fr}.impact__grid{grid-template-columns:1fr}}


/* === V9 (WEFORM) — ajustements layout demandés === */

/* Banner concept alignée sur la largeur du site (container) */
.banner{
  max-width: var(--max);
  margin-left: auto;
  margin-right: auto;
}
.banner img{
  width: 100%;
  height: auto;
}

/* Image impact : respecter la largeur du site (pas de débordement) */
#impact .media,
#impact figure,
#impact img{
  max-width: 100%;
}
#impact .media{
  margin-left: auto;
  margin-right: auto;
}

/* Icônes programme centrées dans leurs colonnes */
.cards .card{
  text-align: center;
}
.cards .card .icon{
  margin-left: auto;
  margin-right: auto;
}


/* === V9 (WEFORM) — overrides spécifiques v8 === */
/* Concept banner (hero-banner) aligné à la largeur du site */
.hero-banner{
  max-width: var(--max);
  margin-left: auto;
  margin-right: auto;
  padding-left: 22px;
  padding-right: 22px;
}
.hero-banner img{
  width:100%;
  height:auto;
  display:block;
  border-radius: var(--radius);
  border:1px solid var(--line);
  max-height: 320px;
  object-fit: cover;
}

/* Impact image: sécurité anti overflow */
#impact .media{ max-width: 100%; }
#impact .media img{ width:100%; height:auto; display:block; object-fit:cover; }


/* === V10 — Impact enrichi === */
.impact-points{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:10px;
  margin-top:14px;
}
.impact-point{
  border:1px solid var(--line);
  border-radius: var(--radius);
  background:#fff;
  padding:12px;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.impact-point strong{ font-size:14px; }
.impact-point span{ color: var(--muted); font-size:13px; }

@media (max-width: 620px){
  .impact-points{ grid-template-columns: 1fr; }
}

/* V12 — Impact image aligned to site width */
#impact .media{
  max-width: var(--max);
  margin-left: auto;
  margin-right: auto;
}
#impact .media img{
  width:100%;
  height:auto;
  display:block;
  object-fit:cover;
}


/* === V13 — Impact image on the right (desktop) === */
@media (min-width: 981px){
  #impact .impact__grid{
    display: grid;
    grid-template-columns: 1.25fr 0.95fr;
    gap: 26px;
    align-items: start;
  }
}


/* === V14 — Icônes programme agrandies === */
.cards .card .icon{
  width:64px;
  height:64px;
}
.cards .card .icon svg{
  width:36px;
  height:36px;
}


/* === V15 — Impact layout final === */
.impact__grid{
  display:grid;
  grid-template-columns: 1.25fr 0.95fr;
  gap:26px;
  align-items:start;
}
@media (max-width: 980px){
  .impact__grid{
    grid-template-columns: 1fr;
  }
}
