/*
 * SENEGO DESIGN SYSTEM — BLOCS ÉDITORIAUX, PUBLICITAIRES & PREMIUM
 * ===============================================================
 * Patrons réutilisables propres à Senego, calqués sur le rendu validé du site
 * (carte article, encart pub, bloc premium, encart éditorial). Un nouveau
 * plugin / une page spéciale (CAN, World Cup, météo, classement…) doit
 * réutiliser ces classes plutôt que d'inventer un style isolé.
 *
 * Construits sur les tokens `--senego-*`. Aucun `!important`. Charger après
 * tokens.css + components.css.
 */

/* ════════════════════════ CARTE ARTICLE ════════════════════════ */
/* Hiérarchie standard : image → catégorie → titre → méta. */
.senego-article-card {
  display: flex;
  flex-direction: column;
  background: var(--senego-color-surface);
  border: 1px solid var(--senego-color-border-soft);
  border-radius: var(--senego-radius-sm);
  box-shadow: var(--senego-shadow-md);
  overflow: hidden;
  transition: box-shadow var(--senego-transition), transform var(--senego-transition);
}
.senego-article-card:hover { box-shadow: var(--senego-shadow-lg); transform: translateY(-1px); }

.senego-article-card__media {
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: var(--senego-color-surface-subtle);
}
.senego-article-card__media img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Badge catégorie en surimpression (orange, comme .category-tag historique). */
.senego-article-card__category {
  position: absolute;
  top: var(--senego-space-md);
  left: var(--senego-space-md);
  padding: 4px 12px;
  border-radius: var(--senego-radius-xs);
  background: var(--senego-color-primary);
  color: #fff;
  font-size: var(--senego-text-sm);
  font-weight: var(--senego-weight-bold);
  text-transform: uppercase;
  z-index: 1;
}
.senego-article-card__body  { padding: var(--senego-space-md); display: flex; flex-direction: column; gap: var(--senego-space-sm); }
.senego-article-card__title {
  margin: 0;
  font-family: var(--senego-font-heading);
  font-size: var(--senego-text-lg);
  font-weight: var(--senego-weight-bold);
  line-height: var(--senego-leading-tight);
  color: var(--senego-color-heading);
}
.senego-article-card__title a { color: inherit; text-decoration: none; }
.senego-article-card__title a:hover { color: var(--senego-color-primary); }
.senego-article-card__meta { color: var(--senego-color-meta); font-size: var(--senego-text-sm); }

/* ════════════════════════ ENCART PUBLICITAIRE ════════════════════════ */
/* Comportement cohérent : surface neutre, label « PUBLICITÉ », hauteur réservée
   (anti-CLS) pour éviter tout saut de mise en page au chargement de l'annonce. */
.senego-ad-slot {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--senego-space-sm);
  background: var(--senego-color-surface);
  border: 1px solid var(--senego-color-border-soft);
  border-radius: var(--senego-radius-sm);
  padding: var(--senego-space-md);
  min-height: 280px;                 /* réserve l'espace : pas de reflow */
  overflow: hidden;
}
.senego-ad-slot::before {
  content: "PUBLICITÉ";
  font-size: var(--senego-text-xs);
  letter-spacing: .08em;
  color: var(--senego-color-muted);
  text-transform: uppercase;
}
.senego-ad-slot--inline  { min-height: 100px; }
.senego-ad-slot--sidebar { min-height: 250px; }
.senego-ad-slot--flat    { box-shadow: none; background: transparent; border-style: dashed; }

/* ════════════════════════ BLOC PREMIUM ════════════════════════ */
.senego-premium {
  position: relative;
  background: var(--senego-color-premium-bg);
  border: 1px solid var(--senego-color-premium);
  border-radius: var(--senego-radius-lg);
  padding: var(--senego-space-lg);
  color: var(--senego-color-heading);
}
.senego-premium__label {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  margin-bottom: var(--senego-space-sm);
  border-radius: var(--senego-radius-xs);
  background: var(--senego-color-premium);
  color: #fff;
  font-size: var(--senego-text-xs);
  font-weight: var(--senego-weight-bold);
  text-transform: uppercase;
}
.senego-premium__title { margin: 0 0 var(--senego-space-sm); font-size: var(--senego-text-xl); font-weight: var(--senego-weight-bold); }
.senego-premium__text  { color: var(--senego-color-text); margin: 0 0 var(--senego-space-md); }

/* ════════════════════════ ENCART ÉDITORIAL ════════════════════════ */
/* Mise en avant rédactionnelle (chapô, « à lire aussi », encadré). */
.senego-editorial {
  background: var(--senego-color-surface);
  border-left: 4px solid var(--senego-color-accent);
  border-radius: var(--senego-radius-sm);
  padding: var(--senego-space-md) var(--senego-space-lg);
  box-shadow: var(--senego-shadow-sm);
}
.senego-editorial__kicker {
  margin: 0 0 var(--senego-space-xs);
  font-size: var(--senego-text-xs);
  font-weight: var(--senego-weight-bold);
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--senego-color-accent);
}
.senego-editorial__title { margin: 0 0 var(--senego-space-sm); font-size: var(--senego-text-lg); font-weight: var(--senego-weight-bold); color: var(--senego-color-heading); }

/* ════════════════════════ RESPONSIVE ════════════════════════ */
@media (max-width: 767px) {
  .senego-ad-slot          { min-height: 250px; }
  .senego-premium          { padding: var(--senego-space-md); }
  .senego-article-card__title { font-size: var(--senego-text-md); }
}
@media (prefers-reduced-motion: reduce) {
  .senego-article-card { transition: none; }
}
