/* ═══════════════════════════════════════════════
   SOS Imprévus — Charte Graphique
   Design tokens + composants partagés
   ═══════════════════════════════════════════════ */

/* ── Design Tokens ───────────────────────────── */
:root {
  /* Backgrounds */
  --bg-light:      #FAFAFA;
  --bg-dark:       #121826;
  --surface-light: #FFFFFF;
  --surface-dark:  #1C2333;
  --surface-mid:   #F1F5F9;

  /* Typographie sémantique */
  --ink-900:  #0F172A;
  --ink-700:  #334155;
  --ink-500:  #64748B;
  --ink-300:  #CBD5E1;
  --ink-light:#F8FAFC;

  /* Statuts */
  --alerte:        #E11D48;
  --alerte-soft:   #FFF1F2;
  --alerte-mid:    #FFE4E6;
  --alerte-dark:   #9F1239;

  --vigilance:     #D97706;
  --vigilance-soft:#FFFBEB;
  --vigilance-mid: #FDE68A;
  --vigilance-dark:#92400E;

  --succes:        #059669;
  --succes-soft:   #ECFDF5;
  --succes-mid:    #A7F3D0;
  --succes-dark:   #065F46;

  --info:          #0284C7;
  --info-soft:     #F0F9FF;

  /* Catégories */
  --cat-maison:    #0369A1;
  --cat-maison-bg: #E0F2FE;
  --cat-sante:     #E11D48;
  --cat-sante-bg:  #FFF1F2;
  --cat-route:     #C2410C;
  --cat-route-bg:  #FFF7ED;
  --cat-admin:     #5B21B6;
  --cat-admin-bg:  #F5F3FF;

  /* Bordures */
  --border-charte: #E2E8F0;
  --border-strong: #CBD5E1;

  /* Rayons */
  --radius-sm:   8px;
  --radius-md:   14px;
  --radius-lg:   20px;
  --radius-pill: 999px;

  /* Espacements */
  --space-xs:  8px;
  --space-sm:  12px;
  --space-md:  20px;
  --space-lg:  32px;
  --space-xl:  48px;
  --space-2xl: 64px;
}

/* ── Polices globales ────────────────────────── */
body {
  font-family: 'Source Sans 3', sans-serif;
}

h1, h2, h3, h4 {
  font-family: 'Plus Jakarta Sans', sans-serif;
}

button, .btn, label {
  font-family: 'Plus Jakarta Sans', sans-serif;
}

/* ── Composant : Boutons ─────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 48px;
  padding: 14px 24px;
  border-radius: var(--radius-pill);
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 15px;
  font-weight: 700;
  border: none;
  cursor: pointer;
  transition: transform 0.15s, box-shadow 0.15s;
  text-decoration: none;
}
.btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.15);
}
.btn-alerte    { background: var(--alerte);    color: #fff; }
.btn-vigilance { background: var(--vigilance); color: #fff; }
.btn-succes    { background: var(--succes);    color: #fff; }
.btn-dark      { background: var(--ink-900);   color: #fff; }
.btn-ghost     { background: transparent; color: var(--ink-900); border: 2px solid var(--border-charte); }
@media (max-width: 640px) { .btn { width: 100%; } }

/* ── Composant : Badges ──────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 12px;
  font-weight: 700;
  padding: 4px 12px;
  border-radius: var(--radius-pill);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.badge-alerte    { background: var(--alerte-mid);    color: var(--alerte-dark); }
.badge-vigilance { background: var(--vigilance-mid); color: var(--vigilance-dark); }
.badge-succes    { background: var(--succes-mid);    color: var(--succes-dark); }
.badge-info      { background: #DBEAFE;              color: #1E40AF; }
.badge-maison    { background: var(--cat-maison-bg); color: var(--cat-maison); }
.badge-sante     { background: var(--cat-sante-bg);  color: var(--alerte-dark); }
.badge-route     { background: var(--cat-route-bg);  color: var(--cat-route); }
.badge-admin     { background: var(--cat-admin-bg);  color: var(--cat-admin); }

/* ── Composant : Carte Notice ────────────────── */
.notice-card {
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-charte);
}
.notice-card-top {
  padding: 20px 22px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.notice-card-top h3 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 18px;
  font-weight: 800;
  color: #fff;
  margin: 0;
}
.notice-card-top p { font-size: 13px; color: rgba(255,255,255,.8); margin: 0; }
.notice-card-body  { padding: 20px 22px; background: #fff; }
.notice-step {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 12px 0;
  border-bottom: 1px solid var(--surface-mid);
}
.notice-step:last-child { border-bottom: none; }
.notice-step-num {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  background: var(--alerte);
  color: #fff;
  font-weight: 800;
  font-size: 13px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.notice-step-text {
  font-family: 'Source Sans 3', sans-serif;
  font-size: 14px;
  color: var(--ink-700);
  line-height: 1.7;
}
