/* CanadaFlorida — feuille de style commune aux articles
   Charge tokens.css avant ce fichier. */

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--cf-bg);color:var(--cf-ink);font-family:var(--cf-font-sans);line-height:1.65;-webkit-font-smoothing:antialiased;font-size:17px}
a{color:var(--cf-ink);text-decoration:underline;text-decoration-color:var(--cf-coral);text-underline-offset:3px;text-decoration-thickness:1.5px}
a:hover{color:var(--cf-coral)}

/* Topbar */
.topbar{display:flex;justify-content:space-between;align-items:center;padding:14px 56px;background:var(--cf-bg-2);border-bottom:1px solid var(--cf-rule);font-size:12.5px;color:var(--cf-muted);font-family:var(--cf-font-mono);text-transform:uppercase;letter-spacing:.06em}
.topbar a{color:var(--cf-ink-2);text-decoration:none;margin-left:16px}
.topbar a:hover{color:var(--cf-coral)}

/* Header */
header.site{display:flex;justify-content:space-between;align-items:center;padding:22px 56px;background:var(--cf-bg);border-bottom:1px solid var(--cf-rule);position:sticky;top:0;z-index:10;backdrop-filter:saturate(140%) blur(8px)}
header.site .brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:inherit}
header.site .brand:hover{color:inherit}
header.site .logo{width:38px;height:38px;border-radius:9px;background:var(--cf-ink);display:grid;place-items:center;color:var(--cf-bg);font-family:var(--cf-font-display);font-weight:600;font-size:15px}
header.site .word{font-family:var(--cf-font-display);font-size:42px;font-weight:500;letter-spacing:-.01em;line-height:1.1}
header.site .word b{font-weight:600}
header.site .word .tag{display:block;font-size:23px;color:var(--cf-muted);font-family:var(--cf-font-mono);text-transform:uppercase;letter-spacing:.05em;margin-top:8px}
.lang-toggle{display:inline-flex;background:var(--cf-bg-2);border:1px solid var(--cf-rule);border-radius:999px;padding:3px;font-size:13px;font-family:var(--cf-font-mono);text-transform:uppercase;letter-spacing:.06em}
.lang-toggle a{padding:6px 14px;border-radius:999px;text-decoration:none;color:var(--cf-muted)}
.lang-toggle a.active{background:var(--cf-surface);color:var(--cf-ink);box-shadow:0 1px 3px rgba(0,0,0,.08)}

/* Breadcrumb */
nav.crumbs{padding:18px 56px;background:var(--cf-bg);border-bottom:1px solid var(--cf-rule);font-family:var(--cf-font-mono);font-size:12px;color:var(--cf-muted);text-transform:uppercase;letter-spacing:.06em}
nav.crumbs a{color:var(--cf-muted);text-decoration:none;margin-right:8px}
nav.crumbs a:hover{color:var(--cf-coral)}
nav.crumbs .sep{margin-right:8px;color:var(--cf-rule)}
nav.crumbs .here{color:var(--cf-ink)}

/* Article shell */
article.guide{max-width:780px;margin:0 auto;padding:48px 24px 24px}
article.guide header.title{margin:0 0 36px}
article.guide header.title .num{font-family:var(--cf-font-mono);font-size:12px;color:var(--cf-coral);text-transform:uppercase;letter-spacing:.1em;font-weight:600;margin:0 0 14px}
article.guide h1{font-family:var(--cf-font-display);font-size:46px;font-weight:600;letter-spacing:-.02em;line-height:1.08;margin:0 0 22px;color:var(--cf-ink)}
article.guide h1 em{font-style:italic;color:var(--cf-coral)}
article.guide .lede{font-size:20px;line-height:1.55;color:var(--cf-ink-2);margin:0 0 24px;font-family:var(--cf-font-display);font-weight:400}
article.guide .meta-row{display:flex;flex-wrap:wrap;gap:18px;font-family:var(--cf-font-mono);font-size:12px;color:var(--cf-muted);text-transform:uppercase;letter-spacing:.06em;border-top:1px solid var(--cf-rule);border-bottom:1px solid var(--cf-rule);padding:14px 0;margin:0 0 36px}
article.guide .meta-row span b{color:var(--cf-ink-2);font-weight:500}

/* Intro 60 secondes */
.intro60{background:var(--cf-bg-2);border:1px solid var(--cf-rule);border-radius:14px;padding:24px 28px;margin:0 0 40px}
.intro60 h2{font-family:var(--cf-font-mono);font-size:11.5px;color:var(--cf-coral);text-transform:uppercase;letter-spacing:.1em;font-weight:600;margin:0 0 12px}
.intro60 p{margin:0 0 10px;font-size:16px;line-height:1.6;color:var(--cf-ink)}
.intro60 p:last-child{margin-bottom:0}
.intro60 ul{margin:8px 0 0;padding:0 0 0 20px;font-size:15.5px;color:var(--cf-ink-2)}
.intro60 ul li{margin:0 0 6px}

/* TOC */
nav.toc{margin:0 0 40px;padding:18px 22px;background:var(--cf-surface);border:1px solid var(--cf-rule);border-radius:10px}
nav.toc h2{font-family:var(--cf-font-mono);font-size:11.5px;color:var(--cf-muted);text-transform:uppercase;letter-spacing:.1em;font-weight:600;margin:0 0 10px}
nav.toc ol{margin:0;padding:0 0 0 22px;font-size:15px;line-height:1.7}
nav.toc ol li a{text-decoration:none;color:var(--cf-ink-2)}
nav.toc ol li a:hover{color:var(--cf-coral)}

/* Body typography */
article.guide section{margin:0 0 40px;scroll-margin-top:80px}
article.guide h2{font-family:var(--cf-font-display);font-size:32px;font-weight:600;letter-spacing:-.015em;line-height:1.2;margin:48px 0 16px;color:var(--cf-ink);padding-top:8px;border-top:2px solid var(--cf-ink);padding-top:18px}
article.guide h2 em{font-style:italic;color:var(--cf-coral)}
article.guide h3{font-family:var(--cf-font-display);font-size:22px;font-weight:600;letter-spacing:-.005em;line-height:1.25;margin:32px 0 12px;color:var(--cf-ink)}
article.guide h4{font-family:var(--cf-font-sans);font-size:17px;font-weight:600;line-height:1.35;margin:22px 0 8px;color:var(--cf-ink)}
article.guide p{margin:0 0 18px;line-height:1.7}
article.guide ul,article.guide ol{margin:0 0 22px;padding:0 0 0 24px}
article.guide ul li,article.guide ol li{margin:0 0 10px;line-height:1.6}
article.guide ul ul,article.guide ol ol,article.guide ul ol,article.guide ol ul{margin:8px 0 0}
article.guide blockquote{margin:24px 0;padding:18px 24px;border-left:3px solid var(--cf-coral);background:var(--cf-bg-2);font-style:italic;color:var(--cf-ink-2)}
article.guide code{font-family:var(--cf-font-mono);font-size:.92em;background:var(--cf-bg-2);padding:1px 6px;border-radius:4px;color:var(--cf-ink)}
article.guide hr{border:none;border-top:1px solid var(--cf-rule);margin:36px 0}
article.guide strong{font-weight:600;color:var(--cf-ink)}
article.guide em{font-style:italic}

/* Marqueurs */
.marker{display:inline-block;font-family:var(--cf-font-mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;font-weight:600;padding:1px 7px;border-radius:4px;vertical-align:2px;margin-right:6px}
.marker.fait{background:var(--cf-coral);color:#fff}
.marker.fourchette{background:var(--cf-amber);color:#3a2300}
.marker.opinion{background:transparent;color:var(--cf-ink-2);border:1px solid var(--cf-rule)}

/* Callouts */
.callout{display:block;margin:24px 0;padding:18px 22px;border-radius:10px;border-left:4px solid var(--cf-coral);background:var(--cf-surface);border-top:1px solid var(--cf-rule);border-right:1px solid var(--cf-rule);border-bottom:1px solid var(--cf-rule)}
.callout > .head{font-family:var(--cf-font-mono);font-size:11.5px;color:var(--cf-coral);text-transform:uppercase;letter-spacing:.1em;font-weight:600;margin:0 0 8px}
.callout p{margin:0 0 8px}
.callout p:last-child{margin:0}
.callout ul{margin:6px 0 0;padding-left:22px}
.callout.warn{border-left-color:var(--cf-amber);background:rgba(232,168,56,.07)}
.callout.warn > .head{color:#7a4600}
.callout.tip{border-left-color:#3a8a5b;background:rgba(58,138,91,.06)}
.callout.tip > .head{color:#1d5c3a}
.callout.compare{border-left-color:var(--cf-ink);background:var(--cf-bg-2)}
.callout.compare > .head{color:var(--cf-ink)}

/* Tableaux */
.table-wrap{margin:24px 0;border:1px solid var(--cf-rule);border-radius:10px;overflow-x:auto}
table.cf{width:100%;border-collapse:collapse;font-size:15px}
table.cf thead th{background:var(--cf-bg-2);text-align:left;padding:12px 14px;font-family:var(--cf-font-mono);font-size:11.5px;color:var(--cf-ink-2);text-transform:uppercase;letter-spacing:.06em;font-weight:600;border-bottom:1px solid var(--cf-rule)}
table.cf tbody td{padding:12px 14px;border-bottom:1px solid var(--cf-rule);vertical-align:top;line-height:1.5}
table.cf tbody tr:last-child td{border-bottom:none}
table.cf tbody tr:nth-child(even){background:var(--cf-bg-2)}

/* Sources */
section.sources{margin:48px 0 0;padding:24px 26px;background:var(--cf-bg-2);border:1px solid var(--cf-rule);border-radius:12px}
section.sources h2{font-family:var(--cf-font-display);font-size:22px;font-weight:600;border-top:none;padding-top:0;margin:0 0 14px}
section.sources p.intro{font-size:14.5px;color:var(--cf-ink-2);margin:0 0 16px}
section.sources ol{margin:0;padding:0 0 0 22px;font-size:14.5px;line-height:1.7;color:var(--cf-ink-2)}
section.sources ol li{margin:0 0 8px}
section.sources ol li a{word-break:break-all}

/* Disclaimer / pied article — règles blindées contre la cascade article.guide strong */
.disclaimer-art{margin:36px 0 0;padding:22px 26px;background:var(--cf-ink);color:#D5D8DC;border-radius:12px;font-size:14px;line-height:1.6}
.disclaimer-art h3{font-family:var(--cf-font-display);font-size:17px;font-weight:600;color:#fff!important;margin:0 0 10px}
.disclaimer-art p{margin:0 0 8px;color:#C4C8CD!important}
.disclaimer-art p:last-child{margin:0}
.disclaimer-art a,article.guide .disclaimer-art a{color:#fff!important;text-decoration-color:var(--cf-coral)}
.disclaimer-art strong,.disclaimer-art b,.disclaimer-art p strong,.disclaimer-art p b,article.guide .disclaimer-art strong,article.guide .disclaimer-art b,article.guide .disclaimer-art p strong,article.guide .disclaimer-art p b{color:#fff!important;font-weight:600}
.disclaimer-art em,article.guide .disclaimer-art em{color:#D5D8DC!important;font-style:italic}

/* Règle Jeff : retirer barre de légende et badges de statut sur toutes les pages */
.legend{display:none!important}
.art .badge,.art-badge{display:none!important}

/* CTA bandeau */
.cta-band{margin:40px 0 0;padding:28px 30px;background:var(--cf-bg-2);border:1px solid var(--cf-rule);border-radius:12px;display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.cta-band h3{font-family:var(--cf-font-display);font-size:19px;font-weight:600;margin:0 0 4px;color:var(--cf-ink)}
.cta-band p{margin:0;font-size:14.5px;color:var(--cf-ink-2)}
.cta-band a.btn{display:inline-flex;align-items:center;padding:11px 20px;background:var(--cf-coral);color:#fff;text-decoration:none;border-radius:8px;font-size:14.5px;font-weight:500;border:1.5px solid var(--cf-coral)}

/* Related */
.related{margin:48px 0 0}
.related h2{font-family:var(--cf-font-display);font-size:22px;font-weight:600;border-top:1px solid var(--cf-rule);padding-top:24px;margin:0 0 16px}
.related-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.related-grid a{padding:14px 16px;border:1px solid var(--cf-rule);border-radius:10px;text-decoration:none;color:var(--cf-ink);background:var(--cf-surface);font-size:14.5px;line-height:1.4;display:block;transition:border-color .15s}
.related-grid a:hover{border-color:var(--cf-ink);color:var(--cf-coral)}

/* Footer */
footer.site{background:var(--cf-ink);color:#D5D8DC;padding:60px 56px 32px;margin-top:64px}
footer.site .foot-grid{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1.6fr repeat(3,1fr);gap:28px}
footer.site h5{font-family:var(--cf-font-display);font-size:13.5px;font-weight:600;color:#fff;margin:0 0 10px;letter-spacing:.01em}
footer.site ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;font-size:14px}
footer.site ul a{color:#A8ADB3;text-decoration:none}
footer.site ul a:hover{color:#fff}
footer.site .foot-disclaimer{margin:36px auto 0;max-width:1280px;font-size:12.5px;color:#7E848A;line-height:1.6;border-top:1px solid #2A2D33;padding-top:20px}

/* Mobile */
@media (max-width:768px){
  .topbar{padding:10px 18px;font-size:11px}
  header.site{padding:14px 18px}
  header.site .word{font-size:32px}
  nav.crumbs{padding:14px 18px}
  article.guide{padding:28px 18px 18px}
  article.guide h1{font-size:32px;line-height:1.1}
  article.guide .lede{font-size:18px}
  article.guide h2{font-size:24px}
  article.guide h3{font-size:19px}
  .intro60{padding:18px 20px}
  .cta-band{padding:20px 22px}
  .disclaimer-art{padding:18px 20px}
  section.sources{padding:18px 20px}
  footer.site{padding:36px 18px 24px}
  footer.site .foot-grid{grid-template-columns:1fr 1fr;gap:24px}
}

/* Print */
@media print{
  .topbar,header.site,nav.crumbs,.cta-band,.related,footer.site{display:none}
  article.guide{padding:0;max-width:none}
  article.guid