/* ============================================================
   BOURSE-VANIER-EXTRA.CSS
   Composants additionnels pour bourse-vanier-canada.html
   Charger APRÈS bourse.css
   ============================================================ */

/* ── HERO SPÉCIFIQUE ──────────────────────────────────────── */
.article-hero.hero-vanier {
  background-image: url('https://images.unsplash.com/photo-1607237138185-eedd9c632b0b?w=1800&q=85');
  background-position: center 38%;
}

/* ── BANDEAU D'HONNÊTETÉ ÉDITORIALE ──────────────────────── */
.honesty-banner {
  background: linear-gradient(135deg, var(--navy) 0%, #1a2f4a 100%);
  border-left: 5px solid var(--gold);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  padding: 22px 28px;
  margin-bottom: 48px;
  display: flex;
  gap: 18px;
  align-items: flex-start;
}
.honesty-banner-icon {
  width: 44px; height: 44px;
  background: rgba(201,168,76,0.15);
  border-radius: 50%;
  border: 2px solid var(--gold);
  display: flex; align-items: center; justify-content: center;
  color: var(--gold); font-size: 1rem; flex-shrink: 0;
}
.honesty-banner-body { flex: 1; }
.honesty-banner-body strong {
  display: block; color: var(--gold); font-size: .85rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase; margin-bottom: 8px;
}
.honesty-banner-body p {
  color: rgba(255,255,255,0.72); font-size: .9rem; line-height: 1.7; margin: 0;
}
.honesty-banner-body p strong {
  color: var(--white); text-transform: none; letter-spacing: 0;
  font-size: inherit; display: inline;
}

/* ── STATUT CHIPS ─────────────────────────────────────────── */
.statut-chip {
  display: inline-flex; align-items: center; gap: 7px;
  font-size: .72rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  padding: 5px 14px; border-radius: 100px; border: 1.5px solid; white-space: nowrap;
}
.statut-chip.ouvert-bientot { background:rgba(39,174,96,0.1); border-color:rgba(39,174,96,0.35); color:#1a9950; }
.statut-chip.a-preparer     { background:rgba(201,168,76,0.1); border-color:rgba(201,168,76,0.35); color:#8a6200; }
.statut-chip.permanent      { background:rgba(11,31,58,0.1); border-color:rgba(11,31,58,0.35); color:var(--navy); }
.statut-chip.remplacee      { background:rgba(231,76,60,0.08); border-color:rgba(231,76,60,0.3); color:#c0392b; }

/* ── BARRE TOP CARD SELON STATUT ──────────────────────────── */
.bourse-card.ouvert-bientot::before { background:linear-gradient(to right,#27ae60,#2ecc71); }
.bourse-card.a-preparer::before     { background:linear-gradient(to right,var(--gold),var(--gold-light)); }
.bourse-card.permanent-card::before { background:linear-gradient(to right,var(--navy-light),#2980b9); }
.bourse-card.remplacee-card::before { background:linear-gradient(to right,#95a5a6,#bdc3c7); opacity:.45; }
.bourse-card.remplacee-card         { opacity:.7; }

/* Info "successeur" dans card */
.successor-info {
  display:flex; align-items:flex-start; gap:12px;
  padding:14px 16px;
  background:rgba(39,174,96,0.06); border:1px solid rgba(39,174,96,0.2);
  border-radius:var(--radius-sm); font-size:.85rem; color:var(--text); margin-top:8px;
}
.successor-info i { color:#27ae60; flex-shrink:0; margin-top:2px; }
.successor-info a { color:#1a7341; text-decoration:underline; font-weight:600; }

/* ── CALENDRIER 2026 ──────────────────────────────────────── */
.calendar-section {
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--radius-lg); overflow:hidden; margin:48px 0;
}
.calendar-header {
  background:var(--navy); padding:20px 32px;
  display:flex; align-items:center; gap:16px;
}
.calendar-header i { color:var(--gold); font-size:1.25rem; }
.calendar-header h3 { color:var(--white); margin:0; font-size:1.15rem; }
.calendar-header .cal-year {
  margin-left:auto; font-size:.72rem; color:rgba(255,255,255,.4);
  letter-spacing:.14em; text-transform:uppercase;
}
.calendar-body { padding:4px 0; }
.calendar-row {
  display:grid; grid-template-columns:120px 1fr auto;
  align-items:center; gap:20px; padding:16px 32px;
  border-bottom:1px solid rgba(201,168,76,.07); transition:background .2s;
}
.calendar-row:last-child { border-bottom:none; }
.calendar-row:hover { background:var(--cream); }
.cal-date {
  font-family:var(--font-display); font-size:1.05rem;
  font-weight:600; color:var(--gold); white-space:nowrap;
}
.cal-date span {
  display:block; font-family:var(--font-body); font-size:.68rem;
  font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  color:var(--text-light); margin-top:2px;
}
.cal-info strong { display:block; font-size:.9rem; color:var(--navy); margin-bottom:3px; }
.cal-info p { font-size:.82rem; color:var(--text-light); margin:0; line-height:1.5; }
.cal-badge {
  display:inline-flex; align-items:center; gap:6px;
  font-size:.68rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  padding:5px 12px; border-radius:100px; white-space:nowrap;
}
.cal-badge.upcoming { background:rgba(39,174,96,.12); color:#1a7341; }
.cal-badge.prepare  { background:rgba(201,168,76,.14); color:#7d5000; }
.cal-badge.toujours { background:rgba(11,31,58,.08); color:var(--navy); }

/* ── COMMENT SE PRÉPARER — GRILLE ────────────────────────── */
.prep-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin:32px 0; }
.prep-card {
  background:var(--white); border:1px solid var(--border); border-radius:var(--radius-md);
  padding:28px 22px; text-align:center; transition:var(--transition);
  opacity:0; transform:translateY(16px);
}
.prep-card.visible { opacity:1; transform:translateY(0); }
.prep-card:hover { box-shadow:var(--shadow-md); border-color:var(--gold); transform:translateY(-4px); }
.prep-card-step {
  font-family:var(--font-display); font-size:2.8rem; font-weight:700;
  color:rgba(201,168,76,.18); line-height:1; margin-bottom:2px;
}
.prep-card-icon {
  width:50px; height:50px; background:var(--navy); border-radius:var(--radius-sm);
  display:flex; align-items:center; justify-content:center;
  color:var(--gold); font-size:1.1rem; margin:0 auto 14px;
}
.prep-card h4 { font-size:.95rem; color:var(--navy); margin-bottom:8px; }
.prep-card p  { font-size:.83rem; color:var(--text-light); line-height:1.65; margin:0; }

/* ── VANIER → BESRC EXPLAINER ────────────────────────────── */
.archive-explainer {
  background:var(--cream); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:36px 40px; margin:32px 0;
  display:grid; grid-template-columns:auto 1fr; gap:28px; align-items:start;
}
.archive-icon {
  width:56px; height:56px; background:rgba(149,165,166,.15);
  border-radius:var(--radius-md); display:flex; align-items:center;
  justify-content:center; color:#7f8c8d; font-size:1.3rem;
  flex-shrink:0; border:1px solid rgba(149,165,166,.3);
}
.archive-body h3 { font-size:1.1rem; color:var(--navy); margin-bottom:10px; }
.archive-body p  { font-size:.9rem; color:var(--text-light); line-height:1.72; margin-bottom:12px; }
.archive-body p:last-child { margin-bottom:0; }
.archive-body strong { color:var(--navy); }

.archive-compare { display:flex; gap:14px; margin-top:18px; flex-wrap:wrap; align-items:center; }
.archive-compare-item {
  flex:1; min-width:150px; background:var(--white);
  border:1px solid var(--border); border-radius:var(--radius-md); padding:16px 18px;
}
.archive-compare-item.new-card {
  border-color:rgba(201,168,76,.35); background:var(--gold-pale);
}
.ac-label {
  display:block; font-size:.67rem; font-weight:700; letter-spacing:.14em;
  text-transform:uppercase; margin-bottom:8px;
}
.archive-compare-item.old-card .ac-label { color:#95a5a6; }
.archive-compare-item.new-card .ac-label { color:var(--gold); }
.ac-name { font-family:var(--font-display); font-size:1rem; color:var(--navy); font-weight:600; display:block; margin-bottom:6px; }
.ac-val  { font-size:.82rem; color:var(--text-light); line-height:1.5; }
.archive-arrow { color:var(--gold); font-size:1.5rem; flex-shrink:0; }

/* ── SIDEBAR COUNTDOWN ────────────────────────────────────── */
.sidebar-countdown {
  background:var(--navy); border-radius:var(--radius-md); padding:20px 22px; text-align:center;
}
.sidebar-countdown h4 { color:var(--white); font-size:.9rem; margin-bottom:4px; }
.sidebar-countdown p  { font-size:.77rem; color:rgba(255,255,255,.42); margin-bottom:16px; line-height:1.5; }
.sc-units { display:flex; justify-content:center; gap:8px; flex-wrap:wrap; }
.sc-unit {
  background:rgba(255,255,255,.05); border:1px solid rgba(201,168,76,.2);
  border-radius:var(--radius-sm); padding:8px 10px; min-width:48px; text-align:center;
}
.sc-unit strong { display:block; font-family:var(--font-display); font-size:1.5rem; color:var(--gold); line-height:1; }
.sc-unit span   { font-size:.58rem; color:rgba(255,255,255,.32); text-transform:uppercase; letter-spacing:.1em; }

/* ── RESPONSIVE ───────────────────────────────────────────── */
@media (max-width:900px) {
  .prep-grid { grid-template-columns:1fr 1fr; }
  .archive-explainer { grid-template-columns:1fr; }
  .archive-icon { margin:0 auto; }
  .calendar-row { grid-template-columns:90px 1fr; }
  .cal-badge { display:none; }
}
@media (max-width:620px) {
  .prep-grid { grid-template-columns:1fr; }
  .honesty-banner { flex-direction:column; gap:12px; }
  .calendar-row { grid-template-columns:1fr; gap:4px; padding:14px 20px; }
  .archive-compare { flex-direction:column; }
  .archive-arrow { transform:rotate(90deg); margin:0 auto; }
}

