/* ============================================================
   DPEM - Design System (maquette)
   Direction de la Protection de l'Environnement Minier
   Charte adaptee de GEC. Theme clair institutionnel.
   Tokens > Layout > Sidebar > Topbar > Composants
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

/* ── 1. TOKENS ───────────────────────────────────────────── */
:root {
  /* Sidebar (vert foncé institutionnel) */
  --sb-width: 264px;
  --sb-bg: #0B3D2E;
  --sb-border: rgba(255,255,255,0.07);
  --sb-text: #A7C4B5;
  --sb-text-hover: #CBD5E1;
  --sb-text-active: #F8FAFC;
  --sb-item-hover: rgba(255,255,255,0.05);
  --sb-item-active: rgba(21,128,61,0.24);
  --sb-accent: #34D399;
  --sb-section: #6B9C86;

  /* Topbar */
  --tb-height: 64px;
  --tb-bg: #FFFFFF;
  --tb-border: #EEF2F7;

  /* Surfaces */
  --body-bg: #F1F5F9;
  --card-bg: #FFFFFF;
  --card-border: #E2E8F0;
  --card-radius: 12px;
  --card-shadow: 0 1px 3px rgba(15,23,42,0.06), 0 1px 2px rgba(15,23,42,0.04);
  --card-shadow-hover: 0 8px 24px rgba(15,23,42,0.10);

  /* Brand (vert foncé institutionnel) */
  --primary: #15803D;
  --primary-dark: #166534;
  --primary-light: #F0FDF4;
  --primary-ring: rgba(21,128,61,0.22);

  /* Drapeau RDC */
  --rdc-blue: #007FFF;
  --rdc-deep: #003087;
  --rdc-yellow: #F7D618;
  --rdc-red: #CE1021;
  --rdc-green: #009639;

  /* Semantique */
  --success: #10B981; --success-light: #ECFDF5; --success-text: #065F46;
  --warning: #F59E0B; --warning-light: #FFFBEB; --warning-text: #92400E;
  --danger:  #EF4444; --danger-light:  #FEF2F2; --danger-text:  #991B1B;
  --info:    #3B82F6; --info-light:    #EFF6FF; --info-text:    #1E40AF;
  --purple:  #8B5CF6; --purple-light:  #F5F3FF; --purple-text:  #5B21B6;
  --teal:    #0D9488; --teal-light:    #F0FDFA; --teal-text:    #115E59;

  /* Texte */
  --t-primary:   #0F172A;
  --t-secondary: #334155;
  --t-muted:     #64748B;
  --t-placeholder: #94A3B8;
  --border: #E2E8F0;

  --font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --r-sm: 6px; --r-md: 8px; --r-lg: 12px; --r-xl: 16px; --r-full: 9999px;
  --tr: all 0.15s ease;
  --tr-slow: all 0.3s cubic-bezier(0.4,0,0.2,1);
}

/* ── 2. BASE ─────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font);
  background: var(--body-bg);
  color: var(--t-primary);
  margin: 0;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  font-size: 14px;
}
a { color: inherit; }
h1, h2, h3, h4 { margin: 0; }
img { max-width: 100%; }

/* Scrollbar */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: #CBD5E1; border-radius: 6px; border: 2px solid var(--body-bg); }
::-webkit-scrollbar-thumb:hover { background: #94A3B8; }

/* ── 3. LAYOUT ───────────────────────────────────────────── */
.dpem-layout { display: flex; min-height: 100vh; }
.dpem-content {
  flex: 1; min-width: 0;
  margin-left: var(--sb-width);
  display: flex; flex-direction: column; min-height: 100vh;
  transition: margin-left var(--tr-slow);
  position: relative; z-index: 0; /* confine la carte Leaflet et tout contenu sous la sidebar */
}
.dpem-main { flex: 1; min-width: 0; padding: 1.75rem 2rem; }
/* La carte ne doit jamais passer au dessus du menu lateral.
   Le contexte d'empilement de .dpem-content (z-index:0) confine deja les
   couches Leaflet ; on garde l'empilement interne de Leaflet intact. */
.dpem-map, .leaflet-container { z-index: 1; }

/* ── 4. SIDEBAR ──────────────────────────────────────────── */
.dpem-sidebar {
  position: fixed; top: 0; left: 0;
  width: var(--sb-width); height: 100vh;
  background: var(--sb-bg);
  border-right: 1px solid var(--sb-border);
  display: flex; flex-direction: column;
  z-index: 100; overflow: hidden;
  transition: var(--tr-slow);
}
.dpem-sidebar::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--rdc-blue) 0 33.34%, var(--rdc-yellow) 33.34% 66.67%, var(--rdc-red) 66.67% 100%);
  z-index: 2;
}
.dpem-sidebar:hover { overflow-y: auto; }
.dpem-sidebar::-webkit-scrollbar { width: 4px; }
.dpem-sidebar::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.12); border: none; }

.dpem-sb-header {
  display: flex; align-items: center; gap: 0.75rem;
  padding: 1.35rem 1.25rem 1rem;
  border-bottom: 1px solid var(--sb-border); flex-shrink: 0;
}
.dpem-sb-logo { display: flex; align-items: center; gap: 0.7rem; text-decoration: none; min-width: 0; }
.dpem-sb-logo img { width: 40px; height: 40px; flex-shrink: 0; }
.dpem-sb-logo-id { display: flex; flex-direction: column; min-width: 0; }
.dpem-sb-logo-text { display: block; font-size: 1rem; font-weight: 800; color: #F8FAFC; line-height: 1.15; letter-spacing: -0.01em; white-space: nowrap; }
.dpem-sb-logo-sub { display: block; font-size: 0.6875rem; color: var(--sb-text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-top: 3px; }

.dpem-sb-nav { flex: 1; padding: 0.65rem 0.75rem 1rem; display: flex; flex-direction: column; gap: 0.1rem; }
.dpem-nav-section { font-size: 0.6875rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.09em; color: var(--sb-section); padding: 1rem 0.75rem 0.4rem; }
.dpem-nav-item {
  display: flex; align-items: center; gap: 0.75rem;
  padding: 0.575rem 0.75rem; border-radius: var(--r-md);
  text-decoration: none; color: var(--sb-text);
  font-size: 0.875rem; font-weight: 500; transition: var(--tr);
  position: relative; white-space: nowrap;
}
.dpem-nav-item:hover { color: var(--sb-text-hover); background: var(--sb-item-hover); }
.dpem-nav-item.active { color: var(--sb-text-active); background: var(--sb-item-active); }
.dpem-nav-item.active::before {
  content: ''; position: absolute; left: 0; top: 20%; bottom: 20%;
  width: 3px; background: var(--sb-accent); border-radius: 0 3px 3px 0;
}
.dpem-nav-icon { width: 1.15rem; text-align: center; flex-shrink: 0; font-size: 0.9375rem; }
.dpem-nav-label { flex: 1; }
.dpem-nav-badge {
  min-width: 19px; height: 19px; background: var(--danger); color: #fff;
  font-size: 0.6875rem; font-weight: 700; border-radius: var(--r-full);
  display: flex; align-items: center; justify-content: center; padding: 0 5px;
}

.dpem-sb-footer { border-top: 1px solid var(--sb-border); padding: 0.75rem; flex-shrink: 0; }
.dpem-sb-user { display: flex; align-items: center; gap: 0.625rem; padding: 0.5rem 0.625rem; border-radius: var(--r-md); cursor: pointer; transition: var(--tr); text-decoration: none; }
.dpem-sb-user:hover { background: var(--sb-item-hover); }
.dpem-avatar {
  width: 36px; height: 36px; border-radius: var(--r-full);
  background: linear-gradient(135deg, #15803D, #0D9488);
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 0.75rem; font-weight: 700; flex-shrink: 0; overflow: hidden;
}
.dpem-sb-user-name { font-size: 0.8125rem; font-weight: 600; color: var(--sb-text-active); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dpem-sb-user-role { font-size: 0.6875rem; color: var(--sb-text); }

/* ── 5. TOPBAR ───────────────────────────────────────────── */
.dpem-topbar {
  position: sticky; top: 0; height: var(--tb-height);
  background: var(--tb-bg); border-bottom: 1px solid var(--tb-border);
  display: flex; align-items: center; padding: 0 1.5rem; gap: 0.85rem;
  z-index: 40; flex-shrink: 0;
}
.dpem-topbar-toggle {
  display: none; width: 38px; height: 38px; background: transparent;
  border: 1px solid var(--border); border-radius: var(--r-md); color: var(--t-muted);
  cursor: pointer; align-items: center; justify-content: center;
}
.dpem-topbar-title { font-size: 1rem; font-weight: 700; color: var(--t-primary); }
.dpem-topbar-sub { font-size: 0.75rem; color: var(--t-muted); margin-top: 1px; }
.dpem-spacer { flex: 1; }
.dpem-topbar-search {
  display: flex; align-items: center; gap: 0.5rem; width: 320px; max-width: 36vw;
  background: var(--body-bg); border: 1px solid var(--border); border-radius: var(--r-full);
  padding: 0.45rem 0.95rem; color: var(--t-muted);
}
.dpem-topbar-search input { border: none; background: transparent; outline: none; font-family: var(--font); font-size: 0.8125rem; width: 100%; color: var(--t-primary); }
.dpem-topbar-btn {
  width: 38px; height: 38px; display: flex; align-items: center; justify-content: center;
  background: transparent; border: none; border-radius: var(--r-md); color: var(--t-muted);
  cursor: pointer; text-decoration: none; font-size: 0.95rem; position: relative; transition: var(--tr);
}
.dpem-topbar-btn:hover { background: var(--body-bg); color: var(--t-primary); }
.dpem-notif-pip { position: absolute; top: 7px; right: 7px; width: 8px; height: 8px; background: var(--danger); border: 2px solid var(--tb-bg); border-radius: var(--r-full); }
.dpem-topbar-user {
  display: flex; align-items: center; gap: 0.55rem; padding: 0.3rem 0.85rem 0.3rem 0.35rem;
  background: var(--body-bg); border: 1px solid var(--border); border-radius: var(--r-full);
  cursor: pointer; color: var(--t-primary); font-size: 0.8125rem; font-weight: 600; transition: var(--tr);
}
.dpem-topbar-user:hover { border-color: var(--primary); }
.dpem-avatar-sm { width: 30px; height: 30px; border-radius: var(--r-full); background: linear-gradient(135deg, #15803D, #0D9488); display: flex; align-items: center; justify-content: center; color: #fff; font-size: 0.6875rem; font-weight: 700; }

/* ── 6. PAGE HEADER ──────────────────────────────────────── */
.dpem-page-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem; margin-bottom: 1.5rem; flex-wrap: wrap; }
.dpem-page-title { font-size: 1.4rem; font-weight: 800; color: var(--t-primary); letter-spacing: -0.02em; }
.dpem-page-desc { font-size: 0.875rem; color: var(--t-muted); margin-top: 0.3rem; max-width: 60ch; }
.dpem-breadcrumb { display: flex; align-items: center; gap: 0.45rem; font-size: 0.75rem; color: var(--t-muted); margin-bottom: 0.6rem; }
.dpem-breadcrumb a { text-decoration: none; }
.dpem-breadcrumb a:hover { color: var(--primary); }
.dpem-page-actions { display: flex; align-items: center; gap: 0.5rem; flex-wrap: wrap; }

/* ── 7. CARDS ────────────────────────────────────────────── */
.dpem-card { background: var(--card-bg); border: 1px solid var(--card-border); border-radius: var(--card-radius); box-shadow: var(--card-shadow); }
.dpem-card-head { display: flex; align-items: center; justify-content: space-between; gap: 0.75rem; padding: 1.1rem 1.35rem; border-bottom: 1px solid var(--card-border); flex-wrap: wrap; }
.dpem-card-title { font-size: 0.95rem; font-weight: 700; color: var(--t-primary); display: flex; align-items: center; gap: 0.55rem; }
.dpem-card-title i { color: var(--primary); font-size: 0.9rem; }
.dpem-card-sub { font-size: 0.75rem; color: var(--t-muted); margin-top: 2px; font-weight: 400; }
.dpem-card-body { padding: 1.35rem; }
.dpem-card-body.tight { padding: 0; }
.dpem-card-foot { padding: 0.85rem 1.35rem; border-top: 1px solid var(--card-border); background: #FCFDFE; display: flex; align-items: center; justify-content: space-between; gap: 0.75rem; }

/* ── 8. STAT CARDS ───────────────────────────────────────── */
.dpem-stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1rem; }
.dpem-stat { background: var(--card-bg); border: 1px solid var(--card-border); border-radius: var(--card-radius); box-shadow: var(--card-shadow); padding: 1.25rem; display: flex; align-items: flex-start; gap: 1rem; transition: var(--tr); }
.dpem-stat:hover { box-shadow: var(--card-shadow-hover); transform: translateY(-2px); }
.dpem-stat-icon { width: 50px; height: 50px; border-radius: var(--r-lg); display: flex; align-items: center; justify-content: center; font-size: 1.3rem; flex-shrink: 0; }
.dpem-stat-icon.blue { background: #EFF6FF; color: #2563EB; }
.dpem-stat-icon.green { background: #ECFDF5; color: #059669; }
.dpem-stat-icon.purple { background: #F5F3FF; color: #7C3AED; }
.dpem-stat-icon.orange { background: #FFF7ED; color: #D97706; }
.dpem-stat-icon.red { background: #FEF2F2; color: #DC2626; }
.dpem-stat-icon.teal { background: #F0FDFA; color: #0D9488; }
.dpem-stat-body { min-width: 0; flex: 1; }
.dpem-stat-label { font-size: 0.8125rem; color: var(--t-muted); font-weight: 500; }
.dpem-stat-value { font-size: 1.9rem; font-weight: 800; color: var(--t-primary); line-height: 1.1; letter-spacing: -0.02em; }
.dpem-stat-trend { font-size: 0.75rem; margin-top: 0.3rem; display: inline-flex; align-items: center; gap: 0.3rem; font-weight: 600; }
.dpem-stat-trend.up { color: var(--success); }
.dpem-stat-trend.down { color: var(--danger); }
.dpem-stat-trend.flat { color: var(--t-muted); }

/* ── 8b. ACTIONS RAPIDES ─────────────────────────────────── */
.dpem-actions-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 0.85rem; }
.dpem-action { display: flex; flex-direction: column; align-items: flex-start; gap: 0.55rem; padding: 1rem; border: 1px solid var(--card-border); border-radius: var(--r-lg); background: var(--card-bg); text-decoration: none; transition: var(--tr); }
.dpem-action:hover { border-color: var(--primary); box-shadow: var(--card-shadow-hover); transform: translateY(-2px); }
.dpem-action-ico { width: 42px; height: 42px; border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 1.05rem; }
.dpem-action-label { font-size: 0.85rem; font-weight: 700; color: var(--t-primary); }
.dpem-action-sub { font-size: 0.72rem; color: var(--t-muted); line-height: 1.35; }

/* ── 9. BUTTONS ──────────────────────────────────────────── */
.dpem-btn { display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem; padding: 0.55rem 1rem; border-radius: var(--r-md); font-size: 0.875rem; font-weight: 600; font-family: var(--font); cursor: pointer; transition: var(--tr); border: 1px solid transparent; text-decoration: none; white-space: nowrap; line-height: 1.25; }
.dpem-btn-primary { background: var(--primary); color: #fff; }
.dpem-btn-primary:hover { background: var(--primary-dark); }
.dpem-btn-secondary { background: var(--card-bg); color: var(--t-primary); border-color: var(--border); }
.dpem-btn-secondary:hover { background: var(--body-bg); border-color: #CBD5E1; }
.dpem-btn-danger { background: var(--danger); color: #fff; }
.dpem-btn-danger:hover { background: #DC2626; }
.dpem-btn-success { background: var(--success); color: #fff; }
.dpem-btn-success:hover { background: #059669; }
.dpem-btn-ghost { background: transparent; color: var(--t-secondary); }
.dpem-btn-ghost:hover { background: var(--body-bg); }
.dpem-btn-sm { padding: 0.4rem 0.75rem; font-size: 0.8125rem; }
.dpem-btn-lg { padding: 0.8rem 1.5rem; font-size: 0.95rem; }
.dpem-btn-icon { padding: 0.5rem; width: 38px; height: 38px; gap: 0; }
.dpem-btn-block { width: 100%; }

/* ── 10. BADGES ──────────────────────────────────────────── */
.dpem-badge { display: inline-flex; align-items: center; gap: 0.3rem; padding: 0.2rem 0.55rem; border-radius: var(--r-full); font-size: 0.6875rem; font-weight: 700; white-space: nowrap; letter-spacing: 0.01em; }
.dpem-badge i { font-size: 0.55rem; }
.dpem-badge-blue { background: var(--info-light); color: var(--info-text); }
.dpem-badge-green { background: var(--success-light); color: var(--success-text); }
.dpem-badge-yellow { background: var(--warning-light); color: var(--warning-text); }
.dpem-badge-red { background: var(--danger-light); color: var(--danger-text); }
.dpem-badge-purple { background: var(--purple-light); color: var(--purple-text); }
.dpem-badge-teal { background: var(--teal-light); color: var(--teal-text); }
.dpem-badge-gray { background: #F1F5F9; color: #475569; }

/* Pastille point */
.dpem-dot { width: 8px; height: 8px; border-radius: var(--r-full); display: inline-block; flex-shrink: 0; }
.dpem-dot.green { background: var(--success); }
.dpem-dot.yellow { background: var(--warning); }
.dpem-dot.red { background: var(--danger); }
.dpem-dot.blue { background: var(--info); }
.dpem-dot.gray { background: #94A3B8; }

/* ── 11. FORMS ───────────────────────────────────────────── */
.dpem-label { display: block; font-size: 0.8125rem; font-weight: 600; color: var(--t-secondary); margin-bottom: 0.4rem; }
.dpem-label .req { color: var(--danger); }
.dpem-input, .dpem-select, .dpem-textarea {
  width: 100%; padding: 0.6rem 0.8rem; background: var(--card-bg);
  border: 1px solid var(--border); border-radius: var(--r-md);
  font-size: 0.875rem; font-family: var(--font); color: var(--t-primary);
  transition: var(--tr); outline: none;
}
.dpem-input:focus, .dpem-select:focus, .dpem-textarea:focus { border-color: var(--primary); box-shadow: 0 0 0 3px var(--primary-ring); }
.dpem-input::placeholder, .dpem-textarea::placeholder { color: var(--t-placeholder); }
.dpem-textarea { resize: vertical; min-height: 90px; }
.dpem-select { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%2364748B' stroke-width='2'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 0.75rem center; padding-right: 2.25rem; }
.dpem-hint { font-size: 0.75rem; color: var(--t-muted); margin-top: 0.3rem; }
.dpem-input-icon-wrap { position: relative; }
.dpem-input-icon-wrap .dpem-input { padding-left: 2.5rem; }
.dpem-input-icon { position: absolute; left: 0.85rem; top: 50%; transform: translateY(-50%); color: var(--t-muted); font-size: 0.85rem; }
.dpem-form-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 1.1rem; }
.dpem-field-full { grid-column: 1 / -1; }

/* Switch */
.dpem-switch { position: relative; display: inline-block; width: 42px; height: 24px; }
.dpem-switch input { opacity: 0; width: 0; height: 0; }
.dpem-switch span { position: absolute; inset: 0; background: #CBD5E1; border-radius: 999px; transition: var(--tr); cursor: pointer; }
.dpem-switch span::before { content: ''; position: absolute; height: 18px; width: 18px; left: 3px; top: 3px; background: #fff; border-radius: 50%; transition: var(--tr); box-shadow: 0 1px 2px rgba(0,0,0,0.2); }
.dpem-switch input:checked + span { background: var(--primary); }
.dpem-switch input:checked + span::before { transform: translateX(18px); }

/* ── 12. TABLES ──────────────────────────────────────────── */
.dpem-table-wrap { overflow-x: auto; }
.dpem-table { width: 100%; border-collapse: collapse; font-size: 0.8125rem; }
.dpem-table thead tr { border-bottom: 1px solid var(--border); }
.dpem-table th { padding: 0.7rem 1rem; text-align: left; font-size: 0.6875rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; color: var(--t-muted); white-space: nowrap; }
.dpem-table td { padding: 0.85rem 1rem; color: var(--t-secondary); border-bottom: 1px solid #EEF2F7; vertical-align: middle; }
.dpem-table tbody tr:last-child td { border-bottom: none; }
.dpem-table tbody tr { transition: var(--tr); }
.dpem-table tbody tr:hover td { background: #F8FAFC; }
.dpem-table td .strong { color: var(--t-primary); font-weight: 600; }
.dpem-cell-main { display: flex; align-items: center; gap: 0.7rem; }
.dpem-cell-ico { width: 34px; height: 34px; border-radius: var(--r-md); background: var(--primary-light); color: var(--primary); display: flex; align-items: center; justify-content: center; font-size: 0.8rem; flex-shrink: 0; }

/* ── 13. TABS ────────────────────────────────────────────── */
.dpem-tabs { display: flex; gap: 0.25rem; border-bottom: 1px solid var(--border); overflow-x: auto; }
.dpem-tab { padding: 0.7rem 1rem; font-size: 0.8125rem; font-weight: 600; color: var(--t-muted); cursor: pointer; border-bottom: 2px solid transparent; white-space: nowrap; background: none; border-top: none; border-left: none; border-right: none; font-family: var(--font); transition: var(--tr); display: inline-flex; align-items: center; gap: 0.45rem; }
.dpem-tab:hover { color: var(--t-secondary); }
.dpem-tab.active { color: var(--primary); border-bottom-color: var(--primary); }
.dpem-tab-pane { display: none; }
.dpem-tab-pane.active { display: block; animation: dpem-fade 0.2s ease; }
@keyframes dpem-fade { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: translateY(0); } }

/* Segmented control / chips */
.dpem-chips { display: flex; flex-wrap: wrap; gap: 0.4rem; }
.dpem-chip { padding: 0.4rem 0.85rem; border-radius: var(--r-full); font-size: 0.75rem; font-weight: 600; border: 1px solid var(--border); background: var(--card-bg); color: var(--t-secondary); cursor: pointer; transition: var(--tr); font-family: var(--font); }
.dpem-chip:hover { border-color: #CBD5E1; }
.dpem-chip.active { background: var(--primary); color: #fff; border-color: var(--primary); }

/* ── 14. FILTER BAR ──────────────────────────────────────── */
.dpem-filters { display: flex; flex-wrap: wrap; align-items: center; gap: 0.6rem; }
.dpem-filters .dpem-select, .dpem-filters .dpem-input { width: auto; min-width: 150px; padding: 0.45rem 0.7rem; font-size: 0.8125rem; }
.dpem-filters .dpem-input-icon-wrap .dpem-input { padding-left: 2.25rem; }

/* ── 15. PROGRESS ────────────────────────────────────────── */
.dpem-progress { height: 8px; background: #EEF2F7; border-radius: 999px; overflow: hidden; }
.dpem-progress > span { display: block; height: 100%; border-radius: 999px; background: var(--primary); }
.dpem-progress > span.green { background: var(--success); }
.dpem-progress > span.orange { background: var(--warning); }
.dpem-progress > span.red { background: var(--danger); }

/* ── 16. TIMELINE ────────────────────────────────────────── */
.dpem-timeline { position: relative; padding-left: 1.75rem; }
.dpem-timeline::before { content: ''; position: absolute; left: 7px; top: 4px; bottom: 4px; width: 2px; background: var(--border); }
.dpem-tl-item { position: relative; padding-bottom: 1.35rem; }
.dpem-tl-item:last-child { padding-bottom: 0; }
.dpem-tl-dot { position: absolute; left: -1.75rem; top: 2px; width: 16px; height: 16px; border-radius: 50%; background: var(--card-bg); border: 3px solid var(--primary); }
.dpem-tl-dot.green { border-color: var(--success); }
.dpem-tl-dot.red { border-color: var(--danger); }
.dpem-tl-dot.gray { border-color: #CBD5E1; }
.dpem-tl-time { font-size: 0.7rem; color: var(--t-muted); }
.dpem-tl-title { font-size: 0.8125rem; font-weight: 600; color: var(--t-primary); margin: 1px 0 2px; }
.dpem-tl-desc { font-size: 0.8125rem; color: var(--t-muted); }

/* ── 17. DROPDOWN ────────────────────────────────────────── */
.dpem-dropdown { position: relative; }
.dpem-dropdown-menu {
  position: absolute; top: calc(100% + 8px); right: 0; min-width: 220px;
  background: var(--card-bg); border: 1px solid var(--card-border); border-radius: var(--r-lg);
  box-shadow: 0 12px 28px rgba(15,23,42,0.14); padding: 0.4rem; z-index: 200;
  opacity: 0; transform: translateY(-6px); pointer-events: none; transition: var(--tr);
}
.dpem-dropdown.open .dpem-dropdown-menu { opacity: 1; transform: translateY(0); pointer-events: auto; }
.dpem-dropdown-item { display: flex; align-items: center; gap: 0.65rem; padding: 0.55rem 0.7rem; border-radius: var(--r-md); text-decoration: none; color: var(--t-secondary); font-size: 0.8125rem; transition: var(--tr); cursor: pointer; }
.dpem-dropdown-item:hover { background: var(--body-bg); color: var(--t-primary); }
.dpem-dropdown-item i { width: 1rem; text-align: center; color: var(--t-muted); }
.dpem-dropdown-item.danger { color: var(--danger); }
.dpem-dropdown-item.danger i { color: var(--danger); }
.dpem-dropdown-divider { height: 1px; background: var(--border); margin: 0.3rem 0; }
.dpem-dropdown-header { padding: 0.55rem 0.7rem 0.3rem; font-size: 0.7rem; font-weight: 700; color: var(--t-muted); text-transform: uppercase; letter-spacing: 0.05em; }

/* ── 18. EMPTY STATE ─────────────────────────────────────── */
.dpem-empty { text-align: center; padding: 3rem 1.5rem; }
.dpem-empty-icon { font-size: 2.5rem; color: var(--t-muted); opacity: 0.35; margin-bottom: 1rem; }
.dpem-empty-title { font-size: 1rem; font-weight: 700; color: var(--t-primary); margin-bottom: 0.4rem; }
.dpem-empty-desc { font-size: 0.875rem; color: var(--t-muted); max-width: 40ch; margin: 0 auto; }

/* ── 19. ALERT / CALLOUT ─────────────────────────────────── */
.dpem-alert { display: flex; gap: 0.75rem; padding: 0.9rem 1.1rem; border-radius: var(--r-lg); font-size: 0.8125rem; border: 1px solid; }
.dpem-alert i { font-size: 0.95rem; margin-top: 1px; }
.dpem-alert-info { background: var(--info-light); border-color: #BFDBFE; color: var(--info-text); }
.dpem-alert-warning { background: var(--warning-light); border-color: #FDE68A; color: var(--warning-text); }
.dpem-alert-danger { background: var(--danger-light); border-color: #FECACA; color: var(--danger-text); }
.dpem-alert-success { background: var(--success-light); border-color: #A7F3D0; color: var(--success-text); }

/* ── 20. TOAST ───────────────────────────────────────────── */
.dpem-toasts { position: fixed; top: calc(var(--tb-height) + 1rem); right: 1.5rem; display: flex; flex-direction: column; gap: 0.5rem; z-index: 300; max-width: 380px; }
.dpem-toast { display: flex; gap: 0.7rem; align-items: flex-start; padding: 0.85rem 1rem; background: var(--card-bg); border: 1px solid var(--card-border); border-left: 3px solid var(--primary); border-radius: var(--r-lg); box-shadow: 0 8px 20px rgba(15,23,42,0.12); animation: dpem-toast-in 0.25s ease; }
.dpem-toast.success { border-left-color: var(--success); }
.dpem-toast.warning { border-left-color: var(--warning); }
.dpem-toast.error { border-left-color: var(--danger); }
@keyframes dpem-toast-in { from { opacity: 0; transform: translateX(20px); } to { opacity: 1; transform: translateX(0); } }

/* ── 21. MODAL ───────────────────────────────────────────── */
.dpem-modal-overlay { position: fixed; inset: 0; background: rgba(15,23,42,0.45); display: none; align-items: center; justify-content: center; z-index: 400; padding: 1rem; }
.dpem-modal-overlay.open { display: flex; animation: dpem-fade 0.15s ease; }
.dpem-modal { background: var(--card-bg); border-radius: var(--r-xl); box-shadow: 0 24px 60px rgba(15,23,42,0.3); width: 100%; max-width: 520px; max-height: 90vh; overflow: auto; }
.dpem-modal-head { display: flex; align-items: center; justify-content: space-between; padding: 1.2rem 1.4rem; border-bottom: 1px solid var(--border); }
.dpem-modal-body { padding: 1.4rem; }
.dpem-modal-foot { padding: 1rem 1.4rem; border-top: 1px solid var(--border); display: flex; justify-content: flex-end; gap: 0.6rem; }

/* ── 22. MAP (cartographie) ──────────────────────────────── */
.dpem-map { width: 100%; height: 100%; min-height: 540px; border-radius: var(--card-radius); }
.dpem-map-legend { display: flex; flex-direction: column; gap: 0.6rem; }
.dpem-legend-row { display: flex; align-items: center; gap: 0.6rem; font-size: 0.8125rem; color: var(--t-secondary); }

/* ── 23. UTILITIES ───────────────────────────────────────── */
.dpem-grid-2 { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 1.25rem; }
.dpem-grid-3 { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 1.25rem; }
.dpem-split { display: grid; grid-template-columns: 2fr 1fr; gap: 1.25rem; }
.dpem-flex { display: flex; align-items: center; gap: 0.6rem; }
.dpem-flex-between { display: flex; align-items: center; justify-content: space-between; gap: 0.75rem; }
.dpem-flex-wrap { flex-wrap: wrap; }
.dpem-mt { margin-top: 1.25rem; }
.dpem-mt-sm { margin-top: 0.75rem; }
.dpem-muted { color: var(--t-muted); }
.dpem-small { font-size: 0.8125rem; }
.dpem-xs { font-size: 0.75rem; }
.dpem-strong { font-weight: 700; color: var(--t-primary); }
.dpem-divider { height: 1px; background: var(--border); margin: 1.25rem 0; }
.dpem-kv { display: flex; flex-direction: column; gap: 0.15rem; }
.dpem-kv-label { font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--t-muted); font-weight: 600; }
.dpem-kv-value { font-size: 0.875rem; color: var(--t-primary); font-weight: 500; }
.dpem-def-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1.1rem 1.5rem; }

/* ── 24. RESPONSIVE ──────────────────────────────────────── */
@media (max-width: 1024px) {
  .dpem-split { grid-template-columns: 1fr; }
}
@media (max-width: 900px) {
  .dpem-sidebar { transform: translateX(-100%); }
  .dpem-sidebar.open { transform: translateX(0); box-shadow: 0 0 40px rgba(0,0,0,0.4); }
  .dpem-content { margin-left: 0; }
  .dpem-topbar-toggle { display: flex; }
  .dpem-topbar-search { display: none; }
  .dpem-main { padding: 1.25rem; }
  .dpem-sidebar-backdrop { position: fixed; inset: 0; background: rgba(15,23,42,0.5); z-index: 90; display: none; }
  .dpem-sidebar-backdrop.open { display: block; }
}
@media (max-width: 560px) {
  .dpem-page-title { font-size: 1.2rem; }
  .dpem-topbar-title { display: none; }
}
