/* ============================================================
   C365 — Design inspiré SharePoint Maven (2026)
   Cards avec image, grille 2 col, sidebar, B&W strict
   ============================================================ */

:root {
  --bw-bg:          #ffffff;
  --bw-fg:          #111111;
  --bw-fg2:         #333333;
  --bw-fg3:         #666666;
  --bw-fg4:         #999999;
  --bw-border:      #e8e8e8;
  --bw-border-dark: #111111;
  --bw-card-shadow: 0 2px 8px rgba(0,0,0,.07);
  --bw-card-shadow-hover: 0 6px 24px rgba(0,0,0,.13);
  --bw-max:         1160px;
  --bw-side:        280px;
  --bw-font:        'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
}

/* ── Reset global ── */
body.page-blog,
body.page-article-blog {
  background: #f7f7f7 !important;
  color: var(--bw-fg) !important;
  font-family: var(--bw-font) !important;
}

/* ── Force couleurs B&W ── */
.page-blog .snav-logo-text,
.page-article-blog .snav-logo-text,
.snav-logo-text { color: var(--bw-fg) !important; font-size: 17px !important; font-weight: 800 !important; letter-spacing: -.03em !important; }

.snav::after, .snav::before { display: none !important; }
.blog-cta, .blog-cta-primary { background: var(--bw-fg) !important; color: var(--bw-bg) !important; border: none !important; border-radius: 3px !important; box-shadow: none !important; }
.blog-cta-ghost { background: none !important; color: var(--bw-fg) !important; border: 1px solid var(--bw-fg) !important; border-radius: 3px !important; }

/* ── NAV ── */
.snav,
.page-blog .snav,
.page-article-blog .snav {
  background: var(--bw-bg) !important;
  border-bottom: 1px solid var(--bw-border) !important;
  box-shadow: 0 1px 4px rgba(0,0,0,.05) !important;
  backdrop-filter: none !important;
}
.snav-inner {
  max-width: var(--bw-max) !important;
  margin: 0 auto !important;
  padding: 0 24px !important;
  height: 60px !important;
  display: flex !important;
  align-items: center !important;
}
.snav-logo { text-decoration: none !important; margin-right: auto !important; }
.snav-logo-img { height: 30px !important; width: auto !important; }
.snav-links { display: flex !important; align-items: center !important; gap: 0 !important; }
.page-blog .snav-link,
.snav-link {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--bw-fg3) !important;
  text-decoration: none !important;
  padding: 6px 14px !important;
  border-radius: 3px !important;
  letter-spacing: .01em !important;
  transition: color .12s, background .12s !important;
  text-transform: none !important;
}
.page-blog .snav-link:hover,
.snav-link:hover { color: var(--bw-fg) !important; background: #f0f0f0 !important; }
.page-blog .snav-link.is-active,
.snav-link.is-active { color: var(--bw-fg) !important; font-weight: 700 !important; background: none !important; }
.snav-end { display: flex !important; align-items: center !important; gap: 8px !important; margin-left: 12px !important; }
.snav-search {
  background: none !important;
  border: 1px solid var(--bw-border) !important;
  border-radius: 4px !important;
  width: 32px !important; height: 32px !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  color: var(--bw-fg4) !important; cursor: pointer !important;
  transition: border-color .12s, color .12s !important;
}
.snav-search:hover { border-color: var(--bw-fg) !important; color: var(--bw-fg) !important; }
.snav-burger-bar { background: var(--bw-fg) !important; }

/* ── MAIN LAYOUT ── */
.page-blog:not(.page-article-blog) .blog-main {
  max-width: var(--bw-max) !important;
  margin: 0 auto !important;
  padding: 36px 24px 80px !important;
  display: grid !important;
  grid-template-columns: 1fr var(--bw-side) !important;
  gap: 0 40px !important;
  align-items: start !important;
  background: none !important;
  border: none !important;
  box-shadow: none !important;
}
.page-blog:not(.page-article-blog) .blog-col-main { min-width: 0 !important; }

/* Cat banner spans full grid */
.blog-cat-banner { grid-column: 1 / -1 !important; }

/* ── SIDEBAR ── */
.blog-sidebar {
  position: sticky !important;
  top: 76px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 28px !important;
  background: none !important;
  border: none !important;
  padding: 0 !important;
  box-shadow: none !important;
}
.blog-sidebar-widget {
  background: var(--bw-bg) !important;
  border: 1px solid var(--bw-border) !important;
  border-radius: 6px !important;
  padding: 20px !important;
  box-shadow: var(--bw-card-shadow) !important;
}
.blog-sidebar-title {
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: .1em !important;
  text-transform: uppercase !important;
  color: var(--bw-fg4) !important;
  margin: 0 0 14px !important;
  padding-bottom: 10px !important;
  border-bottom: 1px solid var(--bw-border) !important;
  font-family: var(--bw-font) !important;
}
.blog-sidebar-about-text,
.blog-sidebar-rss-text {
  font-size: 13px !important;
  color: var(--bw-fg3) !important;
  line-height: 1.6 !important;
  margin: 0 0 14px !important;
}
.blog-sidebar-about-link {
  display: block !important;
  text-align: center !important;
  padding: 10px 16px !important;
  background: var(--bw-fg) !important;
  color: var(--bw-bg) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  border-radius: 4px !important;
  border: none !important;
  transition: opacity .12s !important;
}
.blog-sidebar-about-link:hover { opacity: .8 !important; }
.blog-sidebar-tags { display: flex !important; flex-direction: column !important; gap: 0 !important; }
body .blog-sidebar-tag,
body.page-blog .blog-sidebar-tag,
body.page-category-blog .blog-sidebar-tag {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  color: var(--bw-fg2) !important;
  text-decoration: none !important;
  padding: 8px 0 !important;
  border: none !important;
  border-bottom: 1px solid var(--bw-border) !important;
  border-radius: 0 !important;
  background: none !important;
  --scc: #111 !important;
  transform: none !important;
  box-shadow: none !important;
  transition: color .12s !important;
}
body .blog-sidebar-tag:first-child,
body.page-blog .blog-sidebar-tag:first-child { border-top: 1px solid var(--bw-border) !important; }
body .blog-sidebar-tag:hover,
body.page-blog .blog-sidebar-tag:hover { color: var(--bw-fg) !important; font-weight: 600 !important; background: none !important; transform: none !important; }
body .blog-sidebar-tag.is-active { color: var(--bw-fg) !important; font-weight: 700 !important; }
body .blog-sidebar-tag span,
body.page-blog .blog-sidebar-tag span { font-size: 11px !important; color: var(--bw-fg4) !important; background: none !important; padding: 0 !important; border-radius: 0 !important; }
.blog-sidebar-rss {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--bw-fg) !important;
  text-decoration: none !important;
  border: 1px solid var(--bw-border-dark) !important;
  border-radius: 4px !important;
  padding: 9px 14px !important;
  background: none !important;
  transition: background .12s !important;
}
.blog-sidebar-rss:hover { background: #f5f5f5 !important; }

/* ── QUOI DE NEUF ── */
.blog-whatsnew {
  background: var(--bw-bg) !important;
  border: 1px solid var(--bw-border) !important;
  border-radius: 6px !important;
  padding: 18px 20px !important;
  margin-bottom: 28px !important;
  box-shadow: var(--bw-card-shadow) !important;
}
.blog-whatsnew-title {
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
  color: var(--bw-fg4) !important;
  margin: 0 0 12px !important;
}
.blog-whatsnew-list { list-style: none !important; padding: 0 !important; margin: 0 !important; display: flex !important; flex-direction: column !important; gap: 0 !important; }
.blog-whatsnew-item { border-bottom: 1px solid var(--bw-border) !important; background: none !important; }
.blog-whatsnew-item:last-child { border-bottom: none !important; }
.blog-whatsnew-item a {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  text-decoration: none !important;
  color: var(--bw-fg) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  padding: 9px 0 !important;
  transition: color .12s !important;
}
.blog-whatsnew-item a:hover { color: var(--bw-fg3) !important; }
.blog-whatsnew-cat {
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: .07em !important;
  text-transform: uppercase !important;
  color: var(--bw-fg) !important;
  border: 1px solid var(--bw-border) !important;
  border-radius: 3px !important;
  padding: 2px 7px !important;
  white-space: nowrap !important;
  background: #f5f5f5 !important;
  --wc: none !important;
}
.blog-whatsnew-name { flex: 1 !important; }
.blog-whatsnew-date { font-size: 11px !important; color: var(--bw-fg4) !important; white-space: nowrap !important; }

/* ── LISTE ARTICLES — grille 2 colonnes, cards avec image ── */
.page-blog .blog-list {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 24px !important;
  max-width: none !important;
  flex-direction: unset !important;
}

body .page-blog .blog-list-entry,
body.page-blog .blog-list-entry {
  background: var(--bw-bg) !important;
  border: 1px solid var(--bw-border) !important;
  border-radius: 6px !important;
  overflow: hidden !important;
  padding: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
  box-shadow: var(--bw-card-shadow) !important;
  --entry-cc: #111 !important;
  transition: box-shadow .18s, transform .18s !important;
}
body .page-blog .blog-list-entry:hover,
body.page-blog .blog-list-entry:hover {
  box-shadow: var(--bw-card-shadow-hover) !important;
  transform: translateY(-3px) !important;
  border-color: var(--bw-border) !important;
  background: var(--bw-bg) !important;
}
body .page-blog .blog-list-entry:first-child { border-top: 1px solid var(--bw-border) !important; }

/* Image pleine largeur en haut */
body .page-blog .blog-list-entry-img-wrap,
body.page-blog .blog-list-entry-img-wrap {
  width: 100% !important;
  height: auto !important;
  order: -1 !important;
  flex-shrink: 0 !important;
  border-radius: 0 !important;
  overflow: hidden !important;
  aspect-ratio: unset !important;
  padding: 0 !important;
  display: block !important;
}
body .page-blog .blog-list-entry-img,
body.page-blog .blog-list-entry-img {
  width: 100% !important;
  height: auto !important;
  object-fit: unset !important;
  display: block !important;
  transition: transform .3s !important;
}
body .page-blog .blog-list-entry:hover .blog-list-entry-img { transform: scale(1.02) !important; }

/* Placeholder gris si pas d'image */
body .page-blog .blog-list-entry:not(:has(.blog-list-entry-img-wrap)) .blog-list-entry-body,
body.page-blog .blog-list-entry:not(:has(.blog-list-entry-img-wrap)) .blog-list-entry-body { padding-top: 24px !important; }

/* Corps de la card */
body .page-blog .blog-list-entry-body,
body.page-blog .blog-list-entry-body {
  flex: 1 !important;
  min-width: 0 !important;
  order: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
  padding: 18px 20px 20px !important;
  background: none !important;
}

/* Dateline : catégorie + date */
body .page-blog .blog-list-entry-dateline,
body.page-blog .blog-list-entry-dateline {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  margin-bottom: 10px !important;
  flex-wrap: wrap !important;
  border: none !important;
  padding: 0 !important;
  background: none !important;
}
body .page-blog .blog-list-entry-date,
body.page-blog .blog-list-entry-date {
  font-size: 12px !important;
  color: var(--bw-fg4) !important;
  order: 2 !important;
}
body .page-blog .blog-list-entry-views,
body.page-blog .blog-list-entry-views {
  font-size: 11px !important;
  color: var(--bw-fg4) !important;
  order: 3 !important;
}
body .page-blog .blog-list-entry-views::before { content: '·' !important; margin-right: 4px !important; }

/* Titre */
body .page-blog .blog-list-entry-link,
body.page-blog .blog-list-entry-link { text-decoration: none !important; color: inherit !important; }
body .page-blog .blog-list-entry-title,
body.page-blog .blog-list-entry-title {
  font-size: 17px !important;
  font-weight: 700 !important;
  color: var(--bw-fg) !important;
  line-height: 1.35 !important;
  margin: 0 0 10px !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  letter-spacing: -.02em !important;
  transition: color .12s !important;
  font-family: var(--bw-font) !important;
}
body .page-blog .blog-list-entry-link:hover .blog-list-entry-title,
body.page-blog .blog-list-entry-link:hover .blog-list-entry-title { color: var(--bw-fg3) !important; }

/* Extrait */
body .page-blog .blog-list-entry-excerpt,
body.page-blog .blog-list-entry-excerpt {
  font-size: 13px !important;
  color: var(--bw-fg3) !important;
  line-height: 1.55 !important;
  margin: 0 0 14px !important;
  flex: 1 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 3 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}

/* Footer de card */
body .page-blog .blog-list-entry-footer,
body.page-blog .blog-list-entry-footer {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 8px !important;
  margin-top: auto !important;
  padding-top: 12px !important;
  border-top: 1px solid var(--bw-border) !important;
  background: none !important;
  border-left: none !important;
  border-right: none !important;
  border-bottom: none !important;
}

/* "Lire la suite" link */
body.page-blog .blog-list-entry-read-link,
body .page-blog .blog-list-entry-read-link {
  font-size: 12px !important;
  font-weight: 700 !important;
  color: var(--bw-fg) !important;
  text-decoration: none !important;
  letter-spacing: .03em !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  background: none !important;
  display: inline !important;
  opacity: 1 !important;
  transition: opacity .12s !important;
}
body.page-blog .blog-list-entry-read-link::after,
body .page-blog .blog-list-entry-read-link::after { content: ' →' !important; }
body.page-blog .blog-list-entry-read-link:hover,
body .page-blog .blog-list-entry-read-link:hover { opacity: .55 !important; background: none !important; color: var(--bw-fg) !important; }

/* Badge populaire */
body.page-blog .blog-list-entry-popular,
body .page-blog .blog-list-entry-popular {
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: .05em !important;
  text-transform: uppercase !important;
  color: var(--bw-fg4) !important;
  border: 1px solid var(--bw-border) !important;
  border-radius: 3px !important;
  padding: 2px 7px !important;
  background: #f5f5f5 !important;
}

/* Badge catégorie sur la card (ajouté dans le dateline) */
.blog-list-entry-cat-tag {
  display: inline-block !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: .07em !important;
  text-transform: uppercase !important;
  color: var(--bw-fg) !important;
  background: #f0f0f0 !important;
  border-radius: 3px !important;
  padding: 3px 8px !important;
  text-decoration: none !important;
  order: 1 !important;
  white-space: nowrap !important;
  transition: background .12s !important;
}
.blog-list-entry-cat-tag:hover { background: #e0e0e0 !important; }

/* Séparateurs de mois — cachés dans la grille */
.blog-sep-ornament { display: none !important; }
.blog-month-sep { display: none !important; }

/* ── SORT BAR ── */
.blog-sort-bar,
.page-blog .blog-sort-bar {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  margin-bottom: 20px !important;
  padding: 12px 16px !important;
  border: 1px solid var(--bw-border) !important;
  border-radius: 6px !important;
  background: var(--bw-bg) !important;
  box-shadow: var(--bw-card-shadow) !important;
  flex-wrap: nowrap !important;
}
.blog-sort-label,
.page-blog .blog-sort-label {
  font-size: 12px !important;
  color: var(--bw-fg4) !important;
  margin-right: 4px !important;
  font-weight: 500 !important;
}
.blog-sort-btn,
.page-blog .blog-sort-btn {
  font-size: 12px !important;
  font-weight: 500 !important;
  color: var(--bw-fg3) !important;
  text-decoration: none !important;
  padding: 5px 12px !important;
  border-radius: 4px !important;
  border: 1px solid transparent !important;
  background: none !important;
  transition: all .12s !important;
}
.blog-sort-btn:hover,
.page-blog .blog-sort-btn:hover { border-color: var(--bw-border) !important; color: var(--bw-fg) !important; background: #f5f5f5 !important; }
.blog-sort-btn.is-active,
.page-blog .blog-sort-btn.is-active { background: var(--bw-fg) !important; color: var(--bw-bg) !important; border-color: var(--bw-fg) !important; border-radius: 4px !important; }

/* ── CAT BANNER ── */
.blog-cat-banner {
  background: var(--bw-bg) !important;
  border: 1px solid var(--bw-border) !important;
  border-radius: 6px !important;
  padding: 20px 24px !important;
  margin-bottom: 28px !important;
  box-shadow: var(--bw-card-shadow) !important;
  --cat-cc: #111 !important;
}
.blog-cat-banner-inner { display: flex !important; align-items: center !important; gap: 16px !important; }
.blog-cat-banner-icon {
  width: 48px !important; height: 48px !important;
  background: #f0f0f0 !important;
  border: 1px solid var(--bw-border) !important;
  border-radius: 6px !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  font-size: 20px !important; font-weight: 800 !important; color: var(--bw-fg) !important;
  flex-shrink: 0 !important;
}
.blog-cat-banner-eyebrow { font-size: 11px !important; color: var(--bw-fg4) !important; margin: 0 0 3px !important; }
.blog-cat-banner-eyebrow a { color: var(--bw-fg4) !important; text-decoration: none !important; }
.blog-cat-banner-eyebrow a:hover { color: var(--bw-fg) !important; }
.blog-cat-banner-title { font-size: clamp(20px,3vw,26px) !important; font-weight: 800 !important; color: var(--bw-fg) !important; margin: 0 0 3px !important; letter-spacing: -.03em !important; }
.blog-cat-banner-desc { font-size: 13px !important; color: var(--bw-fg3) !important; margin: 0 !important; }
.blog-cat-banner-stat { margin-left: auto !important; font-size: 12px !important; color: var(--bw-fg4) !important; white-space: nowrap !important; background: #f0f0f0 !important; border-radius: 20px !important; padding: 4px 12px !important; }

/* ── PAGINATION ── */
.blog-pg {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  padding: 32px 0 0 !important;
  border: none !important;
  margin-top: 0 !important;
  background: none !important;
}
.blog-pg-arrow {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--bw-fg) !important;
  text-decoration: none !important;
  padding: 8px 16px !important;
  border: 1px solid var(--bw-border) !important;
  border-radius: 4px !important;
  background: var(--bw-bg) !important;
  transition: background .12s !important;
}
.blog-pg-arrow:hover { background: #f5f5f5 !important; }
.blog-pg-arrow.is-disabled { color: var(--bw-fg4) !important; pointer-events: none !important; opacity: .5 !important; }
.blog-pg-list { display: flex !important; gap: 4px !important; list-style: none !important; padding: 0 !important; margin: 0 !important; }
.blog-pg-num {
  display: flex !important; align-items: center !important; justify-content: center !important;
  width: 36px !important; height: 36px !important;
  font-size: 13px !important; font-weight: 500 !important;
  color: var(--bw-fg2) !important; text-decoration: none !important;
  border-radius: 4px !important;
  border: 1px solid var(--bw-border) !important;
  background: var(--bw-bg) !important;
  transition: background .12s !important;
}
.blog-pg-num:hover { background: #f5f5f5 !important; }
.blog-pg-num.is-current { background: var(--bw-fg) !important; color: var(--bw-bg) !important; font-weight: 700 !important; border-color: var(--bw-fg) !important; }
.blog-pg-ellipsis { font-size: 13px !important; color: var(--bw-fg4) !important; padding: 0 4px !important; display: flex !important; align-items: center !important; height: 36px !important; }

/* ── FOOTER ── */
.blog-footer {
  border-top: 1px solid var(--bw-border) !important;
  background: var(--bw-bg) !important;
  padding: 0 !important;
}
.blog-footer-inner {
  max-width: var(--bw-max) !important;
  margin: 0 auto !important;
  padding: 20px 24px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
}
.blog-footer-copy { font-size: 12px !important; color: var(--bw-fg4) !important; }
.blog-footer-nav { display: flex !important; gap: 20px !important; }
.blog-footer-nav a { font-size: 12px !important; color: var(--bw-fg4) !important; text-decoration: none !important; transition: color .12s !important; }
.blog-footer-nav a:hover { color: var(--bw-fg) !important; }

/* ══════════════════════════════════════════════════════════════
   ARTICLE — Design éditorial B&W, centré, style NYT/Le Monde
   ══════════════════════════════════════════════════════════════ */

/* Fond blanc pur pour la page article */
body.page-article-blog { background: #fff !important; }

/* Wrapper */
.page-article-blog .blog-main,
.page-article-blog .article-main {
  max-width: 720px !important;
  margin: 0 auto !important;
  padding: 0 24px 100px !important;
  display: block !important;
  overflow: visible !important;
  background: none !important;
}
.page-article-blog .article-columns { display: block !important; }
.page-article-blog .blog-sidebar { display: none !important; }

/* ── Breadcrumb ── */
.blog-crumb {
  font-size: 12px !important;
  color: var(--bw-fg4) !important;
  display: flex !important; align-items: center !important;
  gap: 6px !important;
  padding: 20px 0 0 !important;
  margin-bottom: 0 !important;
  background: none !important; border: none !important;
}
.blog-crumb a { color: var(--bw-fg4) !important; text-decoration: none !important; transition: color .12s !important; }
.blog-crumb a:hover { color: var(--bw-fg) !important; }
.blog-crumb-sep { color: #ccc !important; }

/* ── Cover image ── pleine largeur, propre ── */
.article-cover, .article-carousel {
  margin: 28px 0 0 !important;
  width: 100% !important; display: block !important;
  border-radius: 4px !important; overflow: hidden !important;
  border: 1px solid var(--bw-border) !important;
  box-shadow: none !important;
}
.article-cover img, .article-carousel img {
  width: 100% !important; height: auto !important;
  object-fit: unset !important; display: block !important;
}
.article-cover-caption {
  font-size: 11px !important; color: var(--bw-fg4) !important;
  padding: 8px 0 !important; font-style: italic !important;
  border: none !important; background: none !important; margin: 0 !important;
}

/* ── Header article ── */
.article-header {
  background: none !important; border: none !important;
  box-shadow: none !important; padding: 0 !important; margin: 0 !important;
}
.article-columns > .article-header:first-child { border: none !important; border-radius: 0 !important; box-shadow: none !important; }

/* Eyebrow : catégorie + date + durée */
.article-header-meta-top {
  display: flex !important; align-items: center !important;
  gap: 10px !important; flex-wrap: wrap !important;
  padding: 28px 0 12px !important;
}
.article-header-cat-badge {
  display: inline-block !important;
  font-size: 10px !important; font-weight: 700 !important;
  letter-spacing: .1em !important; text-transform: uppercase !important;
  color: var(--bw-fg) !important; background: #f0f0f0 !important;
  border-radius: 2px !important; padding: 4px 10px !important;
  text-decoration: none !important; transition: background .12s !important;
}
.article-header-cat-badge:hover { background: #e0e0e0 !important; }
.article-header-new {
  display: inline-block !important;
  font-size: 10px !important; font-weight: 700 !important;
  letter-spacing: .1em !important; text-transform: uppercase !important;
  color: #fff !important; background: var(--bw-fg) !important;
  border-radius: 2px !important; padding: 4px 8px !important;
}
.article-meta-sep { color: #ddd !important; }
.article-header-read, .article-header-date { font-size: 13px !important; color: var(--bw-fg4) !important; }

/* Titre — grand, serré, éditorial */
.article-title {
  font-size: clamp(28px, 5.5vw, 44px) !important;
  font-weight: 800 !important; color: var(--bw-fg) !important;
  line-height: 1.12 !important; letter-spacing: -.04em !important;
  margin: 0 0 28px !important; font-family: var(--bw-font) !important;
}

/* Barre noire décorative sous le titre */
.article-header::after {
  content: '' !important; display: block !important;
  width: 40px !important; height: 3px !important;
  background: var(--bw-fg) !important;
  margin: -14px 0 32px !important;
}

/* ── Corps article ── */
.article-body {
  background: none !important; border: none !important;
  box-shadow: none !important; padding: 0 !important;
}
.article-body-text {
  padding: 0 !important;
  font-size: 18px !important; line-height: 1.8 !important;
  color: var(--bw-fg) !important;
}
/* ── Typographie article (ciblée .article-content) ── */
.article-content { display: block !important; }
.article-content p { margin: 0 0 1.5em !important; }
.article-content h2 {
  font-size: 25px !important; font-weight: 800 !important;
  color: var(--bw-fg) !important; margin: 2.2em 0 .6em !important;
  letter-spacing: -.03em !important; line-height: 1.2 !important;
}
.article-content h3 { font-size: 20px !important; font-weight: 700 !important; color: var(--bw-fg) !important; margin: 1.8em 0 .5em !important; letter-spacing: -.02em !important; }
.article-content h4 { font-size: 16px !important; font-weight: 700 !important; color: var(--bw-fg2) !important; margin: 1.4em 0 .4em !important; }
.article-content a { color: var(--bw-fg) !important; text-decoration: underline !important; text-underline-offset: 3px !important; text-decoration-color: #bbb !important; transition: text-decoration-color .12s !important; }
.article-content a:hover { text-decoration-color: var(--bw-fg) !important; }
.article-content ul, .article-content ol { padding-left: 1.5em !important; margin: 0 0 1.4em !important; }
.article-content li { margin-bottom: .5em !important; }
.article-content blockquote {
  border-left: 3px solid var(--bw-fg) !important; border-right: none !important;
  border-top: none !important; border-bottom: none !important;
  margin: 2em 0 !important; padding: 0 0 0 24px !important;
  background: none !important; color: var(--bw-fg2) !important;
  font-size: 20px !important; line-height: 1.6 !important;
  font-style: italic !important; border-radius: 0 !important;
}
.article-content pre {
  background: #f5f5f5 !important; border: none !important;
  border-radius: 4px !important; padding: 20px !important;
  overflow-x: auto !important; font-size: 13.5px !important; line-height: 1.6 !important;
  position: relative !important; margin: 0 0 1.5em !important;
}
.article-content code { background: #f0f0f0 !important; border-radius: 3px !important; padding: 2px 6px !important; font-size: .83em !important; color: var(--bw-fg) !important; }
.article-content pre code { background: none !important; padding: 0 !important; font-size: inherit !important; }
.article-content img { max-width: 100% !important; height: auto !important; display: block !important; margin: 2em auto !important; border-radius: 4px !important; border: 1px solid var(--bw-border) !important; }
.article-content table { width: 100% !important; border-collapse: collapse !important; margin: 0 0 1.5em !important; font-size: 15px !important; }
.article-content th { background: #f5f5f5 !important; font-weight: 700 !important; text-align: left !important; padding: 10px 14px !important; border: 1px solid var(--bw-border) !important; }
.article-content td { padding: 9px 14px !important; border: 1px solid var(--bw-border) !important; }
.article-content tr:nth-child(even) td { background: #fafafa !important; }
.article-content hr { border: none !important; border-top: 1px solid var(--bw-border) !important; margin: 2.5em 0 !important; }

/* ── Série d'articles ── */
.article-series {
  background: #f7f7f7 !important;
  border: 1px solid var(--bw-border) !important;
  border-radius: 6px !important;
  padding: 16px 18px !important;
  margin-bottom: 28px !important;
}
.article-series-label { font-size: 12px !important; font-weight: 700 !important; color: var(--bw-fg4) !important; margin: 0 0 10px !important; display: flex !important; align-items: center !important; gap: 6px !important; }
.article-series-list { list-style: none !important; padding: 0 !important; margin: 0 !important; display: flex !important; flex-direction: column !important; gap: 0 !important; }
.article-series-item { display: flex !important; align-items: center !important; gap: 10px !important; padding: 6px 0 !important; border-bottom: 1px solid var(--bw-border) !important; font-size: 13px !important; }
.article-series-item:last-child { border-bottom: none !important; }
.article-series-item.is-current { font-weight: 700 !important; color: var(--bw-fg) !important; }
.article-series-num { width: 20px !important; text-align: center !important; font-size: 11px !important; font-weight: 700 !important; color: var(--bw-fg4) !important; flex-shrink: 0 !important; }
.article-series-item a { color: var(--bw-fg2) !important; text-decoration: none !important; transition: color .12s !important; }
.article-series-item a:hover { color: var(--bw-fg) !important; }

/* ── TOC ── */
.article-toc {
  background: #f9f9f9 !important;
  border: 1px solid var(--bw-border) !important;
  border-left: 3px solid var(--bw-fg) !important;
  border-radius: 4px !important;
  margin-bottom: 28px !important;
  overflow: hidden !important;
}
.article-toc-toggle {
  color: var(--bw-fg) !important; background: none !important;
  font-family: var(--bw-font) !important; font-size: 13px !important;
  font-weight: 700 !important; padding: 12px 16px !important;
  width: 100% !important; text-align: left !important;
  display: flex !important; align-items: center !important; gap: 8px !important;
  border: none !important; cursor: pointer !important;
}
.article-toc-toggle:hover { background: #f0f0f0 !important; }
.article-toc-chevron { margin-left: auto !important; transition: transform .2s !important; }
.article-toc-toggle[aria-expanded="false"] .article-toc-chevron { transform: rotate(-90deg) !important; }
.article-toc-list { list-style: none !important; padding: 0 0 12px !important; margin: 0 !important; counter-reset: toc !important; }
.article-toc-list li { counter-increment: toc !important; }
.article-toc-link { display: block !important; padding: 5px 16px 5px 36px !important; font-size: 13px !important; color: var(--bw-fg3) !important; text-decoration: none !important; position: relative !important; transition: color .12s !important; }
.article-toc-link::before { content: counter(toc) !important; position: absolute !important; left: 16px !important; font-size: 11px !important; font-weight: 700 !important; color: var(--bw-fg4) !important; top: 6px !important; }
.article-toc-link:hover, .article-toc-link.is-active { color: var(--bw-fg) !important; font-weight: 600 !important; }
.article-toc-link.is-active::before { color: var(--bw-fg) !important; }

/* ── Newsletter inline ── */
.article-newsletter-inline {
  background: #f7f7f7 !important;
  border: 1px solid var(--bw-border) !important;
  border-left: 3px solid var(--bw-fg) !important;
  border-radius: 4px !important;
  padding: 20px 22px !important;
  margin: 36px 0 !important;
  display: flex !important; align-items: center !important; gap: 16px !important;
}
.article-newsletter-inline-icon { font-size: 24px !important; flex-shrink: 0 !important; }
.article-newsletter-inline-body { flex: 1 !important; }
.article-newsletter-inline-body strong { font-size: 14px !important; font-weight: 700 !important; color: var(--bw-fg) !important; display: block !important; margin-bottom: 3px !important; }
.article-newsletter-inline-body span { font-size: 13px !important; color: var(--bw-fg3) !important; line-height: 1.4 !important; }
.article-newsletter-inline-btn {
  padding: 10px 18px !important; background: var(--bw-fg) !important; color: var(--bw-bg) !important;
  font-size: 12px !important; font-weight: 700 !important; text-decoration: none !important;
  border-radius: 4px !important; white-space: nowrap !important; flex-shrink: 0 !important;
  transition: opacity .12s !important; border: none !important;
}
.article-newsletter-inline-btn:hover { opacity: .8 !important; }

/* ── Sources / Lab ── */
.article-sources,
.article-lab {
  background: #f9f9f9 !important;
  border: 1px solid var(--bw-border) !important;
  border-radius: 6px !important;
  padding: 18px 20px !important;
  margin-top: 28px !important;
}
.article-sources-label,
.article-sources h3, .article-lab h3 {
  display: block !important;
  font-size: 10px !important; font-weight: 700 !important;
  letter-spacing: .1em !important; text-transform: uppercase !important;
  color: var(--bw-fg4) !important; margin: 0 0 12px !important;
  border: none !important; padding: 0 !important;
}
.article-sources-list { list-style: none !important; padding: 0 !important; margin: 0 !important; }
.article-sources-list li { padding: 0 !important; border: none !important; }
.article-source-pill,
.article-sources a, .article-lab a {
  display: flex !important; align-items: center !important; justify-content: space-between !important;
  padding: 9px 12px !important;
  border: 1px solid var(--bw-border) !important;
  border-radius: 4px !important;
  margin-bottom: 6px !important;
  font-size: 13px !important; color: var(--bw-fg2) !important;
  text-decoration: none !important;
  background: var(--bw-bg) !important;
  transition: border-color .12s, color .12s !important;
}
/* Pas de ::after — le ↗ est déjà dans le HTML généré par PHP */
.article-source-pill:hover,
.article-sources a:hover, .article-lab a:hover { border-color: var(--bw-fg) !important; color: var(--bw-fg) !important; }

/* ── Like + Actions ── */
.article-actions {
  display: flex !important; align-items: center !important; gap: 8px !important;
  padding: 24px 0 !important; margin: 0 !important;
  border-top: 1px solid var(--bw-border) !important;
}
.article-like-btn {
  display: inline-flex !important; align-items: center !important; gap: 6px !important;
  background: none !important; border: 1px solid var(--bw-border) !important;
  border-radius: 3px !important; padding: 8px 16px !important;
  font-size: 13px !important; font-weight: 600 !important; color: var(--bw-fg2) !important;
  cursor: pointer !important; font-family: var(--bw-font) !important;
  transition: border-color .12s, color .12s !important;
}
.article-like-btn:hover { border-color: var(--bw-fg) !important; color: var(--bw-fg) !important; }
.article-like-btn.is-liked { background: var(--bw-fg) !important; color: #fff !important; border-color: var(--bw-fg) !important; }
.article-action-link {
  display: inline-flex !important; align-items: center !important; gap: 6px !important;
  font-size: 13px !important; font-weight: 600 !important; color: var(--bw-fg3) !important;
  background: none !important; border: 1px solid var(--bw-border) !important;
  border-radius: 3px !important; padding: 8px 14px !important;
  cursor: pointer !important; font-family: var(--bw-font) !important;
  transition: border-color .12s, color .12s !important;
}
.article-action-link:hover { border-color: var(--bw-fg) !important; color: var(--bw-fg) !important; }
.article-stamp-lu { display: none !important; }

/* ── Navigation Précédent / Suivant ── */
.article-nav {
  display: grid !important; grid-template-columns: 1fr 1fr !important;
  gap: 1px !important; margin: 48px 0 0 !important; padding: 0 !important;
  border-top: 1px solid var(--bw-border) !important;
  border-bottom: 1px solid var(--bw-border) !important;
  background: var(--bw-border) !important;
}
.article-nav-prev, .article-nav-next {
  display: flex !important; flex-direction: column !important; gap: 5px !important;
  background: #fff !important; padding: 20px 22px !important;
  text-decoration: none !important; color: var(--bw-fg) !important;
  transition: background .12s !important;
}
.article-nav-prev:hover, .article-nav-next:hover { background: #f9f9f9 !important; }
.article-nav-next { align-items: flex-end !important; text-align: right !important; }
.article-nav-dir {
  font-size: 10px !important; font-weight: 700 !important;
  letter-spacing: .12em !important; text-transform: uppercase !important; color: var(--bw-fg4) !important;
}
.article-nav-title {
  font-size: 14px !important; font-weight: 700 !important; color: var(--bw-fg) !important;
  line-height: 1.3 !important;
  display: -webkit-box !important; -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important; overflow: hidden !important;
}

/* ── Commentaires ── */
.article-comments {
  padding: 48px 0 0 !important; border-top: none !important;
  background: none !important; margin: 0 !important;
}
.article-comments-header {
  display: flex !important; align-items: center !important;
  gap: 10px !important; margin-bottom: 28px !important;
  border-bottom: none !important; padding-bottom: 0 !important;
}
.article-comments-title { font-size: 20px !important; font-weight: 800 !important; color: var(--bw-fg) !important; margin: 0 !important; letter-spacing: -.02em !important; }
.article-comments-count {
  display: inline-flex !important; align-items: center !important; justify-content: center !important;
  min-width: 22px !important; height: 22px !important; padding: 0 6px !important;
  background: #f0f0f0 !important; border-radius: 11px !important;
  font-size: 11px !important; font-weight: 700 !important; color: var(--bw-fg3) !important;
}
.article-comments-empty { font-size: 15px !important; color: var(--bw-fg4) !important; font-style: italic !important; }
.article-comment-notice { background: #f5f5f5 !important; border-radius: 3px !important; padding: 12px 16px !important; font-size: 13px !important; color: var(--bw-fg3) !important; margin-bottom: 20px !important; }
.article-comment {
  display: flex !important; gap: 14px !important;
  padding: 20px 0 !important; border-bottom: 1px solid var(--bw-border) !important;
  background: none !important; border-radius: 0 !important;
  border-left: none !important; border-right: none !important; border-top: none !important;
  box-shadow: none !important;
}
.article-comment-avatar {
  width: 38px !important; height: 38px !important; flex-shrink: 0 !important;
  border-radius: 50% !important; background: var(--bw-fg) !important;
  color: #fff !important; display: flex !important;
  align-items: center !important; justify-content: center !important;
  font-size: 15px !important; font-weight: 800 !important;
}
.article-comment-body-wrap { flex: 1 !important; min-width: 0 !important; }
.article-comment-meta { display: flex !important; align-items: center !important; gap: 10px !important; margin-bottom: 6px !important; }
.article-comment-meta strong { font-size: 14px !important; font-weight: 700 !important; color: var(--bw-fg) !important; }
.article-comment-meta time { font-size: 12px !important; color: var(--bw-fg4) !important; }
.article-comment-body { font-size: 15px !important; color: var(--bw-fg2) !important; line-height: 1.65 !important; margin: 0 !important; }
.article-comment-error { background: #fff0f0 !important; border: 1px solid #fcc !important; border-radius: 3px !important; padding: 10px 14px !important; font-size: 13px !important; color: #c00 !important; margin-bottom: 16px !important; }

/* Formulaire */
.article-comment-form-wrap {
  background: #fafafa !important; border: 1px solid var(--bw-border) !important;
  border-radius: 4px !important; padding: 24px !important; margin-top: 32px !important;
}
.article-comment-form-wrap h3 { font-size: 15px !important; font-weight: 700 !important; color: var(--bw-fg) !important; margin: 0 0 20px !important; }
.article-comment-row { display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 14px !important; margin-bottom: 14px !important; }
.article-comment-field { display: flex !important; flex-direction: column !important; gap: 6px !important; margin-bottom: 14px !important; }
.article-comment-field label { font-size: 11px !important; font-weight: 700 !important; letter-spacing: .07em !important; text-transform: uppercase !important; color: var(--bw-fg3) !important; }
.article-comment-field input,
.article-comment-field textarea {
  border: 1px solid var(--bw-border) !important; border-radius: 3px !important;
  padding: 10px 12px !important; font-size: 15px !important;
  font-family: var(--bw-font) !important; background: #fff !important;
  color: var(--bw-fg) !important; width: 100% !important; box-sizing: border-box !important;
  transition: border-color .12s !important; outline: none !important;
}
.article-comment-field input:focus, .article-comment-field textarea:focus { border-color: var(--bw-fg) !important; }
.article-comment-field-hint { font-size: 11px !important; color: var(--bw-fg4) !important; }
.article-comment-char-count { font-size: 11px !important; color: var(--bw-fg4) !important; align-self: flex-end !important; }
.article-comment-submit-row { display: flex !important; align-items: center !important; gap: 14px !important; }
.article-comment-submit-row .blog-cta-primary { font-size: 13px !important; padding: 11px 28px !important; border-radius: 3px !important; }
.article-comment-privacy { font-size: 12px !important; color: var(--bw-fg4) !important; }

/* ── Utilitaires ── */
#readingProgress { height: 3px !important; background: var(--bw-fg) !important; position: fixed !important; top: 0 !important; left: 0 !important; z-index: 9999 !important; }
.snav-search-overlay { background: rgba(255,255,255,.97) !important; }
.snav-search-box { background: var(--bw-bg) !important; border: 1px solid var(--bw-border) !important; border-radius: 6px !important; box-shadow: 0 4px 24px rgba(0,0,0,.10) !important; }
.snav-search-input { color: var(--bw-fg) !important; background: none !important; font-family: var(--bw-font) !important; }
.back-to-top { background: var(--bw-fg) !important; color: var(--bw-bg) !important; border: none !important; border-radius: 4px !important; box-shadow: 0 2px 10px rgba(0,0,0,.18) !important; }
.back-to-top:hover { opacity: .8 !important; }
.article-code-copy { background: var(--bw-bg) !important; border: 1px solid var(--bw-border) !important; color: var(--bw-fg3) !important; }
.article-code-copy.is-copied { background: #f5f5f5 !important; color: var(--bw-fg) !important; border-color: var(--bw-fg) !important; }

/* ── Responsive ── */
@media (max-width: 900px) {
  .page-blog:not(.page-article-blog) .blog-main { grid-template-columns: 1fr !important; gap: 0 !important; padding: 24px 16px 60px !important; }
  .blog-sidebar { position: static !important; padding-top: 36px !important; }
  .blog-cat-banner { grid-column: 1 !important; }
  .page-blog .blog-list { grid-template-columns: 1fr 1fr !important; }
}
@media (max-width: 600px) {
  .page-blog .blog-list { grid-template-columns: 1fr !important; }
  .page-article-blog .blog-main, .page-article-blog .article-main { padding: 0 16px 60px !important; }
  .article-cover, .article-carousel { margin-top: 20px !important; }
  .article-cover img, .article-carousel img { height: auto !important; }
  .article-newsletter-inline { flex-direction: column !important; align-items: flex-start !important; gap: 12px !important; }
  .article-nav { grid-template-columns: 1fr !important; }
  .article-nav-next { align-items: flex-start !important; text-align: left !important; }
  .blog-footer-inner { flex-direction: column !important; gap: 10px !important; text-align: center !important; }
}
@media (max-width: 480px) {
  .snav-links { display: none !important; }
  .article-related-cards { grid-template-columns: 1fr !important; }
}
