/* =====================================================================
   Assurance-Lapin.com — Design System
   Warm, trustworthy, modern. Health-green + conversion-coral.
   ===================================================================== */

/* ---------- Design tokens ---------- */
:root{
  --green-800:#0f4d3c;
  --green-700:#15654f;
  --green-600:#1c7d63;
  --green-500:#26a17b;
  --green-400:#43b892;
  --green-100:#d6f2e6;
  --green-50:#eafaf3;

  --coral-600:#e8451f;
  --coral-500:#ff5c39;
  --coral-400:#ff7a4d;

  --amber:#f6b73c;
  --amber-soft:#fff4d6;

  --ink:#16302a;
  --slate:#4f6560;
  --slate-light:#7d918c;

  --paper:#ffffff;
  --cream:#f5faf7;
  --cream-2:#eef6f1;
  --line:#e0ebe5;
  --line-strong:#cadbd2;

  --red-600:#d64545;
  --red-50:#fdecec;
  --blue-600:#2b6cb0;
  --blue-50:#e9f2fb;

  --radius-sm:8px;
  --radius:14px;
  --radius-lg:22px;
  --radius-pill:999px;

  --shadow-sm:0 1px 2px rgba(16,48,42,.06),0 1px 3px rgba(16,48,42,.08);
  --shadow:0 6px 20px rgba(16,48,42,.08);
  --shadow-lg:0 20px 48px rgba(16,48,42,.14);

  --maxw:1180px;
  --maxw-narrow:820px;

  --font-head:"Poppins",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --font-body:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}

/* ---------- Reset & base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--green-600);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-family:var(--font-head);color:var(--ink);line-height:1.18;font-weight:700;margin:0 0 .5em}
h1{font-size:clamp(2rem,4.5vw,3.15rem);letter-spacing:-.02em}
h2{font-size:clamp(1.55rem,3vw,2.25rem);letter-spacing:-.01em}
h3{font-size:clamp(1.2rem,2vw,1.5rem)}
h4{font-size:1.08rem}
p{margin:0 0 1.1em}
ul,ol{margin:0 0 1.1em;padding-left:1.3em}
li{margin:.35em 0}
strong{font-weight:600;color:var(--ink)}
hr{border:0;border-top:1px solid var(--line);margin:2.5rem 0}
:focus-visible{outline:3px solid var(--green-400);outline-offset:2px;border-radius:4px}

/* ---------- Layout ---------- */
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.container-narrow{max-width:var(--maxw-narrow);margin:0 auto;padding:0 20px}
.section{padding:64px 0}
.section-tight{padding:40px 0}
.bg-white{background:var(--paper)}
.bg-cream{background:var(--cream)}
.bg-cream-2{background:var(--cream-2)}
.bg-green{background:linear-gradient(160deg,var(--green-700),var(--green-800));color:#eafaf3}
.bg-green h2,.bg-green h3,.bg-green h1{color:#fff}
.text-center{text-align:center}
.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.lead{font-size:1.2rem;color:var(--slate);line-height:1.6}
.eyebrow{display:inline-block;font-family:var(--font-head);font-weight:600;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--green-600);margin-bottom:.6rem}
.section-head{max-width:760px;margin:0 auto 40px}
.section-head.left{margin-left:0}
.muted{color:var(--slate)}

/* ---------- Buttons ---------- */
.btn{
  --btn-bg:var(--green-600);
  display:inline-flex;align-items:center;gap:.55em;justify-content:center;
  font-family:var(--font-head);font-weight:600;font-size:1rem;
  padding:.85em 1.5em;border-radius:var(--radius-pill);
  background:var(--btn-bg);color:#fff;border:2px solid transparent;
  cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background .15s ease;
  text-decoration:none;line-height:1.1;box-shadow:var(--shadow-sm);
}
.btn:hover{text-decoration:none;transform:translateY(-2px);box-shadow:var(--shadow)}
.btn:active{transform:translateY(0)}
.btn-cta{
  --btn-bg:linear-gradient(135deg,var(--coral-500),var(--coral-400));
  box-shadow:0 8px 22px rgba(255,92,57,.32);font-size:1.05rem;padding:.95em 1.7em;
}
.btn-cta:hover{box-shadow:0 12px 28px rgba(255,92,57,.42)}
.btn-lg{font-size:1.12rem;padding:1.05em 2em}
.btn-ghost{background:transparent;color:var(--green-700);border-color:var(--line-strong);box-shadow:none}
.btn-ghost:hover{background:var(--green-50);border-color:var(--green-400)}
.btn-white{background:#fff;color:var(--green-700)}
.btn-block{display:flex;width:100%}
.btn-arrow::after{content:"→";font-size:1.05em;transition:transform .15s ease}
.btn-arrow:hover::after{transform:translateX(3px)}

/* ---------- Header / nav ---------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:saturate(1.4) blur(10px);border-bottom:1px solid var(--line);box-shadow:var(--shadow-sm)}
.nav{display:flex;align-items:center;gap:18px;height:70px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--font-head);font-weight:700;font-size:1.22rem;color:var(--ink);white-space:nowrap}
.brand:hover{text-decoration:none}
.brand .logo{width:38px;height:38px;flex:0 0 auto}
.brand b{color:var(--green-600)}
.nav-links{display:flex;align-items:center;gap:4px;margin-left:8px}
.nav-item{position:relative}
.nav-link{display:inline-flex;align-items:center;gap:5px;padding:9px 13px;border-radius:10px;color:var(--ink);font-weight:500;font-size:.97rem}
.nav-link:hover,.nav-item:hover>.nav-link{background:var(--green-50);color:var(--green-700);text-decoration:none}
.nav-link.active{color:var(--green-700);font-weight:600}
.nav-link .caret{width:9px;height:9px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg) translateY(-2px);opacity:.6}
.nav-spacer{margin-left:auto}
.dropdown{position:absolute;top:calc(100% + 6px);left:0;min-width:288px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:8px;opacity:0;visibility:hidden;transform:translateY(6px);transition:.16s ease;z-index:120}
.nav-item:hover>.dropdown,.nav-item:focus-within>.dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown a{display:block;padding:9px 12px;border-radius:9px;color:var(--ink);font-size:.94rem;line-height:1.35}
.dropdown a:hover{background:var(--green-50);text-decoration:none;color:var(--green-700)}
.dropdown a small{display:block;color:var(--slate-light);font-size:.8rem;font-weight:400}
.dropdown-head{padding:6px 12px 2px;font-family:var(--font-head);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--green-600);font-weight:600}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px;margin-left:auto}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0;border-radius:2px;transition:.2s}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;background:linear-gradient(170deg,var(--green-50),var(--cream) 60%)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;padding:56px 0 60px}
.hero-kicker{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--green-100);color:var(--green-700);font-weight:600;font-size:.82rem;padding:6px 14px;border-radius:var(--radius-pill);box-shadow:var(--shadow-sm);margin-bottom:18px}
.hero-kicker .dot{width:8px;height:8px;border-radius:50%;background:var(--green-500);box-shadow:0 0 0 4px var(--green-100)}
.hero h1{margin-bottom:.35em}
.hero-sub{font-size:1.2rem;color:var(--slate);max-width:44ch;margin-bottom:1.5em}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.hero-trust{display:flex;flex-wrap:wrap;gap:20px;margin-top:26px;padding-top:22px;border-top:1px solid var(--line)}
.hero-trust .t{display:flex;align-items:center;gap:9px;font-size:.92rem;color:var(--slate)}
.hero-trust .t b{color:var(--ink);font-family:var(--font-head)}
.hero-media{position:relative}
.hero-media img{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;object-fit:cover;aspect-ratio:3/2}
.hero-badge{position:absolute;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:14px 16px;display:flex;align-items:center;gap:11px}
.hero-badge.b1{bottom:-18px;left:-14px}
.hero-badge.b2{top:-16px;right:-10px}
.hero-badge .ico{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;background:var(--green-50);font-size:1.35rem}
.hero-badge .n{font-family:var(--font-head);font-weight:700;font-size:1.05rem;line-height:1}
.hero-badge .l{font-size:.78rem;color:var(--slate)}

/* page hero (interior pages) */
.page-hero{background:linear-gradient(170deg,var(--green-50),var(--cream) 70%);padding:34px 0 10px}
.page-hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center;padding:22px 0 40px}
.page-hero-media img{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;aspect-ratio:3/2;object-fit:cover}
.page-hero h1{margin-top:.2em}

/* ---------- Breadcrumb ---------- */
.breadcrumb{font-size:.86rem;color:var(--slate);padding-top:6px}
.breadcrumb ol{list-style:none;display:flex;flex-wrap:wrap;gap:6px;padding:0;margin:0}
.breadcrumb li{display:flex;gap:6px;align-items:center;margin:0}
.breadcrumb li+li::before{content:"/";color:var(--slate-light)}
.breadcrumb a{color:var(--slate)}
.breadcrumb a:hover{color:var(--green-600)}
.breadcrumb [aria-current]{color:var(--ink);font-weight:500}

/* ---------- Cards & grids ---------- */
.grid{display:grid;gap:22px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm);transition:transform .15s ease,box-shadow .15s ease}
.card-hover:hover{transform:translateY(-4px);box-shadow:var(--shadow);text-decoration:none}
.card h3{margin-bottom:.4em}
.card .ico{width:52px;height:52px;border-radius:13px;display:grid;place-items:center;background:var(--green-50);font-size:1.6rem;margin-bottom:14px}
.card-link{display:block;color:inherit}
.card-link:hover{text-decoration:none}
.card-link .more{color:var(--green-600);font-weight:600;font-size:.92rem;display:inline-flex;gap:5px;align-items:center;margin-top:6px}
.card-link:hover .more{gap:9px}

/* feature list w/ check */
.checklist{list-style:none;padding:0;margin:0}
.checklist li{position:relative;padding-left:34px;margin:.7em 0}
.checklist li::before{content:"";position:absolute;left:0;top:2px;width:22px;height:22px;border-radius:50%;background:var(--green-50);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%231c7d63' stroke-width='3.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center}
.checklist.tight li{margin:.45em 0}
.crosslist{list-style:none;padding:0;margin:0}
.crosslist li{position:relative;padding-left:34px;margin:.7em 0}
.crosslist li::before{content:"";position:absolute;left:0;top:2px;width:22px;height:22px;border-radius:50%;background:var(--red-50);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='13' height='13' viewBox='0 0 24 24' fill='none' stroke='%23d64545' stroke-width='3.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'/%3E%3Cline x1='6' y1='6' x2='18' y2='18'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center}

/* ---------- Stat cards ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px 20px;text-align:center}
.stat .n{font-family:var(--font-head);font-weight:700;font-size:2.1rem;color:var(--green-600);line-height:1}
.stat .l{color:var(--slate);font-size:.92rem;margin-top:6px}
.bg-green .stat{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.18)}
.bg-green .stat .n{color:#fff}
.bg-green .stat .l{color:#c7e7d9}

/* ---------- Pros / cons ---------- */
.proscons{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.proscons .col{border-radius:var(--radius);padding:24px;border:1px solid var(--line);background:#fff}
.proscons .pros{border-color:var(--green-100);background:linear-gradient(180deg,var(--green-50),#fff)}
.proscons .cons{border-color:#f6d4d4;background:linear-gradient(180deg,var(--red-50),#fff)}
.proscons h4{display:flex;align-items:center;gap:8px;margin-bottom:12px}

/* ---------- Tables ---------- */
.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--line);box-shadow:var(--shadow-sm);background:#fff;-webkit-overflow-scrolling:touch}
table.data{width:100%;border-collapse:collapse;font-size:.96rem;min-width:560px}
table.data caption{text-align:left;padding:14px 18px;font-weight:600;color:var(--slate);font-size:.9rem}
table.data th,table.data td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--line)}
table.data thead th{background:var(--green-700);color:#fff;font-family:var(--font-head);font-weight:600;font-size:.92rem;position:sticky;top:0}
table.data thead th:first-child{border-top-left-radius:var(--radius)}
table.data thead th:last-child{border-top-right-radius:var(--radius)}
table.data tbody tr:nth-child(even){background:var(--cream)}
table.data tbody tr:hover{background:var(--green-50)}
table.data td strong{color:var(--green-700)}
table.data tbody .highlight-col{background:var(--amber-soft)}
.cell-yes{color:var(--green-600);font-weight:700}
.cell-no{color:var(--red-600);font-weight:700}
.cell-mid{color:var(--amber);font-weight:700}
.tag{display:inline-block;font-size:.74rem;font-weight:600;padding:3px 9px;border-radius:var(--radius-pill);background:var(--green-50);color:var(--green-700);font-family:var(--font-head)}
.tag.best{background:var(--coral-500);color:#fff}
.tag.amber{background:var(--amber-soft);color:#8a6111}

/* ---------- FAQ accordion ---------- */
.faq{max-width:820px;margin:0 auto}
.faq details{background:#fff;border:1px solid var(--line);border-radius:var(--radius);margin-bottom:12px;overflow:hidden;transition:box-shadow .15s ease}
.faq details[open]{box-shadow:var(--shadow);border-color:var(--green-100)}
.faq summary{list-style:none;cursor:pointer;padding:18px 22px;font-family:var(--font-head);font-weight:600;font-size:1.05rem;display:flex;justify-content:space-between;gap:16px;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--green-500);transition:transform .2s ease;line-height:1}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .faq-body{padding:0 22px 20px;color:var(--slate)}
.faq .faq-body>*:last-child{margin-bottom:0}

/* ---------- Steps ---------- */
.steps{counter-reset:step;display:grid;gap:20px}
.steps.cols{grid-template-columns:repeat(3,1fr)}
.step{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px 22px 22px}
.step::before{counter-increment:step;content:counter(step);position:absolute;top:-16px;left:22px;width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--green-500),var(--green-600));color:#fff;display:grid;place-items:center;font-family:var(--font-head);font-weight:700;box-shadow:var(--shadow)}
.step h4{margin-top:8px}

/* ---------- Callout boxes ---------- */
.callout{border-radius:var(--radius);padding:20px 22px;margin:1.6em 0;border:1px solid var(--line);background:#fff;display:flex;gap:14px}
.callout .ci{font-size:1.4rem;flex:0 0 auto;line-height:1.4}
.callout p:last-child{margin-bottom:0}
.callout.info{background:var(--blue-50);border-color:#cfe3f5}
.callout.tip{background:var(--green-50);border-color:var(--green-100)}
.callout.warn{background:var(--amber-soft);border-color:#f2d795}
.callout.danger{background:var(--red-50);border-color:#f4c9c9}
.callout h4{margin-bottom:.3em}

/* highlight number box */
.big-num{font-family:var(--font-head);font-weight:800;font-size:clamp(2.4rem,6vw,3.6rem);color:var(--green-600);line-height:1}

/* ---------- Testimonials ---------- */
.testi{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
.testi .stars{color:var(--amber);font-size:1.05rem;letter-spacing:2px;margin-bottom:10px}
.testi .quote{font-size:1.03rem;color:var(--ink);flex:1}
.testi .who{display:flex;align-items:center;gap:12px;margin-top:16px;padding-top:16px;border-top:1px solid var(--line)}
.testi .av{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--green-400),var(--green-600));color:#fff;display:grid;place-items:center;font-family:var(--font-head);font-weight:700}
.testi .who b{display:block;font-size:.95rem}
.testi .who span{font-size:.82rem;color:var(--slate)}

.rating-big{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.rating-big .score{font-family:var(--font-head);font-weight:800;font-size:3rem;color:var(--ink);line-height:1}
.rating-big .stars{color:var(--amber);font-size:1.5rem;letter-spacing:3px}

/* ---------- TOC / sommaire ---------- */
.toc{background:var(--cream-2);border:1px solid var(--line);border-radius:var(--radius);padding:20px 24px;margin:0 0 6px}
.toc h2{font-size:1rem;text-transform:uppercase;letter-spacing:.08em;color:var(--green-700);margin-bottom:.6em}
.toc ol{margin:0;padding-left:1.2em;columns:2;column-gap:32px}
.toc li{margin:.3em 0}
.toc a{color:var(--ink)}
.toc a:hover{color:var(--green-600)}

/* article typography wrapper */
.prose{max-width:760px;margin:0 auto}
.prose h2{margin-top:1.8em;scroll-margin-top:90px}
.prose h3{margin-top:1.4em;scroll-margin-top:90px}
.prose>p:first-of-type{font-size:1.14rem;color:var(--slate)}
.prose img{border-radius:var(--radius);margin:1.5em 0}
.prose table{margin:1.5em 0}

/* ---------- CTA banner ---------- */
.cta-band{background:linear-gradient(135deg,var(--green-600),var(--green-800));border-radius:var(--radius-lg);padding:44px;color:#fff;text-align:center;position:relative;overflow:hidden;box-shadow:var(--shadow)}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(600px 200px at 100% 0,rgba(67,184,146,.35),transparent),radial-gradient(500px 220px at 0 100%,rgba(255,92,57,.22),transparent);pointer-events:none}
.cta-band>*{position:relative}
.cta-band h2{color:#fff;margin-bottom:.35em}
.cta-band p{color:#d5f0e5;max-width:56ch;margin:0 auto 1.4em;font-size:1.1rem}
.cta-band .btn-cta{box-shadow:0 10px 30px rgba(0,0,0,.25)}
.cta-mini{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;align-items:center;color:#bfe6d5;font-size:.9rem}
.cta-mini .m{display:flex;align-items:center;gap:7px}

/* inline mid-content cta */
.cta-inline{background:linear-gradient(135deg,var(--green-50),#fff);border:1px solid var(--green-100);border-left:5px solid var(--green-500);border-radius:var(--radius);padding:22px 24px;display:flex;gap:20px;align-items:center;justify-content:space-between;flex-wrap:wrap;margin:2em 0}
.cta-inline .txt b{font-family:var(--font-head);font-size:1.15rem;display:block}
.cta-inline .txt span{color:var(--slate)}

/* ---------- Comparateur / devis ---------- */
.compare-hero{background:linear-gradient(170deg,var(--green-700),var(--green-800));color:#eafaf3}
.iframe-wrap{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;padding:0}
.iframe-wrap iframe{width:100%;border:0;display:block;min-height:760px}
.iframe-placeholder{min-height:520px;display:grid;place-items:center;text-align:center;padding:50px;background:
  repeating-linear-gradient(45deg,var(--cream),var(--cream) 14px,var(--cream-2) 14px,var(--cream-2) 28px)}
.iframe-placeholder .inner{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:36px;max-width:460px;box-shadow:var(--shadow)}

/* ---------- Logos / trust row ---------- */
.trust-row{display:flex;flex-wrap:wrap;gap:14px 30px;align-items:center;justify-content:center;opacity:.9}
.trust-row .chip{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);border-radius:var(--radius-pill);padding:9px 16px;font-weight:600;font-size:.9rem;color:var(--slate);box-shadow:var(--shadow-sm)}

/* ---------- Footer ---------- */
.site-footer{background:#0e2b23;color:#bcd6cb;padding:56px 0 28px;font-size:.94rem}
.site-footer a{color:#bcd6cb}
.site-footer a:hover{color:#fff}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:36px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.12)}
.footer-brand .brand{color:#fff}
.footer-brand .brand b{color:var(--green-400)}
.footer-brand p{color:#9fbcaf;max-width:34ch;margin-top:14px}
.footer-col h4{color:#fff;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:16px}
.footer-col ul{list-style:none;padding:0;margin:0}
.footer-col li{margin:.5em 0}
.footer-bottom{display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center;padding-top:24px;color:#8aa89b;font-size:.85rem}
.footer-bottom .links{display:flex;flex-wrap:wrap;gap:8px 18px}
.footer-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-pill);padding:7px 14px;font-size:.82rem}
.footer-disclaimer{color:#7b998c;font-size:.78rem;margin-top:16px;line-height:1.5;max-width:900px}

/* ---------- Sitemap page ---------- */
.sitemap-silo{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm)}
.sitemap-silo>a{font-family:var(--font-head);font-weight:700;font-size:1.1rem;color:var(--green-700);display:inline-flex;gap:8px;align-items:center}
.sitemap-silo ul{list-style:none;padding:0;margin:14px 0 0;border-top:1px solid var(--line);padding-top:14px}
.sitemap-silo li{margin:.55em 0;padding-left:16px;position:relative}
.sitemap-silo li::before{content:"›";position:absolute;left:0;color:var(--green-400);font-weight:700}

/* ---------- utility ---------- */
.pill-row{display:flex;flex-wrap:wrap;gap:10px}
.pill{background:#fff;border:1px solid var(--line);border-radius:var(--radius-pill);padding:8px 16px;font-size:.9rem;font-weight:500;color:var(--slate);box-shadow:var(--shadow-sm)}
.pill a{color:inherit}
.anchor-cta{position:sticky;bottom:0;z-index:60}
.divider-soft{height:1px;background:var(--line);margin:0}
.mb-40{margin-bottom:40px}.mb-24{margin-bottom:24px}.mt-32{margin-top:32px}
.maxw-narrow{max-width:var(--maxw-narrow);margin-left:auto;margin-right:auto}

/* related links */
.related{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.related a{display:flex;gap:12px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;color:var(--ink);box-shadow:var(--shadow-sm);transition:.15s}
.related a:hover{text-decoration:none;transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--green-100)}
.related a .ri{font-size:1.3rem}
.related a b{display:block;font-family:var(--font-head);font-size:.98rem}
.related a span{font-size:.84rem;color:var(--slate)}

/* mobile sticky cta bar */
.mobile-cta{display:none}

/* ---------- Responsive ---------- */
@media(max-width:960px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr)}
  .steps.cols{grid-template-columns:1fr}
  .related{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .hero-grid,.page-hero-grid{grid-template-columns:1fr;gap:32px}
  .hero-media{order:-1}
  .toc ol{columns:1}
}
@media(max-width:820px){
  body{font-size:16px}
  .section{padding:48px 0}
  .nav-links{position:fixed;inset:70px 0 auto 0;background:#fff;flex-direction:column;align-items:stretch;gap:0;padding:12px;border-bottom:1px solid var(--line);box-shadow:var(--shadow-lg);transform:translateY(-12px);opacity:0;visibility:hidden;transition:.2s;max-height:calc(100vh - 70px);overflow-y:auto}
  .nav-links.open{transform:translateY(0);opacity:1;visibility:visible}
  .nav-spacer{display:none}
  .nav-toggle{display:block}
  .nav-item{width:100%}
  .nav-link{width:100%;justify-content:space-between}
  .dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;border-left:2px solid var(--green-100);border-radius:0;margin:0 0 8px 14px;min-width:0;padding:2px 0 2px 8px;display:none}
  .nav-item.open>.dropdown{display:block}
  .nav .btn{display:none}
  .nav-links .btn-cta{display:flex;margin-top:8px}
  .proscons,.grid-2,.grid-3{grid-template-columns:1fr}
  .cta-band{padding:32px 22px}
  .cta-inline{flex-direction:column;align-items:flex-start}
  .mobile-cta{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:90;background:#fff;border-top:1px solid var(--line);padding:10px 14px;gap:10px;box-shadow:0 -6px 18px rgba(16,48,42,.1);align-items:center}
  .mobile-cta .btn{flex:1}
  .mobile-cta .mc-txt{display:none}
  body{padding-bottom:64px}
}
@media(max-width:560px){
  .grid-4,.stats{grid-template-columns:1fr}
  .hero-badge{display:none}
  h1{font-size:1.85rem}
  .rating-big .score{font-size:2.4rem}
}
@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition:none!important;animation:none!important}}

/* ============================================================
   v3 — E-E-A-T byline, cookie banner, back-to-top, reveal, a11y
   ============================================================ */

/* Article byline */
.byline{display:flex;flex-wrap:wrap;gap:8px 18px;margin:2px 0 16px;font-size:.85rem;color:var(--slate)}
.byline .by-item{display:inline-flex;align-items:center;gap:6px}

/* Skip link visible on focus */
.skip-link:focus{left:12px!important;top:12px;position:fixed;z-index:200;background:#fff;color:var(--green-700);padding:10px 16px;border-radius:8px;box-shadow:var(--shadow-lg);width:auto;font-weight:600}

/* Back-to-top */
.to-top{position:fixed;right:18px;bottom:24px;z-index:70;width:46px;height:46px;border-radius:50%;border:0;
  background:linear-gradient(135deg,var(--green-500),var(--green-700));color:#fff;font-size:1.3rem;cursor:pointer;
  box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(10px);transition:opacity .2s ease,transform .2s ease}
.to-top.show{opacity:1;visibility:visible;transform:translateY(0)}
.to-top:hover{transform:translateY(-2px)}
@media(max-width:820px){.to-top{bottom:76px;width:42px;height:42px}}


/* Scroll reveal (JS adds .reveal then .in; no-JS = visible) */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .55s ease,transform .55s ease}
.reveal.in{opacity:1;transform:none}

/* Active TOC link (scroll-spy) */
.toc a.active{color:var(--green-700);font-weight:700}

@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important;transition:none}
  .to-top{transition:none}
}

/* ============================================================
   v4 — corrections : double bouton header, contraste tableaux,
   fiabilité (neutralisation du reveal fragile), nav plus tôt
   ============================================================ */

/* Le contenu reste TOUJOURS visible (l'animation d'apparition est retirée) */
.reveal{opacity:1 !important;transform:none !important}

/* Header : le bouton CTA du menu est masqué sur desktop (réservé au menu mobile) */
.nav-links > .btn-cta{display:none}

/* Badges dans les en-têtes de tableau (fond vert) — contraste lisible */
table.data thead th .tag{background:rgba(255,255,255,.92);color:var(--green-800)}
table.data thead th .tag.best{background:var(--coral-500);color:#fff}
table.data thead th .tag.amber{background:#ffdf99;color:#5a3d00}

/* Valeurs "Partiel" / intermédiaires : ambre foncé lisible (avant : trop clair) */
.cell-mid{color:#b26a00}
table.data tbody .highlight-col{background:#fff7e6}        /* mise en avant : corps du tableau uniquement */
/* En-tête de la colonne mise en avant : reste vert (texte blanc lisible) */
table.data thead th.highlight-col{background:var(--green-700)}

/* Bascule en menu hamburger dès 1024px pour éviter tout débordement du header */
@media(max-width:1180px){
  .nav-toggle{display:block}
  .nav-spacer{display:none}
  .nav > .btn-cta{display:none}                 /* cache le bouton desktop quand replié */
  .nav-links{position:fixed;inset:70px 0 auto 0;background:#fff;flex-direction:column;align-items:stretch;
    gap:0;padding:12px;border-bottom:1px solid var(--line);box-shadow:var(--shadow-lg);
    transform:translateY(-12px);opacity:0;visibility:hidden;transition:.2s;
    max-height:calc(100vh - 70px);overflow-y:auto}
  .nav-links.open{transform:translateY(0);opacity:1;visibility:visible}
  .nav-item{width:100%}
  .nav-link{width:100%;justify-content:space-between}
  .dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;
    border-left:2px solid var(--green-100);border-radius:0;margin:0 0 8px 14px;min-width:0;
    padding:2px 0 2px 8px;display:none}
  .nav-item.open>.dropdown{display:block}
  .nav-links > .btn-cta{display:flex;margin-top:8px}   /* le CTA apparaît dans le menu mobile */
}

/* Bouton CTA du header : compact et sur une seule ligne */
.nav-cta{white-space:nowrap;font-size:.96rem;padding:.62em 1.25em}

/* ============================================================
   v6 — polices auto-hébergées, contraste en-tête tableau,
   indicateur de défilement des tableaux (mobile)
   ============================================================ */

/* Ombres de défilement sur les tableaux larges (indique qu'on peut scroller) */
.table-wrap{
  background:
    linear-gradient(to right, #fff 30%, rgba(255,255,255,0)) 0 0,
    linear-gradient(to left, #fff 30%, rgba(255,255,255,0)) 100% 0,
    radial-gradient(farthest-side at 0 50%, rgba(16,48,42,.14), rgba(0,0,0,0)) 0 0,
    radial-gradient(farthest-side at 100% 50%, rgba(16,48,42,.14), rgba(0,0,0,0)) 100% 0;
  background-repeat:no-repeat;
  background-size:44px 100%, 44px 100%, 16px 100%, 16px 100%;
  background-attachment:local, local, scroll, scroll;
}

/* "À retenir" — encadré points clés */
.takeaways{background:linear-gradient(180deg,var(--green-50),#fff);border:1px solid var(--green-100);
  border-left:5px solid var(--green-500);border-radius:var(--radius);padding:20px 24px;margin:1.8em 0}
.takeaways .tk-title{font-family:var(--font-head);font-weight:700;font-size:1.12rem;margin:0 0 .5em;color:var(--ink)}
.takeaways ul{list-style:none;padding:0;margin:0}
.takeaways li{position:relative;padding-left:26px;margin:.5em 0;color:var(--ink)}
.takeaways li::before{content:"✓";position:absolute;left:0;top:0;color:var(--green-600);font-weight:800}

/* Nav à 8 rubriques : espacement compact sur desktop large */
@media(min-width:1181px){ .nav-link{padding:9px 11px;font-size:.95rem} .nav{gap:12px} }
