/* ================================================================
   Veille Libye — Interface web
   Thème sombre, sobre, professionnel.
   ================================================================ */

/* === Variables de couleurs et typographie === */
:root {
    --bg-primary:    #0d1117;
    --bg-secondary:  #161b22;
    --bg-tertiary:   #21262d;
    --bg-hover:      #30363d;
    --border:        #30363d;
    --border-subtle: #21262d;

    --text-primary:   #c9d1d9;
    --text-secondary: #8b949e;
    --text-muted:     #6e7681;
    --accent:         #58a6ff;

    --green: #3fb950;
    --amber: #d29922;
    --red:   #f85149;
    --blue:  #58a6ff;

    --font:      'Segoe UI', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
    --font-mono: 'Cascadia Code', 'Fira Code', 'Consolas', monospace;

    --radius: 6px;
    --navbar-height: 52px;
}

/* === Reset minimal === */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

body {
    background-color: var(--bg-primary);
    color: var(--text-primary);
    font-family: var(--font);
    font-size: 14px;
    line-height: 1.6;
    min-height: 100vh;
}

/* ================================================================
   Navbar
   ================================================================ */

.navbar {
    background-color: var(--bg-secondary);
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    padding: 0 24px;
    height: var(--navbar-height);
    position: sticky;
    top: 0;
    z-index: 100;
    gap: 32px;
}

.navbar-brand {
    font-size: 14px;
    font-weight: 600;
    color: var(--text-primary);
    letter-spacing: 0.03em;
    text-transform: uppercase;
    white-space: nowrap;
    flex-shrink: 0;
}

.nav-tabs {
    display: flex;
    list-style: none;
    height: 100%;
    gap: 0;
}

.nav-item a {
    display: flex;
    align-items: center;
    height: 100%;
    padding: 0 16px;
    color: var(--text-secondary);
    text-decoration: none;
    font-size: 14px;
    border-bottom: 2px solid transparent;
    transition: color 0.15s ease, border-color 0.15s ease;
}

.nav-item a:hover {
    color: var(--text-primary);
    border-bottom-color: var(--border);
}

.nav-item.active a {
    color: var(--accent);
    border-bottom-color: var(--accent);
}

/* ================================================================
   Contenu principal
   ================================================================ */

.main-content {
    max-width: 1280px;
    margin: 0 auto;
    padding: 32px 24px;
}

/* ================================================================
   En-tête de page
   ================================================================ */

.page-header {
    display: flex;
    align-items: baseline;
    gap: 12px;
    margin-bottom: 20px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--border-subtle);
}

.page-header h1 {
    font-size: 18px;
    font-weight: 600;
    color: var(--text-primary);
}

.badge-count {
    font-size: 12px;
    color: var(--text-muted);
    background-color: var(--bg-tertiary);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 2px 10px;
    white-space: nowrap;
}

/* ================================================================
   Tableau de données
   ================================================================ */

.table-container {
    overflow-x: auto;
    border: 1px solid var(--border);
    border-radius: var(--radius);
}

.data-table {
    width: 100%;
    border-collapse: collapse;
    white-space: nowrap;
}

.data-table thead tr {
    background-color: var(--bg-secondary);
}

.data-table th {
    padding: 10px 16px;
    text-align: left;
    font-size: 11px;
    font-weight: 600;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    border-bottom: 1px solid var(--border);
}

.data-table td {
    padding: 10px 16px;
    border-bottom: 1px solid var(--border-subtle);
    color: var(--text-primary);
    vertical-align: middle;
}

.data-table tbody tr:last-child td {
    border-bottom: none;
}

.data-table tbody tr:hover {
    background-color: var(--bg-hover);
}

/* Colonnes spécifiques */
.cell-date {
    font-family: var(--font-mono);
    font-size: 12px;
    color: var(--text-secondary);
}

.cell-number {
    font-family: var(--font-mono);
    text-align: center;
    color: var(--text-secondary);
}

.cell-empty {
    color: var(--text-muted);
}

/* ================================================================
   Badges
   ================================================================ */

.badge {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    white-space: nowrap;
}

/* Fiabilité */
.badge-elevee {
    background-color: rgba(63, 185, 80, 0.15);
    color: var(--green);
    border: 1px solid rgba(63, 185, 80, 0.3);
}

.badge-moyenne {
    background-color: rgba(210, 153, 34, 0.15);
    color: var(--amber);
    border: 1px solid rgba(210, 153, 34, 0.3);
}

.badge-faible {
    background-color: rgba(248, 81, 73, 0.15);
    color: var(--red);
    border: 1px solid rgba(248, 81, 73, 0.3);
}

/* Type d'alerte */
.badge-initiale {
    background-color: rgba(88, 166, 255, 0.12);
    color: var(--blue);
    border: 1px solid rgba(88, 166, 255, 0.25);
}

.badge-intensification {
    background-color: rgba(248, 81, 73, 0.12);
    color: var(--red);
    border: 1px solid rgba(248, 81, 73, 0.25);
}

/* ================================================================
   État vide (aucune donnée)
   ================================================================ */

.empty-state {
    padding: 64px 24px;
    text-align: center;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    color: var(--text-muted);
}

.empty-state p {
    font-size: 14px;
}

/* ================================================================
   Carte interactive (onglet Map)
   ================================================================ */

/* Supprime padding et max-width sur le <main> pour que la carte
   occupe tout l'espace disponible sous la navbar */
.main-content--map {
    max-width: none;
    padding: 0;
    height: calc(100vh - var(--navbar-height));
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

#map {
    width: 100%;
    height: 100%;
}

/* Bouton bascule fond de carte (contrôle Leaflet custom, topleft) */
.btn-fond-carte {
    background-color: var(--bg-secondary);
    color: var(--text-primary);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 6px 12px;
    font-size: 12px;
    font-family: var(--font);
    cursor: pointer;
    box-shadow: 0 1px 5px rgba(0, 0, 0, 0.4);
    white-space: nowrap;
    transition: background-color 0.15s ease;
}

.btn-fond-carte:hover {
    background-color: var(--bg-hover);
}

/* Contrôle de couches Leaflet — thème sombre */
.leaflet-control-layers {
    background-color: var(--bg-secondary) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius) !important;
    box-shadow: 0 1px 5px rgba(0, 0, 0, 0.4) !important;
    color: var(--text-primary) !important;
    font-size: 12px !important;
    font-family: var(--font) !important;
}

.leaflet-control-layers-list label {
    color: var(--text-primary) !important;
}

/* Boutons zoom Leaflet — thème sombre */
.leaflet-control-zoom a {
    background-color: var(--bg-secondary) !important;
    color: var(--text-primary) !important;
    border-color: var(--border) !important;
}

.leaflet-control-zoom a:hover {
    background-color: var(--bg-hover) !important;
}

/* Attribution Leaflet — discret sur fond sombre */
.leaflet-control-attribution {
    background-color: rgba(13, 17, 23, 0.7) !important;
    color: var(--text-muted) !important;
    font-size: 10px !important;
}

.leaflet-control-attribution a {
    color: var(--accent) !important;
}

/* Popups Leaflet — thème sombre */
.leaflet-popup-content-wrapper {
    background-color: var(--bg-secondary) !important;
    color: var(--text-primary) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius) !important;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.6) !important;
}

.leaflet-popup-tip {
    background-color: var(--bg-secondary) !important;
}

.leaflet-popup-close-button {
    color: var(--text-muted) !important;
}

/* Contenu popup — alerte */
.popup-alerte {
    font-size: 13px;
    line-height: 1.5;
    min-width: 200px;
}

.popup-date {
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--text-muted);
    margin-bottom: 4px;
}

.popup-categorie {
    font-size: 14px;
    margin-bottom: 4px;
}

.popup-lieu {
    font-size: 12px;
    color: var(--text-secondary);
    margin-bottom: 6px;
}

.popup-meta {
    font-size: 11px;
    color: var(--text-muted);
    margin-bottom: 6px;
}

.popup-fiab {
    display: inline-block;
    padding: 1px 5px;
    border-radius: 8px;
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.popup-fiab--elevee  { background: rgba(63, 185, 80, 0.15);  color: var(--green); }
.popup-fiab--moyenne { background: rgba(210, 153, 34, 0.15); color: var(--amber); }
.popup-fiab--faible  { background: rgba(248, 81, 73, 0.15);  color: var(--red); }

.popup-type {
    font-style: italic;
}

.popup-texte-alerte {
    font-size: 12px;
    line-height: 1.55;
    color: var(--text-secondary);
    border-top: 1px solid var(--border-subtle);
    padding-top: 6px;
    padding-right: 8px;
    margin-top: 8px;
    word-break: break-word;
    white-space: pre-wrap;
    max-height: 200px;
    overflow-y: auto;
}

.popup-texte-alerte::-webkit-scrollbar        { width: 5px; }
.popup-texte-alerte::-webkit-scrollbar-track  { background: var(--bg-tertiary); border-radius: 3px; }
.popup-texte-alerte::-webkit-scrollbar-thumb  { background: var(--border); border-radius: 3px; }
.popup-texte-alerte::-webkit-scrollbar-thumb:hover { background: var(--text-muted); }

/* Contenu popup — lieu */
.popup-lieu-detail {
    font-size: 13px;
    min-width: 160px;
}

.popup-lieu-nom {
    margin-bottom: 4px;
    font-size: 14px;
}

.popup-lieu-mentions {
    font-size: 12px;
    color: var(--text-secondary);
}

.popup-lieu-aliases {
    font-size: 11px;
    color: var(--text-muted);
    margin-top: 4px;
    word-break: break-word;
}

/* Légende des catégories (bottomright) */
.map-legende {
    background-color: rgba(22, 27, 34, 0.9);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 10px 14px;
    font-size: 12px;
    color: var(--text-primary);
    font-family: var(--font);
    max-height: 50vh;
    overflow-y: auto;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.5);
}

.map-legende strong {
    display: block;
    margin-bottom: 8px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-muted);
}

.legende-item {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 5px;
    font-size: 12px;
    white-space: nowrap;
}

.legende-puce {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    flex-shrink: 0;
    border: 1.5px solid rgba(255, 255, 255, 0.2);
}

/* ================================================================
   Architecture (onglet graphe — étape 2.2)
   ================================================================ */

/* Pleine hauteur, identique à la map */
.main-content--archi,
.main-content--politique {
    max-width: none;
    padding: 0;
    height: calc(100vh - var(--navbar-height));
    overflow: hidden;
}

.archi-layout {
    position: relative;
    width: 100%;
    height: 100%;
}

/* Barre d'outils en haut : recherche + toggle */
.archi-toolbar {
    position: absolute;
    top: 12px;
    left: 12px;
    right: 12px;
    z-index: 10;
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
    pointer-events: none;     /* laisse passer les clics aux enfants seulement */
}

.archi-toolbar > * {
    pointer-events: auto;
}

.search-bar {
    display: flex;
    align-items: center;
    gap: 8px;
    background-color: var(--bg-secondary);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 6px 8px;
    box-shadow: 0 1px 5px rgba(0, 0, 0, 0.4);
}

.search-bar input {
    background-color: transparent;
    color: var(--text-primary);
    border: none;
    outline: none;
    font-size: 13px;
    font-family: var(--font);
    width: 240px;
}

.search-bar input::placeholder {
    color: var(--text-muted);
}

.search-bar button {
    background-color: var(--bg-tertiary);
    color: var(--text-primary);
    border: 1px solid var(--border);
    border-radius: 4px;
    padding: 4px 10px;
    font-size: 12px;
    font-family: var(--font);
    cursor: pointer;
    transition: background-color 0.15s ease;
}

.search-bar button:hover {
    background-color: var(--bg-hover);
}

.toggle-non-confirme {
    display: flex;
    align-items: center;
    gap: 8px;
    background-color: var(--bg-secondary);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 6px 12px;
    font-size: 12px;
    color: var(--text-secondary);
    cursor: pointer;
    box-shadow: 0 1px 5px rgba(0, 0, 0, 0.4);
}

.toggle-non-confirme input {
    accent-color: var(--accent);
    cursor: pointer;
}

/* Filtres par catégorie (étape 2.5e) — panneau groupant les 5 cases */
.graph-filtres {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
    background-color: var(--bg-secondary);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 6px 12px;
    font-size: 12px;
    color: var(--text-secondary);
    box-shadow: 0 1px 5px rgba(0, 0, 0, 0.4);
}

.graph-filtres label {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    cursor: pointer;
}

.graph-filtres input {
    accent-color: var(--accent);
    cursor: pointer;
}

/* Boutons « vue par défaut » / « réinitialiser » (étape 2.5e) */
.vue-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    background-color: var(--bg-secondary);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 6px 8px;
    box-shadow: 0 1px 5px rgba(0, 0, 0, 0.4);
}

.vue-actions button {
    background-color: var(--bg-tertiary);
    color: var(--text-primary);
    border: 1px solid var(--border);
    border-radius: 4px;
    padding: 4px 10px;
    font-size: 12px;
    font-family: var(--font);
    cursor: pointer;
    transition: background-color 0.15s ease;
}

.vue-actions button:hover {
    background-color: var(--bg-hover);
}

.archi-compteur {
    font-size: 12px;
    color: var(--text-muted);
    font-family: var(--font-mono);
    background-color: rgba(13, 17, 23, 0.6);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius);
    padding: 4px 10px;
}

/* Canevas Cytoscape */
#cy {
    width: 100%;
    height: 100%;
    background-color: #1a1a1a;
}

.archi-erreur {
    color: var(--red);
    padding: 24px;
    font-size: 14px;
}

/* Tooltip popper (mouseover sur un nœud) */
.tooltip-popper {
    background-color: var(--bg-secondary);
    color: var(--text-primary);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 8px 12px;
    font-size: 12px;
    line-height: 1.5;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.6);
    max-width: 260px;
    pointer-events: none;
    z-index: 50;
}

.tooltip-popper strong {
    color: var(--text-primary);
}

.tooltip-popper em {
    color: var(--text-muted);
    font-style: normal;
}

/* Fiche latérale droite */
.fiche {
    position: absolute;
    top: 0;
    right: 0;
    width: 400px;
    max-width: 90vw;
    height: 100%;
    background-color: #2a2a2a;
    border-left: 1px solid var(--border);
    box-shadow: -4px 0 16px rgba(0, 0, 0, 0.5);
    transform: translateX(0);
    transition: transform 0.25s ease;
    z-index: 20;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.fiche--fermee {
    transform: translateX(105%);   /* hors écran à droite */
}

.fiche-close {
    position: absolute;
    top: 8px;
    right: 12px;
    background: transparent;
    border: none;
    color: var(--text-muted);
    font-size: 24px;
    line-height: 1;
    cursor: pointer;
    padding: 4px 8px;
}

.fiche-close:hover {
    color: var(--text-primary);
}

.fiche-tabs {
    display: flex;
    border-bottom: 1px solid var(--border);
    padding: 0 16px;
    margin-top: 8px;
}

.fiche-tab {
    background: transparent;
    border: none;
    color: var(--text-secondary);
    padding: 12px 12px;
    font-size: 13px;
    font-family: var(--font);
    cursor: pointer;
    border-bottom: 2px solid transparent;
}

.fiche-tab--active {
    color: var(--accent);
    border-bottom-color: var(--accent);
}

.fiche-content {
    padding: 16px 20px;
    overflow-y: auto;
    flex: 1;
}

.fiche-section {
    margin-bottom: 20px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--border-subtle);
}

.fiche-section:last-child {
    border-bottom: none;
}

.fiche-titre {
    font-size: 18px;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 4px;
}

.fiche-acronyme {
    font-size: 13px;
    color: var(--text-muted);
    font-family: var(--font-mono);
    margin-bottom: 6px;
}

.fiche-modif {
    display: inline-block;
    margin-top: 4px;
    font-size: 11px;
    color: var(--amber);
    background-color: rgba(210, 153, 34, 0.12);
    border: 1px solid rgba(210, 153, 34, 0.3);
    border-radius: 12px;
    padding: 2px 8px;
}

.fiche-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 6px 0;
}

.fiche-label {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-muted);
}

.fiche-valeur {
    font-family: var(--font-mono);
    font-size: 13px;
    color: var(--text-primary);
}

/* Pastilles de statut dans la fiche */
.fiche-statut {
    display: inline-block;
    padding: 2px 10px;
    border-radius: 12px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.fiche-statut--non_confirme {
    background-color: rgba(110, 118, 129, 0.2);
    color: var(--text-muted);
    border: 1px solid var(--border);
}

.fiche-statut--peu_confirme {
    background-color: rgba(88, 166, 255, 0.15);
    color: var(--blue);
    border: 1px solid rgba(88, 166, 255, 0.3);
}

.fiche-statut--confirme {
    background-color: rgba(46, 124, 184, 0.2);
    color: #5a9fd4;
    border: 1px solid rgba(90, 159, 212, 0.3);
}

.fiche-statut--verifie_manuellement {
    background-color: rgba(76, 175, 80, 0.15);
    color: var(--green);
    border: 1px solid rgba(76, 175, 80, 0.3);
}

/* ================================================================
   Alertes (onglet liste — étape 2.4)
   ================================================================ */

/* Pleine hauteur : même pattern que archi/politique */
.main-content--alertes {
    max-width: none;
    padding: 0;
    height: calc(100vh - var(--navbar-height));
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

/* Conteneur global de l'onglet */
.alertes-layout {
    display: flex;
    flex-direction: column;
    height: 100%;
}

/* ── Barre de filtres ──────────────────────────────────────────── */

.filtre-bar {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    padding: 10px 16px;
    background-color: var(--bg-secondary);
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
}

.filtre-group {
    display: flex;
    align-items: center;
}

/* Input texte recherche */
.filtre-search input {
    background-color: var(--bg-primary);
    color: var(--text-primary);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 5px 10px;
    font-size: 13px;
    font-family: var(--font);
    width: 220px;
    outline: none;
    transition: border-color 0.15s ease;
}

.filtre-search input:focus {
    border-color: var(--accent);
}

.filtre-search input::placeholder {
    color: var(--text-muted);
}

/* Selects et date inputs */
.filtre-bar select,
.filtre-bar input[type="date"] {
    background-color: var(--bg-primary);
    color: var(--text-primary);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 5px 8px;
    font-size: 13px;
    font-family: var(--font);
    outline: none;
    cursor: pointer;
    transition: border-color 0.15s ease;
}

.filtre-bar select:focus,
.filtre-bar input[type="date"]:focus {
    border-color: var(--accent);
}

/* Séparateur "→" entre les deux champs de date */
.filtre-sep {
    margin: 0 6px;
    color: var(--text-muted);
    font-size: 12px;
}

/* Bouton réinitialiser */
.btn-reset {
    background-color: var(--bg-tertiary);
    color: var(--text-secondary);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 5px 12px;
    font-size: 12px;
    font-family: var(--font);
    cursor: pointer;
    transition: background-color 0.15s ease, color 0.15s ease;
}

.btn-reset:hover {
    background-color: var(--bg-hover);
    color: var(--text-primary);
}

/* Compteur "N alerte(s)" */
.alertes-compteur {
    margin-left: auto;
    font-size: 12px;
    color: var(--text-muted);
    font-family: var(--font-mono);
    background-color: var(--bg-tertiary);
    border: 1px solid var(--border-subtle);
    border-radius: 12px;
    padding: 2px 10px;
    white-space: nowrap;
}

/* ── Corps : liste + panneau latéral ───────────────────────────── */

.alertes-body {
    display: flex;
    flex: 1;
    overflow: hidden;
    position: relative;
}

/* Colonne scrollable des cartes */
.alertes-list {
    flex: 1;
    overflow-y: auto;
    padding: 14px 16px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.alertes-list::-webkit-scrollbar        { width: 6px; }
.alertes-list::-webkit-scrollbar-track  { background: var(--bg-primary); }
.alertes-list::-webkit-scrollbar-thumb  { background: var(--border); border-radius: 3px; }
.alertes-list::-webkit-scrollbar-thumb:hover { background: var(--text-muted); }

/* États vide / chargement */
.alertes-loading,
.alertes-vide {
    padding: 48px 24px;
    text-align: center;
    color: var(--text-muted);
    font-size: 14px;
}

/* ── Carte alerte ───────────────────────────────────────────────── */

.alerte-card {
    background-color: var(--bg-secondary);
    border: 1px solid var(--border);
    border-left-width: 3px;          /* bande colorée par catégorie (JS) */
    border-radius: var(--radius);
    padding: 12px 14px;
    cursor: pointer;
    transition: border-color 0.15s ease, background-color 0.15s ease;
}

.alerte-card:hover {
    background-color: var(--bg-tertiary);
    border-color: var(--accent);
    border-left-color: inherit;      /* conserve la couleur catégorie */
}

/* Carte sélectionnée (panneau de détail ouvert sur cette carte) */
.alerte-card--active {
    background-color: var(--bg-tertiary);
    border-color: var(--accent);
    border-left-color: inherit;
}

/* En-tête de carte : badges + date */
.card-header {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
    margin-bottom: 8px;
}

/* Date relative — poussée à droite */
.card-date {
    margin-left: auto;
    font-size: 11px;
    color: var(--text-muted);
    font-family: var(--font-mono);
    white-space: nowrap;
    flex-shrink: 0;
}

/* Badge catégorie (couleur appliquée dynamiquement par JS) */
.badge-categorie {
    display: inline-block;
    padding: 2px 9px;
    border-radius: 12px;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.03em;
    white-space: nowrap;
}

/* Badge fiabilité */
.badge-fiab {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    white-space: nowrap;
}

.badge-fiab--elevee {
    background-color: rgba(63, 185, 80, 0.15);
    color: var(--green);
    border: 1px solid rgba(63, 185, 80, 0.3);
}

.badge-fiab--moyenne {
    background-color: rgba(210, 153, 34, 0.15);
    color: var(--amber);
    border: 1px solid rgba(210, 153, 34, 0.3);
}

.badge-fiab--faible {
    background-color: rgba(110, 118, 129, 0.15);
    color: var(--text-muted);
    border: 1px solid rgba(110, 118, 129, 0.3);
}

/* Badge type d'alerte */
.badge-type-alerte {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    white-space: nowrap;
}

.badge-type-alerte--initiale {
    background-color: rgba(88, 166, 255, 0.12);
    color: var(--blue);
    border: 1px solid rgba(88, 166, 255, 0.25);
}

.badge-type-alerte--intensification {
    background-color: rgba(248, 81, 73, 0.12);
    color: var(--red);
    border: 1px solid rgba(248, 81, 73, 0.25);
}

/* Corps de la carte : métadonnées + indicateur sources */
.card-body {
    display: flex;
    align-items: flex-start;
    gap: 12px;
}

.card-meta {
    flex: 1;
    min-width: 0;      /* empêche le débordement en flex */
}

.card-lieu {
    font-size: 12px;
    color: var(--text-secondary);
    margin-bottom: 4px;
}

.card-lieu-icon {
    margin-right: 3px;
}

/* Aperçu du texte : 3 lignes max, tronqué */
.card-apercu {
    font-size: 12px;
    color: var(--text-muted);
    line-height: 1.5;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    word-break: break-word;
    white-space: pre-wrap;
}

/* Pastille "nombre de sources" en haut à droite */
.card-sources {
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1px;
    font-size: 10px;
    color: var(--text-muted);
    font-family: var(--font-mono);
    background-color: var(--bg-tertiary);
    border: 1px solid var(--border-subtle);
    border-radius: 4px;
    padding: 4px 8px;
    white-space: nowrap;
    min-width: 36px;
}

.card-sources-nb {
    font-size: 15px;
    font-weight: 700;
    color: var(--text-secondary);
    line-height: 1;
}

/* ── Panneau de détail latéral ──────────────────────────────────── */

.alertes-detail {
    position: absolute;
    top: 0;
    right: 0;
    width: 420px;
    max-width: 90vw;
    height: 100%;
    background-color: #2a2a2a;
    border-left: 1px solid var(--border);
    box-shadow: -4px 0 16px rgba(0, 0, 0, 0.5);
    transform: translateX(0);
    transition: transform 0.25s ease;
    z-index: 20;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

/* Panneau fermé — hors écran à droite */
.alertes-detail--ferme {
    transform: translateX(105%);
}

.detail-close {
    position: absolute;
    top: 8px;
    right: 12px;
    background: transparent;
    border: none;
    color: var(--text-muted);
    font-size: 24px;
    line-height: 1;
    cursor: pointer;
    padding: 4px 8px;
    z-index: 1;
}

.detail-close:hover {
    color: var(--text-primary);
}

/* Zone de contenu scrollable */
.detail-content {
    padding: 20px;
    overflow-y: auto;
    flex: 1;
}

.detail-content::-webkit-scrollbar        { width: 6px; }
.detail-content::-webkit-scrollbar-track  { background: var(--bg-tertiary); border-radius: 3px; }
.detail-content::-webkit-scrollbar-thumb  { background: var(--border); border-radius: 3px; }
.detail-content::-webkit-scrollbar-thumb:hover { background: var(--text-muted); }

/* Titre du panneau (= catégorie colorée) */
.detail-titre {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 4px;
    padding-right: 32px;     /* évite le chevauchement avec le ✕ */
}

/* Rangée de badges sous le titre */
.detail-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 6px;
    margin-bottom: 16px;
}

/* Section avec séparateur */
.detail-section {
    margin-bottom: 16px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--border-subtle);
}

.detail-section:last-child {
    border-bottom: none;
    margin-bottom: 0;
}

/* Label de section */
.detail-label {
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    color: var(--text-muted);
    margin-bottom: 4px;
}

/* Valeur monospace (dates, chiffres) */
.detail-valeur {
    font-size: 13px;
    color: var(--text-primary);
    font-family: var(--font-mono);
}

/* Grille 2 colonnes pour les métadonnées */
.detail-meta-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}

.detail-meta-item {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

/* Corps texte de l'alerte */
.detail-texte {
    font-size: 12px;
    color: var(--text-secondary);
    line-height: 1.65;
    white-space: pre-wrap;
    word-break: break-word;
}

/* Notes admin (style ambre, italique) */
.detail-notes {
    font-size: 12px;
    color: var(--amber);
    line-height: 1.6;
    white-space: pre-wrap;
    font-style: italic;
}

/* ================================================================
   Placeholder (onglets à venir)
   ================================================================ */

.placeholder {
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 72px 32px;
    text-align: center;
    max-width: 480px;
    margin: 0 auto;
}

.placeholder-icon {
    font-size: 28px;
    color: var(--text-muted);
    margin-bottom: 16px;
    opacity: 0.5;
}

.placeholder h1 {
    font-size: 18px;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 8px;
}

.placeholder-label {
    font-size: 13px;
    color: var(--accent);
    margin-bottom: 12px;
    font-weight: 500;
}

.placeholder-desc {
    font-size: 13px;
    color: var(--text-muted);
    line-height: 1.6;
}

/* ================================================================
   Sous-onglets Map (Carte / Lieux) — étape 2.5a
   ================================================================ */

.map-subtabs {
    flex: 0 0 auto;
    display: flex;
    gap: 4px;
    padding: 8px 12px;
    background: var(--bg-secondary);
    border-bottom: 1px solid var(--border);
}

.map-subtab {
    background: transparent;
    color: var(--text-secondary);
    border: 1px solid transparent;
    border-radius: var(--radius);
    padding: 6px 16px;
    font-size: 13px;
    font-family: var(--font);
    cursor: pointer;
    transition: background-color 0.15s ease, color 0.15s ease;
}

.map-subtab:hover {
    background: var(--bg-hover);
    color: var(--text-primary);
}

.map-subtab.active {
    background: var(--bg-tertiary);
    color: var(--text-primary);
    border-color: var(--border);
}

/* Conteneurs de vue : remplissent l'espace restant sous les sous-onglets */
.map-vue {
    flex: 1 1 auto;
    min-height: 0;
    position: relative;
}

.map-vue[hidden] {
    display: none;
}

#vue-lieux {
    overflow-y: auto;
    padding: 16px 24px;
}

/* ── Barre d'outils du panneau Lieux ── */
.lieux-toolbar {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}

.lieux-recherche {
    flex: 1 1 280px;
    max-width: 360px;
    background: var(--bg-secondary);
    color: var(--text-primary);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 8px 12px;
    font-size: 13px;
    font-family: var(--font);
}

.lieux-recherche:focus {
    outline: none;
    border-color: var(--accent);
}

.lieux-toggle {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    color: var(--text-secondary);
    cursor: pointer;
}

.lieux-compteur {
    margin-left: auto;
    font-size: 12px;
    color: var(--text-muted);
}

/* ── Tableau des lieux ── */
.lieux-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}

.lieux-table thead th {
    text-align: left;
    padding: 8px 12px;
    color: var(--text-secondary);
    font-weight: 600;
    border-bottom: 1px solid var(--border);
    position: sticky;
    top: 0;
    background: var(--bg-primary);
}

.lieux-table tbody td {
    padding: 8px 12px;
    border-bottom: 1px solid var(--border-subtle);
    color: var(--text-primary);
}

.lieux-table tbody tr:hover {
    background: var(--bg-secondary);
}

.lieux-td-nom {
    font-weight: 500;
}

.lieux-td-coord {
    font-family: var(--font-mono);
    font-size: 12px;
    color: var(--text-secondary);
}

.lieux-td-alertes {
    text-align: center;
    color: var(--text-secondary);
}

.lieux-td-actions {
    white-space: nowrap;
}

.lieux-action {
    background: transparent;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 4px 8px;
    margin-right: 4px;
    cursor: pointer;
    font-size: 14px;
    transition: background-color 0.15s ease;
}

.lieux-action:hover:not(:disabled) {
    background: var(--bg-hover);
}

.lieux-action:disabled {
    opacity: 0.35;
    cursor: not-allowed;
}

.lieux-loading,
.lieux-vide,
.lieux-erreur {
    padding: 24px;
    text-align: center;
    color: var(--text-muted);
    font-size: 13px;
}

.lieux-erreur {
    color: var(--red);
}

/* ── Badge statut (manuel / auto) ── */
.badge-statut {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 10px;
    font-size: 11px;
    font-weight: 600;
}

.badge-statut--manuel {
    background: rgba(210, 153, 34, 0.15);
    color: var(--amber);
    border: 1px solid rgba(210, 153, 34, 0.35);
}

.badge-statut--auto {
    background: var(--bg-tertiary);
    color: var(--text-muted);
}

/* ================================================================
   Modale d'édition (partagée Lieux / Alertes) — étape 2.5a
   ================================================================ */

.modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1000;
    padding: 24px;
}

.modal-overlay[hidden] {
    display: none;
}

.modal {
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-radius: 8px;
    width: 100%;
    max-width: 520px;
    max-height: 90vh;
    overflow-y: auto;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
}

.modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid var(--border);
}

.modal-header h2 {
    font-size: 16px;
    font-weight: 600;
    color: var(--text-primary);
}

.modal-close {
    background: transparent;
    border: none;
    color: var(--text-secondary);
    font-size: 22px;
    line-height: 1;
    cursor: pointer;
    padding: 0 4px;
}

.modal-close:hover {
    color: var(--text-primary);
}

.modal-body {
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.modal-field {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.modal-field > span {
    font-size: 12px;
    color: var(--text-secondary);
    font-weight: 500;
}

.modal-field > span em {
    color: var(--text-muted);
    font-style: normal;
}

.modal-field input[type="text"],
.modal-field input[type="number"],
.modal-field select,
.modal-field textarea {
    background: var(--bg-primary);
    color: var(--text-primary);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 8px 10px;
    font-size: 13px;
    font-family: var(--font);
    width: 100%;
}

.modal-field textarea {
    resize: vertical;
    min-height: 60px;
    line-height: 1.5;
}

.modal-field input:focus,
.modal-field select:focus,
.modal-field textarea:focus {
    outline: none;
    border-color: var(--accent);
}

.modal-field-row {
    display: flex;
    gap: 14px;
}

.modal-field-row .modal-field {
    flex: 1;
}

.modal-field--check {
    flex-direction: row;
    align-items: center;
    gap: 8px;
}

.modal-field--check span {
    font-size: 13px;
    color: var(--text-primary);
}

.modal-hint {
    font-size: 11px;
    color: var(--text-muted);
    line-height: 1.4;
}

.modal-erreur {
    background: rgba(248, 81, 73, 0.12);
    color: var(--red);
    border: 1px solid rgba(248, 81, 73, 0.35);
    border-radius: var(--radius);
    padding: 8px 12px;
    font-size: 12px;
}

.modal-erreur[hidden] {
    display: none;
}

.modal-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 4px;
}

.btn-primaire,
.btn-secondaire {
    border-radius: var(--radius);
    padding: 8px 18px;
    font-size: 13px;
    font-family: var(--font);
    cursor: pointer;
    border: 1px solid var(--border);
    transition: background-color 0.15s ease;
}

.btn-primaire {
    background: var(--accent);
    color: #0d1117;
    border-color: var(--accent);
    font-weight: 600;
}

.btn-primaire:hover {
    background: #79b8ff;
}

.btn-secondaire {
    background: transparent;
    color: var(--text-secondary);
}

.btn-secondaire:hover {
    background: var(--bg-hover);
    color: var(--text-primary);
}

/* ── Édition d'alerte : bouton ✏️ + badge « modifié manuellement » ── */
.detail-edit-btn {
    background: transparent;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    color: var(--text-secondary);
    padding: 6px 12px;
    font-size: 12px;
    font-family: var(--font);
    cursor: pointer;
    margin-bottom: 12px;
    transition: background-color 0.15s ease;
}

.detail-edit-btn:hover {
    background: var(--bg-hover);
    color: var(--text-primary);
}

.badge-modifie {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 10px;
    font-size: 11px;
    font-weight: 600;
    background: rgba(210, 153, 34, 0.15);
    color: var(--amber);
    border: 1px solid rgba(210, 153, 34, 0.35);
}

/* ================================================================
   Édition de graphe (étape 2.5c) — fiche relation, légende, fusion
   ================================================================ */

/* Actions dans la fiche latérale (boutons ✏️ / 🗑️) */
.fiche-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.fiche-edit-btn,
.fiche-delete-btn {
    background: transparent;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    color: var(--text-secondary);
    padding: 6px 12px;
    font-size: 12px;
    font-family: var(--font);
    cursor: pointer;
    transition: background-color 0.15s ease, color 0.15s ease;
}

.fiche-edit-btn:hover {
    background: var(--bg-hover);
    color: var(--text-primary);
}

.fiche-delete-btn {
    border-color: rgba(248, 81, 73, 0.4);
    color: var(--red);
}

.fiche-delete-btn:hover {
    background: rgba(248, 81, 73, 0.12);
}

.fiche-relation-sens {
    font-size: 14px;
    color: var(--text-primary);
    margin-top: 6px;
    line-height: 1.5;
}

.fiche-fleche {
    color: var(--accent);
    margin: 0 4px;
}

/* ── Légende dépliable (superposée au graphe, sous la barre d'outils) ── */
.legend-toggle {
    position: absolute;
    top: 56px;
    right: 12px;
    z-index: 11;
    background: var(--bg-secondary);
    color: var(--text-primary);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 6px 12px;
    font-size: 12px;
    font-family: var(--font);
    cursor: pointer;
    box-shadow: 0 1px 5px rgba(0, 0, 0, 0.4);
}

.legend-toggle:hover {
    background: var(--bg-hover);
}

.legend-panel {
    position: absolute;
    top: 92px;
    right: 12px;
    z-index: 11;
    width: 250px;
    max-height: 65vh;
    overflow-y: auto;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.5);
    font-size: 12px;
}

.legend-panel[hidden] {
    display: none;
}

.legend-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 12px;
    border-bottom: 1px solid var(--border);
    font-weight: 600;
    color: var(--text-primary);
}

.legend-close {
    background: transparent;
    border: none;
    color: var(--text-secondary);
    font-size: 18px;
    line-height: 1;
    cursor: pointer;
}

.legend-close:hover {
    color: var(--text-primary);
}

.legend-content {
    padding: 10px 12px;
}

.legend-section {
    margin-bottom: 12px;
}

.legend-section:last-child {
    margin-bottom: 0;
}

.legend-titre {
    font-weight: 600;
    color: var(--text-secondary);
    margin-bottom: 6px;
    text-transform: uppercase;
    font-size: 10px;
    letter-spacing: 0.04em;
}

.legend-item {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 5px;
    color: var(--text-primary);
}

/* ── Récap de la modale de fusion ── */
.fusion-recap {
    font-size: 14px;
    color: var(--text-primary);
    line-height: 1.6;
}

.fusion-details {
    margin: 8px 0 0 18px;
    padding: 0;
    color: var(--text-secondary);
    font-size: 13px;
}

.fusion-details li {
    margin-bottom: 4px;
}
