/* ============================================================
   PERRIN UI — Design System
   Extrait du tableau de bord "État des retards clients".
   Réutilisable sur n'importe quelle application web.

   ── POUR RÉ-HABILLER (autre marque / autre app) ──
   Ne touchez qu'au bloc :root ci-dessous : changez les 4 couleurs
   de marque (--blue, --orange, --dark, --gray) et, si besoin, le
   fond/typo. Tous les composants suivent automatiquement.
   Les polices se chargent via le @import en tête de fichier.
   ============================================================ */

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

:root{
  /* —— Marque (à personnaliser) —— */
  --blue:#37BEEC;     /* accent secondaire / info        */
  --blue-d:#1896c4;   /* variante foncée de l'accent      */
  --orange:#E5540F;   /* accent principal / alerte        */
  --dark:#1A1A17;     /* texte fort / boutons             */
  --gray:#5C5D53;     /* texte secondaire de marque       */

  /* —— Neutres d'interface —— */
  --bg:#f4f6f8;       /* fond de page        */
  --card:#ffffff;     /* fond des surfaces   */
  --line:#e6e9ed;     /* bordures / filets   */
  --ink:#1A1A17;      /* texte courant       */
  --muted:#727a82;    /* texte atténué       */

  /* —— Échelle de sévérité (graphes, badges d'ancienneté) —— */
  --b1:#37BEEC;       /* faible    */
  --b2:#f4a72f;       /* moyen     */
  --b3:#E5540F;       /* élevé     */
  --b4:#b3261e;       /* critique  */

  /* —— Effets —— */
  --radius:14px;
  --shadow:0 1px 2px rgba(16,24,40,.04),0 4px 16px rgba(16,24,40,.06);

  /* —— Typographie —— */
  --font-body:'Manrope',system-ui,sans-serif;
  --font-display:'Archivo',sans-serif;
}

/* ---------- Base ---------- */
*{box-sizing:border-box}
body{background:var(--bg);color:var(--ink);font-family:var(--font-body);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased;margin:0}
h1,h2,h3,.disp{font-family:var(--font-display)}
.num{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}   /* chiffres alignés */
.wrap{max-width:1320px;margin:0 auto;padding:26px 28px 60px}            /* conteneur de page */

/* ---------- Boutons ---------- */
.btn{font-family:var(--font-display);font-weight:700;font-size:12px;letter-spacing:.02em;border:none;cursor:pointer;
  background:var(--dark);color:#fff;padding:9px 16px;border-radius:8px;display:inline-flex;align-items:center;gap:7px;transition:.15s}
.btn:hover{background:#000;transform:translateY(-1px)}
.btn svg{width:14px;height:14px}
.btn.ghost{background:#fff;color:var(--dark);border:1.5px solid var(--line)}
.btn.ghost:hover{background:#f6f8fa;border-color:#cfd6dd}
.btn[disabled]{opacity:.55;cursor:default;transform:none}
.mini-btn{font-family:var(--font-body);font-size:11px;font-weight:700;color:var(--gray);background:#fff;border:1px solid var(--line);border-radius:8px;padding:6px 11px;cursor:pointer;white-space:nowrap}
.mini-btn:hover{border-color:var(--orange);color:var(--orange)}   /* action utilitaire de barre d'outils (Compact, Tout plier…) */

/* ---------- Surfaces (panneaux) ---------- */
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow)}
.panel h3{margin:0 0 16px;font-size:13px;font-weight:800;letter-spacing:.02em;text-transform:uppercase;color:var(--dark);display:flex;align-items:center;gap:8px}
.panel h3 .dot{width:8px;height:8px;border-radius:2px;background:var(--orange)}

/* ---------- KPI ---------- */
.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.kpi .lab{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}
.kpi .val{font-family:var(--font-display);font-weight:800;font-size:27px;letter-spacing:-.02em;margin-top:6px;color:var(--dark)}
.kpi .val small{font-size:14px;font-weight:700;color:var(--muted)}
.kpi .note{font-size:11.5px;color:var(--muted);margin-top:4px;font-weight:500}
.kpi.hero{background:linear-gradient(135deg,#fff 0%,#fff6f2 100%);border-color:#f7d6c6}      /* mise en avant (accent principal) */
.kpi.hero .val{color:var(--orange)}
.kpi.hero::after{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--orange)}
.kpi.info{background:linear-gradient(135deg,#fff 0%,#eef9fe 100%);border-color:#c8ecfa}       /* variante info (accent secondaire) */
.kpi.info .val{color:var(--blue-d)}
.kpi.info::after{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--blue)}
.kpi.alert{background:linear-gradient(135deg,#fff 0%,#fdf0ea 100%);border-color:#f3c9b6}      /* alerte / à traiter */
.kpi.alert .val{color:#c2480c}
.kpi.alert::after{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:#c2480c}

/* ---------- Badges & pastilles d'état ---------- */
.ty{display:inline-block;font-size:9px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;padding:2px 6px;border-radius:4px;background:#eef0f3;color:var(--gray);vertical-align:1px;line-height:1.15}
.ty.danger{background:#fdecea;color:#b3261e}   /* avoir / anomalie       */
.ty.accent{background:#ede7f6;color:#5e35b1}   /* affacturage / spécial  */
.ty.info{background:#e8f0fe;color:#1967d2}     /* situation / information */
.ty.warn{background:#fff3e0;color:#e65100}     /* bloquée / vigilance     */
.ty.ok{background:#e6f4ea;color:#137333}       /* caution / conforme      */
.badge-j{display:inline-block;font-weight:800;font-size:12px;padding:3px 9px;border-radius:7px;min-width:54px;text-align:center}
.badge-j.j1{background:#e2f4fc;color:#1187b8}
.badge-j.j2{background:#fdf0d9;color:#b07a12}
.badge-j.j3{background:#fde7da;color:#c2480c}
.badge-j.j4{background:#fbe0de;color:#a51f17}
.st-pill{display:inline-block;font-size:10.5px;font-weight:800;letter-spacing:.03em;text-transform:uppercase;padding:3px 9px;border-radius:6px}
.st-pill.due{background:#fde7da;color:#c2480c}
.st-pill.ok{background:#e8f8ee;color:#1f9d57}
.ech-late{display:inline-block;font-size:9px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;background:#fbe0de;color:#a51f17;padding:1px 6px;border-radius:4px;vertical-align:1px}
.cond{display:inline-block;font-size:10.5px;font-weight:700;color:var(--gray);background:#f3f5f7;border:1px solid var(--line);border-radius:5px;padding:2px 7px;white-space:nowrap;cursor:default} /* valeur abrégée, détail dans title="" */
.dsub{display:block;font-size:10px;color:var(--muted);font-weight:600;margin-top:1px}  /* sous-information d'une cellule (ex. date secondaire) */
.relances{display:flex;gap:3px;margin-top:4px}  /* pastilles de progression (pré-relance P + niveaux 1-3) */
.rl{width:15px;height:15px;border-radius:4px;background:#eef0f3;color:#9aa1a8;font-size:9px;font-weight:800;display:flex;align-items:center;justify-content:center}
.rl.on{background:var(--orange);color:#fff}

/* ---------- Chips / filtres ---------- */
.toolbar{display:flex;flex-direction:column;margin:18px 0 14px}
.filters{display:flex;align-items:center;gap:14px 18px;flex-wrap:wrap;padding-top:14px;border-top:1px solid var(--line)}
.chips{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.chip{font-size:12px;font-weight:700;border:1.5px solid var(--line);background:#fff;color:var(--gray);padding:6px 13px;border-radius:20px;cursor:pointer;transition:.12s;font-family:var(--font-body)}
.chip:hover{border-color:var(--gray)}
.chip.on{background:var(--dark);border-color:var(--dark);color:#fff}
.chip-grp-lab{font-size:10.5px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-right:2px}

/* ---------- Recherche ---------- */
.search{position:relative;width:100%;max-width:460px}
.search input{width:100%;border:2px solid var(--line);border-radius:11px;padding:12px 16px 12px 42px;font-family:var(--font-body);font-size:14px;font-weight:600;color:var(--dark);background:#fff;outline:none;box-shadow:var(--shadow);transition:.15s}
.search input::placeholder{color:#9aa1a8;font-weight:500}
.search input:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(55,190,236,.18)}
.search svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--blue-d);transition:.15s;pointer-events:none}
.search:focus-within svg{color:var(--orange)}

/* ---------- Onglets-cartes ---------- */
.tabs{display:flex;gap:12px;flex-wrap:wrap;margin:30px 0 0}
.tab{flex:1;min-width:250px;display:flex;align-items:center;gap:14px;text-align:left;background:var(--card);
  border:1.5px solid var(--line);border-radius:var(--radius);padding:15px 20px;cursor:pointer;transition:.18s;position:relative;overflow:hidden;font-family:var(--font-body)}
.tab:hover{border-color:#cfd6dd;transform:translateY(-1px);box-shadow:var(--shadow)}
.tab.on{box-shadow:var(--shadow)}
.tab::before{content:"";position:absolute;left:0;top:0;bottom:0;width:0;transition:width .18s}
.tab.on::before{width:5px}
.tab-ico{width:44px;height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex:none;background:#f0f2f5;color:var(--gray);transition:.18s}
.tab-ico svg{width:22px;height:22px}
.tab-txt{display:flex;flex-direction:column;gap:1px;min-width:0}
.tab-title{font-family:var(--font-display);font-weight:800;font-size:16px;color:var(--dark);letter-spacing:-.01em}
.tab-sub{font-size:12px;font-weight:600;color:var(--muted)}
.tab .badge{margin-left:auto;flex:none;background:#eef0f3;color:var(--gray);font-size:13px;font-weight:800;padding:4px 13px;border-radius:20px}
.tab.on{border-color:#f7d6c6}                                   /* actif = accent principal */
.tab.on::before{background:var(--orange)}
.tab.on .tab-ico{background:var(--orange);color:#fff}
.tab.on .badge{background:var(--orange);color:#fff}
.tab.alt.on{border-color:#c8ecfa}                               /* variante = accent secondaire */
.tab.alt.on::before{background:var(--blue)}
.tab.alt.on .tab-ico{background:var(--blue);color:#fff}
.tab.alt.on .badge{background:var(--blue);color:#fff}

/* ---------- Tableaux ---------- */
.tbl-wrap{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:clip} /* clip (et non hidden) pour laisser fonctionner l'en-tête sticky */
table.ds{width:100%;border-collapse:collapse;font-size:13px}
table.ds thead th{position:sticky;top:0;z-index:4;background:#fafbfc;box-shadow:inset 0 -1.5px 0 var(--line);text-align:left;padding:11px 14px;font-size:11px;font-weight:800;
  letter-spacing:.04em;text-transform:uppercase;color:var(--gray);white-space:nowrap;cursor:pointer;user-select:none}
table.ds thead th.r{text-align:right}
table.ds thead th.sorted{color:var(--dark)}
table.ds thead th .arr{opacity:.35;font-size:10px;margin-left:3px}
table.ds thead th.sorted .arr{opacity:1;color:var(--orange)}
table.ds tbody td{padding:10px 14px;border-bottom:1px solid #f0f2f5;vertical-align:top}
table.ds tbody tr:hover{background:#f9fbfd}
table.ds tbody tr:last-child td{border-bottom:none}
table.ds td.r{text-align:right}
.mt{font-family:var(--font-display);font-weight:800;font-size:13.5px;color:var(--dark)}
.mt.neg{color:#b3261e}
table.ds tfoot td{padding:13px 14px;background:#fafbfc;border-top:2px solid var(--line);font-weight:800;font-family:var(--font-display);font-size:14px;color:var(--dark)}
table.ds tfoot td.lab{text-transform:uppercase;font-size:11px;letter-spacing:.05em;color:var(--gray)}

/* mode densité : table.ds.compact (togglé par un .mini-btn) */
table.ds.compact tbody td{padding-top:7px;padding-bottom:7px}
table.ds.compact .cell-sub,table.ds.compact .dsub{display:none}    /* .cell-sub = sous-lignes optionnelles */
table.ds.compact .cell-ellipsis{max-width:320px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* lignes de regroupement (table à sections) */
tr.grp{cursor:pointer;background:#eef2f6}
tr.grp:hover{background:#e6ebf0}
tr.grp td{padding:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.grp-in{display:flex;align-items:center;gap:12px;padding:11px 14px}
.grp-tog{font-size:10px;color:var(--gray);transition:transform .15s;width:11px;flex:none}
tr.grp.col .grp-tog{transform:rotate(-90deg)}
.grp-name{font-family:var(--font-display);font-weight:800;font-size:13px;color:var(--dark)}
.grp-name em{font-style:normal;font-weight:600;color:var(--muted);font-size:11.5px;margin-left:7px}
.grp-meta{font-size:11px;color:var(--muted);font-weight:600}
.grp-tot{margin-left:auto;font-family:var(--font-display);font-weight:800;font-size:14px;color:var(--dark)}

/* ---------- Barres (jauges horizontales) ---------- */
.bar-track{height:22px;background:#f0f2f5;border-radius:6px;overflow:hidden}
.bar-fill{height:100%;border-radius:6px;transition:width .9s cubic-bezier(.16,1,.3,1);min-width:3px;background:linear-gradient(90deg,var(--blue),var(--blue-d))}

/* ---------- Indicateur "temps réel" ---------- */
.live{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;color:var(--gray)}
.live-dot{width:9px;height:9px;border-radius:50%;background:#9aa1a8;box-shadow:0 0 0 3px rgba(154,161,168,.18);flex:none}
.live.ok .live-dot{background:#1f9d57;box-shadow:0 0 0 3px rgba(31,157,87,.18);animation:pulse 2s infinite}
.live.err .live-dot{background:#c2480c;box-shadow:0 0 0 3px rgba(194,72,12,.18)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}

/* ---------- Utilitaires de grille ---------- */
.grid-kpi{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px}
.grid-2{display:grid;grid-template-columns:1.1fr 1fr;gap:14px}
@media(max-width:760px){.grid-2{grid-template-columns:1fr}}
