
:root{
  --bg:#f7f9fc;
  --paper:#ffffff;
  --text:#0f172a;
  --muted:#6b7280;
  --primary:#2F6CFD;
  --primary-700:#1F56E8;
  --primary-200:#DBEAFE;
  --accent:#35C7B2;
  --shadow:0 10px 30px rgba(24,30,60,.10);
  --radius:18px;
  --maxw:1200px;
}
*{box-sizing:border-box}
html,body{height:100%background:radial-gradient(1200px 600px at 0% -10%, rgba(219,234,254,.6), transparent 70%), linear-gradient(180deg,var(--bg),#fff 60%);}
body{margin:0;color:var(--text);
  font:16px/1.55 Inter, ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial; -webkit-font-smoothing:antialiasedbackground:radial-gradient(1200px 600px at 0% -10%, rgba(219,234,254,.6), transparent 70%), linear-gradient(180deg,var(--bg),#fff 60%);}
a{color:var(--primary);text-decoration:none}
.container{max-width:var(--maxw);margin:0 auto;padding:28px 24px 36px}
.header{display:flex;align-items:center;justify-content:space-between;padding:18px 0}
.brand{display:flex;align-items:center;gap:10px;font-weight:800}
.brand-img{height:56px;width:auto;display:block;object-fit:contain}
.nav-cta{display:inline-flex;align-items:center;gap:10px;color:#fff;text-decoration:none;background:linear-gradient(180deg,#4C8DFF 0%, #2563EB 100%);padding:16px 22px;border-radius:14px;font-weight:900;box-shadow:0 6px 18px rgba(37,99,235,.25);}
.hero{display:grid;grid-template-columns:minmax(640px,1fr) 600px;gap:64px;align-items:stretch;margin:10px 0 30px}
.hero .kicker{display:inline-block;background:#EAF2FF;color:#2F6CFD;padding:10px 16px;border-radius:12px;font-weight:800;border:1px solid #e0eaff}
.hero h1{font-size:clamp(38px,3.8vw,50px);line-height:1.075;margin:14px 0 14px;font-weight:800;color:#2F6CFD;letter-spacing:-0.2px}
.hero p{color:#35465a;font-size:16.5px;line-height:1.7}
.card{background:#fff;border-radius:20px;box-shadow:0 12px 34px rgba(16,38,94,.08);padding:34px 30px;border:1px solid #eaf0ff}
.btn{display:inline-flex;align-items:center;gap:10px;border:none;color:#fff;background:linear-gradient(180deg,#4C8DFF 0%, #2563EB 100%);padding:16px 22px;border-radius:14px;font-weight:900;box-shadow:0 6px 18px rgba(37,99,235,.25);}
.partners{border-top:1px solid #eef1f5;margin-top:18px;padding-top:22px;color:#8e94a3}
.section{margin:28px 0}
.box{background:var(--paper);border-radius:18px;box-shadow:var(--shadow);padding:20px}
.list{list-style:none;margin:0;padding:0;display:grid;gap:12px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.ul{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.split{display:grid;grid-template-columns:.9fr 1.1fr;gap:26px;align-items:center}
.split img{width:100%;border-radius:16px;box-shadow:var(--shadow)}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.step{background:var(--paper);box-shadow:var(--shadow);border-radius:16px;padding:18px}
.step .label{display:inline-block;background:#eef0ff;color:var(--primary);padding:6px 12px;border-radius:999px;font-weight:900}
.faq{max-width:800px;margin:0 auto}
.faq-item{border-top:1px solid #e5ecfb}
.faq-item button{width:100%;text-align:left;background:none;border:none;padding:16px 4px;font-size:18px;font-weight:900;display:flex;justify-content:space-between;align-items:center}
.faq-item .answer{display:none;color:#4b5563;padding:0 0 16px}
.faq-item.open .answer{display:block}
.footer{margin-top:28px;padding:28px 0;border-top:1px solid #eef1f5;color:#6d7381;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap}
.form-wrap{max-width:760px;margin:12px auto}
label{font-weight:800;display:block;margin:10px 0 6px}
input,select,textarea{width:100%;padding:12px 14px;border-radius:12px;border:1px solid #e7e9f3;background:#fff;outline:none}
input:focus,select:focus,textarea:focus{box-shadow:0 0 0 3px rgba(109,93,246,.25);border-color:#cfd3ff}
.input-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.select-row{position:relative}
.select-row:after{content:"▾";position:absolute;right:14px;top:50%;transform:translateY(-50%);color:#6b6f7c;pointer-events:none}
.small{font-size:12px;color:#7b8193}
.icon-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px;align-items:center}
.phone-row{display:grid;grid-template-columns:180px 1fr;gap:10px;align-items:center}
@media (max-width: 980px){
 .hero{display:grid;grid-template-columns:minmax(640px,1fr) 600px;gap:64px;align-items:stretch;margin:10px 0 30px}
  .split{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .input-row{grid-template-columns:1fr}
}

@media (max-width:600px){.brand-img{height:56px;width:auto;display:block;object-fit:contain}}

.footer-centered{flex-direction:column;align-items:center;text-align:center}
.footer-centered .brand{margin-bottom:8px}
.footer-centered .brand .brand-word{font-weight:900;font-size:36px;letter-spacing:.2px}
.footer-centered .small{max-width:980px}

.card{background:#fff;border-radius:20px;box-shadow:0 12px 34px rgba(16,38,94,.08);padding:34px 30px;border:1px solid #eaf0ff}

.footer-contact{display:flex;gap:10px;align-items:center;justify-content:center;margin:6px 0 10px}
.footer-contact a{color:#2563EB;font-weight:700}

@media (max-width:600px){.brand-img{height:56px;width:auto;display:block;object-fit:contain}}

.cta-card{height:100%;display:flex;flex-direction:column;justify-content:space-evenly;gap:22px}
.cta-title{display:flex;align-items:center;gap:10px;font-weight:800;color:#0a1a2f;margin-bottom:14px}
.cta-label{color:#0a1a2f;font-weight:900}
.cta-btn{display:flex;align-items:center;justify-content:center;gap:12px;min-height:66px;width:100%;background:linear-gradient(180deg,#4F8BFF 0%, #2563EB 100%);color:#fff;border:none;border-radius:16px;font-weight:900;font-size:19px;box-shadow:0 14px 30px rgba(37,99,235,.18);cursor:pointer}
.cta-icons-title{margin-top:22px;color:#172131;font-weight:900}
.cta-icons{display:flex;gap:12px;flex-wrap:wrap;align-items:center}

@media(max-width:640px){.brand-img{height:44px}}

.hero>aside{align-self:stretch}

.cta-card{height:100%;display:flex;flex-direction:column;justify-content:space-evenly;gap:22px}

.cta-title, .cta-icons-title{ text-align:center; }

.cta-icons{ display:flex; justify-content:center; align-items:center; }


/* Mobile polish & measure */
@media (max-width: 1024px){
  html,body{overflow-x:hidden}
  .container{padding-inline:16px}
  .grid,.grid-2,.grid-3,[class*="grid-cols"],.hero-grid,.cols{display:grid;grid-template-columns:1fr !important;gap:16px}
  .card,.panel,.form-card,.final-wrap{max-width:100% !important;margin-inline:auto}
  .header{display:flex;align-items:center;gap:12px}
  .header .nav-cta{position:static !important;margin-left:auto}
}
@media (max-width: 600px){
  .brand-img{max-height:28px;width:auto}
  .chip{font-size:13px !important;padding:8px 12px !important;border-radius:999px !important}
  .hero h1,h1.hero-title{font-size:clamp(24px,6.4vw,32px) !important;line-height:1.15 !important;margin:8px 0 10px !important}
  .hero,.section-hero,.hero .content,.hero .copy,.hero .prose,.hero .text,.hero h1,h1.hero-title,.hero p,.hero .lead,.hero ul,.hero li,.rating-line,.badges,.proof{text-align:center !important;margin-left:auto !important;margin-right:auto !important}
  .hero ul{list-style-position:inside;padding-left:0 !important}
  .header .nav-cta{display:none !important}
  .mobile-cta-only{display:block;text-align:center;margin:10px auto 6px}
  .mobile-cta{display:inline-flex;align-items:center;justify-content:center;width:100%;max-width:520px;padding:14px 18px;font-weight:800;font-size:16px;line-height:1;border-radius:14px;text-decoration:none}
}
@media (max-width: 430px){
  html{-webkit-text-size-adjust:100%}
  .hero .container,.section-hero .container,.container{padding-left:max(14px,env(safe-area-inset-left)) !important;padding-right:max(14px,env(safe-area-inset-right)) !important;margin-inline:auto !important;box-sizing:border-box}
  .hero,.section-hero{width:100%;margin-inline:0 !important}
  .hero .grid,.hero-grid,.hero .cols{display:grid !important;grid-template-columns:1fr !important}
  .hero .content,.hero .copy,.hero .prose,.hero .text,.hero-left,.col-left,.hero .stack,.hero .grid>*{padding-inline:0 !important;margin-inline:0 !important;max-width:100% !important;width:100% !important}
  .hero h1,h1.hero-title{font-size:clamp(19px,4.4vw,22px) !important;line-height:1.18 !important;overflow-wrap:anywhere !important;word-break:break-word !important;text-wrap:balance;margin:6px 0 8px !important}
  .hero p,.hero .lead{font-size:14px !important;line-height:1.42 !important}
}
/* Reading measure */
@media (max-width: 600px){
  .hero .copy,.hero .prose,.hero .text,.hero p,.hero .lead{max-width:36ch !important}
  .hero h1,h1.hero-title{max-width:26ch !important}
}
/* Mobile-only <br> */
br.only-mobile{display:none}
@media (max-width: 600px){ br.only-mobile{display:block} }
img,video{max-width:100%;height:auto}


/* v33 — Strong centering for hero on tablet & mobile */
@media (max-width: 1024px){
  /* Force single-column hero and center its content */
  .hero .grid, .hero-grid, .hero .cols, .grid-2, .grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 16px;
  }
  .hero, .section-hero {
    text-align: center !important;
  }
  .hero .grid > *, .hero-left, .hero-right, .col-left, .col-right, .hero .content, .hero .copy, .hero .prose, .hero .text {
    margin-left: auto !important;
    margin-right: auto !important;
    max-width: 36rem; /* ~576px */
    width: 100% !important;
    justify-self: center !important;
  }

  /* Center key elements */
  .chip, .chip-centered { 
    display: inline-block; 
    margin-left: auto !important; 
    margin-right: auto !important; 
  }
  .hero h1, h1.hero-title, .hero p, .hero .lead {
    text-align: center !important;
  }
  .rating-line, .proof, .badges {
    display: flex; 
    flex-wrap: wrap; 
    justify-content: center; 
    gap: 8px;
    text-align: center !important;
  }

  /* Move the header CTA out (we already inject a mobile CTA below the proof) */
  .header .nav-cta{ display:none !important; }

  /* Keep the reading measure */
  .hero .copy, .hero .prose, .hero .text, .hero p, .hero .lead { max-width: 36ch !important; }
  .hero h1, h1.hero-title { max-width: 26ch !important; }
}

/* Slight spacing tune for the injected mobile CTA */
@media (max-width: 1024px){
  .mobile-cta-only{ margin: 14px auto 6px; }
  .mobile-cta{ max-width: 520px; }
}

@media (max-width: 1024px){
  .chip, .chip-badge, .chip-primary { 
    text-align: center !important;
  }
}


/* v34 — Ultra-centered hero on phones */
@media (max-width: 600px){
  /* Kill any sneaky paddings that push to the right */
  .hero, .hero *{
    box-sizing: border-box;
  }
  .hero .content, .hero .copy, .hero .prose, .hero .text,
  .hero-left, .col-left, .hero .stack, .hero .grid > *{
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
  .hero .grid, .hero-grid, .hero .cols{
    display:grid !important;
    grid-template-columns: 1fr !important;
    justify-items: center !important;
    align-items: start !important;
    gap: 14px;
  }
  /* Center critical blocks explicitly */
  .chip, .chip-primary, .chip-badge, .chip-centered{
    display:inline-flex !important;
    justify-content:center; align-items:center;
    margin-inline:auto !important;
  }
  .hero h1, h1.hero-title,
  .hero p, .hero .lead,
  .rating-line, .proof{
    text-align:center !important;
    margin-inline:auto !important;
    text-wrap:balance;
  }
  /* KPI line (90% ...) */
  .hero .kpi, .hero .stat, .hero .meta, .hero .bullet, .hero .dotline{
    text-align:center !important;
    justify-content:center !important;
  }
  /* Stars row + "Choisi par..." */
  .rating-line, .proof{
    display:flex; flex-wrap:wrap; justify-content:center; gap:8px;
  }
}


/* v35 — Perfect centering on iPhone */
@media (max-width: 600px){
  /* Ensure perfectly symmetrical padding on the hero container */
  .section-hero, .hero, .section-hero .container, .hero .container{
    padding-left: 16px !important;
    padding-right: 16px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  /* Make every hero row occupy full width and be centered */
  .hero h1, .hero p, .hero .lead, .hero .kpi, .hero .stat, .hero .meta,
  .rating-line, .proof, .chip, .chip-primary{
    width: 100% !important;
    max-width: 100% !important;
    text-align: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  /* The chip "Compte suspendu/banni ?" */
  .chip, .chip-primary{
    display: inline-flex !important;
    justify-content: center !important;
    align-items: center !important;
  }

  /* Paragraph reading measure while still width:100 for centering */
  .hero p, .hero .lead{
    max-width: 36ch !important;
  }
  .hero h1{ max-width: 26ch !important; }

  /* KPI line "90%" and the stars line */
  .hero .kpi, .hero .stat, .dotline{
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
  }
  .rating-line, .proof{
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
  }

  /* Kill any accidental horizontal offsets */
  .hero .grid, .hero-grid, .hero .cols{
    display: grid !important;
    grid-template-columns: 1fr !important;
    justify-items: center !important;
    align-items: start !important;
  }
  .hero .grid > *{
    padding-left: 0 !important; padding-right: 0 !important;
    margin-left: auto !important; margin-right: auto !important;
  }
}


/* v36 — Subtle left nudge for the whole hero block on small iPhones */
@media (max-width: 600px){
  /* unified nudge for the hero content pieces */
  .hero h1, .hero p, .hero .lead,
  .hero .content, .hero .copy, .hero .prose, .hero .text,
  .chip, .chip-primary, .chip-badge,
  .rating-line, .proof,
  .hero .kpi, .hero .stat, .dotline {
    position: relative;
    left: -6px; /* slight shift left */
  }
}


/* v37 — left nudge tuned to -8px on small screens */
@media (max-width: 600px){
  .hero h1, .hero p, .hero .lead,
  .hero .content, .hero .copy, .hero .prose, .hero .text,
  .chip, .chip-primary, .chip-badge,
  .rating-line, .proof,
  .hero .kpi, .hero .stat, .dotline {
    left: -8px !important;
  }
}


/* v38 — stronger left nudge with clamp for different iPhones */
@media (max-width: 600px){
  .hero h1, .hero p, .hero .lead,
  .hero .content, .hero .copy, .hero .prose, .hero .text,
  .chip, .chip-primary, .chip-badge,
  .rating-line, .proof,
  .hero .kpi, .hero .stat, .dotline {
    position: relative;
    left: clamp(-18px, -3.5vw, -12px) !important;
  }
}


/* v39 — Reset nudges & true flex centering on phones */
@media (max-width: 600px){
  /* Reset previous left offsets */
  .hero h1, .hero p, .hero .lead,
  .hero .content, .hero .copy, .hero .prose, .hero .text,
  .chip, .chip-primary, .chip-badge,
  .rating-line, .proof,
  .hero .kpi, .hero .stat, .dotline {
    left: 0 !important;
  }

  /* Make the hero container full-width and symmetrically padded */
  .section-hero, .hero, .section-hero .container, .hero .container{
    max-width: 100vw !important;
    width: 100% !important;
    padding-left: 14px !important;
    padding-right: 14px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  /* Flex column + perfect centering */
  .hero .grid, .hero-grid, .hero .cols{
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 14px;
  }

  .hero .grid > *,
  .hero-left, .col-left, .hero-right, .col-right,
  .hero .content, .hero .copy, .hero .prose, .hero .text{
    align-self: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  /* Reading measure while centered */
  .hero h1{ max-width: 26ch !important; text-align: center !important; }
  .hero p, .hero .lead{ max-width: 36ch !important; text-align: center !important; }

  /* Chip & proof lines */
  .chip, .chip-primary, .chip-badge{
    display:inline-flex !important;
    justify-content:center !important;
    align-items:center !important;
  }
  .rating-line, .proof, .hero .kpi{
    display:flex !important;
    flex-wrap:wrap !important;
    align-items:center !important;
    justify-content:center !important;
    gap:8px !important;
    width: 100% !important;
  }
}


/* v40 — translate whole hero slightly to the left on phones */
@media (max-width: 600px){
  html, body { overflow-x: hidden !important; }
  .section-hero, .hero, .section-hero .container, .hero .container {
    width: 100vw !important;
    max-width: 100vw !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    box-sizing: border-box;
  }
  /* Subtle left translation to counter residual white band */
  .section-hero, .hero {
    transform: translateX(-12px);
  }
}
