/* ══════════════════════════════════════════════════════════════
   BLOG HOME — page template partagée Skin A & Skin B
   ══════════════════════════════════════════════════════════════ */

/* ── Variables locales ─────────────────────────────────────── */
.bh-page {
  --bh-gap:    18px;
  --bh-max:    1280px;
  --bh-px:     40px;
  --bh-radius: 14px;
}

/* ══════════════════════════════════════════════════════════════
   INTRO ÉDITORIALE (contenu éditeur de la page)
   ══════════════════════════════════════════════════════════════ */
.bh-page-content {
  border-bottom: 1px solid var(--ink-100, #f1f5f9);
}
.bh-page-content__inner {
  max-width: 720px;
  margin: 0 auto;
  padding: 48px var(--bh-px) 56px;
  font-size: 16px;
  line-height: 1.8;
  color: var(--ink-600, #475569);
  text-align: center;
}
.bh-page-content__h1 {
  font-family: var(--font-display, inherit);
  font-size: clamp(28px, 3.5vw, 44px);
  font-weight: 800;
  color: var(--ink-900, #0f172a);
  letter-spacing: -.03em;
  line-height: 1.15;
  margin: 0 0 20px;
}
.bh-page-content__inner > *:first-child { margin-top: 0; }
.bh-page-content__inner > *:last-child  { margin-bottom: 0; }

/* ══════════════════════════════════════════════════════════════
   SECTION DERNIERS ARTICLES — patchwork overlay
   ══════════════════════════════════════════════════════════════ */
.bh-latest {
  background: var(--white, #fff);
  padding: 56px 0 72px;
}
.bh-latest__inner {
  max-width: var(--bh-max);
  margin: 0 auto;
  padding: 0 var(--bh-px);
}
.bh-latest__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 24px;
}
.bh-latest__title {
  font-family: var(--font-display, inherit);
  font-size: clamp(22px, 2.2vw, 28px);
  font-weight: 800;
  color: var(--ink-900, #0f172a);
  margin: 0;
  letter-spacing: -.025em;
}

/* Grille patchwork */
.bh-lpatch {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: 260px 260px;
  grid-auto-rows: 260px;
  gap: var(--bh-gap);
}
/* Premier article : occupe 2 colonnes × 2 rangées */
.bh-lpatch .bh-ocard:nth-child(1) {
  grid-column: span 2;
  grid-row: span 2;
}

/* ── Overlay card ─────────────────────────────────────────── */
.bh-ocard {
  --sa-card-cat:          var(--brand, #4f46e5);
  --sa-card-cat-bg:       var(--brand-soft, rgba(79,70,229,.08));
  --sa-card-cat-hover:    #ffffff;
  --sa-card-cat-bg-hover: var(--brand, #4f46e5);
  position: relative;
  border-radius: var(--bh-radius);
  overflow: hidden;
  background: #1a1428;
  display: flex;
  flex-direction: column;
  text-decoration: none;
}
.bh-ocard .bh-ocard__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  opacity: .90;
  transition: opacity .2s ease;
}
.bh-ocard:hover .bh-ocard__img {
  opacity: .75;
}
.bh-ocard__grad {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(12, 6, 30, .72) 0%,
    rgba(12, 6, 30, .16) 55%,
    transparent 100%
  );
}
.bh-ocard__body {
  position: relative;
  z-index: 1;
  margin-top: auto;
  padding: 18px 20px 20px;
}
.bh-ocard:nth-child(1) .bh-ocard__body { padding: 24px 28px 28px; }
.bh-ocard .bh-ocard__cat {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--sa-card-cat);
  background: var(--sa-card-cat-bg);
  padding: 3px 10px;
  border-radius: 50px;
  margin-bottom: 8px;
  text-decoration: none;
  transition: background .15s, color .15s;
}
.bh-ocard .bh-ocard__cat:hover { background: var(--sa-card-cat-bg-hover); color: var(--sa-card-cat-hover); }
.bh-ocard__title {
  font-family: var(--font-display, inherit);
  font-size: 17px;
  font-weight: 700;
  color: #fff;
  line-height: 1.35;
  margin: 0 0 7px;
}
.bh-ocard:nth-child(1) .bh-ocard__title {
  font-size: clamp(22px, 2vw, 28px);
  margin-bottom: 10px;
}
.bh-ocard__title a {
  color: inherit;
  text-decoration: none;
}
.bh-ocard__meta {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: rgba(255,255,255,.5);
}

/* ══════════════════════════════════════════════════════════════
   SECTIONS PAR CATÉGORIE
   ══════════════════════════════════════════════════════════════ */
.bh-section {
  max-width: var(--bh-max);
  margin: 0 auto;
  padding: 64px var(--bh-px) 56px;
}
.bh-section__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 28px;
}
.bh-section__title {
  font-family: var(--font-display, inherit);
  font-size: clamp(22px, 2.2vw, 28px);
  font-weight: 800;
  color: var(--ink-900, #0f172a);
  margin: 0;
  letter-spacing: -.025em;
  position: relative;
  padding-bottom: 10px;
}
.bh-section__title::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0;
  width: 32px; height: 3px;
  background: var(--brand-grad, linear-gradient(90deg,#4f46e5,#7c3aed));
  border-radius: 2px;
}
.bh-section__more {
  --bh-more-color:       var(--brand, #4f46e5);
  --bh-more-border:      var(--brand, #4f46e5);
  --bh-more-bg:          transparent;
  --bh-more-color-hover: #ffffff;
  --bh-more-bg-hover:    var(--brand, #4f46e5);
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 13px;
  font-weight: 600;
  color: var(--bh-more-color);
  text-decoration: none;
  white-space: nowrap;
  flex-shrink: 0;
  padding: 6px 14px;
  border: 1.5px solid var(--bh-more-border);
  border-radius: 50px;
  background: var(--bh-more-bg);
  transition: background .15s, color .15s, border-color .15s;
}
.bh-section__more:hover {
  background: var(--bh-more-bg-hover);
  color: var(--bh-more-color-hover);
  border-color: var(--bh-more-bg-hover);
}

/* ══════════════════════════════════════════════════════════════
   GRILLE D'ARTICLES
   ══════════════════════════════════════════════════════════════ */
.bh-grid {
  display: grid;
  gap: var(--bh-gap);
}
.bh-grid--3col { grid-template-columns: repeat(3, 1fr); }
.bh-grid--4col { grid-template-columns: repeat(4, 1fr); }
.bh-grid--6col { grid-template-columns: repeat(3, 1fr); }

/* Featured card — reserved for future use outside sections */
.bh-card--featured {
  grid-column: span 2;
}

/* ── Card ──────────────────────────────────────────────────── */
.bh-card {
  --sa-card-bg:           #ffffff;
  --sa-card-border:       #f1f5f9;
  --sa-card-title:        var(--ink-900, #0f172a);
  --sa-card-text:         var(--ink-500, #64748b);
  --sa-card-cat:          var(--brand, #4f46e5);
  --sa-card-cat-bg:       var(--brand-soft, rgba(79,70,229,.08));
  --sa-card-cat-hover:    #ffffff;
  --sa-card-cat-bg-hover: var(--brand, #4f46e5);
  --sa-card-meta:         var(--ink-300, #94a3b8);
  background: var(--sa-card-bg);
  border-radius: var(--bh-radius);
  overflow: hidden;
  box-shadow: 0 2px 12px rgba(0,0,0,.07);
  border: 1px solid var(--sa-card-border);
  transition: box-shadow .2s ease;
  display: flex;
  flex-direction: column;
}
.bh-card:hover {
  box-shadow: var(--shadow-lg, 0 12px 40px rgba(0,0,0,.14));
}
.bh-card__img-wrap {
  display: block;
  overflow: hidden;
  height: 200px;
}
.bh-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.bh-card__body {
  padding: 20px 22px 24px;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.bh-card .bh-card__cat {
  display: inline-block;
  align-self: flex-start;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--sa-card-cat);
  text-decoration: none;
  background: var(--sa-card-cat-bg);
  padding: 3px 10px;
  border-radius: 50px;
  margin-bottom: 10px;
  transition: background .15s, color .15s;
}
.bh-card .bh-card__cat:hover { background: var(--sa-card-cat-bg-hover); color: var(--sa-card-cat-hover); }
.bh-card__title {
  font-family: var(--font-display, inherit);
  font-size: 20px;
  font-weight: 700;
  color: var(--sa-card-title);
  line-height: 1.38;
  margin: 0 0 10px;
  flex: 1;
}
.bh-card__title a { color: inherit; text-decoration: none; transition: color .15s; }
.bh-card__title a:hover { color: var(--brand, #4f46e5); }
.bh-card__excerpt {
  font-size: 14px;
  color: var(--sa-card-text);
  line-height: 1.65;
  margin: 0 0 14px;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.bh-card__meta {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--sa-card-meta);
  margin-top: auto;
}

/* ══════════════════════════════════════════════════════════════
   LIST MODE — bh-llist / bh-lcard (Skin A)
   ══════════════════════════════════════════════════════════════ */
.bh-llist {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.bh-lcard {
  --sa-card-bg:           #ffffff;
  --sa-card-border:       #f1f5f9;
  --sa-card-title:        var(--ink-900, #0f172a);
  --sa-card-text:         var(--ink-500, #64748b);
  --sa-card-cat:          var(--brand, #4f46e5);
  --sa-card-cat-bg:       var(--brand-soft, rgba(79,70,229,.08));
  --sa-card-cat-hover:    #ffffff;
  --sa-card-cat-bg-hover: var(--brand, #4f46e5);
  --sa-card-meta:         var(--ink-300, #94a3b8);
  display: flex;
  gap: 0;
  background: var(--sa-card-bg);
  border: 1px solid var(--sa-card-border);
  border-radius: var(--bh-radius, 10px);
  overflow: hidden;
  transition: box-shadow .2s ease;
}
.bh-lcard:hover { box-shadow: var(--shadow-md, 0 6px 24px rgba(0,0,0,.1)); }

.bh-lcard__img-wrap {
  width: 220px;
  min-width: 220px;
  flex-shrink: 0;
  overflow: hidden;
  display: flex;
}
.bh-lcard__img {
  width: 100%;
  object-fit: cover;
  display: block;
  min-height: 160px;
}
.bh-lcard__body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  padding: 20px 22px;
}
.bh-lcard__cat {
  display: inline-block;
  align-self: flex-start;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--sa-card-cat);
  text-decoration: none;
  background: var(--sa-card-cat-bg);
  padding: 3px 10px;
  border-radius: 50px;
  margin-bottom: 10px;
  transition: background .15s, color .15s;
}
.bh-lcard__cat:hover { background: var(--sa-card-cat-bg-hover); color: var(--sa-card-cat-hover); }
.bh-lcard__title {
  font-family: var(--font-display, inherit);
  font-size: 20px;
  font-weight: 700;
  color: var(--sa-card-title);
  line-height: 1.35;
  margin: 0 0 9px;
}
.bh-lcard__title a { color: inherit; text-decoration: none; transition: color .15s; }
.bh-lcard__title a:hover { color: var(--brand, #4f46e5); }
.bh-lcard__excerpt {
  font-size: 14px;
  color: var(--sa-card-text);
  line-height: 1.65;
  margin: 0 0 12px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.bh-lcard__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: auto;
}
.bh-lcard__meta {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--sa-card-meta);
}
.bh-lcard__read {
  font-size: 13px;
  font-weight: 700;
  color: var(--sa-card-read, var(--brand, #4f46e5));
  text-decoration: none;
  white-space: nowrap;
}
.bh-lcard__read:hover { color: var(--brand-dark, var(--brand)); }

/* ══════════════════════════════════════════════════════════════
   CTA BAND
   ══════════════════════════════════════════════════════════════ */
.bh-cta-band {
  background: linear-gradient(135deg, var(--bhla-cta-bg1, #4f46e5) 0%, var(--bhla-cta-bg2, #a855f7) 100%);
  margin-top: 80px;
}
.bh-cta-band__inner {
  max-width: var(--bh-max);
  margin: 0 auto;
  padding: 72px var(--bh-px);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}
.bh-cta-band__title {
  font-family: var(--font-display, inherit);
  font-size: clamp(26px, 3vw, 42px);
  font-weight: 800;
  color: var(--bhla-cta-title, #fff);
  margin: 0;
  letter-spacing: -.03em;
  line-height: 1.15;
}
.bh-cta-band__sub {
  font-size: 17px;
  color: var(--bhla-cta-sub, rgba(255,255,255,.82));
  max-width: 480px;
  margin: 0;
  line-height: 1.65;
}
.bh-cta-band__btn {
  background: var(--bhla-cta-btn-bg, #fff);
  color: var(--bhla-cta-btn-color, var(--brand, #4f46e5)) !important;
  font-size: 15px;
  font-weight: 700;
  padding: 15px 38px;
  border-radius: 50px;
  text-decoration: none !important;
  margin-top: 8px;
  transition: transform .15s, box-shadow .15s;
  display: inline-block;
  box-shadow: 0 4px 20px rgba(0,0,0,.15);
}
.bh-cta-band__btn:hover {
  background: linear-gradient(135deg, var(--bhla-cta-btn-hover-bg1, #f3f0ff), var(--bhla-cta-btn-hover-bg2, #ede9fe));
  color: var(--bhla-cta-btn-hover-color, var(--brand, #4f46e5)) !important;
  box-shadow: 0 8px 32px rgba(0,0,0,.22);
}

/* ── Layout split : image gauche / texte droite ────────────── */
.bh-cta-band--split {
  display: grid;
  grid-template-columns: 1fr 1fr;
}
.bh-cta-band__img-col {
  position: relative;
  overflow: hidden;
  min-height: 340px;
}
.bh-cta-band__img-col img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.bh-cta-band--split .bh-cta-band__inner {
  text-align: left;
  align-items: flex-start;
  max-width: none;
  justify-content: center;
  padding: 56px 60px;
}
.bh-cta-band--split .bh-cta-band__sub {
  max-width: 420px;
}

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
  .bh-page { --bh-px: 28px; }
  .bh-grid--4col { grid-template-columns: repeat(2, 1fr); }
  .bh-grid--6col { grid-template-columns: repeat(2, 1fr); }
  .bh-card--featured { grid-column: span 2; }
  .bh-lpatch { grid-template-columns: 1fr 1fr 1fr; }
}
@media (max-width: 768px) {
  .bh-page { --bh-px: 20px; }
  .bh-lpatch {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 220px 220px;
    grid-auto-rows: 220px;
  }
  .bh-lpatch .bh-ocard:nth-child(1) { grid-column: span 2; grid-row: span 1; }
  .bh-grid--3col,
  .bh-grid--4col,
  .bh-grid--6col { grid-template-columns: 1fr 1fr; }
  .bh-card--featured { grid-column: span 2; grid-template-columns: 1fr; }
  .bh-card--featured .bh-card__img-wrap { height: 200px; }
}
@media (max-width: 520px) {
  .bh-lpatch { grid-template-columns: 1fr; grid-template-rows: none; grid-auto-rows: 220px; }
  .bh-lpatch .bh-ocard:nth-child(1) { grid-column: span 1; grid-row: span 1; }
  .bh-grid--3col,
  .bh-grid--4col,
  .bh-grid--6col { grid-template-columns: 1fr; }
  .bh-card--featured { grid-column: span 1; }
  .bh-section { padding-top: 40px; }
  .bh-page-content__inner { padding: 32px var(--bh-px); font-size: 15px; }
  /* lcard : vertical sur mobile */
  .bh-lcard { flex-direction: column; }
  .bh-lcard__img-wrap { width: 100%; }
  .bh-lcard__img { min-height: 200px; }
  .bh-lcard__footer { flex-direction: column; align-items: flex-start; gap: 6px; }
}
@media (max-width: 768px) {
  .bh-cta-band--split { grid-template-columns: 1fr; }
  .bh-cta-band__img-col { min-height: 240px; position: relative; }
  .bh-cta-band--split .bh-cta-band__inner { text-align: center; align-items: center; padding: 48px var(--bh-px); }
  .bh-cta-band--split .bh-cta-band__sub { max-width: 480px; }
}

/* ══════════════════════════════════════════════════════════════
   BREADCRUMB — inline dans bh-page-content / bh-page-h1-only
   ══════════════════════════════════════════════════════════════ */

/* Réinitialise les styles "bande" des skins : ici le breadcrumb
   est à l'intérieur du bloc de contenu, pas une bande séparée  */
.bh-page-breadcrumb {
  display:       flex;
  align-items:   center;
  gap:           6px;
  flex-wrap:     wrap;
  font-size:     12px;
  color:         var(--ink-500, #64748b);
  background:    none;
  border:        none;
  padding:       0;
  margin:        0 0 14px;
}

/* bh-page-h1-only : le breadcrumb est la seule chose visible,
   on lui donne un contenant avec padding cohérent               */
.bh-page-h1-only {
  padding: 24px var(--lx, clamp(16px, 4vw, 40px));
}
