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

  /* 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:48px; --h2:32px; --h3:22px; --p: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(16,185,129,.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)}

/* ---------- 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}

/* ---------- 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 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(16,185,129,.1); color:var(--accent-600); border-color:rgba(16,185,129,.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(16,185,129,.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(16,185,129,.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__grid{
  display:grid; 
  grid-template-columns:repeat(3,1fr); 
  gap:40px; 
  align-items:center; 
  justify-items:center;
  max-width:900px; 
  margin:0 auto;
}
.confiance__item{
  display:flex; 
  align-items:center; 
  justify-content:center;
  width:100%; 
  height:120px; 
  padding:20px; 
  background:#fff; 
  border:1px solid var(--line); 
  border-radius:var(--radius);
  box-shadow:var(--shadow-soft);
  transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.confiance__item:hover{
  transform:translateY(-4px);
  box-shadow:0 12px 32px rgba(0,0,0,.08);
  border-color:rgba(16,185,129,.2);
}
.confiance__logo{
  max-width:100%; 
  max-height:100%; 
  width:auto; 
  height:auto; 
  object-fit:contain;
  filter:grayscale(100%) opacity(0.7);
  transition:filter .3s ease;
}
.confiance__item:hover .confiance__logo{
  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{font-size:40px; text-align:center; margin-bottom:16px; 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)}


/* 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(16,185,129,.3); outline-offset:2px}

/* ---------- 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__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(16,185,129,.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(16,185,129,.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(16,185,129,.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(16,185,129,.03); transform:translateY(-2px); box-shadow:var(--shadow-soft)}
.form-button-choice input:checked + .form-button-choice__content{border-color:var(--accent); background:rgba(16,185,129,.08); box-shadow:0 0 0 3px rgba(16,185,129,.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(16,185,129,.03)}
.form-checkbox-inline:has(input:checked){border-color:var(--accent); background:rgba(16,185,129,.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(16,185,129,.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(16,185,129,.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(16,185,129,.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__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:80px 0}
.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(16,185,129,.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(16,185,129,.3)}
.btn--declic:hover{background:var(--accent-600); transform:translateY(-2px); box-shadow:0 8px 20px rgba(16,185,129,.4)}

/* Bouton Déclic 90 plus visible */
.btn--accompagnement{background:var(--accent); color:#fff; border-color:var(--accent); box-shadow:0 4px 14px rgba(16,185,129,.3)}
.btn--accompagnement:hover{background:var(--accent-600); transform:translateY(-2px); box-shadow:0 8px 20px rgba(16,185,129,.4)}
.form__submit--accompagnement{background:var(--accent); color:#fff; border-color:var(--accent); box-shadow:0 4px 14px rgba(16,185,129,.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(16,185,129,.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(16,185,129,.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(16,185,129,.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(16,185,129,.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%}
}