/* -----------------------------
   Base / Reset léger
------------------------------ */
* { box-sizing: border-box; }
html { font-size: 16px; }
body { margin: 0; font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; color: #0a2540; line-height: 1.6; background: #fff; }
img, video { max-width: 100%; height: auto; display: block; }

/* Containers */
.container { width: 100%; max-width: 1100px; padding: 0 16px; margin: 0 auto; }

/* Typo */
h1,h2,h3 { font-family: Montserrat, Inter, system-ui, -apple-system, sans-serif; margin: 0 0 .6rem; line-height: 1.25; }
h1 { font-size: 2rem; }
h2 { font-size: 1.5rem; }
h3 { font-size: 1.15rem; }
p { margin: 0 0 1rem; }
.small { font-size: .9rem; opacity: .9; }
.tag { display:inline-block; font-size:.85rem; padding:.25rem .5rem; border:1px solid #e5e7eb; border-radius:999px; }

/* Boutons & CTA (accent bleu clair) */
.button, .cta, button, input[type="submit"] {
  display: inline-block;
  padding: .7rem 1rem;
  border-radius: .6rem;
  text-decoration: none;
  color: #fff;
  transition: background .2s;
}
.button.primary { background: #3B82F6; }
.button.primary:hover,
.button:hover,
.cta:hover,
button:hover,
.button.ghost {
  background: transparent;
  color: #3B82F6;
}
.button.ghost:hover { background: #EFF6FF; }

/* Liens */
a { color: #3B82F6; text-decoration: none; }
a:hover { text-decoration: underline; }

/* Inputs focus */
input:focus, textarea:focus, select:focus {
  border-color: #3B82F6;
  box-shadow: 0 0 0 2px #93C5FD;
  outline: none;
}

/* -----------------------------
   Header / Nav (burger + drawer)
------------------------------ */
.site-header { position: sticky; top: 0; z-index: 1000; background: #ffffffcc; backdrop-filter: blur(8px); border-bottom: 1px solid #eef2f7; }
.site-header .nav { display: flex; align-items: center; gap: 1rem; min-height: 64px; }

.brand { display:flex; align-items:center; gap:.6rem; text-decoration:none; color:#0a2540; font-weight:700; }
.logo { font-size: 1.1rem; }
.brand-wrap { display:flex; flex-direction:column; line-height:1.1; }
.brand-line1 { font-size:1rem; }
.brand-line2 { font-size:.88rem; opacity:.8; }

#nav-toggle { display: none; }
.burger { margin-left: auto; cursor: pointer; font-size: 1.35rem; padding:.4rem .6rem; border-radius:.5rem; }

.menu {
  /* Par défaut : desktop géré plus bas */
}

/* -----------------------------
   Sections / Cards / Grids
------------------------------ */
.section { padding: 2rem 0; }
.card { background:#fff; border:1px solid #eef2f7; border-radius:.75rem; padding:1rem; box-shadow:0 1px 3px rgba(0,0,0,0.03); }
.card p { margin-bottom:.75rem; }

.grid-2, .grid-3 { display: grid; gap: 1rem; }
.grid-2 { grid-template-columns: 1fr; }
.grid-3 { grid-template-columns: 1fr; }

/* Section alternative + cartes colorées */
.section.alt { background:#f9fafb; padding:2rem 0; }
.card.highlight { border-radius: .75rem; padding: 1.5rem; box-shadow: 0 2px 6px rgba(0,0,0,.05); }
.card.highlight.apps { background:#eef2ff; border:1px solid #c7d2fe; color:#1e1b4b; }
.card.highlight.emailing { background:#ecfdf5; border:1px solid #a7f3d0; color:#064e3b; }
.section-title { font-size:1.6rem; font-weight:700; margin-bottom:2rem; text-align:center; color:#111827; }

/* -----------------------------
   Hero
------------------------------ */
.hero { padding: 2.5rem 0 2rem; background:#fff; position:relative; overflow:hidden; }
.hero h1 { font-size: 1.6rem; }
.hero .lead { font-size: 1rem; }
.hero .actions { display:flex; flex-wrap:wrap; gap:.6rem; margin:1rem 0; }
.hero .kpis { display:grid; grid-template-columns: 1fr; gap:.5rem; margin-top:1rem; }
.kpi { padding:.5rem .75rem; border:1px dashed #e5e7eb; border-radius:.5rem; }

/* -----------------------------
   Illustrations fines (accent bleu)
------------------------------ */
.hero, .section, .site-footer { position: relative; overflow: hidden; }
.illu { position:absolute; pointer-events:none; user-select:none; color:#93C5FD; opacity:.14; z-index:0; }
.illu.orbit { width:320px; height:320px; right:-40px; top:-40px; }
.illu.corner-top { width:220px; height:220px; right:-30px; top:-30px; }
.illu.corner-bottom { width:220px; height:220px; left:-30px; bottom:-30px; transform: rotate(180deg); }
.illu.wave { width:620px; height:160px; left:50%; transform:translateX(-50%); bottom:-40px; }
.card, .container, .site-footer .container { position:relative; z-index:1; }


/* -----------------------------
   À propos (portrait + layout)
------------------------------ */
.section.about { background:#fff; padding:2rem 0; }
.section.about .grid-2 { display:grid; grid-template-columns:1fr; gap:1rem; align-items:start; }
.section.about .portrait img {
  max-width: 220px; height:auto; border-radius:50%;
  display:block; margin:1rem auto 0; box-shadow:0 4px 12px rgba(0,0,0,.08);
}
.section.about .list { margin:1rem 0 1.5rem; padding-left:1.2rem; list-style:disc; }
.section.about h1 { font-size:1.75rem; }

/* Aligner le texte en bas de l'image à partir de 900px */
@media (min-width: 900px) {
  .section.about .grid-2 { grid-template-columns: 1fr 0.8fr; gap:2rem; align-items:end; }
  .section.about .portrait img { margin-left: auto; max-width: 240px; }
}

/* -----------------------------
   Footer
------------------------------ */
.site-footer { background:#fff; border-top:1px solid #eef2f7; padding-top: 2rem; }

/* -----------------------------
   Responsive global
------------------------------ */
/* >= 640px : petites tablettes */
@media (min-width: 640px) {
  .grid-2 { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .grid-3 { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .hero h1 { font-size: 1.9rem; }
  .button, button, input[type="submit"] { width: auto; }
  form.grid-3, form .grid-3 { display:grid; grid-template-columns: 1fr 1fr; gap:.75rem; }
  .hero .kpis { grid-template-columns: repeat(2, minmax(0,1fr)); }
}

/* >= 900px : tablettes / petits laptops */
@media (min-width: 900px) {
  .section { padding: 3rem 0; }
  .grid-3 { grid-template-columns: repeat(3, minmax(0,1fr)); }
  .hero .kpis { grid-template-columns: repeat(3, minmax(0,1fr)); }
  .svc-icon { width: 26px; height: 26px; }
}

/* >= 1200px : desktop */
@media (min-width: 1200px) {
  .grid-3 { grid-template-columns: repeat(4, minmax(0,1fr)); }
  .section { padding: 4rem 0; }
  .hero h1 { font-size: 2.2rem; }
}

/* Tap targets & formulaires */
.menu a, .button, button { min-height: 44px; }
input, textarea, select { width:100%; padding:.7rem .8rem; border:1px solid #e5e7eb; border-radius:.5rem; font:inherit; }

/* ==== NAV MOBILE : forcer le comportement drawer ==== */
:root { --header-h: 64px; }

@media (max-width: 900px){
  .brand-wrap{ max-width: 70%; }
  .brand-line1{ font-size: .98rem; }
  .brand-line2{ font-size: .82rem; opacity: .85; }

  .site-header .menu{ display: none !important; }

  #nav-toggle:not(:checked) + label.burger + nav.menu{
    display: none !important;
  }
  #nav-toggle:checked + label.burger + nav.menu{
    display: block !important;
    position: fixed;
    top: var(--header-h);
    left: 0; right: 0;
    background: #fff;
    padding: .75rem 1rem 1.25rem;
    border-bottom: 1px solid #eef2f7;
    z-index: 999;
  }

  .menu a{ display:block; padding: .9rem 0; font-size: 1.05rem; }

  .lock-scroll{ height: 100vh; overflow: hidden; }
}

/* Desktop : menu inline normal */
@media (min-width: 901px){
  .menu{ position: static !important; display: flex !important; gap: 1rem; padding: 0; border: 0; background: transparent; }
  .menu a{ padding: .25rem .5rem; font-size: 1rem; }
  .burger{ display: none; }
}

/* État actif du lien courant */
.menu a.active,
.menu a[aria-current="page"]{
  color:#2563EB;
  font-weight:600;
  position:relative;
}
@media (min-width:901px){
  .menu a.active::after,
  .menu a[aria-current="page"]::after{
    content:""; position:absolute; left:0; right:0; bottom:-6px;
    height:2px; background:#3B82F6; border-radius:2px;
  }
}


/* === NAV: état par défaut (desktop & mobile) === */
#nav-toggle{ display:none; }

/* Tiroir mobile : TOUJOURS caché par défaut */
.drawer{ display:none; }
.drawer-overlay{ display:none; }

/* Burger caché en desktop */
.nav-burger{ display:none; }

/* Desktop >= 901px : menu inline, tiroir & overlay complètement absents */
@media (min-width:901px){
  .menu{ display:flex !important; }
  .drawer, .drawer-overlay{ display:none !important; }
  .nav-burger{ display:none !important; }
}

/* Mobile <= 900px : menu inline caché, burger visible */
@media (max-width:900px){
  .menu{ display:none !important; }
  .nav-burger{ display:inline-block; cursor:pointer; width:44px; height:44px; display:grid; place-items:center; }

  /* style du tiroir */
  .drawer{
    position:fixed; left:0; right:0; top:64px;
    background:#fff; border-bottom:1px solid #e5e7eb;
    padding:1rem; z-index:999;
    /* caché par défaut ci-dessus (display:none) */
  }
  .drawer a{ display:block; padding:.9rem 0; color:inherit; text-decoration:none; }

  .drawer-overlay{
    position:fixed; inset:0; background:rgba(0,0,0,.25);
    z-index:998;
  }

  /* Ouverture : n’afficher que quand #nav-toggle est coché */
  #nav-toggle:checked ~ .drawer{ display:block; }
  #nav-toggle:checked ~ .drawer-overlay{ display:block; }

  /* Option : masquer la brand quand ouvert */
  #nav-toggle:checked ~ header .brand{ opacity:.0; visibility:hidden; pointer-events:none; }
}

/* === Variables (si pas déjà présentes) === */
:root{
  --accent:#3B82F6;           /* bleu clair */
  --accent-700:#2563EB;
  --ink:#0a2540;
  --muted:#64748b;
  --hero-bg:#F5F8FC;          /* fond du hero, légèrement bleuté */
  --chip-bg:#f8fafc;
  --chip-br:#e5e7eb;
}

/* === HERO : plus d’air + fond différent === */
.hero{
  background: var(--hero-bg);
  padding: 56px 0 48px;   /* + d’air en haut */
  border-bottom: 1px solid #e9eef6; /* séparation douce */
}
@media(min-width:900px){
  .hero{ padding: 72px 0 60px; }
}
.hero .lead{ color: var(--muted); }

/* === Section suivante : + d’espace en haut pour respirer depuis le hero === */
.section{ padding: 48px 0; }
@media(min-width:900px){ .section{ padding: 64px 0; } }

/* === KPI regroupés === */
.kpi-groups{
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  margin-top: 18px;
}
.kpi-group{
  display: flex;
  align-items: flex-start;
  gap: 10px;
  flex-wrap: wrap;
}
.kpi-title{
  font-size: .9rem;
  font-weight: 700;
  color: var(--muted);
  letter-spacing: .02em;
  text-transform: uppercase;
  padding-top: .35rem;
}
.kpi-list{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.kpi-chip{
  background: var(--chip-bg);
  border: 1px solid var(--chip-br);
  border-radius: 999px;
  padding: .35rem .6rem;
  font-size: .9rem;
  color: var(--ink);
  white-space: nowrap;
}

/* === Bouton dans la nav === */
.menu .btn,
.drawer .btn{
  display:inline-block;
  padding:.5rem .9rem;
  border-radius:.6rem;
  border:1px solid transparent;
  font-weight:600;
  text-decoration:none;
}
.menu .btn.primary,
.drawer .btn.primary{
  background:var(--accent);
  color:#fff;
  border-color:var(--accent);
}
.menu .btn.primary:hover,
.drawer .btn.primary:hover{ background:var(--accent-700); }

/* Spacing fin pour éviter que le bouton colle aux liens sur desktop */
.menu a + .btn.primary{ margin-left:.25rem; }

/* NAV: liens et bouton même hauteur */
.menu { align-items: center; }

.menu a,
.menu .btn {
  display: flex;
  align-items: center;
  height: 40px;        /* même hauteur */
  line-height: 1;
  padding: 0 .65rem;
}

.menu .btn.primary {
  padding: 0 .85rem;   /* un peu plus large mais même hauteur */
}

/* Grille responsive des services */
.services-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem; /* un peu plus d’espace */
}

@media (min-width: 640px) {
  .services-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 900px) {
  .services-grid {
    grid-template-columns: repeat(3, 1fr); /* 3 colonnes desktop */
  }
}

/* Toutes les cartes services = même hauteur */
.services-grid .card {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

/* Force des lignes égales dans la grille */
.services-grid {
  grid-auto-rows: 1fr;
}

/* --- EYEBROW (chip "Conseil en communication numérique") --- */
.eyebrow, .tag {
  display:inline-block;
  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:999px;
  padding:.6rem .6rem;
  font-size:.9rem;
  color:#334155;
  line-height:1;
  margin-bottom:1.25rem;
}

/* --- HERO spacing (titre, desc, boutons, KPIs) --- */
.hero { padding:72px 0 56px; }
.hero h1 { margin:0 0 1.1rem; }
.hero p.lead { margin:0 0 1.6rem; }
.hero .cta { display:flex; flex-wrap:wrap; gap:.75rem; margin:0 0 1.8rem; }
.hero .kpi-groups, .hero .kpis { margin-top:1.2rem; }

/* --- BOUTONS DU HERO : empêcher le plein-largeur hérité --- */
.hero .cta a { display:inline-flex !important; align-items:center; justify-content:center;
               width:auto !important; min-height:40px; padding:.55rem .9rem; line-height:1; }

/* --- Style bouton principal (bleu) : pour "Coaching Essentiel" --- */
.btn.primary, .hero .cta .button.primary {
  background:#3B82F6; color:#fff; border:1px solid #3B82F6; border-radius:.6rem; font-weight:600;
}
.btn.primary:hover, .hero .cta .button.primary:hover { background:#2563EB; }

/* --- Style bouton secondaire (blanc/texte bleu) : pour "Voir les services" --- */
/* fonctionne avec .btn.light OU avec ton ancien markup .button.ghost */
.btn.light,
.hero .cta .button.ghost {
  background:#fff !important;
  color:#1d4ed8 !important;
  border:1px solid #1d4ed8 !important;
  border-radius:.6rem;
  font-weight:600;
}
.btn.light:hover,
.hero .cta .button.ghost:hover { background:#f0f5ff !important; }

/* Option : réduire légèrement la largeur du conteneur des boutons en mobile si besoin */
/* @media(max-width:480px){ .hero .cta { justify-content:flex-start; } } */

/* Supprimer soulignement des liens au survol et en focus */
a, a:visited {
  text-decoration: none;
}
a:hover, a:focus {
  text-decoration: none;
}

/* ========= ABOUT : portrait flottant + intro ========= */
.about-intro{ padding: 40px 0 24px; }
.about-intro .chip{
  display:inline-block; background:#fff; border:1px solid #e5e7eb;
  border-radius:999px; padding:.35rem .6rem; font-size:.9rem; color:#334155;
  margin-bottom: .8rem;
}
.about-intro h1{ margin:0 0 .5rem; }
.about-intro .lead{ color:#475569; max-width: 760px; }

/* flotter l’image à droite et enrouler le texte */
.about-portrait-float{
  float: right;
  width: 220px;                 /* taille contrôlée */
  margin: 0 0 12px 24px;        /* espace à gauche et en bas */
  shape-outside: ellipse(50% 60% at 50% 40%);
  clip-path:   ellipse(50% 60% at 50% 40%);
}
.about-portrait-float img{
  display:block; width:100%; height:auto;
  background:#fff; padding:10px;
}
/* mobile : on arrête le float */
@media (max-width: 900px){
  .about-portrait-float{ float:none; width:160px; margin:0 auto 12px; shape-outside:none; clip-path:none; }
}
.clearfix::after{ content:""; display:block; clear:both; }

/* ========= Valeurs & approche : 3 colonnes centrées ========= */
.about-values{ background:#fafbfc; border-top:1px solid #eef2f7; }
.about-values h2{ text-align:center; margin:0 0 1rem; }

.values-grid.values-3{
  display:grid; gap:16px; grid-template-columns:1fr;
  max-width:1100px; margin:0 auto;    /* centré, pleine largeur de la zone */
}
@media (min-width:640px){ .values-grid.values-3{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:900px){ .values-grid.values-3{ grid-template-columns:repeat(3,1fr); } }

.value-card{
  background:#fff; border:1px solid #e8eef5; border-radius:.9rem; padding:16px;
  text-align:center; box-shadow:0 1px 3px rgba(0,0,0,.03);
  display:flex; flex-direction:column; gap:.45rem;
}
.value-icon{
  display:inline-flex; width:24px; height:24px; margin:0 auto 6px;
  color:#2563EB; opacity:.95;
}
.value-icon svg{ width:100%; height:100%; stroke:currentColor; fill:none; }
.value-card h3{ margin:.1rem 0 .2rem; font-size:1.05rem; }
.value-card p{ margin:0; color:#475569; }

/* === FOOTER === */
.site-footer{
  margin-top: 56px;
  background: #f7f9fc;
  border-top: 1px solid #e8eef5;
  padding: 28px 0 40px;
}

/* Newsletter card */
.nl-card{
  background:#fff;
  border:1px solid #e8eef5;
  border-radius: 14px;
  padding: 16px;
  box-shadow: 0 4px 16px rgba(10,37,64,.04);
  margin: 0 0 24px;
}
.nl-head{ display:flex; align-items:baseline; gap:10px; margin-bottom:10px; }
.nl-head h2{ margin:0; font-size:1.05rem; }
.nl-sub{ margin:0; color:#64748b; font-size:.95rem; }
.nl-form{ display:flex; gap:10px; flex-wrap:wrap; }
.nl-form input{
  flex:1 1 260px; min-height:44px; padding:0 12px; border:1px solid #dfe7f1; border-radius:10px;
  font:inherit; background:#fbfdff;
}
.nl-form .btn{
  min-height:44px; padding:0 16px; border-radius:10px; font-weight:600;
}

/* Grille 1→2→3 colonnes */
.footer-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 18px;
}
@media (min-width:680px){
  .footer-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width:980px){
  .footer-grid{ grid-template-columns: 2fr 1fr 1fr; } /* marque + 2 colonnes */
}

/* Colonne marque */
.brandline{ display:flex; align-items:center; gap:12px; margin-bottom:8px; }
.brandline .logo{ font-size:18px; color:#2563EB; }
.brandline .fn{ font-weight:800; }
.brandline .tag{ color:#64748b; }
.copy{ color:#8a99ad; font-size:.95rem; }

/* Colonnes */
.f-col h3{ margin:.2rem 0 .4rem; font-size:1rem; }
.f-list{ list-style:none; padding:0; margin:0; display:grid; gap:6px; }
.f-list a{ color:#0a2540; text-decoration:none; }
.f-list a:hover{ text-decoration:underline; }

/* Accessibilité (label invisibles) */
.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0; }


/* === Services — préambule */
.svc-hero{
  background:#F5F8FC; border-bottom:1px solid #e9eef6;
  padding:56px 0 36px;
}
.svc-hero .chip{
  display:inline-block; background:#fff; border:1px solid #e5e7eb;
  border-radius:999px; padding:.35rem .6rem; font-size:.9rem; color:#334155; margin-bottom:.8rem;
}
.svc-hero h1{ margin:0 0 .5rem; }
.svc-hero .lead{ color:#475569; max-width:860px; }

/* === Feature (Coaching Essentiel) */
.svc-feature{
  background:#fff; border:1px solid #e8eef5; border-radius:14px; padding:18px 16px;
  box-shadow:0 2px 12px rgba(10,37,64,.04);
}
.svc-feature__head{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-bottom:6px; }
.svc-feature__head .icon{ width:22px; height:22px; color:#2563EB; }
.svc-feature__head h2{ margin:0; }
.svc-feature__head .price{ margin-left:auto; color:#0a2540; font-weight:700; }
.svc-feature p{ margin:.25rem 0 .8rem; color:#475569; }
.svc-feature .cta{ display:flex; gap:.6rem; flex-wrap:wrap; }

/* === Grille des services */
.services-grid{
  display:grid; gap:14px; grid-template-columns:1fr;
}
@media(min-width:720px){ .services-grid{ grid-template-columns:repeat(2,1fr); } }
@media(min-width:1040px){ .services-grid{ grid-template-columns:repeat(3,1fr); } }

.card{
  background:#fff; border:1px solid #e8eef5; border-radius:12px; padding:14px;
  display:flex; flex-direction:column; gap:.4rem;
}
.card-head{ display:flex; align-items:center; gap:8px; }
.mini-icon{ width:18px; height:18px; color:#2563EB; opacity:.95; }
.card p{ margin:0; color:#475569; }
.card .link{ text-decoration:none; color:#1d4ed8; }
.card .link:hover{ text-decoration:underline; }

/* === Services complémentaires (pastel) */
.svc-addons{ background:#fafbfc; border-top:1px solid #eef2f7; }
.svc-addons .subtle{ text-align:center; margin:0 0 1rem; }
.addons-grid{
  display:grid; gap:12px; grid-template-columns:1fr;
  max-width:1100px; margin:0 auto;
}
@media(min-width:720px){ .addons-grid{ grid-template-columns:repeat(2,1fr); } }
.addon{
  background:#fff; border:1px solid #e6eef9; border-radius:12px; padding:14px;
  box-shadow:0 1px 6px rgba(10,37,64,.03);
}
.addon-head{ display:flex; align-items:center; gap:8px; margin-bottom:4px; }
.addon p{ margin:0; color:#475569; }

/* === Boutons (rappels) */
.btn.primary{ background:#3B82F6; color:#fff; border:1px solid #3B82F6; border-radius:.6rem; padding:.55rem .9rem; font-weight:600; }
.btn.primary:hover{ background:#2563EB; }
.btn.light{ background:#fff; color:#1d4ed8; border:1px solid #1d4ed8; border-radius:.6rem; padding:.55rem .9rem; font-weight:600; }
.btn.light:hover{ background:#f0f5ff; }

/* Note de contact */
.note{ background:#f7faff; border:1px solid #e1ecff; color:#0a2540; border-radius:10px; padding:12px; }
/* === Services — préambule */
.svc-hero{ background:#F5F8FC; border-bottom:1px solid #e9eef6; padding:56px 0 36px; }
.svc-hero .chip{ display:inline-block; background:#fff; border:1px solid #e5e7eb; border-radius:999px; padding:.35rem .6rem; font-size:.9rem; color:#334155; margin-bottom:.8rem; }
.svc-hero h1{ margin:0 0 .5rem; }
.svc-hero .lead{ color:#475569; max-width:860px; }

/* === Feature (Coaching Essentiel) */
.svc-feature{ background:#fff; border:1px solid #e8eef5; border-radius:14px; padding:18px 16px; box-shadow:0 2px 12px rgba(10,37,64,.04); }
.svc-feature__head{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-bottom:6px; }
.svc-feature__head .icon{ width:22px; height:22px; color:#2563EB; }
.svc-feature__head h2{ margin:0; }
.svc-feature__head .price{ margin-left:auto; color:#0a2540; font-weight:700; }
.svc-feature .intro{ margin:.25rem 0 .6rem; color:#475569; }
.svc-feature .bullets{ margin:.2rem 0 .8rem; padding-left:1.1rem; }
.svc-feature .bullets li{ margin:.15rem 0; }
.svc-feature .cta{ display:flex; gap:.6rem; flex-wrap:wrap; }

/* === Fiches détaillées */
.svc-stack{ display:grid; gap:14px; max-width:1000px; margin:0 auto; }
.svc-card{ background:#fff; border:1px solid #e8eef5; border-radius:12px; padding:16px; box-shadow:0 1px 8px rgba(10,37,64,.03); }
.svc-card__head{ display:flex; align-items:center; gap:8px; margin-bottom:2px; }
.mini-icon{ width:18px; height:18px; color:#2563EB; opacity:.95; }
.svc-card .intro{ color:#475569; margin:.2rem 0 .6rem; }
.svc-columns{ display:grid; gap:10px; grid-template-columns:1fr; }
@media(min-width:820px){ .svc-columns{ grid-template-columns:repeat(2,1fr); } }
.bullets{ padding-left:1.1rem; margin:0; }
.bullets li{ margin:.15rem 0; }

/* === Services complémentaires (pastel) */
.svc-addons {
  background: #f9fbff; /* pastel clair (même logique que page d'accueil) */
  border-top: 1px solid #eef2f7;
  padding: 48px 0;
}

.addons-stack {
  display: grid;
  gap: 20px;
  max-width: 1000px;
  margin: 0 auto;
}

.addon {
  background: #fdfefe; /* reste blanc mais posé sur un fond pastel */
  border: 1px solid #e6eef9;
  border-radius: 12px;
  padding: 18px 16px;
  box-shadow: 0 1px 6px rgba(10,37,64,.03);
}

.addon-head {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}

.addon h3 {
  margin: 0;
}

.addon .intro {
  margin: .2rem 0 .5rem;
  color: #475569;
}


/* Boutons (rappel) */
.btn.primary{ background:#3B82F6; color:#fff; border:1px solid #3B82F6; border-radius:.6rem; padding:.55rem .9rem; font-weight:600; }
.btn.primary:hover{ background:#2563EB; }
.btn.light{ background:#fff; color:#1d4ed8; border:1px solid #1d4ed8; border-radius:.6rem; padding:.55rem .9rem; font-weight:600; }
.btn.light:hover{ background:#f0f5ff; }

/* ===== Coaching Essentiel — mise en avant tarif ===== */
.svc-feature--highlight{
  border-color:#cfe2ff; box-shadow:0 6px 22px rgba(10,37,64,.06);
}

.svc-feature__top{
  display:flex; align-items:flex-start; gap:12px; margin-bottom:8px;
}
.svc-feature__title{ display:flex; align-items:center; gap:10px; }
.svc-feature__title .icon{ width:24px; height:24px; color:#2563EB; }
.svc-feature__title h2{ margin:0; }

/* Badge prix */
.price-badge{
  margin-left:auto; display:flex; flex-direction:column; align-items:center;
  min-width:110px; padding:8px 10px;
  border:2px solid #3B82F6; border-radius:12px;
  background:#F5FAFF; text-align:center;
}
.price-main{ font-weight:800; font-size:1.4rem; line-height:1; color:#0a2540; }
.price-sub{ font-size:.85rem; color:#1d4ed8; }

/* meta chips sous le titre */
.feature-meta{
  list-style:none; padding:0; margin:4px 0 10px; display:flex; gap:8px; flex-wrap:wrap;
}
.feature-meta li{
  font-size:.92rem; color:#1f3245; background:#fff; border:1px solid #e1e9f5;
  border-radius:999px; padding:.25rem .55rem;
}

/* atouts en barre */
.feature-highlights{
  display:flex; gap:10px; flex-wrap:wrap; margin:.2rem 0 .8rem;
  color:#0a2540;
}
.feature-highlights span{
  background:#f0f6ff; border:1px solid #d7e6ff; border-radius:10px; padding:.3rem .55rem;
  font-size:.93rem;
}

/* responsive */
@media (max-width:720px){
  .price-badge{ min-width:96px; padding:6px 8px; }
  .price-main{ font-size:1.2rem; }
}

.services-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
  gap: 1.5rem;
  margin-top: 2rem;
}

.service-card {
  border-radius: 12px;
  padding: 1.5rem;
  background: #f9fafb;
  box-shadow: 0 2px 6px rgba(0,0,0,0.05);
}

.pastel-blue {
  background: #e8f0fe; /* Bleu pastel clair */
}

.pastel-green {
  background: #e6f7ef; /* Vert pastel clair */
}

.service-card h3 {
  margin-bottom: 0.5rem;
  font-weight: 600;
}

.service-card ul {
  margin-top: 0.75rem;
  padding-left: 1.2rem;
}

/* === HERO Services */
.svc-hero{ background:#F5F8FC; border-bottom:1px solid #e9eef6; padding:56px 0 36px; }
.svc-hero .chip{ display:inline-block; background:#fff; border:1px solid #e5e7eb; border-radius:999px; padding:.35rem .6rem; font-size:.9rem; color:#334155; margin-bottom:.8rem; }
.svc-hero h1{ margin:0 0 .5rem; }
.svc-hero .lead{ color:#475569; max-width:860px; }

/* === Feature (Coaching Essentiel) — très marqué */
.svc-feature{ background:#fff; border:1px solid #e8eef5; border-radius:14px; padding:18px 16px; box-shadow:0 2px 12px rgba(10,37,64,.04); }
.svc-feature--highlight{ border-color:#cfe2ff; box-shadow:0 6px 22px rgba(10,37,64,.06); }
.svc-feature__top{ display:flex; align-items:flex-start; gap:12px; margin-bottom:8px; }
.svc-feature__title{ display:flex; align-items:center; gap:10px; }
.svc-feature__title .icon{ width:24px; height:24px; color:#2563EB; }
.svc-feature__title h2{ margin:0; }
.svc-feature__title .flag{ margin-left:8px; font-size:.8rem; font-weight:700; color:#1d4ed8; background:#edf4ff; border:1px solid #cfe2ff; border-radius:999px; padding:.15rem .5rem; }
.price-badge{ margin-left:auto; display:flex; flex-direction:column; align-items:center; min-width:110px; padding:8px 10px; border:2px solid #3B82F6; border-radius:12px; background:#F5FAFF; text-align:center; }
.price-main{ font-weight:800; font-size:1.4rem; line-height:1; color:#0a2540; }
.price-sub{ font-size:.85rem; color:#1d4ed8; }
.feature-meta{ list-style:none; padding:0; margin:4px 0 10px; display:flex; gap:8px; flex-wrap:wrap; }
.feature-meta li{ font-size:.92rem; color:#1f3245; background:#fff; border:1px solid #e1e9f5; border-radius:999px; padding:.25rem .55rem; }
.svc-feature .intro{ margin:.2rem 0 .6rem; color:#475569; }
.feature-highlights{ display:flex; gap:10px; flex-wrap:wrap; margin:.1rem 0 .8rem; color:#0a2540; }
.feature-highlights span{ background:#f0f6ff; border:1px solid #d7e6ff; border-radius:10px; padding:.3rem .55rem; font-size:.93rem; }
.svc-feature .cta{ display:flex; gap:.6rem; flex-wrap:wrap; }

/* === Fiches détaillées */
.svc-stack{ display:grid; gap:14px; max-width:1000px; margin:0 auto; }
.svc-card{ background:#fff; border:1px solid #e8eef5; border-radius:12px; padding:16px; box-shadow:0 1px 8px rgba(10,37,64,.03); }
.svc-card__head{ display:flex; align-items:center; gap:8px; margin-bottom:2px; }
.mini-icon{ width:18px; height:18px; color:#2563EB; opacity:.95; }
.svc-card .intro{ color:#475569; margin:.2rem 0 .6rem; }
.svc-columns{ display:grid; gap:10px; grid-template-columns:1fr; }
@media(min-width:820px){ .svc-columns{ grid-template-columns:repeat(2,1fr); } }
.bullets{ padding-left:1.1rem; margin:0; }
.bullets li{ margin:.15rem 0; }

/* === Services complémentaires — PASTEL identique à l’accueil */
.svc-addons{ background:#f9fbff; border-top:1px solid #eef2f7; padding:48px 0; }
.svc-addons .subtle{ text-align:center; margin:0 0 1rem; }
.addons-grid{ display:grid; gap:16px; grid-template-columns:1fr; max-width:1000px; margin:0 auto; }
@media(min-width:860px){ .addons-grid{ grid-template-columns:repeat(2,1fr); } }
.addon{ border-radius:14px; padding:18px 16px; border:1px solid transparent; }
.addon .intro{ margin:.1rem 0 .4rem; color:#475569; }

/* pastels (matching homepage) */
.pastel-blue  { background:#e8f0fe; border-color:#dbe7ff; }
.pastel-green { background:#e6f7ef; border-color:#d6f1e3; }

.addon-head{ display:flex; align-items:center; gap:8px; margin-bottom:6px; }
.addon-head h3{ margin:0; }

/* Boutons (rappel) */
.btn.primary{ background:#3B82F6; color:#fff; border:1px solid #3B82F6; border-radius:.6rem; padding:.55rem .9rem; font-weight:600; }
.btn.primary:hover{ background:#2563EB; }
.btn.light{ background:#fff; color:#1d4ed8; border:1px solid #1d4ed8; border-radius:.6rem; padding:.55rem .9rem; font-weight:600; }
.btn.light:hover{ background:#f0f5ff; }

/* Responsive prix */
@media (max-width:720px){
  .price-badge{ min-width:96px; padding:6px 8px; }
  .price-main{ font-size:1.2rem; }
}

/* === Blog – cohérence avec la DA === */
.blog-tools{ margin-top:14px; }
.blog-tools .tools-row{ display:flex; gap:10px; flex-wrap:wrap; }
.blog-tools input[type="search"],
.blog-tools select{
  min-height:42px; padding:0 12px; border:1px solid #dfe7f1; border-radius:10px; background:#fbfdff; font:inherit;
}
.blog-tools input[type="search"]{ flex:1 1 260px; }
.blog-tools .tools-active{ display:flex; align-items:center; gap:8px; margin-top:8px; color:#475569; }
.chip.small{ padding:.2rem .45rem; font-size:.8rem; }

.blog-grid{
  display:grid; gap:14px;
  grid-template-columns: 1fr;
}
@media(min-width:720px){ .blog-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media(min-width:1040px){ .blog-grid{ grid-template-columns: repeat(3, minmax(0,1fr)); } }

.post-card{
  background:#fff; border:1px solid #e8eef5; border-radius:14px; padding:14px;
  box-shadow:0 2px 12px rgba(10,37,64,.04); display:flex; flex-direction:column; gap:.5rem;
}
.post-card .post-head h2{ margin:.1rem 0 .2rem; font-size:1.05rem; }
.post-card .post-head h2 a{ color:#0a2540; text-decoration:none; }
.post-card .post-head h2 a:hover{ text-decoration:underline; }
.post-card .meta{ color:#64748b; font-size:.9rem; display:flex; gap:8px; align-items:center; }
.post-card .excerpt{ color:#475569; margin:.1rem 0 .4rem; min-height:3.5em; }
.post-card .tags{ display:flex; gap:6px; flex-wrap:wrap; list-style:none; padding:0; margin:.1rem 0; }
.post-card .tags a{
  display:inline-block; background:#f5f8fc; border:1px solid #e1e9f5; border-radius:999px; padding:.25rem .55rem;
  font-size:.86rem; color:#1d4ed8; text-decoration:none;
}
.post-card .tags a:hover{ background:#eff6ff; }
.card-cta{ margin-top:auto; display:flex; justify-content:flex-end; }

/* Bouton “ghost” */
.btn.ghost{
  background:#fff; color:#1f2937; border:1px solid #d7e3f0; border-radius:10px; padding:.45rem .7rem; text-decoration:none;
}
.btn.ghost:hover{ background:#f5f8fc; }

/* Pagination */
.pagination{
  display:flex; justify-content:center; align-items:center; gap:10px;
  margin-top:18px; color:#475569;
}
.pagination .page{
  background:#fff; border:1px solid #dfe7f1; border-radius:10px; padding:.4rem .7rem; text-decoration:none; color:#0a2540;
}
.pagination .page:hover{ background:#f5f8fc; }
.pagination .page.disabled{ pointer-events:none; opacity:.45; }
.pagination .current{ font-weight:700; color:#0a2540; }
.pagination .sep{ width:10px; height:1px; background:#e3e9f3; display:inline-block; }

/* === Article détail === */
.post-meta{
  display:flex; gap:8px; align-items:center; color:#64748b; margin-top:6px;
}
.tags{ list-style:none; padding:0; margin:10px 0 0; display:flex; gap:8px; flex-wrap:wrap; }
.tags li a{
  display:inline-block; background:#f5f8fc; border:1px solid #e1e9f5; border-radius:999px;
  padding:.25rem .55rem; font-size:.86rem; color:#1d4ed8; text-decoration:none;
}
.tags li a:hover{ background:#eff6ff; }

/* prose lisible pour le corps */
.prose{ color:#0a2540; }
.prose p{ line-height:1.75; margin: .7rem 0; color:#374151; }
.prose h2{ font-size:1.35rem; margin:1.2rem 0 .4rem; }
.prose h3{ font-size:1.15rem; margin:1rem 0 .3rem; }
.prose ul, .prose ol{ padding-left:1.25rem; margin:.6rem 0; }
.prose li{ margin:.25rem 0; }
.prose a{ color:#1d4ed8; text-decoration:underline; }

/* CTA Coaching Essentiel */
.cta-feature{
  margin:22px 0; padding:14px; border:1px solid #cfe2ff; background:#F5FAFF;
  border-radius:14px; box-shadow:0 4px 18px rgba(10,37,64,.05);
}
.cta-feature__content{ display:flex; align-items:flex-start; gap:12px; }
.cta-left{ display:flex; align-items:flex-start; gap:10px; }
.cta-left .icon{ width:22px; height:22px; color:#2563EB; margin-top:2px; }
.cta-feature h3{ margin:0 0 2px; }
.cta-feature p{ margin:0; color:#475569; }
.cta-actions{ margin-top:10px; display:flex; gap:10px; flex-wrap:wrap; }

/* badge prix réutilisé en version compacte */
.price-badge.small{ min-width:96px; padding:6px 8px; margin-left:auto; }
.price-badge.small .price-main{ font-size:1.2rem; }

/* Navigation prev/next */
.post-nav{ display:flex; justify-content:space-between; align-items:center; margin:18px 0 4px; }
.post-nav .nav-link{ color:#0a2540; text-decoration:none; border-bottom:1px dashed #c7d6ea; }
.post-nav .nav-link:hover{ color:#1d4ed8; border-color:#a7c3ec; }

/* Section liés */
.related{ margin-top:24px; }
.related h3{ margin-bottom:10px; }

/* === Testimonials (Avis clients) === */
.testimonials {
  background: #f5f8fc;
  padding: 48px 0;
  border-top: 1px solid #e5ebf3;
}

.testimonials h2 {
  text-align: center;
  margin-bottom: 24px;
}

.testimonial-track {
  display: flex;
  gap: 20px;
  overflow-x: auto;
  scroll-behavior: smooth;
  padding-bottom: 10px;
}

.testimonial-track::-webkit-scrollbar {
  display: none;
}

.testimonial {
  min-width: 280px;
  max-width: 340px;
  flex: 0 0 auto;
  background: #fff;
  border: 1px solid #e0e6f0;
  border-radius: 12px;
  padding: 18px;
  box-shadow: 0 2px 8px rgba(10,37,64,.05);
}

.testimonial p {
  font-style: italic;
  color: #374151;
  margin: 0 0 12px;
}

.testimonial .author {
  font-size: .9rem;
  font-weight: 600;
  color: #1d4ed8;
}


/* ===== Correction définitive icônes ===== */

/* Boîte autour de l’icône */
.svc-card__head .mini-icon,
.addon-head .mini-icon {
  width: 18px !important;    /* Taille fixe */
  height: 18px !important;
  flex: 0 0 18px !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  margin-top: 3px;
  color: #2563eb;
}

/* SVG à l’intérieur */
.svc-card__head .mini-icon svg,
.addon-head .mini-icon svg {
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  min-height: 18px !important;
  max-width: 18px !important;
  max-height: 18px !important;
  flex-shrink: 0 !important;
}

/* Titre à côté */
.svc-card__head h3,
.addon-head h3 {
  margin: 0;
  line-height: 1.3;
}

.service-card svg {
  width: 22px;
  height: 22px;
  flex-shrink: 0;
  margin-right: 8px;
}

.service-card.featured svg {
  width: 22px !important;
  height: 22px !important;
}

.service-card p {
  margin-bottom: 1rem; /* ajoute de l’air sous le texte */
}

.service-card .btn {
  margin-top: auto; /* pousse le bouton en bas de la carte */
}
.svc-section{
  --pad: clamp(18px, 3vw, 28px);
  --radius: 14px;
  --ring: 1px solid rgba(20,43,79,.10);
  padding: calc(var(--pad) * 1.25) var(--pad);
  border-radius: var(--radius);
  border: var(--ring);
  margin: 42px 0;
  position: relative;
}
.svc-section + .svc-section{ margin-top: 56px; }

.svc-section--coach{
  background: linear-gradient(180deg,#f5f9ff 0%,#f8fbff 60%,#ffffff 100%);
  border-color: rgba(44,96,188,.18);
  box-shadow: inset 0 -56px 56px -56px rgba(44,96,188,.10);
}
.svc-section--build{
  background: linear-gradient(180deg,#f7fff9 0%,#fbfffd 60%,#ffffff 100%);
  border-color: rgba(22,132,86,.18);
  box-shadow: inset 0 -56px 56px -56px rgba(22,132,86,.10);
}

.svc-head{ display:flex; align-items:center; gap:14px; margin-bottom:22px; }
.svc-badge{
  font: 600 12px/1.2 Inter,system-ui;
  letter-spacing:.02em; text-transform:uppercase;
  padding:6px 10px; border-radius:999px;
  border:1px solid currentColor; opacity:.75;
}
.svc-title{ font: 800 clamp(20px,2.8vw,28px)/1.2 Inter,system-ui; margin:0; }

.svc-grid{ display:grid; gap:16px; grid-template-columns: repeat(12,1fr); }
.svc-grid > .card{ grid-column: span 6; }
@media (max-width: 860px){ .svc-grid > .card{ grid-column: 1 / -1; } }

.card .card-title{ display:flex; align-items:center; gap:10px; font-weight:700; }
.card .card-title svg{ width:18px; height:18px; color:#11284c; opacity:.95; }
.chip{ margin-left:.4rem; font:600 12px/1 Inter,system-ui; padding:4px 8px; border-radius:999px; border:1px solid rgba(0,0,0,.12); }
.card .card-actions{ margin-top:14px; display:flex; gap:10px; flex-wrap:wrap; }

.card--cta-reserver .btn.primary{ background:#2463e9; }
.card--cta-contact  .btn.primary{ background:#0e7d53; }

.card.pastel-blue   { background:#eef5ff; border-color:#d9e7ff; }
.card.pastel-green  { background:#ecfbf2; border-color:#d2f3df; }
.card.pastel-purple { background:#f4edfc; border-color:#e6dbfb; }

.svc-sep{ height:1px; margin:38px 0 -6px; background:linear-gradient(90deg,transparent,rgba(0,0,0,.10),transparent); border-radius:1px; }

/* ===== Hero plus aéré + séparation visuelle ===== */
.hero--soft {
  background: linear-gradient(180deg, #f6f9ff 0%, #ffffff 70%);
  border-bottom: 1px solid rgba(0,0,0,.06);
  padding: clamp(36px, 6vw, 72px) 0 clamp(24px, 4vw, 40px);
}
.hero--soft .actions { margin-top: 16px; display:flex; gap:10px; flex-wrap:wrap; }
.hero--soft .eyebrow { color:#52607a; font-weight:600; letter-spacing:.02em; }

/* ===== Sections de services (déjà posées chez toi, on complète juste) ===== */
.svc-section{
  --pad: clamp(18px, 3vw, 28px);
  --radius: 14px;
  --ring: 1px solid rgba(20,43,79,.10);
  padding: calc(var(--pad) * 1.25) var(--pad);
  border-radius: var(--radius);
  border: var(--ring);
  margin: 42px 0;
}
.svc-section--coach{ background: linear-gradient(180deg,#f5f9ff 0%,#f8fbff 70%,#fff 100%); border-color: rgba(44,96,188,.18); }
.svc-section--build{ background: linear-gradient(180deg,#f7fff9 0%,#fbfffd 70%,#fff 100%); border-color: rgba(22,132,86,.18); }
.svc-section--assist{ background: linear-gradient(180deg,#fbf6ff 0%,#ffffff 70%); border-color: rgba(125,63,172,.18); }

.svc-head{ display:flex; align-items:center; gap:14px; margin-bottom:22px; }
.svc-badge{ font:600 12px/1.2 Inter,system-ui; letter-spacing:.02em; text-transform:uppercase; padding:6px 10px; border-radius:999px; border:1px solid currentColor; opacity:.75; }
.svc-title{ font:800 clamp(20px,2.8vw,28px)/1.2 Inter,system-ui; margin:0; }

.svc-grid{ display:grid; gap:16px; grid-template-columns: repeat(12,1fr); }
.svc-grid > .card{ grid-column: span 6; }
.card--span-12 { grid-column: 1 / -1; } /* carte mise en avant pleine largeur */

@media (max-width: 860px){
  .svc-grid > .card, .card--span-12 { grid-column: 1 / -1; }
}

/* Cartes */
.card .card-title{ display:flex; align-items:center; gap:10px; font-weight:700; }
.card .card-title svg{ width:18px; height:18px; color:#11284c; opacity:.95; }
.card .card-actions{ margin-top:14px; display:flex; gap:10px; flex-wrap:wrap; }
.chip{ margin-left:.4rem; font:600 12px/1 Inter,system-ui; padding:4px 8px; border-radius:999px; border:1px solid rgba(0,0,0,.12); }

/* Thèmes CTA */
.card--cta-reserver .btn.primary{ background:#2463e9; }
.card--cta-contact  .btn.primary{ background:#0e7d53; }

/* Pastels techniques */
.card.pastel-blue   { background:#eef5ff; border:1px solid #d9e7ff; border-radius:14px; }
.card.pastel-green  { background:#ecfbf2; border:1px solid #d2f3df; border-radius:14px; }
.card.pastel-purple { background:#f4edfc; border:1px solid #e6dbfb; border-radius:14px; }

/* Séparateur visuel entre grandes sections */
.svc-sep{ height:1px; margin:38px 0 -6px; background:linear-gradient(90deg,transparent,rgba(0,0,0,.10),transparent); border-radius:1px; }

/* ——— Dividers / sections ——— */
.section {
  margin: 72px 0;
  position: relative;
}
.section .section-head {
  display:flex; align-items:center; gap:.75rem; margin-bottom:28px;
}
.section .section-kicker {
  font-size:.75rem; font-weight:600; letter-spacing:.04em;
  padding:.25rem .6rem; border:1px solid var(--line);
  border-radius:999px; color:var(--text-weak); background:var(--bg);
}
.section h2 { margin:0; font-size:1.7rem; line-height:1.2; }

/* divider fin */
.divider {
  display:flex; align-items:center; gap:.75rem; margin:40px 0 28px;
}
.divider::before, .divider::after {
  content:""; flex:1 1; height:1px; background:linear-gradient(90deg, transparent, var(--line), transparent);
}
.divider .dot {
  width:8px; height:8px; border-radius:50%;
  background:var(--accent-soft);
  box-shadow:0 0 0 3px color-mix(in srgb, var(--accent-soft) 25%, transparent);
}

/* ——— Feature rows (alternance) ——— */
.feature {
  display:grid; grid-template-columns: 1.3fr .9fr; gap:28px;
  align-items:center; background:var(--surface);
  border:1px solid var(--line); border-radius:14px; padding:24px;
}
.feature + .feature { margin-top:18px; }
.feature.reverse { grid-template-columns:.9fr 1.3fr; }
.feature .copy p { margin:.5rem 0 0; color:var(--text-weak); }
.feature .actions { margin-top:14px; display:flex; gap:.5rem; flex-wrap:wrap; }

/* illu légère */
.feature .illu {
  position:relative; aspect-ratio:4/3; border-radius:12px;
  background:var(--bg);
  overflow:hidden; border:1px dashed color-mix(in srgb, var(--line) 60%, transparent);
}
.feature .spark {
  position:absolute; inset:8% 10% auto auto; width:56%; opacity:.25;
  color:var(--accent);
}
.feature .mesh {
  position:absolute; inset:auto -10% -20% -10%; height:180%;
  opacity:.12; color:var(--text-weak);
}

/* ——— grille cartes ——— */
.cards-2 { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media (max-width: 880px){ .feature{grid-template-columns:1fr;} .feature.reverse{grid-template-columns:1fr;} .cards-2{grid-template-columns:1fr;} }

/* ——— icônes (sprite) ——— */
.icon {
  width:18px; height:18px; display:inline-block; vertical-align:-3px; color:var(--accent);
}
.card-title .icon { margin-right:.5rem; }

/* ——— CTA variations ——— */
.button.ghost { background:#fff; border:1px solid var(--accent-lite); color:var(--accent-ink); }
.button.success { background: var(--green); border-color:transparent; color:#fff; }

:root{
  --surface: #fff; /* carte */
  --accent: #1e63ff;
  --accent-ink:#1952cc;
  --accent-lite: color-mix(in srgb, var(--accent) 18%, #cbd5e1);
  --accent-soft: color-mix(in srgb, var(--accent) 12%, #e6efff);
  --green:#16a34a;
}

/* --- Taille icônes harmonisée --- */
.icon {
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
  color: var(--slate-700);
  opacity: .9;
  transform: translateY(1px);
}

/* Bolt un peu plus visible mais pas énorme */
.card-title .icon use[href="#icon-bolt"] {
  color: var(--blue-600);
  opacity: .9;
}

/* --- Espacement entre contenu et boutons dans les cartes --- */
.section .card .actions {
  margin-top: 10px;
}

/* --- Séparateurs visuels entre sections --- */
.divider {
  display: flex;
  justify-content: center;
  margin: 28px 0;
}
.divider .dot {
  width: 56px;
  height: 8px;
  border-radius: 999px;
  background: var(--slate-200);
  box-shadow: 0 0 0 6px rgba(148,163,184,.12);
}

/* --- Cartes pastel (services techniques & asso) --- */
.pastel-blue { background: var(--blue-100); border-color: rgba(2,6,23,.06); }
.pastel-green { background: var(--green-50); border-color: rgba(2,6,23,.06); }
.pastel-lilac { background: var(--lilac-50); border-color: rgba(2,6,23,.06); }

/* --- Boutons Contact en vert (services complémentaires & asso) --- */
.button.success {
  --bg: #106c3b;
  color: #fff;
  border: none;
  box-shadow: 0 6px 14px rgba(16,108,59,.15);
}
.button.success:hover {
  background: #0c5a31;
}

/* ========================
   Fallback variables
   ======================== */
:root{
  --blue-600:#2563eb;
  --blue-700:#1d4ed8;
  --green-600:#0e9f6e;
  --green-700:#0c5a31;
  --slate-900:#0f172a;
  --slate-800:#1e293b;
  --slate-700:#334155;
  --slate-600:#475569;
  --slate-500:#64748b;
  --slate-400:#94a3b8;
  --slate-300:#cbd5e1;
  --slate-200:#e2e8f0;
  --slate-100:#f1f5f9;

  --blue-50:#e7efff;
  --green-50:#e8f6ef;
  --lilac-50:#f1effe;

  --radius:14px;
  --radius-lg:18px;
  --shadow:0 6px 22px rgba(2,6,23,.06);
}

/* ========================
   Container & typographie légère
   ======================== */
.container{max-width:1120px;margin:0 auto;padding:24px 16px;}
h1,h2,h3{color:var(--slate-900)}
p{color:var(--slate-700)}
.eyebrow{color:#52607a;font-weight:600;letter-spacing:.02em}

/* ========================
   Sections, entêtes & grilles
   ======================== */
.svc-section{margin:36px 0}
.svc-head{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.svc-badge{
  font:600 12px/1.1 Inter,system-ui; letter-spacing:.03em; text-transform:uppercase;
  padding:6px 10px; border-radius:999px; border:1px solid currentColor; opacity:.75;
}
.svc-title{margin:0}

.svc-grid{display:grid;gap:16px;grid-template-columns:repeat(12,1fr)}
/* 2 colonnes par défaut */
.svc-grid > .card{grid-column:span 6}
@media (max-width:960px){ .svc-grid{grid-template-columns:repeat(12,1fr)} .svc-grid > .card{grid-column:1 / -1} }

/* Séparateur doux utilisé entre sections */
.divider{display:flex;justify-content:center;margin:28px 0}
.divider .dot{
  width:56px;height:8px;border-radius:999px;background:var(--slate-200);
  box-shadow:0 0 0 6px rgba(148,163,184,.12)
}

/* ========================
   Cartes
   ======================== */
.card{
  background:#fff; border:1px solid var(--slate-200); border-radius:var(--radius);
  padding:18px; box-shadow:var(--shadow);
}
.card-title{
  display:flex; align-items:center; gap:10px;
  margin:0 0 8px; font-weight:700; color:var(--slate-900);
}
.card p{margin:0 0 8px; line-height:1.55}

/* Pastels (teaser prestations / bloc asso) */
.pastel-blue  { background:var(--blue-50);  border-color:rgba(2,6,23,.06) }
.pastel-green { background:var(--green-50); border-color:rgba(2,6,23,.06) }
.pastel-lilac { background:var(--lilac-50); border-color:rgba(2,6,23,.06) }

/* Petites listes (Coaching Essentiel) */
ul.min{margin:.35rem 0 .5rem 1.1rem;color:var(--slate-700)}
ul.min li{margin:.15rem 0}

/* Prix / chip */
.pill{
  margin-left:8px; font-weight:600; font-size:.8rem;
  color:var(--blue-600); background:#fff; border:1px solid var(--slate-200);
  border-radius:999px; padding:4px 8px;
}

/* ========================
   Icônes (sprite)
   ======================== */
.icon{
  width:18px; height:18px; flex:0 0 18px; color:var(--slate-700);
  opacity:.9; transform:translateY(1px);
}
/* bolt un peu plus visible, sans être énorme */
.card-title .icon use[href="#icon-bolt"]{ color:var(--blue-600); opacity:.95 }

/* ========================
   Boutons
   ======================== */
.button{
  --bg: var(--blue-600); --fg:#fff; --bd:transparent;
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 14px; border-radius:12px; font-weight:600;
  background:var(--bg); color:var(--fg); border:1px solid var(--bd);
  transition:transform .06s ease, background .2s ease, box-shadow .2s ease;
  box-shadow:0 6px 14px rgba(37,99,235,.15); text-decoration:none;
}
.button:hover{transform:translateY(-1px); background:var(--blue-700)}
.button:active{transform:translateY(0)}

.button.ghost{
  --bg:#fff; --fg:var(--slate-800); --bd:var(--slate-200);
  background:var(--bg); color:var(--fg); border-color:var(--bd); box-shadow:none;
}
.button.ghost:hover{background:var(--slate-100)}
.button.light{
  --bg:#fff; --fg:var(--blue-600); --bd:var(--blue-600);
  background:#fff; color:var(--blue-600); border:1px solid var(--blue-600); box-shadow:none;
}
.button.success{
  --bg:var(--green-600); --fg:#fff; --bd:transparent;
  background:var(--green-600); color:#fff; border:none;
  box-shadow:0 6px 14px rgba(16,108,59,.15);
}
.button.success:hover{background:var(--green-700)}

/* Alignement générique des groupes de boutons */
.actions{display:flex; gap:10px; flex-wrap:wrap}

/* ========================
   Hero (léger + texture)
   ======================== */
.hero{position:relative}
.hero .actions{margin-top:14px}

/* ========================
   Carousel d’avis (simple)
   ======================== */
#carousel-avis [data-slide]{animation:fadeIn .25s ease}
@keyframes fadeIn{from{opacity:.2; transform:translateY(4px)} to{opacity:1; transform:none}}
#prev-avis,#next-avis{min-width:40px; justify-content:center}

/* ========================
   Responsive fin
   ======================== */
@media (max-width:960px){
  .svc-head{flex-wrap:wrap}
  .svc-grid{gap:14px}
}
@media (max-width:540px){
  .pill{font-size:.78rem}
  .button{padding:9px 13px; border-radius:10px}
}

/* ===== Nouveau rythme éditorial ===== */
:root{
  --ink:#0f172a; --muted:#475569; --line:#e2e8f0;
  --blue:#2563eb; --blue-soft:#eef5ff;
  --green:#0e7d53; --green-soft:#ecfbf2;
  --lilac-soft:#f4edfc;
}

.container{max-width:1120px;margin:0 auto;padding:28px 16px;}

/* Titres + sous-titres */
.h-eyebrow{font:600 12px/1 Inter,system-ui;letter-spacing:.04em;text-transform:uppercase;color:#64748b;margin:0 0 8px}
.h1{font:800 clamp(28px,4vw,44px)/1.1 Inter,system-ui;color:var(--ink);margin:.2rem 0 .6rem}
.h2{font:800 clamp(22px,3vw,30px)/1.2 Inter,system-ui;color:var(--ink);margin:0}
.lead{color:var(--muted);max-width:70ch}

/* Swoops (séparateurs courbes) */
.swoop{position:relative;margin:44px 0 22px}
.swoop svg{display:block;width:100%;height:42px}
.swoop path{fill:none;stroke:var(--line);stroke-width:1}

/* Grilles éditoriales */
.mosaic{display:grid;gap:18px;grid-template-columns:repeat(12,1fr)}
.mosaic .card{grid-column:span 4}
.mosaic .card--lg{grid-column:span 7}
.mosaic .card--md{grid-column:span 5}
@media (max-width: 940px){ .mosaic .card,.mosaic .card--lg,.mosaic .card--md{grid-column:1 / -1}}

/* Cartes */
.card{
  background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px 18px 16px;
  box-shadow:0 10px 24px rgba(2,6,23,.05); position:relative; overflow:hidden;
}
.card.pastel-blue{background:var(--blue-soft);}
.card.pastel-green{background:var(--green-soft);}
.card.pastel-lilac{background:var(--lilac-soft);}
.card-title{display:flex;align-items:center;gap:10px;margin:0 0 8px;font-weight:800}
.card-title .icon{width:18px;height:18px;color:#1f2b45;opacity:.9}
.card p{color:var(--muted);margin:0 0 10px}
.card .actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}

/* Boutons */
.button{--bg:var(--blue);--fg:#fff;--bd:transparent;
  display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:12px;
  background:var(--bg);color:var(--fg);border:1px solid var(--bd);font-weight:700}
.button.ghost{--bg:#fff;--fg:var(--ink);--bd:var(--line)}
.button.success{--bg:var(--green)}
.button.light{--bg:#fff;--fg:var(--blue);--bd:var(--blue)}

/* Décors subtils (traits fins) */
.decoy{position:absolute;inset:auto -24px -24px auto;opacity:.10}
.decoy svg{width:180px;height:180px}

/* Bandes éditoriales (pas des cartes) */
.band{margin:40px 0 20px}
.band .kicker{display:inline-block;padding:6px 10px;border:1px solid var(--line);border-radius:999px;color:#64748b;font:600 12px/1 Inter,system-ui;letter-spacing:.04em;text-transform:uppercase;margin-bottom:8px}
.band h3{font:800 20px/1.25 Inter,system-ui;margin:4px 0 6px}
.band p{color:var(--muted);max-width:70ch}

/* Mini “liste check” */
.check{list-style:none;padding:0;margin:6px 0}
.check li{padding-left:20px;position:relative;margin:4px 0;color:var(--muted)}
.check li:before{content:"✓";position:absolute;left:0;top:0;color:var(--green);font-weight:800}

/* Témoignages en ruban (auto défilement) */
.ribbon{display:flex;gap:12px;overflow:auto;scroll-snap-type:x mandatory;padding-bottom:6px}
.ribbon .quote{scroll-snap-align:start;min-width:320px}
.quote blockquote{margin:0 0 8px;color:#334155}
.quote footer{color:#64748b}

/* -------- USP (Pourquoi me choisir ?) -------- */
.usp-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1.8rem;
  margin-top: 1.5rem;
}
.usp-item {
  background: #f9fafc;
  border-radius: 12px;
  padding: 1.5rem;
  box-shadow: 0 2px 6px rgba(0,0,0,0.05);
  transition: transform .2s;
}
.usp-item:hover {
  transform: translateY(-4px);
}
.usp-item h3 {
  font-size: 1.1rem;
  margin-bottom: .5rem;
  display: flex;
  align-items: center;
  gap: .5rem;
}
.usp-item .ico {
  width: 20px;
  height: 20px;
  color: var(--primary, #2563eb);
}

/* -------- Feature rows (les 3 chapitres) -------- */
.feature-list {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  margin-top: 1.5rem;
}
.feature-row {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
  border-bottom: 1px solid #e5e7eb;
  padding-bottom: 1.5rem;
}
.feature-ico {
  flex: 0 0 40px;
}
.feature-ico svg {
  width: 32px;
  height: 32px;
  color: var(--primary, #2563eb);
}
.feature-body h3 {
  margin: 0 0 .5rem;
  font-size: 1.25rem;
}
.feature-body p {
  margin: 0 0 .75rem;
}
.feature-body .row-cta {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
}

/* -------- Chapitres -------- */
.chapter {
  padding: 4rem 0;
}
.chapter.soft {
  background: #f7f9fc;
}
.chapter-title {
  margin-bottom: 1rem;
}
.kicker {
  display: block;
  font-size: .85rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: #64748b;
  margin-bottom: .4rem;
}
.pill {
  background: #e0f2fe;
  color: #0369a1;
  font-size: .75rem;
  padding: 2px 8px;
  border-radius: 999px;
  margin-left: .5rem;
}

/* -------- Testimonials -------- */
.testimonial-track {
  display: flex;
  gap: 1.2rem;
  overflow-x: auto;
  scroll-behavior: smooth;
  padding: 1rem 0;
}
.testimonial {
  flex: 0 0 300px;
  background: #fff;
  border-radius: 10px;
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
  padding: 1rem 1.2rem;
}
.testimonial blockquote {
  font-style: italic;
  margin: 0 0 .5rem;
}
.testimonial figcaption {
  font-size: .9rem;
  color: #475569;
}
