/* ---------- Design tokens ---------- */
:root{
  --ink:#0F172A;          /* titres */
  --ink-2:#334155;        /* texte */
  --muted:#64748B;        /* métas / détails */
  --bg:#FFFFFF;
  --bg-soft:#F8FAFC;
  --line:#E5E7EB;
  --accent:#6BBDA4;
  --accent-600:#34C896;

  /* Nouveaux accents complémentaires */
  --accent-2:#2563EB;      /* bleu doux */
  --accent-2-600:#1D4ED8;
  --accent-3:#F5E6D3;      /* beige clair pour fonds */
  --accent-3-ink:#7C6A55;  /* encre douce sur beige */

  --radius:12px;
  --shadow:0 8px 24px rgba(0,0,0,.06);
  --shadow-soft:0 4px 14px rgba(0,0,0,.04);

  --maxw:1200px;
  --gutter:40px;

  --h1:clamp(32px, 4vw, 48px); --h2:clamp(22px, 3vw, 32px); --h3:clamp(17px, 1.8vw, 22px); --p:clamp(16px, 1.2vw, 18px);

  /* Gradients utilitaires */
  --bg-gradient-1: radial-gradient(1200px 600px at 10% -10%, rgba(37,99,235,.08), transparent 55%), radial-gradient(1000px 500px at 110% 10%, rgba(107,189,164,.10), transparent 45%);
  --bg-gradient-2: linear-gradient(180deg, #ffffff 0%, #f8fafc 60%, #f1f5f9 100%);
  --bg-gradient-3: radial-gradient(800px 400px at -10% 90%, rgba(245,230,211,.5), transparent 50%), radial-gradient(800px 400px at 110% -10%, rgba(37,99,235,.08), transparent 55%);
}

/* ---------- Reset + base ---------- */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--ink-2); background:var(--bg); line-height:1.7; font-size:var(--p);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img{max-width:100%; height:auto; display:block}
a{color:var(--ink); text-decoration:none}
a:hover{color:var(--accent)}

/* Liens dans le contenu — visibles uniquement au survol */
main p a,
main li a,
main .faq__item p a,
main .garantie-item__text a,
main .methode__step-description a,
main .section__intro a,
main .hero__subtitle a,
main .contact__promise a {
  color: var(--ink-2) !important;
  text-decoration: none !important;
}
main p a:hover,
main li a:hover,
main .faq__item p a:hover,
main .garantie-item__text a:hover,
main .methode__step-description a:hover,
main .section__intro a:hover,
main .hero__subtitle a:hover,
main .contact__promise a:hover {
  color: var(--accent) !important;
  text-decoration: underline !important;
  text-underline-offset: 3px;
  text-decoration-color: var(--accent);
}

/* ---------- Layout helpers ---------- */
.container{max-width:var(--maxw); padding:0 var(--gutter); margin:0 auto}
section{padding:96px 0}
.section__title{font-size:var(--h2); color:var(--ink); margin:0 0 20px; font-weight:700; text-align:center}
.section--soft{background:var(--bg-soft)}
.section--tight{padding-top:56px; padding-bottom:56px}

/* subtle separators */
.section__divider{height:1px; background:var(--line); margin:56px 0}

/* ---------- Breadcrumbs ---------- */
.breadcrumbs{padding:16px 0; background:var(--bg-soft); border-bottom:1px solid var(--line)}
.breadcrumbs__list{display:flex; align-items:center; gap:8px; list-style:none; margin:0; padding:0; flex-wrap:wrap}
.breadcrumbs__item{display:flex; align-items:center; gap:8px; font-size:14px; color:var(--muted)}
.breadcrumbs__item:not(:last-child)::after{content:"›"; color:var(--muted); font-size:16px; font-weight:400}
.breadcrumbs__link{color:var(--muted); text-decoration:none; transition:color .2s ease}
.breadcrumbs__link:hover{color:var(--accent); text-decoration:underline}
.breadcrumbs__current{color:var(--ink-2); font-weight:500}

/* ---------- Header sticky ---------- */
.nav{position:sticky; top:0; z-index:1000; background:rgba(255,255,255,.9); backdrop-filter:blur(8px); border-bottom:1px solid rgba(226,232,240,.6)}
.nav.is-scrolled{box-shadow:0 10px 30px rgba(15,23,42,.05)}
.nav__container{display:flex; align-items:center; justify-content:space-between; max-width:var(--maxw); padding:14px var(--gutter); margin:0 auto}
.nav__logo-text{font-weight:700; letter-spacing:.2px; color:var(--ink)}
.nav__menu{display:flex; gap:22px; list-style:none; margin:0; padding:0}
.nav__item{position:relative}
.nav__link{color:var(--ink-2); font-weight:500; display:block; padding:8px 0}
.nav__link:hover{color:var(--ink)}
.nav__link--highlight{color:var(--accent); font-weight:600}
.nav__link--highlight:hover{color:var(--accent-600)}
/* dropdown */
.nav__item--dropdown{position:relative}
.nav__dropdown{position:absolute; top:100%; left:0; min-width:280px; background:#fff; border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow); list-style:none; margin:8px 0 0; padding:8px 0; opacity:0; visibility:hidden; transform:translateY(-10px); transition:all .2s ease; z-index:100}
.nav__item--dropdown:hover .nav__dropdown{opacity:1; visibility:visible; transform:translateY(0)}
.nav__dropdown li{padding:0}
.nav__dropdown-link{display:block; padding:12px 20px; color:var(--ink-2); font-weight:500; font-size:15px; transition:background .2s ease, color .2s ease}
.nav__dropdown-link:hover{background:var(--bg-soft); color:var(--ink); text-decoration:none}
/* burger */
.nav__burger{display:none; background:none; border:0; cursor:pointer}
.nav__burger-line{display:block; width:22px; height:2px; background:var(--ink); margin:5px 0}

/* ---------- Hero ---------- */
.hero{position:relative; padding:120px 0; overflow:hidden}
.hero::before,
.hero::after{
  content:""; position:absolute; inset:auto auto auto auto; z-index:-1; border-radius:999px; filter:blur(40px); opacity:.5;
}
.hero::before{width:320px; height:320px; right:-120px; top:-100px; background:linear-gradient(135deg,#eef2ff,#f1f5f9)}
.hero::after{width:280px; height:280px; left:-120px; bottom:-120px; background:linear-gradient(135deg,#f1f5f9,#e2e8f0)}
.hero__content{max-width:860px; margin:0 auto; text-align:center}
.hero__title{font-size:var(--h1); line-height:1.15; color:var(--ink); margin:0 0 16px; font-weight:700}
.hero__subtitle{color:var(--ink-2); font-size:20px; margin:0 auto 28px; max-width:720px}
.hero__links{display:flex; gap:18px; justify-content:center; margin-bottom:12px}
.hero__link{font-size:14px; color:var(--muted)}
.hero__link:hover{color:var(--accent)}
.hero__benefits{list-style:none; padding:0; margin:0 0 32px; max-width:720px; margin-left:auto; margin-right:auto; text-align:left}
.hero__benefits li{padding:12px 0 12px 32px; position:relative; color:var(--ink-2); font-size:17px; line-height:1.6}
.hero__benefits li::before{content:"✓"; position:absolute; left:0; color:var(--accent); font-weight:700; font-size:18px}
.hero__cta{display:flex; gap:14px; justify-content:center; flex-wrap:wrap}

/* ---------- Hero Split (index) ---------- */
.hero--split{padding:100px 0 80px; background: var(--bg-gradient-2)}
.hero--split::before{width:500px; height:500px; right:-150px; top:-150px; background:radial-gradient(circle, rgba(107,189,164,.18) 0%, rgba(37,99,235,.08) 60%, transparent 80%); opacity:1}
.hero--split::after{width:400px; height:400px; left:-150px; bottom:-100px; background:radial-gradient(circle, rgba(37,99,235,.07) 0%, transparent 70%); opacity:1}

.hero__split{display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center}

/* Colonne texte */
.hero__col-text{display:flex; flex-direction:column; gap:0}

/* Badge de confiance */
.hero__trust-badge{
  display:inline-flex; align-items:center; gap:10px;
  background:rgba(107,189,164,.10); border:1px solid rgba(107,189,164,.25);
  color:var(--accent-600); font-size:13px; font-weight:600;
  padding:8px 16px; border-radius:999px; margin-bottom:24px; width:fit-content;
}
.hero__trust-dot{
  width:8px; height:8px; border-radius:50%;
  background:var(--accent); flex-shrink:0;
  box-shadow:0 0 0 3px rgba(107,189,164,.25);
  animation:pulse-dot 2s ease-in-out infinite;
}
@keyframes pulse-dot{
  0%,100%{box-shadow:0 0 0 3px rgba(107,189,164,.25)}
  50%{box-shadow:0 0 0 6px rgba(107,189,164,.12)}
}

/* Titre split + gradient sur SEO */
.hero__title--split{
  font-size:clamp(36px, 4.5vw, 60px); line-height:1.1;
  color:var(--ink); margin:0 0 20px; font-weight:700; text-align:left;
}
.hero__title-gradient{
  background:linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.hero__subtitle--split{
  color:var(--ink-2); font-size:18px; line-height:1.7;
  margin:0 0 32px; text-align:left;
}
.hero__cta--split{justify-content:flex-start; margin-bottom:20px}
.hero--split .hero__links{justify-content:flex-start}

/* Colonne photo */
.hero__col-photo{display:flex; justify-content:center; align-items:center}
.hero__photo-wrap{position:relative; width:300px; height:300px; flex-shrink:0}
.hero__photo{
  width:300px; height:300px; object-fit:cover; object-position:top center;
  border-radius:50%;
  box-shadow:0 8px 32px rgba(15,23,42,.14), 0 0 0 4px rgba(107,189,164,.25);
}

/* Responsive hero split */
@media(max-width:900px){
  .hero__split{grid-template-columns:1fr; gap:40px}
  .hero__col-photo{order:-1}
  .hero__photo-wrap{width:180px; height:180px; margin:0 auto}
  .hero__photo{width:180px; height:180px}
  .hero__title--split{text-align:center; font-size:clamp(30px,6vw,44px)}
  .hero__subtitle--split{text-align:center}
  .hero__cta--split{justify-content:center}
  .hero--split .hero__links{justify-content:center}
}

/* Hero About - styles améliorés */
.hero--about{padding:140px 0 100px; background:linear-gradient(180deg, #f8fafc 0%, #ffffff 100%)}
.hero--about .hero__badges{display:flex; gap:12px; justify-content:center; margin-bottom:24px; flex-wrap:wrap}
.badge{display:inline-flex; align-items:center; padding:8px 16px; border-radius:20px; font-size:14px; font-weight:600; border:1px solid}
.badge--primary{background:rgba(107,189,164,.1); color:var(--accent-600); border-color:rgba(107,189,164,.2)}
.badge--secondary{background:rgba(37,99,235,.08); color:var(--accent-2-600); border-color:rgba(37,99,235,.15)}
.hero__title--large{font-size:56px; line-height:1.1; margin-bottom:12px}
.hero__tagline{font-size:22px; color:var(--accent); font-weight:600; margin:0 0 20px; letter-spacing:-.02em}
.hero--about .hero__subtitle{max-width:680px; margin:0 auto 40px; line-height:1.7}

/* Stats Hero */
.hero__stats{display:flex; gap:48px; justify-content:center; margin:40px 0; flex-wrap:wrap}
.stat-item{text-align:center}
.stat-item__number{font-size:48px; font-weight:700; color:var(--accent); line-height:1; margin-bottom:8px; background:linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text}
.stat-item__label{font-size:14px; color:var(--muted); font-weight:500; text-transform:uppercase; letter-spacing:.5px}

/* Hero Déclic Visibilité - H1 plus gros */
.hero__title--declic{font-size:56px; line-height:1.1; margin-bottom:24px; color:#f8fafc}
.hero__subtitle--declic{color:rgba(248,250,252,.92)}
.hero__title-line{display:block}

/* Espacement badges vers CTA */
.hero__badges{margin-bottom:32px}

/* ---------- Section Parcours (About) ---------- */
.parcours{padding:80px 0; background:var(--bg)}
.parcours__content{display:grid; grid-template-columns:1.2fr .8fr; gap:56px; align-items:start}
.parcours__text h2{font-size:var(--h2); color:var(--ink); margin:0 0 24px; font-weight:700}
.parcours__text p{color:var(--ink-2); line-height:1.7; margin-bottom:20px}
.parcours__list{list-style:none; padding:0; margin:20px 0}
.parcours__list li{padding:12px 0 12px 32px; position:relative; color:var(--ink-2); line-height:1.6}
.parcours__list li::before{content:"→"; position:absolute; left:0; color:var(--accent); font-weight:700; font-size:18px}
.parcours__image{display:flex; align-items:center; justify-content:center}
.parcours__placeholder{background:var(--bg-soft); border:2px dashed var(--line); border-radius:var(--radius); padding:60px 40px; text-align:center; color:var(--muted)}
.parcours__placeholder p{margin:8px 0}

/* ---------- Section Compétences (About) ---------- */
.competences{padding:80px 0; background:var(--bg-soft)}
.competences__grid{display:grid; grid-template-columns:repeat(3,1fr); gap:32px}
.competence-card{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:32px; box-shadow:var(--shadow); transition:transform .2s ease, box-shadow .2s ease; display:flex; flex-direction:column}
.competence-card:hover{transform:translateY(-4px); box-shadow:0 12px 34px rgba(0,0,0,.10)}
.competence-card__icon{font-size:40px; text-align:center; margin-bottom:20px; line-height:1}
.competence-card h3{font-size:var(--h3); margin:0 0 20px; color:var(--ink); font-weight:700; text-align:center}
.competence-card__list{list-style:none; padding:0; margin:0 0 24px; flex-grow:1}
.competence-card__list li{padding:10px 0 10px 24px; position:relative; color:var(--ink-2); line-height:1.6; font-size:15px}
.competence-card__list li::before{content:"✓"; position:absolute; left:0; color:var(--accent); font-weight:700; font-size:16px}
.competence-card__footer{margin:0; padding-top:20px; border-top:1px solid var(--line); font-size:13px; color:var(--muted); line-height:1.5}

/* ---------- Section Approche (About) ---------- */
.approche{padding:80px 0; background:var(--bg)}
.approche__principles{display:grid; grid-template-columns:repeat(2,1fr); gap:32px; max-width:1000px; margin:0 auto}
.principle-item{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:32px; box-shadow:var(--shadow-soft); transition:transform .2s ease, box-shadow .2s ease}
.principle-item:hover{transform:translateY(-2px); box-shadow:var(--shadow)}
.principle-item h3{font-size:20px; margin:0 0 16px; color:var(--ink); font-weight:700; line-height:1.3}
.principle-item p{margin:0; color:var(--ink-2); line-height:1.7; font-size:16px}

/* ---------- Section Contact CTA ---------- */
.contact-cta{padding:80px 0; background:var(--bg-soft)}
.contact-cta__content{text-align:center; max-width:700px; margin:0 auto}
.contact-cta__content h2{font-size:var(--h2); color:var(--ink); margin:0 0 16px; font-weight:700}
.contact-cta__content p{font-size:18px; color:var(--ink-2); line-height:1.7; margin:0 0 32px}
.contact-cta__actions{display:flex; gap:16px; justify-content:center; flex-wrap:wrap}

/* ---------- Buttons ---------- */
.btn{display:inline-flex; align-items:center; justify-content:center; padding:12px 22px; border-radius:16px; font-weight:600; border:1px solid transparent; transition:.2s ease; box-shadow:var(--shadow-soft)}
.btn--large{padding:14px 26px}
.btn--primary{background:var(--accent); color:#fff}
.btn--primary:hover{background:var(--accent-600); box-shadow:0 10px 24px rgba(107,189,164,.22); transform:translateY(-1px)}
.btn--outline{background:transparent; color:var(--accent); border-color:var(--accent)}
.btn--outline:hover{background:var(--accent); color:#fff; box-shadow:0 10px 24px rgba(107,189,164,.18); transform:translateY(-1px)}
.btn--secondary{background:var(--accent-2); color:#fff; border-color:var(--accent-2)}
.btn--secondary:hover{background:var(--accent-2-600); box-shadow:0 10px 24px rgba(37,99,235,.24); transform:translateY(-1px)}
.btn--full{width:100%}

/* ---------- "Confiance" logos ---------- */
.confiance__label{
  text-align:center; font-size:13px; font-weight:600; text-transform:uppercase;
  letter-spacing:.08em; color:var(--muted); margin:0 0 32px;
}
.confiance__grid{
  display:flex;
  flex-wrap:wrap;
  gap:40px;
  align-items:center;
  justify-content:center;
  max-width:900px;
  margin:0 auto;
}
.confiance__logo{
  height:56px; width:auto; max-width:180px;
  object-fit:contain;
  filter:grayscale(100%) opacity(0.45);
  transition:filter .3s ease;
}
.confiance__logo:hover{
  filter:grayscale(0%) opacity(1);
}

/* ---------- Cards grid ---------- */
.cards{display:grid; grid-template-columns:repeat(3,1fr); gap:24px; align-items:stretch}
.cards--centered{grid-template-columns:repeat(2,1fr); max-width:800px; margin:0 auto}
.card{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:24px;
  box-shadow:var(--shadow); transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.card:hover{transform:translateY(-3px); box-shadow:0 12px 34px rgba(0,0,0,.10); border-color:rgba(37,99,235,.25)}
.card__icon-wrap{
  width:52px; height:52px; border-radius:14px;
  background:rgba(107,189,164,.12); border:1px solid rgba(107,189,164,.2);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:18px; flex-shrink:0;
}
.card__icon{font-size:26px; line-height:1}
.card__title{font-size:var(--h3); margin:0 0 8px; color:var(--ink); font-weight:700}
.card__text{margin:0 0 14px; color:var(--ink-2)}
.card__link{font-weight:600; color:var(--ink)}
.card__link:hover{color:var(--accent)}

/* Card featured */
.card--featured{
  border-left:3px solid var(--accent);
  background:rgba(107,189,164,.04);
}
.card--featured .card__icon-wrap{
  background:rgba(107,189,164,.18); border-color:rgba(107,189,164,.3);
}
.card--featured .card__link{color:var(--accent)}
.card--featured .card__link:hover{color:var(--accent-600)}


/* Liens : soulignement fin au survol */
a{color:var(--ink); text-decoration:none}
a:hover{color:var(--accent)}
a:hover{text-decoration:underline; text-underline-offset:3px; text-decoration-thickness:1px}

/* ---------- Contact grid ---------- */
.contact__grid{display:grid; grid-template-columns:1.1fr .9fr; gap:40px; align-items:start}
.contact__promise{color:var(--ink); font-weight:600}
.contact__benefits{margin:16px 0 0; padding-left:20px}
.form{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:24px; box-shadow:var(--shadow)}
.form__group{margin-bottom:14px}
.form__label{display:block; font-size:14px; color:#475569; margin-bottom:6px}
.form__input,.form__select,.form__textarea{
  width:100%; padding:12px 12px; border:1px solid var(--line); border-radius:10px; background:#fff; font:inherit;
}
.form__input:focus,.form__select:focus,.form__textarea:focus{outline:2px solid #e2f7ee; border-color:#c7f0df}
.form__checkbox{display:flex; align-items:flex-start; gap:10px; font-size:14px; color:#475569; cursor:pointer}
.form__checkbox input[type="checkbox"]{appearance:none; -webkit-appearance:none; -moz-appearance:none; width:18px; height:18px; border:2px solid var(--line); border-radius:4px; margin-top:3px; cursor:pointer; flex-shrink:0; transition:all .2s ease}
.form__checkbox input[type="checkbox"]:checked{background:var(--accent); border-color:var(--accent); position:relative}
.form__checkbox input[type="checkbox"]:checked::after{content:"✓"; position:absolute; top:50%; left:50%; transform:translate(-50%, -50%); color:#fff; font-size:12px; font-weight:700}
.form__checkbox input[type="checkbox"]:focus{outline:2px solid rgba(107,189,164,.3); outline-offset:2px}

/* ---------- CTA sombre ---------- */
.cta-dark{background:var(--ink); padding:80px 0}
.cta-dark__content{text-align:center; max-width:640px; margin:0 auto}
.cta-dark__title{font-size:clamp(26px, 3vw, 38px); color:#fff; font-weight:700; margin:0 0 16px; line-height:1.2}
.cta-dark__sub{font-size:18px; color:rgba(255,255,255,.65); margin:0 0 36px; line-height:1.6}
.cta-dark__actions{display:flex; gap:14px; justify-content:center; flex-wrap:wrap}
.btn--accent-white{background:var(--accent); color:#fff; border-color:var(--accent)}
.btn--accent-white:hover{background:var(--accent-600); box-shadow:0 10px 28px rgba(107,189,164,.3); transform:translateY(-1px)}
.btn--ghost{background:transparent; color:rgba(255,255,255,.8); border:1px solid rgba(255,255,255,.25)}
.btn--ghost:hover{background:rgba(255,255,255,.08); color:#fff; transform:translateY(-1px)}

/* ---------- Footer ---------- */
.footer{background:var(--bg-soft); border-top:1px solid var(--line); padding:64px 0 0}
.footer__grid{display:grid; grid-template-columns:repeat(4,1fr); gap:32px; padding:64px 0}
.footer__content{display:grid; grid-template-columns:repeat(4,1fr); gap:32px; margin-bottom:40px}
.footer__section{display:flex; flex-direction:column}
.footer__section h3{margin:0 0 16px; font-size:16px; color:var(--ink); font-weight:700}
.footer__section ul{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:8px}
.footer__section li a{color:#475569; font-size:15px; text-decoration:none; white-space:nowrap}
.footer__section li a:hover{color:var(--ink)}
.footer__column{display:flex; flex-direction:column}
.footer__title{margin:0 0 16px; font-size:16px; color:var(--ink); font-weight:700}
.footer__links{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:8px}
.footer__link{color:#475569; font-size:15px; white-space:nowrap}
.footer__link:hover{color:var(--ink)}
.footer__bottom{display:flex; gap:18px; justify-content:space-between; align-items:center; padding:24px 0 0; border-top:1px solid var(--line)}
.footer__bottom p{margin:0; color:#64748B; font-size:13px}
.footer__bottom .footer__links{display:flex; align-items:center; gap:16px}
.footer__bottom .footer__links a{color:#64748B; font-size:13px; text-decoration:none}
.footer__bottom .footer__links a:hover{color:var(--ink)}
.footer__social-link{display:inline-flex !important; align-items:center; gap:5px; color:#0A66C2 !important; transition:opacity 0.2s ease}
.footer__social-link:hover{opacity:0.8 !important; color:#0A66C2 !important}

/* ---------- Blog ---------- */
.hero--blog{padding:80px 0 60px}
.blog-filtres{padding:32px 0 0}
.blog-filtres__list{display:flex; flex-wrap:wrap; gap:10px}
.blog-filtre{background:var(--bg-soft); border:1.5px solid var(--line,#E2E8F0); color:var(--ink-2); font-size:14px; font-weight:500; padding:8px 18px; border-radius:999px; cursor:pointer; transition:all 0.18s ease; font-family:inherit}
.blog-filtre:hover{border-color:var(--accent); color:var(--accent)}
.blog-filtre--actif{background:var(--accent); border-color:var(--accent); color:#fff}
.blog-section{padding:48px 0 80px}
.blog-grille{display:grid; grid-template-columns:repeat(3,1fr); gap:28px}
.blog-carte{background:#fff; border:1px solid var(--line,#E2E8F0); border-radius:var(--radius); display:flex; flex-direction:column; transition:box-shadow 0.2s ease, transform 0.2s ease}
.blog-carte:hover{box-shadow:0 8px 32px rgba(0,0,0,0.09); transform:translateY(-3px)}
.blog-carte__corps{padding:28px 28px 16px; flex:1; display:flex; flex-direction:column; gap:14px}
.blog-carte__meta{display:flex; align-items:center; gap:10px; flex-wrap:wrap}
.blog-carte__categorie{font-size:12px; font-weight:600; padding:4px 10px; border-radius:999px; text-transform:uppercase; letter-spacing:0.04em}
.blog-carte__lecture{font-size:13px; color:var(--muted)}
.blog-carte__titre{font-size:17px; font-weight:700; color:var(--ink); line-height:1.4; margin:0}
.blog-carte__titre-lien{color:inherit; text-decoration:none}
.blog-carte__titre-lien:hover{color:var(--accent)}
.blog-carte__extrait{font-size:15px; color:var(--ink-2); line-height:1.6; margin:0}
.blog-carte__pied{padding:16px 28px 24px; display:flex; justify-content:space-between; align-items:center; border-top:1px solid var(--line,#E2E8F0)}
.blog-carte__date{font-size:13px; color:var(--muted)}
.blog-carte__lien{font-size:14px; font-weight:600; color:var(--accent); text-decoration:none}
.blog-carte__lien:hover{text-decoration:underline}
.blog-carte__bientot{font-size:13px; color:var(--muted); font-style:italic}
.blog-loading,.blog-vide{color:var(--muted); font-size:16px; text-align:center; padding:48px 0; grid-column:1/-1}
.blog-newsletter{padding:64px 0}
.blog-newsletter__content{display:flex; align-items:center; justify-content:space-between; gap:32px; flex-wrap:wrap}
.blog-newsletter__titre{font-size:22px; font-weight:700; color:var(--ink); margin:0 0 8px}
.blog-newsletter__sous-titre{font-size:16px; color:var(--ink-2); margin:0}
@media(max-width:900px){.blog-grille{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){
  .blog-grille{grid-template-columns:1fr}
  .blog-newsletter__content{flex-direction:column; text-align:center}
}

/* ---------- Témoignage ---------- */
.temoignage-section{padding:64px 0}
.temoignage-card{background:var(--bg-soft); border-left:4px solid var(--accent); border-radius:var(--radius); padding:40px 48px; max-width:760px; margin:0 auto; position:relative}
.temoignage-card--large{max-width:860px; padding:48px 56px}
.temoignage-card__quote{color:var(--accent); opacity:0.4; margin-bottom:20px; display:block}
.temoignage-card__text{font-size:18px; line-height:1.75; color:var(--ink-2); font-style:italic; margin:0 0 28px; quotes:none}
.temoignage-card--large .temoignage-card__text{font-size:19px}
.temoignage-card__author{display:flex; flex-direction:column; gap:4px; border-top:1px solid var(--line, #E2E8F0); padding-top:20px}
.temoignage-card__name{font-weight:700; font-size:16px; color:var(--ink)}
.temoignage-card__role{font-size:14px; color:var(--muted)}
@media(max-width:768px){
  .temoignage-card{padding:28px 24px}
  .temoignage-card--large{padding:32px 24px}
  .temoignage-card__text{font-size:16px}
}
.footer__legal{display:flex; gap:16px}
.footer__copyright{color:#64748B; font-size:13px}

/* ---------- Page Contact - Formulaire unifié ---------- */
.hero--contact{padding:100px 0 60px; background:var(--bg-gradient-1)}

/* Hero Newsletter */
.hero--newsletter{padding:120px 0 80px; background:var(--bg-gradient-1)}
.hero--newsletter .hero__title{font-size:56px; line-height:1.1; margin-bottom:20px}
.hero--newsletter .hero__subtitle{font-size:22px; max-width:720px}

/* Newsletter Section */
.newsletter-section{padding:60px 0 100px}
.newsletter-form-wrapper{max-width:600px; margin:0 auto; padding:40px 20px}

.contact-form-section{padding:80px 0; background:var(--bg)}
.contact-form{max-width:800px; margin:0 auto; background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:48px; box-shadow:var(--shadow)}

/* Étapes du formulaire */
.form-step{margin-bottom:40px}
.form-step__header{margin-bottom:32px}
.form-step__title{font-size:var(--h2); color:var(--ink); margin:0 0 4px; font-weight:700}
.form-step__subtitle{font-size:14px; color:var(--muted); margin:0}

/* Champs de formulaire */
.form-field{margin-bottom:24px}
.form-label{display:block; font-size:15px; font-weight:600; color:var(--ink); margin-bottom:8px}
.form-label-hint{font-weight:400; color:var(--muted); font-size:14px}
.form-input,.form-textarea{width:100%; padding:12px 16px; border:1px solid var(--line); border-radius:10px; background:#fff; font:inherit; font-size:15px; color:var(--ink); transition:border .2s ease, box-shadow .2s ease}
.form-input:focus,.form-textarea:focus{outline:none; border-color:var(--accent); box-shadow:0 0 0 3px rgba(107,189,164,.1)}
.form-textarea{resize:vertical; min-height:100px; line-height:1.6}
.form-hint{margin:6px 0 0; font-size:13px; color:var(--muted)}

/* Lignes de formulaire */
.form-row{display:grid; gap:20px; margin-bottom:24px}
.form-row--two{grid-template-columns:repeat(2,1fr)}

/* Groupes radio */
.form-radio-group{display:flex; gap:12px; flex-wrap:wrap}
.form-radio{display:inline-flex; align-items:center; padding:10px 18px; border:1px solid var(--line); border-radius:10px; cursor:pointer; transition:all .2s ease; background:#fff}
.form-radio input[type="radio"]{margin:0 8px 0 0; cursor:pointer}
.form-radio:hover{border-color:var(--accent); background:rgba(107,189,164,.03)}
.form-radio input[type="radio"]:checked + span{color:var(--accent); font-weight:600}
.form-radio:has(input:checked){border-color:var(--accent); background:rgba(107,189,164,.08)}

/* Boutons de choix (Votre besoin) */
.form-button-group{display:grid; grid-template-columns:repeat(3,1fr); gap:16px}
.form-button-choice{cursor:pointer}
.form-button-choice input[type="radio"]{position:absolute; opacity:0; pointer-events:none}
.form-button-choice__content{display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px; padding:24px 16px; border:2px solid var(--line); border-radius:12px; background:#fff; transition:all .2s ease; min-height:120px}
.form-button-choice:hover .form-button-choice__content{border-color:var(--accent); background:rgba(107,189,164,.03); transform:translateY(-2px); box-shadow:var(--shadow-soft)}
.form-button-choice input:checked + .form-button-choice__content{border-color:var(--accent); background:rgba(107,189,164,.08); box-shadow:0 0 0 3px rgba(107,189,164,.1)}
.form-button-choice__icon{font-size:28px}
.form-button-choice__text{font-size:15px; font-weight:600; color:var(--ink); text-align:center}

/* Accordéon */
.form-accordion{margin:40px 0; padding-top:32px; border-top:1px solid var(--line)}
.form-accordion__trigger{display:flex; align-items:center; gap:12px; padding:16px 24px; width:100%; background:var(--bg-soft); border:1px solid var(--line); border-radius:12px; font-size:16px; font-weight:600; color:var(--ink); cursor:pointer; transition:all .2s ease}
.form-accordion__trigger:hover{background:#fff; border-color:var(--accent); color:var(--accent)}
.form-accordion__icon{font-size:20px; font-weight:700; transition:transform .2s ease}
.form-accordion__trigger.active .form-accordion__icon{transform:rotate(45deg)}
.form-accordion__content{max-height:0; overflow:hidden; transition:max-height .3s ease}
.form-accordion__content.active{max-height:2000px; padding-top:32px}

/* Groupes checkbox */
.form-checkbox-group{display:flex; gap:12px; flex-wrap:wrap}
.form-checkbox-inline{display:inline-flex; align-items:center; padding:10px 18px; border:1px solid var(--line); border-radius:10px; cursor:pointer; transition:all .2s ease; background:#fff}
.form-checkbox-inline input[type="checkbox"]{margin:0 8px 0 0; cursor:pointer}
.form-checkbox-inline:hover{border-color:var(--accent); background:rgba(107,189,164,.03)}
.form-checkbox-inline:has(input:checked){border-color:var(--accent); background:rgba(107,189,164,.08)}

/* Budget */
.form-budget-group{display:flex; gap:10px; flex-wrap:wrap}
.form-budget-choice{cursor:pointer}
.form-budget-choice input[type="radio"]{position:absolute; opacity:0; pointer-events:none}
.form-budget-choice span{display:inline-block; padding:10px 20px; border:1px solid var(--line); border-radius:10px; background:#fff; font-size:14px; font-weight:600; color:var(--ink); transition:all .2s ease}
.form-budget-choice:hover span{border-color:var(--accent); background:rgba(107,189,164,.03)}
.form-budget-choice input:checked + span{border-color:var(--accent); background:var(--accent); color:#fff}

/* Fichiers */
.form-input-file{padding:10px}

/* Checkbox block */
.form-checkbox-block{display:flex; align-items:flex-start; gap:12px; cursor:pointer}
.form-checkbox-block input[type="checkbox"]{margin-top:3px; cursor:pointer}
.form-checkbox-block span{font-size:14px; color:var(--ink-2); line-height:1.5}

/* Consentement RGPD */
.form-consent{margin:32px 0; padding:20px; background:var(--bg-soft); border-radius:10px}
.form-consent .form-checkbox-block span{font-size:15px; color:var(--ink)}

/* Submit */
.form-submit-wrapper{text-align:center; margin-top:32px}
.form-submit-note{margin-top:12px; font-size:14px; color:var(--muted)}

/* Contact Info */
.contact-info{padding:80px 0; background:var(--bg-soft)}
.contact-info__content{text-align:center}
.contact-info__grid{display:grid; grid-template-columns:repeat(3,1fr); gap:32px; margin-top:40px}
.contact-info__grid--two{grid-template-columns:repeat(2,1fr); max-width:700px; margin-left:auto; margin-right:auto}
.contact-info__item{text-align:center}
.contact-info__icon{font-size:40px; margin-bottom:16px}
.contact-info__item h3{font-size:var(--h3); color:var(--ink); margin:0 0 12px; font-weight:700}
.contact-info__item p{margin:0; font-size:16px; color:var(--ink-2)}
.contact-info__item a{color:var(--accent); font-weight:600; text-decoration:none}
.contact-info__item a:hover{text-decoration:underline}

/* ---------- Section Pourquoi traducteur SEO ---------- */
.pourquoi-traducteur-seo{padding:96px 0; background:var(--bg)}
.section__intro{font-size:20px; color:var(--ink-2); text-align:center; max-width:800px; margin:0 auto 48px; line-height:1.6}
.benefices-seo__grid{display:grid; grid-template-columns:repeat(3,1fr); gap:32px}
.benefice-card{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:32px; box-shadow:var(--shadow-soft); transition:transform .2s ease, box-shadow .2s ease}
.benefice-card:hover{transform:translateY(-4px); box-shadow:var(--shadow)}
.benefice-card__icon{font-size:48px; text-align:center; margin-bottom:20px; line-height:1}
.benefice-card__title{font-size:20px; font-weight:700; color:var(--ink); margin:0 0 16px; text-align:center; line-height:1.3}
.benefice-card__description{font-size:16px; color:var(--ink-2); line-height:1.6; margin:0; text-align:center}

/* ---------- Section Livrables SEO ---------- */
.livrables-seo{padding:96px 0}
.livrables-seo__content{max-width:900px; margin:0 auto}
.livrables-list{list-style:none; padding:0; margin:0 0 40px}
.livrables-list li{display:flex; align-items:flex-start; gap:20px; padding:24px; background:#fff; border:1px solid var(--line); border-radius:var(--radius); margin-bottom:16px; box-shadow:var(--shadow-soft); transition:transform .2s ease, box-shadow .2s ease}
.livrables-list li:hover{transform:translateX(4px); box-shadow:var(--shadow)}
.livrable-icon{font-size:32px; flex-shrink:0; line-height:1}
.livrable-text{flex:1}
.livrable-text strong{font-size:17px; color:var(--ink); font-weight:700; display:block; margin-bottom:4px}
.livrable-detail{font-size:15px; color:var(--muted); display:block; margin-top:4px}
.option-relecture{display:flex; align-items:flex-start; gap:20px; padding:28px; background:linear-gradient(135deg, rgba(107,189,164,.08) 0%, rgba(37,99,235,.08) 100%); border:2px solid var(--accent); border-radius:var(--radius); box-shadow:var(--shadow)}
.option-relecture__icon{font-size:32px; flex-shrink:0; line-height:1}
.option-relecture__content{flex:1; font-size:16px; color:var(--ink-2); line-height:1.6}
.option-relecture__content strong{color:var(--ink); font-weight:700}

/* ---------- Section Méthode en 5 étapes ---------- */
.methode-section{padding:96px 0; background:var(--bg)}
.methode__steps{max-width:900px; margin:0 auto; display:flex; flex-direction:column; gap:24px}
.methode__step{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:32px; box-shadow:var(--shadow-soft); transition:transform .2s ease, box-shadow .2s ease}
.methode__step:hover{transform:translateY(-2px); box-shadow:var(--shadow)}
.methode__step-header{display:flex; align-items:center; gap:20px; margin-bottom:16px}
.methode__number{flex-shrink:0; width:48px; height:48px; background:var(--accent); color:#fff; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:24px; font-weight:700}
.methode__step-title{font-size:22px; font-weight:700; color:var(--ink); margin:0; line-height:1.3}
.methode__step-description{font-size:16px; color:var(--ink-2); line-height:1.6; margin:0 0 16px}
.methode__livrables{padding:16px 20px; background:var(--bg-soft); border-left:3px solid var(--accent); border-radius:8px; font-size:15px; color:var(--ink-2); line-height:1.5}
.methode__livrables strong{color:var(--ink); font-weight:700}

/* ---------- Section Résultats ---------- */
.resultats-section{padding:96px 0}
.resultats__grid{display:grid; grid-template-columns:repeat(3,1fr); gap:28px; margin-bottom:48px}
.resultat-card{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:32px; box-shadow:var(--shadow-soft); transition:transform .2s ease, box-shadow .2s ease; display:flex; flex-direction:column; align-items:center; text-align:center}
.resultat-card:hover{transform:translateY(-4px); box-shadow:var(--shadow)}
.resultat-card__icon{font-size:48px; margin-bottom:20px; line-height:1}
.resultat-card__title{font-size:19px; font-weight:700; color:var(--ink); margin:0 0 12px; line-height:1.3}
.resultat-card__description{font-size:15px; color:var(--ink-2); line-height:1.6; margin:0}

/* KPIs Details */
.kpis-details{max-width:800px; margin:0 auto; background:#fff; border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow-soft)}
.kpis-details__trigger{display:flex; align-items:center; gap:12px; padding:20px 24px; cursor:pointer; font-size:17px; font-weight:600; color:var(--ink); list-style:none; transition:background .2s ease}
.kpis-details__trigger::-webkit-details-marker{display:none}
.kpis-details__trigger:hover{background:var(--bg-soft)}
.kpis-details__icon{font-size:24px; line-height:1}
.kpis-details__text{flex:1}
.kpis-details[open] .kpis-details__trigger{background:var(--bg-soft); border-bottom:1px solid var(--line)}
.kpis-details__content{padding:24px}
.kpis-list{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:12px}
.kpis-list li{padding:12px 16px; background:var(--bg-soft); border-left:3px solid var(--accent); border-radius:8px; font-size:15px; color:var(--ink-2); line-height:1.5}

/* ---------- Section Process de traduction ---------- */
.process-traduction{padding:96px 0; background:var(--bg)}
.process__steps{max-width:900px; margin:0 auto; display:flex; flex-direction:column; gap:24px}
.process__step{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:32px; box-shadow:var(--shadow-soft); transition:transform .2s ease, box-shadow .2s ease}
.process__step:hover{transform:translateY(-2px); box-shadow:var(--shadow)}
.process__step-header{display:flex; align-items:center; gap:20px; margin-bottom:16px}
.process__number{flex-shrink:0; width:48px; height:48px; background:var(--accent); color:#fff; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:24px; font-weight:700}
.process__step-title{font-size:22px; font-weight:700; color:var(--ink); margin:0; line-height:1.3}
.process__step-description{font-size:16px; color:var(--ink-2); line-height:1.6; margin:0}

/* ---------- Section Livrables standard ---------- */
.livrables-standard{padding:96px 0}
.livrables__grid{display:grid; grid-template-columns:repeat(2,1fr); gap:24px}
.livrable-item{display:flex; align-items:flex-start; gap:16px; padding:24px; background:#fff; border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow-soft); transition:transform .2s ease, box-shadow .2s ease}
.livrable-item:hover{transform:translateY(-2px); box-shadow:var(--shadow)}
.livrable-item__icon{font-size:32px; flex-shrink:0; line-height:1}
.livrable-item__title{font-size:16px; font-weight:600; color:var(--ink); margin:0; line-height:1.5}

/* ---------- Section Formats & outils ---------- */
.formats-outils{padding:96px 0; background:var(--bg)}
.formats-outils__content{display:grid; grid-template-columns:repeat(2,1fr); gap:32px; max-width:1000px; margin:0 auto}
.formats-outils__section{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:32px; box-shadow:var(--shadow-soft); transition:transform .2s ease, box-shadow .2s ease}
.formats-outils__section:hover{transform:translateY(-4px); box-shadow:var(--shadow)}
.formats-outils__header{display:flex; align-items:center; gap:16px; margin-bottom:16px}
.formats-outils__icon{font-size:40px; line-height:1}
.formats-outils__subtitle{font-size:22px; font-weight:700; color:var(--ink); margin:0; line-height:1.3}
.formats-outils__text{font-size:16px; color:var(--ink-2); line-height:1.7; margin:0}

/* ---------- Section Garanties ---------- */
.garanties{padding:96px 0}
.garanties__list{display:grid; grid-template-columns:repeat(2,1fr); gap:24px; max-width:1000px; margin:0 auto}
.garantie-item{display:flex; align-items:flex-start; gap:16px; padding:24px; background:#fff; border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow-soft); transition:transform .2s ease, box-shadow .2s ease}
.garantie-item:hover{transform:translateY(-2px); box-shadow:var(--shadow)}
.garantie-item__icon{font-size:32px; flex-shrink:0; line-height:1}
.garantie-item__content{flex:1}
.garantie-item__title{font-size:17px; font-weight:700; color:var(--ink); margin:0 0 8px; line-height:1.3}
.garantie-item__text{font-size:15px; color:var(--ink-2); line-height:1.6; margin:0}

/* ---------- Section Spécialisations ---------- */
.specialisations{padding:96px 0}
.specialisations__grid{display:grid; grid-template-columns:repeat(2,1fr); gap:32px; margin-bottom:40px}
.specialisation-card{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:32px; box-shadow:var(--shadow-soft); transition:transform .2s ease, box-shadow .2s ease}
.specialisation-card:hover{transform:translateY(-4px); box-shadow:var(--shadow)}
.specialisation-card__header{display:flex; align-items:center; gap:16px; margin-bottom:16px}
.specialisation-card__icon{font-size:40px; line-height:1}
.specialisation-card__title{font-size:22px; font-weight:700; color:var(--ink); margin:0; line-height:1.3}
.specialisation-card__intro{font-size:17px; color:var(--ink-2); line-height:1.6; margin:0 0 24px}
.specialisation-card__content{margin-top:20px}
.specialisation-card__subtitle{font-size:15px; font-weight:600; color:var(--ink); margin:0 0 12px}
.specialisation-card__list{list-style:none; padding:0; margin:0}
.specialisation-card__list li{padding:10px 0 10px 28px; position:relative; color:var(--ink-2); line-height:1.6; font-size:15px}
.specialisation-card__list li::before{content:"•"; position:absolute; left:8px; color:var(--accent); font-weight:700; font-size:20px}
.specialisations__footer{text-align:center; padding:32px; background:linear-gradient(135deg, rgba(107,189,164,.08) 0%, rgba(37,99,235,.08) 100%); border:1px solid var(--accent); border-radius:var(--radius); box-shadow:var(--shadow-soft)}
.specialisations__footer p{margin:0; font-size:17px; color:var(--ink); line-height:1.6; font-weight:500}

/* ---------- Responsive ---------- */
@media (max-width: 1024px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .cards--centered{max-width:700px}
  .confiance__grid{grid-template-columns:repeat(2,1fr); gap:32px}
  .contact__grid{grid-template-columns:1fr}
  .parcours__content{grid-template-columns:1fr; gap:40px}
  .parcours__image{order:1}
  .parcours__text{order:2}
  .intro__content{grid-template-columns:1fr !important; gap:40px; text-align:center}
  .intro__image{order:1 !important}
  .intro__text{order:2 !important}
  .comment-ca-marche__grid{grid-template-columns:1fr !important; gap:24px}
  .pourquoi-avec-moi__content{grid-template-columns:1fr !important; gap:40px}
  .pourquoi-avec-moi__image{order:1 !important}
  .pourquoi-avec-moi__text{order:2 !important}
  .competences__grid{grid-template-columns:repeat(2,1fr)}
  .footer__content{grid-template-columns:repeat(2,1fr)}
  .footer__grid{grid-template-columns:repeat(2,1fr)}
  .benefices-seo__grid{grid-template-columns:repeat(2,1fr)}
  .resultats__grid{grid-template-columns:repeat(2,1fr)}
  .specialisations__grid{grid-template-columns:1fr}
  .livrables__grid{grid-template-columns:1fr}
  .formats-outils__content{grid-template-columns:1fr}
  .garanties__list{grid-template-columns:1fr}
}
@media (max-width: 640px){
  :root{--h1:34px; --h2:26px; --h3:18px; --p:16px; --gutter:20px}
  .nav__menu{display:none}
  .nav__menu.is-open{display:flex; flex-direction:column}
  .nav__burger{display:block}
  .cards{grid-template-columns:1fr}
  .cards--centered{max-width:100%}
  .confiance__grid{grid-template-columns:1fr; gap:24px}
  .confiance__item{height:100px}
  .intro{padding:60px 0}
  .intro__content{grid-template-columns:1fr !important; gap:32px; text-align:center}
  .intro__image{order:1 !important}
  .intro__text{order:2 !important}
  .profile-image--large{width:200px; height:200px}
  /* Afficher versions courtes sur mobile */
  .intro__text--mobile{display:block}
  .intro__text--desktop{display:none}
  .parcours__text--mobile{display:block}
  .parcours__text--desktop{display:none}
  .pourquoi-avec-moi__text--mobile{display:block}
  .pourquoi-avec-moi__text--desktop{display:none}
  section{padding:72px 0}
  .hero__title--declic{font-size:38px; line-height:1.15}
  .ce-que-vous-obtenez__grid{grid-template-columns:1fr !important; gap:24px; margin-bottom:32px}
  .benefit-card{padding:24px !important}
  .benefit-card__header{flex-direction:column; align-items:center; text-align:center; gap:12px; margin-bottom:16px}
  .benefit-card__icon{flex-shrink:0}
  .benefit-card__title{font-size:20px !important; margin:0}
  .benefit-card__description{font-size:15px !important}
  .ce-que-vous-obtenez__cta{margin-top:32px !important}
  .ce-que-vous-obtenez__cta .btn{width:100%; padding:16px 24px; font-size:18px}
  .comment-ca-marche__grid{grid-template-columns:1fr !important; gap:20px; margin-bottom:24px}
  .step-card{padding:28px 24px !important; display:flex !important; flex-direction:column !important; align-items:center !important; text-align:center !important; min-height:auto}
  .step-card__header{flex-direction:column !important; align-items:center !important; text-align:center !important; gap:16px; margin-bottom:16px; width:100%}
  .step-card__icon{flex-shrink:0}
  .step-card__title{font-size:20px !important; margin:0}
  .step-card__description{font-size:15px !important; margin:0; line-height:1.6}
  .pourquoi-avec-moi__content{grid-template-columns:1fr !important; gap:24px; text-align:center}
  .pourquoi-avec-moi__image{order:1 !important}
  .pourquoi-avec-moi__text{order:2 !important}
  .reservation__benefits{flex-direction:column; gap:16px}
  .hero--accompagnement .hero__title{font-size:38px; line-height:1.15}
  .resultats-grid{grid-template-columns:1fr; gap:20px}
  .pas-pour-vous__list{grid-template-columns:1fr; gap:16px}

  /* Hero About responsive */
  .hero--about{padding:80px 0 60px}
  .hero__title--large{font-size:38px}
  .hero__tagline{font-size:18px}
  .hero__stats{gap:32px}
  .stat-item__number{font-size:36px}
  .stat-item__label{font-size:13px}
  .hero__cta{flex-direction:column; width:100%}
  .hero__cta .btn{width:100%}
  .competences__grid{grid-template-columns:1fr}
  .approche__principles{grid-template-columns:1fr}
  .footer__content{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr}
  .footer__bottom{flex-direction:column; gap:16px; text-align:center}

  /* Contact Form responsive */
  .contact-form{padding:32px 24px}
  .form-row--two{grid-template-columns:1fr}
  .form-button-group{grid-template-columns:1fr; gap:12px}
  .form-button-choice__content{padding:20px 16px; min-height:auto}
  .contact-info__grid{grid-template-columns:1fr; gap:24px}
  .contact-info__grid--two{grid-template-columns:1fr}
  .benefices-seo__grid{grid-template-columns:1fr; gap:20px}
  .section__intro{font-size:17px; margin-bottom:32px}
  .benefice-card{padding:24px}
  .benefice-card__icon{font-size:40px; margin-bottom:16px}
  .benefice-card__title{font-size:18px; margin-bottom:12px}
  .benefice-card__description{font-size:15px}
  .livrables-list li{padding:20px; gap:16px}
  .livrable-icon{font-size:28px}
  .livrable-text strong{font-size:16px}
  .option-relecture{padding:20px; gap:16px}
  .option-relecture__icon{font-size:28px}
  .option-relecture__content{font-size:15px}
  .methode__step{padding:24px}
  .methode__step-header{flex-direction:column; align-items:flex-start; gap:12px}
  .methode__number{width:40px; height:40px; font-size:20px}
  .methode__step-title{font-size:19px}
  .methode__step-description{font-size:15px}
  .methode__livrables{padding:12px 16px; font-size:14px}
  .resultats__grid{grid-template-columns:1fr; gap:20px}
  .resultat-card{padding:24px}
  .resultat-card__icon{font-size:40px; margin-bottom:16px}
  .resultat-card__title{font-size:17px; margin-bottom:10px}
  .resultat-card__description{font-size:14px}
  .kpis-details__trigger{padding:16px 20px; font-size:16px}
  .kpis-details__icon{font-size:20px}
  .kpis-details__content{padding:20px}
  .kpis-list li{padding:10px 14px; font-size:14px}
  .process__step{padding:24px}
  .process__step-header{flex-direction:column; align-items:flex-start; gap:12px}
  .process__number{width:40px; height:40px; font-size:20px}
  .process__step-title{font-size:19px}
  .process__step-description{font-size:15px}
  .livrable-item{padding:20px; gap:12px}
  .livrable-item__icon{font-size:28px}
  .livrable-item__title{font-size:15px}
  .formats-outils__section{padding:24px}
  .formats-outils__icon{font-size:32px}
  .formats-outils__subtitle{font-size:19px}
  .formats-outils__text{font-size:15px}
  .garantie-item{padding:20px; gap:12px}
  .garantie-item__icon{font-size:28px}
  .garantie-item__title{font-size:16px}
  .garantie-item__text{font-size:14px}
}

/* ---------- Reveal on scroll (bonus) ---------- */
.reveal{opacity:0; transform:translateY(18px); transition:.5s ease}
.reveal.is-visible{opacity:1; transform:none}

/* ---------- Sections décoratives et utilitaires ---------- */
/* Dégradés réutilisables */
.gradient-bg{background:var(--bg-gradient-1)}
.gradient-bg--soft{background:var(--bg-gradient-2)}
.gradient-bg--beige{background:var(--bg-gradient-3)}

/* Overlay de gradient subtil */
.gradient-overlay{position:relative; overflow:hidden}
.gradient-overlay::after{content:""; position:absolute; inset:-2px; z-index:-1; background:var(--bg-gradient-1)}

/* Motif grille légère (style Figma/systeme.io) */
.pattern-grid{position:relative}
.pattern-grid::before{content:""; position:absolute; inset:0; z-index:-1; background-image:linear-gradient(rgba(15,23,42,.05) 1px, transparent 1px), linear-gradient(90deg, rgba(15,23,42,.05) 1px, transparent 1px); background-size:24px 24px}

/* Petits points doux */
.pattern-dots{position:relative}
.pattern-dots::before{content:""; position:absolute; inset:0; z-index:-1; background-image:radial-gradient(rgba(15,23,42,.05) 1px, transparent 1.5px); background-size:18px 18px}

/* Lignes d’accent au dessus d’un titre ou section */
.accent-line{position:relative}
.accent-line::before{content:""; position:absolute; top:-14px; left:50%; transform:translateX(-50%); width:64px; height:4px; border-radius:4px; background:linear-gradient(90deg, var(--accent) 0%, var(--accent-2) 100%)}

/* Appliquer des fonds aux sections clés */
.hero{background:var(--bg-gradient-1)}
.services-seo{background:var(--bg-gradient-2)}
.formations{background:var(--bg-gradient-3)}

/* Sections Déclic Visibilité avec contraste */
.hero--declic{
  background:
    radial-gradient(620px 360px at 78% 20%, rgba(249,115,22,.60), transparent 70%),
    radial-gradient(620px 360px at 22% 25%, rgba(249,115,22,.55), transparent 70%),
    radial-gradient(520px 320px at 88% -5%, rgba(250,204,21,.45), transparent 68%),
    radial-gradient(520px 320px at 12% 105%, rgba(250,204,21,.45), transparent 68%),
    linear-gradient(140deg, #111827 0%, #f97316 48%, #facc15 100%);
  color:#0b1120;
}
.hero--declic::before,
.hero--declic::after{
  background:radial-gradient(circle, rgba(255,255,255,.35), transparent 70%);
  opacity:.65;
  filter:blur(60px);
}
.hero--declic .badge{
  background:rgba(15,23,42,.6);
  border-color:rgba(15,23,42,.4);
  color:#f8fafc;
}
.preuves{background:var(--bg-soft)}
.ce-que-vous-obtenez{background:var(--bg)}
.pour-qui{background:var(--bg-soft)}
.comment-ca-marche{background:var(--bg)}
.pourquoi-avec-moi{background:linear-gradient(135deg, #f0f9ff 0%, #e0f2fe 50%, #f0f9ff 100%)}
.scope{background:var(--bg-soft)}
.reservation{background:var(--bg)}
.faq{background:var(--bg-soft)}

/* Sections Déclic 90 avec contraste */
.hero--accompagnement{
  background:
    radial-gradient(620px 360px at 78% 20%, rgba(249,115,22,.60), transparent 70%),
    radial-gradient(620px 360px at 22% 25%, rgba(249,115,22,.55), transparent 70%),
    radial-gradient(520px 320px at 88% -5%, rgba(250,204,21,.45), transparent 68%),
    radial-gradient(520px 320px at 12% 105%, rgba(250,204,21,.45), transparent 68%),
    linear-gradient(140deg, #111827 0%, #f97316 48%, #facc15 100%);
  color:#0b1120;
}
.hero--accompagnement::before,
.hero--accompagnement::after{
  background:radial-gradient(circle, rgba(255,255,255,.35), transparent 70%);
  opacity:.65;
  filter:blur(60px);
}
.hero--accompagnement .hero__title{
  color:#f8fafc;
}
.hero--accompagnement .hero__subtitle{
  color:rgba(248,250,252,.92);
}
.ce-que-vous-obtenez{background:var(--bg)}
.pour-qui{background:var(--bg-soft)}
.resultats-attendus{background:var(--bg)}
.pourquoi-avec-moi{background:linear-gradient(135deg, #f0f9ff 0%, #e0f2fe 50%, #f0f9ff 100%)}
.reservation{background:var(--bg)}

/* Section "Pour qui" - plus gros, icônes alignées */
.pour-qui__intro{font-size:20px; line-height:1.6; margin-bottom:32px; color:var(--ink-2)}
.pour-qui__list{list-style:none; padding:0; margin:0 0 48px}
.pour-qui__item{display:flex; align-items:flex-start; gap:16px; padding:28px; background:#fff; border:1px solid var(--line); border-radius:var(--radius); margin-bottom:20px; box-shadow:var(--shadow-soft)}
.pour-qui__header{display:flex; align-items:center; gap:16px; margin-bottom:12px}
.pour-qui__icon{flex-shrink:0; font-size:24px}
.pour-qui__title{font-size:22px; font-weight:700; color:var(--ink); margin:0}
.pour-qui__description{font-size:16px; color:var(--ink-2); line-height:1.6; margin:0}
.pour-qui__cta{text-align:center; margin-top:48px}

/* Section "Comment ça marche" - 3 colonnes, icônes alignées */
.comment-ca-marche__grid{display:grid; grid-template-columns:repeat(3,1fr); gap:32px; margin-bottom:32px}
.step-card{padding:32px; background:#fff; border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow-soft)}
.step-card__header{display:flex; align-items:center; gap:14px; margin-bottom:16px}
.step-card__icon{flex-shrink:0}
.step-card__icon .icon-square{width:48px; height:48px; font-size:24px; display:inline-flex; align-items:center; justify-content:center; border-radius:12px; background:#f97316; color:#fff}
.step-card__title{font-size:22px; font-weight:700; color:var(--ink); margin:0}
.step-card__description{font-size:16px; color:var(--ink-2); line-height:1.6; margin:0}
.comment-ca-marche__note{text-align:center; font-size:15px; color:var(--muted); margin-top:24px}

/* Section "Pourquoi avec moi" - photo plus petite */
.pourquoi-avec-moi__content{display:grid; grid-template-columns:auto 1fr; gap:40px; align-items:start; position:relative}
.pourquoi-avec-moi__image{text-align:center; position:relative; z-index:2}
.profile-image{width:200px; height:200px; border-radius:50%; margin:0 auto 16px; overflow:hidden; border:3px solid #fff; box-shadow:0 8px 24px rgba(0,0,0,.15)}
.profile-image--large{width:240px; height:240px; margin:0}
.profile-image__img{width:100%; height:100%; object-fit:cover; object-position:center}

/* ---------- Introduction Section ---------- */
.intro{padding:64px 0; background:var(--bg-soft)}
.intro__text-only{
  max-width:760px; margin:0 auto;
  background:#fff; border:1px solid var(--line);
  border-radius:var(--radius); padding:40px 48px;
  box-shadow:var(--shadow-soft);
}
.intro .container{max-width:860px}
.intro__content{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:56px;
  align-items:center;
  max-width:900px;
  margin:0 auto
}
.intro__image{display:flex; align-items:center; justify-content:center}
.intro__text{font-size:18px; line-height:1.7; color:var(--ink-2)}
.intro__paragraph{margin:0 0 20px}
.intro__paragraph:last-child{margin-bottom:0}
/* Versions desktop/mobile pour intro */
.intro__text--mobile{display:none}
.intro__text--desktop{display:block}
/* Versions desktop/mobile pour parcours */
.parcours__text--mobile{display:none}
.parcours__text--desktop{display:block}
/* Versions desktop/mobile pour pourquoi-avec-moi */
.pourquoi-avec-moi__text--mobile{display:none}
.pourquoi-avec-moi__text--desktop{display:block}
.profile-info__name{font-size:18px; font-weight:700; color:var(--ink); margin-bottom:4px}
.profile-info__title{font-size:15px; color:var(--ink-2)}
.pourquoi-avec-moi__text{font-size:17px; line-height:1.7; color:var(--ink-2); position:relative; z-index:2}
.pourquoi-avec-moi__text p{margin-bottom:20px}
.pourquoi-avec-moi__text p:last-child{margin-bottom:0}

/* Section Réservation - bénéfices sur une ligne */
.reservation__benefits{display:flex; gap:24px; flex-wrap:wrap; margin-top:20px}
.benefit-item{display:flex; align-items:center; gap:8px; font-size:16px; color:var(--ink-2)}
.benefit-icon{font-size:20px; flex-shrink:0}
.benefit-text{white-space:nowrap}

/* Décoration pour la section "Pourquoi avec moi" */
.pourquoi-avec-moi::before{content:""; position:absolute; top:0; right:0; width:200px; height:200px; background:radial-gradient(circle, rgba(107,189,164,.1) 0%, transparent 70%); border-radius:50%; transform:translate(50%, -50%)}
.pourquoi-avec-moi::after{content:""; position:absolute; bottom:0; left:0; width:150px; height:150px; background:radial-gradient(circle, rgba(59,130,246,.1) 0%, transparent 70%); border-radius:50%; transform:translate(-50%, 50%)}

/* Styles spécifiques Déclic 90 */
.hero--accompagnement .hero__title{font-size:48px; line-height:1.1; margin-bottom:24px}
.hero--accompagnement .hero__subtitle{font-size:20px; line-height:1.6; margin-bottom:32px; color:var(--ink-2)}

/* Section "Ce que vous obtenez" Déclic 90 - 3 colonnes (desktop) */
@media (min-width: 641px){
  /* Styles pour Déclic 90 uniquement - avec icône centrée */
  .ce-que-vous-obtenez:not(.ce-que-vous-obtenez--declic-visibilite) .ce-que-vous-obtenez__grid{display:grid; grid-template-columns:repeat(3,1fr); gap:32px; margin-bottom:48px}
  .ce-que-vous-obtenez:not(.ce-que-vous-obtenez--declic-visibilite) .benefit-card{padding:32px; background:#fff; border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow-soft)}
  .ce-que-vous-obtenez:not(.ce-que-vous-obtenez--declic-visibilite) .benefit-card__icon{text-align:center; margin-bottom:20px}
  .ce-que-vous-obtenez:not(.ce-que-vous-obtenez--declic-visibilite) .benefit-card__icon .icon-circle,.ce-que-vous-obtenez:not(.ce-que-vous-obtenez--declic-visibilite) .benefit-card__icon .icon-square{width:64px; height:64px; font-size:32px; display:inline-flex; align-items:center; justify-content:center; border-radius:16px; background:var(--accent); color:#fff; margin:0 auto}
  .ce-que-vous-obtenez:not(.ce-que-vous-obtenez--declic-visibilite) .benefit-card__icon .icon-circle{border-radius:50%}
  .ce-que-vous-obtenez:not(.ce-que-vous-obtenez--declic-visibilite) .benefit-card__title{font-size:22px; font-weight:700; color:var(--ink); margin-bottom:16px; text-align:center}
  .ce-que-vous-obtenez:not(.ce-que-vous-obtenez--declic-visibilite) .benefit-card__description{font-size:16px; color:var(--ink-2); line-height:1.6; margin:0; text-align:center}
}

/* Section "Pour qui" Déclic 90 */

/* Résultats attendus */
.resultats-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:24px; margin:32px 0}
.resultat-card{display:flex; align-items:flex-start; gap:16px; padding:24px; background:#fff; border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow-soft)}
.resultat-icon{font-size:28px; flex-shrink:0; line-height:1; margin-top:2px}
.resultat-content{flex:1}
.resultat-title{font-size:18px; font-weight:700; color:var(--ink); margin:0 0 8px; line-height:1.3}
.resultat-desc{font-size:15px; color:var(--ink-2); line-height:1.6; margin:0}
.resultats-note{text-align:center; font-size:15px; color:var(--muted); margin-top:32px; font-style:italic}

/* Pas pour vous */
.pas-pour-vous__list{display:grid; grid-template-columns:repeat(2,1fr); gap:20px; margin-top:20px}
.pas-pour-vous__item{display:flex; align-items:flex-start; gap:12px; padding:20px; background:#fff; border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow-soft)}
.pas-pour-vous__icon{font-size:20px; flex-shrink:0; margin-top:2px}
.pas-pour-vous__item p{margin:0; font-size:15px; color:var(--ink-2); line-height:1.5}

/* Section "Ce que vous obtenez" Déclic Visibilité - 3 colonnes (desktop) */
@media (min-width: 641px){
  /* Styles pour Déclic Visibilité uniquement - avec header horizontal */
  .ce-que-vous-obtenez__grid{display:grid; grid-template-columns:repeat(3,1fr); gap:32px; margin-bottom:48px}
  .benefit-card{padding:32px; background:#fff; border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow-soft)}
  .benefit-card__header{display:flex; align-items:center; gap:14px; margin-bottom:16px}
  .benefit-card__icon{flex-shrink:0}
  .benefit-card__icon .icon-circle,.benefit-card__icon .icon-square{width:48px; height:48px; font-size:24px; display:inline-flex; align-items:center; justify-content:center; border-radius:12px; background:#f97316; color:#fff}
  .benefit-card__icon .icon-circle{border-radius:50%}
  .benefit-card__title{font-size:22px; font-weight:700; color:var(--ink); margin:0}
  .benefit-card__description{font-size:16px; color:var(--ink-2); line-height:1.6; margin:0}
  .ce-que-vous-obtenez__cta{text-align:center; margin-top:48px}
  
  /* Override pour Déclic 90 avec icône centrée */
  .ce-que-vous-obtenez:not(.ce-que-vous-obtenez--declic-visibilite) .benefit-card__icon{text-align:center; margin-bottom:20px}
  .ce-que-vous-obtenez:not(.ce-que-vous-obtenez--declic-visibilite) .benefit-card__icon .icon-circle,
  .ce-que-vous-obtenez:not(.ce-que-vous-obtenez--declic-visibilite) .benefit-card__icon .icon-square{width:64px; height:64px; font-size:32px; margin:0 auto}
  .ce-que-vous-obtenez:not(.ce-que-vous-obtenez--declic-visibilite) .benefit-card__title{text-align:center; margin-bottom:16px}
  .ce-que-vous-obtenez:not(.ce-que-vous-obtenez--declic-visibilite) .benefit-card__description{text-align:center}
}

/* Bouton Déclic plus visible */
.btn--declic{background:var(--accent); color:#fff; border-color:var(--accent); box-shadow:0 4px 14px rgba(107,189,164,.3)}
.btn--declic:hover{background:var(--accent-600); transform:translateY(-2px); box-shadow:0 8px 20px rgba(107,189,164,.4)}

/* Bouton Déclic 90 plus visible */
.btn--accompagnement{background:var(--accent); color:#fff; border-color:var(--accent); box-shadow:0 4px 14px rgba(107,189,164,.3)}
.btn--accompagnement:hover{background:var(--accent-600); transform:translateY(-2px); box-shadow:0 8px 20px rgba(107,189,164,.4)}
.form__submit--accompagnement{background:var(--accent); color:#fff; border-color:var(--accent); box-shadow:0 4px 14px rgba(107,189,164,.3); padding:18px 40px; font-size:20px; font-weight:700; width:100%; max-width:100%; border-radius:16px}
.form__submit--accompagnement:hover{background:var(--accent-600); transform:translateY(-2px); box-shadow:0 8px 20px rgba(107,189,164,.4)}

/* ---------- Services principaux (Consultant SEO) ---------- */
.services-principaux{padding:96px 0; background:var(--bg-soft)}
.services-principaux__grid{display:grid; grid-template-columns:repeat(2,1fr); gap:32px; max-width:1100px; margin:0 auto}
.service-card{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:32px; box-shadow:var(--shadow); transition:transform .2s ease, box-shadow .2s ease; display:flex; flex-direction:column; height:100%}
.service-card:hover{transform:translateY(-4px); box-shadow:0 12px 34px rgba(0,0,0,.12)}
.service-card__icon{font-size:48px; text-align:center; margin-bottom:16px; line-height:1}
.service-card__title{font-size:26px; font-weight:700; color:var(--ink); margin:0 0 8px; text-align:center}
.service-card__subtitle{font-size:16px; color:var(--muted); text-align:center; margin:0 0 20px}
.service-card__price{text-align:center; padding:20px 0; margin-bottom:20px; border-bottom:1px solid var(--line)}
.price-amount{display:block; font-size:32px; font-weight:700; color:var(--accent); line-height:1.2}
.price-period{display:block; font-size:14px; color:var(--muted); margin-top:4px}
.service-card__content{flex:1; margin-bottom:24px}
.service-card__content h4{font-size:16px; font-weight:700; color:var(--ink); margin:0 0 12px}
.service-card__features,.service-card__perfect-for{list-style:none; padding:0; margin:0 0 20px}
.service-card__features li,.service-card__perfect-for li{padding:8px 0 8px 24px; position:relative; color:var(--ink-2); line-height:1.6; font-size:15px}
.service-card__features li::before{content:"✓"; position:absolute; left:0; color:var(--accent); font-weight:700; font-size:16px}
.service-card__perfect-for li::before{content:"•"; position:absolute; left:0; color:var(--accent); font-weight:700; font-size:20px}
.service-card__cta{text-align:center; margin-top:auto}

/* Format choice */
.format-choice{margin-top:48px; padding-top:48px; border-top:2px solid var(--line)}
.format-choice__title{font-size:26px; font-weight:700; color:var(--ink); margin:0 0 32px; text-align:center}
.format-choice__grid{display:grid; grid-template-columns:repeat(2,1fr); gap:32px; margin-bottom:24px}
.format-choice__card{background:#fff; border:1px solid var(--accent); border-radius:var(--radius); padding:24px; box-shadow:var(--shadow-soft)}
.format-choice__card h4{font-size:18px; font-weight:700; color:var(--ink); margin:0 0 16px}
.format-choice__card ul{list-style:none; padding:0; margin:0}
.format-choice__card li{padding:8px 0; color:var(--ink-2); font-size:15px; line-height:1.6}
.format-choice__help{text-align:center; font-size:16px; color:var(--ink-2); margin:0}
.format-choice__help a{color:var(--accent); font-weight:600}

/* FAQ SEO */
.faq-seo{padding:96px 0; background:var(--bg)}
.faq-seo__list{max-width:900px; margin:0 auto}
.faq-item{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:28px; margin-bottom:20px; box-shadow:var(--shadow-soft); transition:transform .2s ease, box-shadow .2s ease}
.faq-item:hover{transform:translateY(-2px); box-shadow:var(--shadow)}
.faq-item__question{font-size:20px; font-weight:700; color:var(--ink); margin:0 0 16px; line-height:1.4}
.faq-item__answer{font-size:16px; color:var(--ink-2); line-height:1.7; margin:0}
.faq-item__answer p{margin:0}

/* Maillage interne */
.maillage-interne{padding:64px 0; background:linear-gradient(135deg, rgba(107,189,164,.08) 0%, rgba(37,99,235,.08) 100%); border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
.maillage-interne__content{max-width:800px; margin:0 auto; text-align:center}
.maillage-interne__content h3{font-size:26px; font-weight:700; color:var(--ink); margin:0 0 16px}
.maillage-interne__content p{font-size:17px; color:var(--ink-2); line-height:1.7; margin:0 0 24px}

/* Contact */
.contact{padding:96px 0; background:var(--bg-soft)}
.contact__content{display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:start}
.contact__info h3{font-size:24px; font-weight:700; color:var(--ink); margin:0 0 16px}
.contact__info p{font-size:16px; color:var(--ink-2); line-height:1.7; margin:0 0 24px}
.contact__benefits{list-style:none; padding:0; margin:0}
.contact__benefits li{padding:10px 0 10px 28px; position:relative; color:var(--ink-2); line-height:1.6; font-size:16px}
.contact__benefits li::before{content:"✓"; position:absolute; left:0; color:var(--accent); font-weight:700; font-size:18px}

/* Responsive - Services SEO */
@media (max-width: 1024px){
  .services-principaux__grid{grid-template-columns:1fr; gap:24px}
  .format-choice__grid{grid-template-columns:1fr}
}
@media (max-width: 640px){
  .service-card{padding:24px}
  .service-card__title{font-size:22px}
  .price-amount{font-size:28px}
  .format-choice__card{padding:20px}
  .contact__content{grid-template-columns:1fr}
}

/* ---------- Services Hub (Page Services) ---------- */
.services-hub{padding:96px 0; background:var(--bg)}
.services-hub__grid{display:grid; grid-template-columns:repeat(3,1fr); gap:40px; margin-bottom:48px}
.service-hub-card{display:flex; flex-direction:column; background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:40px 32px; box-shadow:var(--shadow-soft); transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease; text-decoration:none; color:inherit; height:100%}
.service-hub-card:hover{transform:translateY(-6px); box-shadow:0 12px 36px rgba(0,0,0,.12); border-color:var(--accent)}
.service-hub-card:focus{outline:3px solid var(--accent); outline-offset:2px}
.service-hub-card__icon{font-size:48px; text-align:center; margin-bottom:24px; line-height:1}
.service-hub-card__title{font-size:24px; font-weight:700; color:var(--ink); margin:0 0 16px; text-align:center; line-height:1.3}
.service-hub-card__description{font-size:17px; color:var(--ink-2); line-height:1.7; text-align:center; margin:0 0 24px; flex:1}
.service-hub-card__link{display:block; font-size:16px; font-weight:600; color:var(--accent); text-align:center; text-decoration:none; transition:text-decoration .2s ease}
.service-hub-card:hover .service-hub-card__link{text-decoration:underline; text-underline-offset:3px}

/* Services hub footer */
.services-hub__footer{text-align:center; padding:48px; background:linear-gradient(135deg, rgba(107,189,164,.08) 0%, rgba(37,99,235,.08) 100%); border:1px solid var(--accent); border-radius:var(--radius); box-shadow:var(--shadow-soft)}
.services-hub__footer-text{font-size:20px; color:var(--ink); margin:0 0 24px; font-weight:600; line-height:1.5}

/* Responsive - Services Hub */
@media (max-width: 768px){
  .services-hub__grid{grid-template-columns:1fr; gap:24px}
  .service-hub-card{padding:32px 24px}
  .services-hub__footer{padding:32px 24px}
  .services-hub__footer-text{font-size:18px}
}

/* ---------- Processus Hub (Page Services) ---------- */
.processus-hub{padding:96px 0; background:var(--bg-soft)}
.processus-hub__steps{display:grid; grid-template-columns:repeat(4,1fr); gap:32px; margin-bottom:48px}
.processus-hub-step{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:32px 24px; box-shadow:var(--shadow-soft); transition:transform .2s ease, box-shadow .2s ease}
.processus-hub-step:hover{transform:translateY(-4px); box-shadow:var(--shadow)}
.processus-hub-step__number{width:56px; height:56px; background:var(--accent); color:#fff; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:28px; font-weight:700; margin:0 auto 20px}
.processus-hub-step h3{font-size:20px; font-weight:700; color:var(--ink); margin:0 0 12px; text-align:center; line-height:1.3}
.processus-hub-step p{font-size:15px; color:var(--ink-2); line-height:1.6; margin:0 0 16px; text-align:center}
.processus-hub-step__livrables{font-size:14px; color:var(--ink-2); line-height:1.5; padding:16px; background:var(--bg-soft); border-radius:8px; border-left:3px solid var(--accent)}
.processus-hub-step__livrables strong{color:var(--ink); font-weight:600}

/* Délais indicatifs */
.processus-hub__delais{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:32px; box-shadow:var(--shadow-soft); margin-bottom:32px}
.processus-hub__delais h3{font-size:22px; font-weight:700; color:var(--ink); margin:0 0 20px; text-align:center}
.processus-hub__delais ul{list-style:none; padding:0; margin:0; max-width:700px; margin:0 auto}
.processus-hub__delais li{padding:12px 0 12px 32px; position:relative; color:var(--ink-2); line-height:1.6; font-size:16px}
.processus-hub__delais li::before{content:"⏱️"; position:absolute; left:0; font-size:20px}

/* Micro-CTA */
.processus-hub__cta{text-align:center; padding:32px; background:linear-gradient(135deg, rgba(107,189,164,.08) 0%, rgba(37,99,235,.08) 100%); border:1px solid var(--accent); border-radius:var(--radius); box-shadow:var(--shadow-soft)}
.processus-hub__cta p{font-size:20px; color:var(--ink); margin:0 0 20px; font-weight:600}

/* Responsive - Processus Hub */
@media (max-width: 1024px){
  .processus-hub__steps{grid-template-columns:repeat(2,1fr); gap:24px}
}
@media (max-width: 640px){
  .processus-hub__steps{grid-template-columns:1fr; gap:20px}
  .processus-hub-step{padding:24px 20px}
  .processus-hub-step__number{width:48px; height:48px; font-size:24px; margin-bottom:16px}
  .processus-hub-step h3{font-size:18px}
  .processus-hub__delais{padding:24px 20px}
  .processus-hub__delais h3{font-size:20px}
  .processus-hub__cta{padding:24px 20px}
  .processus-hub__cta p{font-size:18px}
}

/* ---------- Pourquoi Formation (Page Formations) ---------- */
.pourquoi-formation{padding:96px 0; background:var(--bg-soft)}
.pourquoi-formation__grid{display:grid; grid-template-columns:repeat(3,1fr); gap:40px}
.pourquoi-formation__item{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:32px; box-shadow:var(--shadow-soft); transition:transform .2s ease, box-shadow .2s ease; display:flex; flex-direction:column; height:100%}
.pourquoi-formation__item:hover{transform:translateY(-4px); box-shadow:0 12px 34px rgba(0,0,0,.12)}
.pourquoi-formation__icon{font-size:48px; text-align:center; margin-bottom:20px; line-height:1}
.pourquoi-formation__item h3{font-size:22px; font-weight:700; color:var(--ink); margin:0 0 16px; text-align:center; line-height:1.3}
.pourquoi-formation__item > p{font-size:16px; color:var(--ink-2); line-height:1.7; margin:0 0 20px; text-align:left}
.pourquoi-formation__points{list-style:none; padding:0; margin:0 0 20px}
.pourquoi-formation__points li{padding:8px 0 8px 24px; position:relative; color:var(--ink-2); line-height:1.7; font-size:15px}
.pourquoi-formation__points li::before{content:"•"; position:absolute; left:0; color:var(--accent); font-weight:700; font-size:20px}
.pourquoi-formation__resultat{font-size:15px; color:var(--muted); line-height:1.6; margin:20px 0 16px; text-align:left}
.pourquoi-formation__resultat em{font-style:italic; font-weight:400}
.pourquoi-formation__link{display:inline-block; font-size:15px; font-weight:600; color:var(--accent); text-decoration:none; transition:color .2s ease, text-decoration .2s ease; margin-top:auto}
.pourquoi-formation__link:hover{color:var(--accent-600); text-decoration:underline; text-underline-offset:3px}

/* Responsive - Pourquoi Formation */
@media (max-width: 1024px){
  .pourquoi-formation__grid{grid-template-columns:1fr; gap:24px}
}
@media (max-width: 640px){
  .pourquoi-formation__item{padding:24px}
  .pourquoi-formation__item h3{font-size:20px}
}

/* ---------- Formations Cards (Page Formations) ---------- */
.formations{padding:96px 0; background:var(--bg)}
.formations__grid{display:grid; gap:40px; margin:0 auto}
.formations__grid--two{grid-template-columns:repeat(2, 1fr); max-width:1000px}
.formation-card{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:40px 32px; box-shadow:var(--shadow-soft); transition:transform .2s ease, box-shadow .2s ease; display:flex; flex-direction:column; height:100%}
.formation-card:hover{transform:translateY(-4px); box-shadow:0 12px 34px rgba(0,0,0,.12)}
.formation-card__badge{display:inline-block; padding:6px 16px; background:var(--accent); color:#fff; font-size:14px; font-weight:600; border-radius:20px; margin-bottom:20px; align-self:flex-start}
.formation-card__badge--popular{background:linear-gradient(135deg, var(--accent) 0%, var(--accent-600) 100%)}
.formation-card__title{font-size:26px; font-weight:700; color:var(--ink); margin:0 0 12px; line-height:1.2}
.formation-card__subtitle{font-size:16px; color:var(--ink-2); line-height:1.6; margin:0 0 24px}
.formation-card__content{flex:1; margin-bottom:28px}
.formation-card__features{list-style:none; padding:0; margin:0 0 24px}
.formation-card__features li{padding:10px 0 10px 28px; position:relative; color:var(--ink-2); line-height:1.6; font-size:15px}
.formation-card__features li::before{content:"✓"; position:absolute; left:0; color:var(--accent); font-weight:700; font-size:18px}
.formation-card__perfect{padding:20px; background:var(--bg-soft); border-left:3px solid var(--accent); border-radius:8px; margin-top:24px}
.formation-card__perfect p{margin:0; font-size:15px; color:var(--ink-2); line-height:1.6}
.formation-card__cta{text-align:center}
.btn--full{width:auto; max-width:280px; display:inline-block; padding:16px 32px}

/* Responsive - Formations Cards */
@media (max-width: 1024px){
  .formations__grid--two{grid-template-columns:1fr; max-width:600px}
}
@media (max-width: 640px){
  .formation-card{padding:32px 24px}
  .formation-card__title{font-size:24px}
  .btn--full{max-width:100%; width:100%}
}

/* =============================================
   ARTICLE DE BLOG
   ============================================= */

/* Hero article */
.article-hero{
  padding: 60px 0 40px;
  background: var(--bg-soft);
  border-bottom: 1px solid var(--line);
}
.article-hero__inner{
  max-width: 760px;
  margin: 0 auto;
}
.article-hero__retour{
  display: inline-block;
  font-size: 14px;
  color: var(--muted);
  text-decoration: none;
  margin-bottom: 24px;
  transition: color .2s;
}
.article-hero__retour:hover{ color: var(--accent); }
.article-hero__meta{
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 20px;
  font-size: 14px;
  color: var(--muted);
}
.article-hero__titre{
  font-size: clamp(26px, 4vw, 38px);
  font-weight: 700;
  color: var(--ink);
  line-height: 1.25;
  margin: 0;
}

/* Corps article */
.article-corps{
  padding: 60px 0 80px;
}
.article-corps__inner{
  max-width: 760px;
  margin: 0 auto;
  font-size: 18px;
  line-height: 1.8;
  color: var(--ink-2);
}
.article-corps__inner p{
  margin: 0 0 24px;
}
.article-liste{
  margin: 0 0 24px 0;
  padding: 0;
  list-style: none;
}
.article-liste li{
  padding: 8px 0 8px 32px;
  position: relative;
  color: var(--ink-2);
  line-height: 1.7;
}
.article-liste li::before{
  content: "→";
  position: absolute;
  left: 0;
  color: var(--accent);
  font-weight: 700;
}

.article-h2{
  font-size: 22px;
  font-weight: 700;
  color: var(--ink);
  margin: 40px 0 12px;
  line-height: 1.3;
}

.article-encadre{
  background: #F0FAF6;
  border: 2px solid var(--accent);
  border-radius: var(--radius);
  padding: 20px 24px;
  margin: 0 0 36px;
}
.article-encadre__titre{
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--accent-600);
  margin: 0 0 10px;
}
.article-encadre p{
  margin: 0;
  color: var(--ink-2);
  font-size: 16px;
  line-height: 1.65;
}

.kit-survie{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin: 28px 0 36px;
}
.kit-survie__carte{
  border: 1.5px solid var(--line);
  border-radius: var(--radius);
  padding: 20px;
  background: #fff;
}
.kit-survie__label{
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  padding: 3px 10px;
  border-radius: 20px;
  margin-bottom: 12px;
}
.kit-survie__label--a{ background: #DCFCE7; color: #166534; }
.kit-survie__label--b{ background: #FEF9C3; color: #854D0E; }
.kit-survie__label--c{ background: #EFF6FF; color: #1E40AF; }
.kit-survie__titre{
  font-size: 15px;
  font-weight: 700;
  color: var(--ink);
  margin: 0 0 10px;
}
.kit-survie__texte{
  font-size: 14px;
  color: var(--ink-2);
  line-height: 1.6;
  margin: 0;
}
@media (max-width: 640px){
  .kit-survie{ grid-template-columns: 1fr; }
}

@media (max-width: 640px){
  .article-hero{ padding: 40px 0 28px; }
  .article-corps{ padding: 40px 0 60px; }
  .article-corps__inner{ font-size: 17px; }
  .article-h2{ font-size: 20px; margin-top: 32px; }
}

/* ============================================
   DÉCLIC 90 — Hero & Benefits
   ============================================ */

/* Hero */
.hero--d90-luxury{
  background:
    radial-gradient(ellipse 800px 500px at 60% -10%, rgba(249,115,22,.45), transparent 65%),
    radial-gradient(ellipse 600px 400px at 10% 90%, rgba(250,204,21,.25), transparent 65%),
    linear-gradient(155deg, #0f172a 0%, #1e1b4b 55%, #0f172a 100%);
  color: #f8fafc;
  padding: 100px 0 80px;
  position: relative;
  overflow: hidden;
}
.hero--d90-luxury::before{
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle 300px at 75% 40%, rgba(249,115,22,.12), transparent 70%);
  pointer-events: none;
}

/* Contenu hero */
.hero__content--d90-luxury{
  max-width: 680px;
  margin: 0 auto;
  text-align: center;
}
.hero__eyebrow--d90{
  display: inline-block;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #f97316;
  background: rgba(249,115,22,.12);
  border: 1px solid rgba(249,115,22,.3);
  border-radius: 999px;
  padding: 5px 16px;
  margin-bottom: 24px;
}
.hero__title--d90-luxury{
  font-size: clamp(40px, 6vw, 64px);
  font-weight: 800;
  line-height: 1.08;
  color: #f8fafc;
  margin: 0 0 8px;
  letter-spacing: -.02em;
}
.hero__title--d90-luxury .title-accent{
  display: block;
  font-size: clamp(22px, 3.5vw, 36px);
  font-weight: 500;
  color: #f97316;
  letter-spacing: 0;
  margin-top: 6px;
}
.hero__subtitle--d90-luxury{
  font-size: 18px;
  line-height: 1.7;
  color: rgba(248,250,252,.8);
  margin: 24px 0 36px;
  max-width: 560px;
}

/* Stats badges */
.hero__stats--d90{
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 40px;
}
.stat-badge--d90{
  display: flex;
  flex-direction: column;
  align-items: center;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 14px;
  padding: 16px 24px;
  min-width: 90px;
  backdrop-filter: blur(8px);
}
.stat-badge--d90__number{
  font-size: 32px;
  font-weight: 800;
  color: #f97316;
  line-height: 1;
}
.stat-badge--d90__label{
  font-size: 12px;
  font-weight: 500;
  color: rgba(248,250,252,.6);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-top: 4px;
}

/* Bouton d90-luxury */
.btn--d90-luxury{
  display: inline-block;
  background: linear-gradient(135deg, #f97316 0%, #ea580c 100%);
  color: #fff;
  font-weight: 700;
  font-size: 17px;
  padding: 16px 36px;
  border-radius: 12px;
  text-decoration: none;
  border: none;
  box-shadow: 0 4px 24px rgba(249,115,22,.4), 0 1px 0 rgba(255,255,255,.1) inset;
  transition: transform .2s, box-shadow .2s;
  cursor: pointer;
}
.btn--d90-luxury:hover{
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(249,115,22,.5), 0 1px 0 rgba(255,255,255,.1) inset;
}

/* ---- Section "Ce que vous obtenez" ---- */
.section--d90-benefits{
  padding: 80px 0 80px;
  background: #f8fafc;
}
.section__title--d90{
  font-size: clamp(26px, 4vw, 38px);
  font-weight: 800;
  color: #0f172a;
  text-align: center;
  margin: 0 0 12px;
  letter-spacing: -.02em;
}
.accent-bar--d90{
  width: 48px;
  height: 4px;
  background: linear-gradient(90deg, #f97316, #facc15);
  border-radius: 999px;
  margin: 0 auto 48px;
}

/* Grille 3 colonnes */
.benefits-grid--d90{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

/* Carte */
.benefit-card--d90{
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 20px;
  padding: 36px 32px;
  box-shadow: 0 2px 12px rgba(15,23,42,.06);
  transition: transform .2s, box-shadow .2s;
}
.benefit-card--d90:hover{
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(15,23,42,.1);
}

/* Numéro 01 / 02 / 03 */
.benefit-card--d90__number{
  display: inline-block;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .08em;
  color: #f97316;
  background: rgba(249,115,22,.1);
  border-radius: 999px;
  padding: 4px 14px;
  margin-bottom: 20px;
}
.benefit-card--d90__title{
  font-size: 20px;
  font-weight: 700;
  color: #0f172a;
  margin: 0 0 12px;
  line-height: 1.3;
}
.benefit-card--d90__description{
  font-size: 16px;
  color: #475569;
  line-height: 1.7;
  margin: 0;
}

/* CTA centré sous la grille */
.text-center--d90{
  text-align: center;
}
.mt-64--d90{
  margin-top: 48px;
}

/* Responsive */
@media (max-width: 900px){
  .benefits-grid--d90{
    grid-template-columns: 1fr;
    gap: 20px;
    max-width: 560px;
    margin: 0 auto;
  }
  .hero--d90-luxury{
    padding: 72px 0 60px;
  }
}
@media (max-width: 640px){
  .hero__title--d90-luxury{
    font-size: 36px;
  }
  .hero__subtitle--d90-luxury{
    font-size: 16px;
  }
  .stat-badge--d90{
    padding: 12px 18px;
    min-width: 76px;
  }
  .stat-badge--d90__number{
    font-size: 26px;
  }
  .btn--d90-luxury{
    font-size: 16px;
    padding: 14px 28px;
  }
  .benefit-card--d90{
    padding: 28px 24px;
  }
  .section--d90-benefits{
    padding: 60px 0;
  }
}

/* ============================================
   DÉCLIC VISIBILITÉ — Hero & Benefits
   ============================================ */

/* Hero explosive */
.hero--dv-explosive{
  background:
    radial-gradient(ellipse 700px 500px at 80% 30%, rgba(249,115,22,.55), transparent 65%),
    radial-gradient(ellipse 500px 400px at 20% 80%, rgba(234,88,12,.35), transparent 65%),
    linear-gradient(135deg, #7c3aed 0%, #c2410c 50%, #ea580c 100%);
  color: #fff;
  padding: 100px 0 80px;
  position: relative;
  overflow: hidden;
}
.hero--dv-explosive::before{
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle 250px at 85% 20%, rgba(255,255,255,.08), transparent 70%);
  pointer-events: none;
}

.hero__content--dv-explosive{
  max-width: 680px;
}

/* Titre très grand, impactant */
.hero__title--dv-explosive{
  font-size: clamp(52px, 9vw, 88px);
  font-weight: 900;
  line-height: 0.95;
  color: #fff;
  letter-spacing: -.03em;
  margin: 0 0 24px;
  text-shadow: 0 2px 20px rgba(0,0,0,.2);
}

.hero__subtitle--dv-explosive{
  font-size: 19px;
  line-height: 1.65;
  color: rgba(255,255,255,.9);
  margin: 0 0 32px;
  max-width: 540px;
}

/* Badges */
.hero__badges--dv{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 36px;
}
.badge--dv{
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 14px;
  font-weight: 600;
  color: #fff;
  background: rgba(255,255,255,.15);
  border: 1px solid rgba(255,255,255,.25);
  border-radius: 999px;
  padding: 7px 16px;
  backdrop-filter: blur(8px);
}

/* Bouton explosive */
.btn--dv-explosive{
  display: inline-block;
  background: #fff;
  color: #c2410c;
  font-weight: 800;
  font-size: 17px;
  padding: 18px 40px;
  border-radius: 12px;
  text-decoration: none;
  border: none;
  box-shadow: 0 4px 24px rgba(0,0,0,.25);
  transition: transform .2s, box-shadow .2s;
  letter-spacing: .01em;
}
.btn--dv-explosive:hover{
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 10px 36px rgba(0,0,0,.3);
}

/* ---- Section "Ce que vous obtenez" DV ---- */
.section--dv-benefits{
  padding: 80px 0;
  background: #fff;
}
.section__title--dv{
  font-size: clamp(26px, 4vw, 38px);
  font-weight: 800;
  color: #0f172a;
  text-align: center;
  margin: 0 0 48px;
  letter-spacing: -.02em;
}
/* Aussi utilisé dans le body declic-visibilite pour section__title--declic */
.section__title--declic{
  font-size: clamp(22px, 3.5vw, 32px);
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 24px;
}

/* Grille 3 colonnes */
.benefits-grid--dv{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

/* Cartes DV */
.benefit-card--dv{
  background: #fff;
  border: 2px solid #f1f5f9;
  border-radius: 20px;
  padding: 36px 28px;
  box-shadow: 0 2px 16px rgba(15,23,42,.06);
  transition: transform .2s, box-shadow .2s, border-color .2s;
  text-align: center;
}
.benefit-card--dv:hover{
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(234,88,12,.12);
  border-color: rgba(249,115,22,.3);
}
.benefit-card--dv__icon{
  font-size: 40px;
  display: block;
  margin-bottom: 16px;
}
.benefit-card--dv__title{
  font-size: 20px;
  font-weight: 700;
  color: #0f172a;
  margin: 0 0 12px;
  line-height: 1.3;
}
.benefit-card--dv__description{
  font-size: 16px;
  color: #475569;
  line-height: 1.7;
  margin: 0;
}

/* Responsive DV */
@media (max-width: 900px){
  .benefits-grid--dv{
    grid-template-columns: 1fr;
    gap: 20px;
    max-width: 500px;
    margin: 0 auto;
  }
  .hero--dv-explosive{
    padding: 72px 0 60px;
  }
}
@media (max-width: 640px){
  .hero__title--dv-explosive{
    font-size: 48px;
  }
  .hero__subtitle--dv-explosive{
    font-size: 17px;
  }
  .btn--dv-explosive{
    font-size: 16px;
    padding: 16px 28px;
  }
  .benefit-card--dv{
    padding: 28px 20px;
  }
  .section--dv-benefits{
    padding: 60px 0;
  }
}