/* ═══════════════════════════════════════════════════════════════
   ANStat Platform — CSS Autonome v5
   Agence Nationale de la Statistique — Côte d'Ivoire
   Orange #F39323 | Vert #49655A | Montserrat
   ═══════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,400&display=swap');

/* ── TOKENS ─────────────────────────────────────────────────── */
:root {
  --o:      #F39323;
  --o-dk:   #D97010;
  --o-lt:   #FAB54A;
  --o-pale: rgba(243,147,35,.10);
  --o-sh:   0 6px 24px rgba(243,147,35,.30);
  --g:      #49655A;
  --g-dk:   #2A3C35;
  --g-dkk:  #192520;
  --g-lt:   #0A9B6F;
  --bg:     #F0F2F1;
  --wh:     #FFFFFF;
  --s50:    #F8FAF9;
  --s100:   #EDF0EE;
  --s200:   #D4DDD8;
  --s300:   #B0BEB8;
  --s400:   #879990;
  --s500:   #5C6E67;
  --s600:   #415049;
  --s700:   #2C3A33;
  --s800:   #182420;
  --red:    #DC3545;
  --amber:  #E6A817;
  --blue:   #2D7DD2;
  --teal:   #0097A7;
  --sb:     252px;
  --hh:     62px;
  --r:      9px;
  --r-lg:   14px;
  --r-xl:   20px;
  --f:      'Montserrat', -apple-system, sans-serif;
  --sh-xs:  0 1px 4px rgba(0,0,0,.05);
  --sh-sm:  0 3px 12px rgba(0,0,0,.08);
  --sh-md:  0 8px 30px rgba(0,0,0,.10);
  --sh-lg:  0 16px 52px rgba(0,0,0,.14);
}

/* ── RESET ──────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:14px;scroll-behavior:smooth}
body{font-family:var(--f);font-size:.875rem;line-height:1.5;color:var(--s600);background:var(--bg);-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
button{cursor:pointer;font-family:var(--f)}
ul,ol{list-style:none}
input,select,textarea{font-family:var(--f)}

/* scrollbar */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--s200);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--o)}

/* ══════════════════════════════════════════════════════════════
   LAYOUT PRINCIPAL
   ══════════════════════════════════════════════════════════════ */

/* ── HEADER ─────────────────────────────────────────────────── */
.app-header{
  position:fixed;top:0;left:0;right:0;
  height:var(--hh);
  background:var(--g-dkk);
  display:flex;align-items:center;
  z-index:500;
  box-shadow:0 1px 0 rgba(255,255,255,.04),0 4px 24px rgba(0,0,0,.32);
}
/* barre orange sous le header (côté contenu) */
.app-header::after{
  content:'';position:absolute;bottom:0;left:var(--sb);right:0;height:2px;
  background:linear-gradient(90deg,var(--o),transparent 70%);
}
.app-header__logo{
  width:var(--sb);height:100%;
  display:flex;align-items:center;justify-content:center;
  padding:0 18px;
  background:rgba(0,0,0,.18);
  border-right:1px solid rgba(255,255,255,.05);
  flex-shrink:0;
  transition:opacity .2s;
}
.app-header__logo:hover{opacity:.85}
.app-header__logo-wrap{background:rgba(255,255,255,.95);border-radius:8px;padding:4px 10px;display:flex;align-items:center;justify-content:center}
.app-header__logo img{max-height:30px;max-width:140px;object-fit:contain}

.header-toggle{
  background:none;border:none;
  color:rgba(255,255,255,.40);font-size:19px;
  padding:0 16px;height:var(--hh);
  display:flex;align-items:center;
  transition:color .18s;
}
.header-toggle:hover{color:var(--o)}

.header-right{display:flex;align-items:center;gap:6px;margin-left:auto;padding-right:18px}

/* bouton Nouvelle Publication */
.btn-header-new{
  background:var(--o);color:#fff;border:none;
  border-radius:8px;font-size:11px;font-weight:700;
  letter-spacing:.4px;text-transform:uppercase;
  padding:8px 16px;
  display:flex;align-items:center;gap:7px;
  transition:all .16s;white-space:nowrap;
}
.btn-header-new:hover{background:var(--o-dk);box-shadow:var(--o-sh);transform:translateY(-1px);color:#fff}

/* icône bouton header */
.hdr-icon{
  width:36px;height:36px;border-radius:8px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.07);
  color:rgba(255,255,255,.50);font-size:15px;
  display:flex;align-items:center;justify-content:center;
  transition:all .16s;cursor:pointer;position:relative;
}
.hdr-icon:hover{background:rgba(243,147,35,.16);border-color:rgba(243,147,35,.25);color:var(--o-lt)}
.hdr-badge{
  position:absolute;top:-4px;right:-4px;
  min-width:16px;height:16px;background:var(--red);color:#fff;
  border-radius:8px;font-size:8px;font-weight:800;
  display:flex;align-items:center;justify-content:center;
  border:2px solid var(--g-dkk);padding:0 3px;
}

/* dropdown header */
.hdr-drop{position:relative}
.hdr-drop-menu{
  position:absolute;top:calc(100% + 10px);right:0;
  background:var(--wh);border:1px solid var(--s100);
  border-radius:var(--r-lg);box-shadow:var(--sh-lg);
  min-width:240px;overflow:hidden;
  opacity:0;visibility:hidden;
  transform:translateY(-8px) scale(.97);
  transition:all .16s ease;z-index:600;
}
.hdr-drop.open .hdr-drop-menu{opacity:1;visibility:visible;transform:none}
.hdr-drop-head{
  padding:11px 16px 9px;background:var(--s50);
  border-bottom:1px solid var(--s100);
  font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:.7px;color:var(--s400);
}
.hdr-drop-item{
  display:flex;align-items:flex-start;gap:10px;
  padding:11px 14px;color:var(--s700);font-size:12px;
  font-weight:500;transition:background .12s;
  border-bottom:1px solid var(--s100);
}
.hdr-drop-item:last-child{border-bottom:none}
.hdr-drop-item:hover{background:var(--o-pale);color:var(--o-dk)}
.hdr-drop-item.unread{border-left:3px solid var(--o);background:rgba(243,147,35,.03)}
.notif-body{flex:1}
.notif-msg{font-size:11px;font-weight:500;color:var(--s700);line-height:1.4}
.notif-time{font-size:9px;color:var(--s400);margin-top:2px}
.notif-dot{width:8px;height:8px;border-radius:50%;background:var(--o);flex-shrink:0;margin-top:4px}
.hdr-drop-footer{
  padding:10px;text-align:center;background:var(--s50);
  font-size:11px;font-weight:700;color:var(--o);
  border-top:1px solid var(--s100);
}
.hdr-drop-footer:hover{color:var(--o-dk)}

/* menu profil */
.profile-drop{min-width:190px;padding:6px}
.profile-drop .hdr-drop-item{border-radius:8px;border:none;margin-bottom:2px;padding:9px 12px}
.profile-drop .hdr-drop-item i{width:16px;text-align:center;color:var(--s400)}

/* ── SIDEBAR ────────────────────────────────────────────────── */
.app-sidebar{
  position:fixed;top:0;bottom:0;left:0;
  width:var(--sb);
  background:var(--g-dk);
  padding-top:var(--hh);
  z-index:400;
  overflow-y:auto;overflow-x:hidden;
  border-right:1px solid rgba(255,255,255,.03);
  transition:transform .26s cubic-bezier(.4,0,.2,1);
}
.app-sidebar::-webkit-scrollbar{width:3px}
.app-sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.07)}

/* user bloc */
.sb-user{
  display:flex;align-items:center;gap:10px;
  padding:14px 14px 12px;
  background:rgba(0,0,0,.22);
  border-bottom:1px solid rgba(255,255,255,.05);
}
.sb-user-avatar{
  width:38px;height:38px;border-radius:50%;
  object-fit:cover;border:2px solid var(--o);flex-shrink:0;
}
.sb-user-name{font-size:12px;font-weight:700;color:rgba(255,255,255,.9);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}
.sb-user-role{font-size:9px;font-weight:600;color:rgba(255,255,255,.32);text-transform:uppercase;letter-spacing:.7px;margin-top:2px}

/* navigation */
.sb-nav{padding:8px 0 80px}
.sb-section{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,.20);padding:14px 18px 6px}
.nav-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;margin:2px 8px;
  border-radius:var(--r);
  color:rgba(255,255,255,.48);font-size:12px;font-weight:500;
  transition:all .15s;border-left:2px solid transparent;
  cursor:pointer;
}
.nav-item:hover{background:rgba(255,255,255,.07);color:rgba(255,255,255,.82);border-left-color:rgba(243,147,35,.30)}
.nav-item.active{background:linear-gradient(90deg,rgba(243,147,35,.22),rgba(243,147,35,.06));color:var(--o-lt);border-left-color:var(--o);font-weight:700}
.nav-icon{font-size:14px;width:18px;text-align:center;flex-shrink:0;color:rgba(255,255,255,.26);transition:color .15s}
.nav-item:hover .nav-icon,.nav-item.active .nav-icon{color:var(--o)}
.nav-label{flex:1;line-height:1.3}
.nav-arrow{font-size:10px;color:rgba(255,255,255,.22);transition:transform .2s}
.treeview.open .nav-arrow{transform:rotate(90deg)}
.sb-sub{
  margin:0 8px 4px;padding:4px 0 4px 10px;
  background:rgba(0,0,0,.15);border-radius:0 0 var(--r) var(--r);
  display:none;
}
.treeview.open .sb-sub{display:block}
.sub-item{
  display:flex;align-items:center;gap:8px;
  padding:7px 12px;border-radius:7px;
  color:rgba(255,255,255,.38);font-size:11px;font-weight:500;
  transition:all .13s;margin-bottom:1px;
}
.sub-item:hover{background:rgba(255,255,255,.06);color:rgba(255,255,255,.75)}
.sub-item::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--o);opacity:.45;flex-shrink:0}
.sb-footer{
  position:absolute;bottom:0;left:0;right:0;
  padding:10px 14px;border-top:1px solid rgba(255,255,255,.04);
  text-align:center;font-size:9px;font-weight:600;
  color:rgba(255,255,255,.16);letter-spacing:.6px;text-transform:uppercase;
}
.sb-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.5);z-index:399;
  backdrop-filter:blur(3px);
}

/* ── CONTENU ────────────────────────────────────────────────── */
.app-content{
  margin-left:var(--sb);margin-top:var(--hh);
  padding:26px 28px;
  min-height:calc(100vh - var(--hh));
}

/* ══════════════════════════════════════════════════════════════
   COMPOSANTS
   ══════════════════════════════════════════════════════════════ */

/* ── PAGE HEADER ────────────────────────────────────────────── */
.page-hdr{
  display:flex;align-items:flex-start;justify-content:space-between;
  margin-bottom:24px;gap:16px;flex-wrap:wrap;
}
.page-hdr-left{}
.page-hdr-left h1{
  font-size:22px;font-weight:900;color:var(--s800);
  letter-spacing:-.5px;display:flex;align-items:center;gap:10px;line-height:1.2;
}
.page-hdr-left h1 i{color:var(--o);font-size:18px}
.page-hdr-left p{font-size:12px;color:var(--s400);margin-top:4px}
.page-hdr-right{display:flex;gap:8px;align-items:center;flex-wrap:wrap}

/* ── CARD ───────────────────────────────────────────────────── */
.card{
  background:var(--wh);border-radius:var(--r-lg);
  border:1px solid var(--s100);box-shadow:var(--sh-xs);
  overflow:hidden;
}
.card-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 20px 12px;
  background:var(--s50);border-bottom:1px solid var(--s100);
}
.card-header h3{
  font-size:13px;font-weight:700;color:var(--s800);
  display:flex;align-items:center;gap:9px;
}
.card-header h3::before{
  content:'';width:3px;height:14px;
  background:var(--o);border-radius:2px;flex-shrink:0;
}
.card-header h3 i{color:var(--o)}
.card-tag{
  font-size:9px;font-weight:700;text-transform:uppercase;
  letter-spacing:.6px;color:var(--s400);
  background:var(--s100);border-radius:20px;padding:3px 9px;
}
.card-body{padding:20px}
.card-footer{
  padding:12px 20px;background:var(--s50);
  border-top:1px solid var(--s100);
  display:flex;align-items:center;justify-content:flex-end;gap:8px;
}

/* ── BOUTONS ────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  font-family:var(--f);font-size:12px;font-weight:600;
  padding:9px 16px;border-radius:var(--r);border:none;cursor:pointer;
  transition:all .15s;line-height:1;white-space:nowrap;text-decoration:none;
  vertical-align:middle;
}
.btn-primary{background:var(--o);color:#fff;box-shadow:0 2px 10px rgba(243,147,35,.26)}
.btn-primary:hover{background:var(--o-dk);color:#fff;box-shadow:var(--o-sh);transform:translateY(-1px)}
.btn-success{background:var(--g-lt);color:#fff;box-shadow:0 2px 10px rgba(10,155,111,.22)}
.btn-success:hover{background:#088357;color:#fff;transform:translateY(-1px)}
.btn-secondary{background:var(--s100);color:var(--s700)}
.btn-secondary:hover{background:var(--s200);color:var(--s800)}
.btn-danger{background:rgba(220,53,69,.10);color:var(--red);border:1px solid rgba(220,53,69,.20)}
.btn-danger:hover{background:var(--red);color:#fff;border-color:var(--red)}
.btn-info{background:rgba(73,101,90,.10);color:var(--g);border:1px solid rgba(73,101,90,.18)}
.btn-info:hover{background:var(--g);color:#fff;border-color:var(--g)}
.btn-warning{background:rgba(230,168,23,.12);color:#7A5200;border:1px solid rgba(230,168,23,.20)}
.btn-warning:hover{background:var(--amber);color:#fff;border-color:var(--amber)}
.btn-outline{background:transparent;color:var(--s600);border:1.5px solid var(--s200)}
.btn-outline:hover{border-color:var(--o);color:var(--o);background:var(--o-pale)}
.btn-sm{padding:5px 10px;font-size:11px;border-radius:7px}
.btn-lg{padding:11px 22px;font-size:13px;font-weight:700}
.btn-block{width:100%;margin-bottom:8px;justify-content:flex-start}
.btn i{flex-shrink:0}

/* ── BADGES ─────────────────────────────────────────────────── */
.badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 9px;border-radius:20px;
  font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:.4px;line-height:1.4;white-space:nowrap;
}
.badge-success{background:rgba(10,155,111,.12);color:#077A51}
.badge-primary{background:rgba(73,101,90,.12);color:var(--g)}
.badge-warning{background:rgba(230,168,23,.15);color:#7A5200}
.badge-danger{background:rgba(220,53,69,.12);color:#A0202D}
.badge-info{background:rgba(45,125,210,.12);color:#1B5FA0}
.badge-dark{background:rgba(25,37,32,.10);color:var(--s500)}
.badge-secondary{background:var(--s100);color:var(--s500)}
.badge-orange{background:rgba(243,147,35,.14);color:var(--o-dk)}
.badge-teal{background:rgba(0,151,167,.12);color:#00838F}
.badge-dot::before{content:'';width:6px;height:6px;border-radius:50%;background:currentColor;display:inline-block}

/* ── FORMULAIRES ────────────────────────────────────────────── */
.form-group{margin-bottom:18px}
label,.form-label{
  display:block;font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:.4px;
  color:var(--s500);margin-bottom:6px;
}
.form-control{
  display:block;width:100%;
  padding:10px 14px;font-family:var(--f);font-size:13px;
  color:var(--s800);background:var(--wh);
  border:1.5px solid var(--s200);border-radius:var(--r);
  transition:border-color .15s,box-shadow .15s;
  line-height:1.5;appearance:none;-webkit-appearance:none;
}
.form-control:focus{outline:none;border-color:var(--o);box-shadow:0 0 0 3px rgba(243,147,35,.10)}
.form-control::placeholder{color:var(--s300)}
textarea.form-control{min-height:100px;resize:vertical}
select.form-control{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7' viewBox='0 0 12 7'%3E%3Cpath d='M1 1l5 4.5L11 1' stroke='%23879990' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;
  padding-right:36px;cursor:pointer;
}
.form-hint{font-size:11px;color:var(--s400);margin-top:4px}
.form-error{font-size:11px;color:var(--red);margin-top:4px;display:block}

/* input file stylisé */
.file-drop{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  border:2px dashed var(--s200);border-radius:var(--r-lg);
  padding:28px 20px;background:var(--s50);
  cursor:pointer;transition:all .18s;text-align:center;
}
.file-drop:hover{border-color:var(--o);background:var(--o-pale)}
.file-drop i{font-size:32px;color:var(--s300);margin-bottom:10px;display:block}
.file-drop p{font-size:12px;color:var(--s400);font-weight:500;margin-bottom:6px}
.file-drop small{font-size:10px;color:var(--s300)}
.file-drop input[type=file]{display:none}
.file-drop.has-file{border-color:var(--g-lt);background:rgba(10,155,111,.05)}
.file-drop.has-file i{color:var(--g-lt)}

/* ── TABLEAUX ───────────────────────────────────────────────── */
.table-wrap{overflow-x:auto;border-radius:var(--r-lg);border:1px solid var(--s100)}
table.table{width:100%;border-collapse:collapse;font-size:12px}
table.table thead th{
  background:var(--g-dk);color:rgba(255,255,255,.72);
  font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:.8px;padding:11px 14px;border:none;white-space:nowrap;
}
table.table thead th:first-child{border-radius:0}
table.table tbody tr{border-bottom:1px solid var(--s100);transition:background .1s}
table.table tbody tr:last-child{border-bottom:none}
table.table tbody tr:hover td{background:rgba(243,147,35,.05)}
table.table tbody td{padding:11px 14px;color:var(--s500);vertical-align:middle;border:none}
table.table tbody td strong{color:var(--s800);font-weight:700}
.td-actions{display:flex;gap:5px;align-items:center}

/* ── ALERTES FLASH ──────────────────────────────────────────── */
.flash-wrap{margin-bottom:20px}
.alert{
  display:flex;align-items:flex-start;gap:10px;
  padding:12px 16px;border-radius:var(--r);
  border:1px solid transparent;
  font-size:12px;font-weight:500;margin-bottom:8px;
}
.alert i{font-size:14px;flex-shrink:0;margin-top:1px}
.alert-success{background:rgba(10,155,111,.08);color:#077A51;border-color:rgba(10,155,111,.18)}
.alert-danger{background:rgba(220,53,69,.08);color:#A0202D;border-color:rgba(220,53,69,.18)}
.alert-warning{background:rgba(230,168,23,.09);color:#7A5200;border-color:rgba(230,168,23,.20)}
.alert-info{background:rgba(73,101,90,.08);color:var(--g);border-color:rgba(73,101,90,.18)}

/* ── DATATABLES ─────────────────────────────────────────────── */
div.dataTables_wrapper{font-family:var(--f);font-size:12px;color:var(--s600)}
div.dataTables_length,div.dataTables_filter{margin-bottom:14px}
div.dataTables_length label,div.dataTables_filter label{font-size:12px;color:var(--s400);font-weight:500;display:flex;align-items:center;gap:8px}
div.dataTables_filter input,div.dataTables_length select{
  border:1.5px solid var(--s200);border-radius:var(--r);
  font-family:var(--f);font-size:12px;padding:6px 10px;
  background:var(--wh);color:var(--s700);
  transition:border-color .15s;appearance:none;
}
div.dataTables_filter input:focus,div.dataTables_length select:focus{outline:none;border-color:var(--o);box-shadow:0 0 0 2px rgba(243,147,35,.10)}
div.dataTables_info{color:var(--s400);font-size:11px}
div.dataTables_paginate .paginate_button{
  border-radius:7px;font-family:var(--f);font-size:11px;font-weight:600;
  padding:5px 10px;border:1px solid var(--s100) !important;
  color:var(--s500) !important;margin:0 2px;cursor:pointer;
  transition:all .13s;background:transparent !important;
}
div.dataTables_paginate .paginate_button:hover{background:var(--o-pale) !important;border-color:rgba(243,147,35,.25) !important;color:var(--o-dk) !important}
div.dataTables_paginate .paginate_button.current,
div.dataTables_paginate .paginate_button.current:hover{background:var(--o) !important;border-color:var(--o) !important;color:#fff !important}
div.dataTables_paginate .paginate_button.disabled{color:var(--s300) !important;pointer-events:none}

/* ── DASHBOARD KPI ──────────────────────────────────────────── */
.kpi-strip{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:14px;margin-bottom:24px;
}
.kpi-card{
  background:var(--wh);border:1px solid var(--s100);
  border-radius:var(--r-lg);padding:16px 18px;
  display:flex;align-items:flex-start;gap:12px;
  box-shadow:var(--sh-xs);
  border-left:3px solid var(--o);
  transition:box-shadow .18s,transform .18s;
  position:relative;overflow:hidden;
}
.kpi-card:hover{box-shadow:var(--sh-sm);transform:translateY(-2px)}
.kpi-card::after{
  content:'';position:absolute;top:-20px;right:-20px;
  width:70px;height:70px;border-radius:50%;
  background:var(--kpi-color,var(--o));opacity:.05;
}
.kpi-card.kpi-total{border-left-color:var(--g-lt);--kpi-color:var(--g-lt)}
.kpi-card.kpi-traitement{border-left-color:var(--blue);--kpi-color:var(--blue)}
.kpi-card.kpi-corriger{border-left-color:var(--amber);--kpi-color:var(--amber)}
.kpi-card.kpi-valide{border-left-color:var(--g-lt);--kpi-color:var(--g-lt)}
.kpi-card.kpi-diffuse{border-left-color:var(--teal);--kpi-color:var(--teal)}
.kpi-icon{
  width:40px;height:40px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;flex-shrink:0;
  background:var(--kpi-color,var(--o));
  color:#fff;opacity:.9;
}
.kpi-body{flex:1;min-width:0}
.kpi-val{font-size:26px;font-weight:900;color:var(--s800);line-height:1;letter-spacing:-1px}
.kpi-lbl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--s400);margin-top:4px}

/* ── GRAPHIQUES BLOC ────────────────────────────────────────── */
.charts-row{display:grid;grid-template-columns:60fr 40fr;gap:20px;margin-bottom:20px}
.charts-row-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.chart-card{background:var(--wh);border:1px solid var(--s100);border-radius:var(--r-lg);box-shadow:var(--sh-xs);overflow:hidden}
.chart-card-header{padding:14px 18px 10px;border-bottom:1px solid var(--s100);display:flex;align-items:center;justify-content:space-between}
.chart-card-header h4{font-size:12px;font-weight:700;color:var(--s800);display:flex;align-items:center;gap:8px}
.chart-card-header h4 i{color:var(--o)}
.chart-card-body{padding:16px}

/* ── DETAIL PUBLICATION ─────────────────────────────────────── */
.pub-detail-grid{display:grid;grid-template-columns:2fr 1fr;gap:20px;align-items:start}
.detail-table{width:100%;border-collapse:collapse}
.detail-table tr{border-bottom:1px solid var(--s100)}
.detail-table tr:last-child{border-bottom:none}
.detail-table th{
  width:200px;padding:12px 16px 12px 0;
  font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:.4px;color:var(--s400);vertical-align:top;
  white-space:nowrap;
}
.detail-table td{padding:12px 0;font-size:13px;color:var(--s700);vertical-align:top}
.detail-table td strong{color:var(--s800)}
.correction-msg{
  background:rgba(220,53,69,.07);border:1px solid rgba(220,53,69,.16);
  border-radius:var(--r);padding:10px 14px;
  color:#A0202D;font-size:12px;font-weight:500;
  display:flex;gap:8px;align-items:flex-start;
  margin-top:8px;
}
.correction-msg i{color:var(--red);flex-shrink:0;margin-top:2px}

/* action sidebar */
.action-sidebar{display:flex;flex-direction:column;gap:0}
.action-sidebar .btn{width:100%;justify-content:flex-start;margin-bottom:6px}
.action-sidebar hr{margin:8px 0}

/* ── BIBLIOTHÈQUE ───────────────────────────────────────────── */

/* Navigation sections */
.lib-nav-wrap{
  display:flex;align-items:center;gap:12px;
  margin-bottom:18px;flex-wrap:wrap;
}
.lib-nav{
  display:flex;gap:4px;flex-wrap:wrap;flex:1;
}
.lib-nav-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 13px;border-radius:8px;
  font-size:11px;font-weight:700;letter-spacing:.2px;
  color:var(--s500);cursor:pointer;
  border:none;background:var(--s100);
  font-family:var(--f);white-space:nowrap;
  transition:all .14s;
}
.lib-nav-btn:hover{background:var(--wh);color:var(--o);box-shadow:var(--sh-xs)}
.lib-nav-btn.active{background:var(--o);color:#fff;box-shadow:0 2px 8px rgba(243,147,35,.30)}
.lib-nav-btn i{font-size:11px}

/* Recherche */
.lib-search{
  display:flex;align-items:center;gap:8px;
  background:var(--wh);border:1.5px solid var(--s200);
  border-radius:var(--r);padding:8px 12px;
  transition:border-color .15s;min-width:200px;
}
.lib-search:focus-within{border-color:var(--o);box-shadow:0 0 0 2px rgba(243,147,35,.10)}
.lib-search i{color:var(--s400);font-size:12px}
.lib-search input{border:none;outline:none;font-family:var(--f);font-size:12px;color:var(--s800);background:transparent;width:150px}
.lib-search input::placeholder{color:var(--s300)}

/* Compteur */
.lib-count-bar{
  display:flex;align-items:center;gap:8px;
  font-size:11px;color:var(--s400);margin-bottom:20px;
}
.lib-count-section{font-weight:700;color:var(--o)}

/* Bloc section */
.lib-section-block{
  background:var(--wh);border-radius:var(--r-lg);
  border:1px solid var(--s100);
  margin-bottom:20px;overflow:hidden;
  transition:box-shadow .15s;
}
.lib-section-block:hover{box-shadow:var(--sh-sm)}

/* En-tête section */
.lib-section-hdr{
  display:flex;align-items:center;gap:14px;
  padding:18px 22px;
  border-left:4px solid var(--o);
  background:linear-gradient(90deg,rgba(243,147,35,.03) 0%,transparent 60%);
}
.lib-section-icon{
  width:42px;height:42px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-size:17px;flex-shrink:0;
}
.lib-section-meta{flex:1;min-width:0}
.lib-section-title{font-size:13px;font-weight:800;color:var(--s800);margin-bottom:3px}
.lib-section-desc{font-size:11px;color:var(--s400);line-height:1.5}
.lib-section-count{
  width:32px;height:32px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:800;flex-shrink:0;
}
.lib-section-add{
  width:32px;height:32px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.04);font-size:16px;
  transition:all .15s;flex-shrink:0;text-decoration:none;
}
.lib-section-add:hover{background:rgba(243,147,35,.12);transform:scale(1.1)}

/* Section vide — liste structurelle */
.lib-section-body-empty{
  padding:0 22px 20px;
}
.lib-section-items-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:6px 16px;margin-bottom:14px;padding-top:10px;
}
.lib-struct-item{
  display:flex;align-items:flex-start;gap:8px;
  font-size:11px;color:var(--s500);line-height:1.5;
}
.lib-struct-dot{
  width:6px;height:6px;border-radius:50%;
  flex-shrink:0;margin-top:5px;
}
.lib-section-cta{
  display:flex;align-items:center;gap:8px;
  padding:10px 14px;border-radius:var(--r);
  background:var(--s50);border:1px dashed var(--s200);
  font-size:11px;color:var(--s400);
}
.lib-section-cta i{font-size:14px}
.lib-section-cta a{color:var(--o);font-weight:600;text-decoration:none}

/* Grille inner (dans une section) */
.lib-grid-inner{
  padding:0 18px 18px;
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:14px;
}

/* Cards ressources */
.lib-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}
.lib-card{
  background:var(--wh);border-radius:var(--r);
  border:1px solid var(--s100);overflow:hidden;
  transition:all .18s;display:flex;flex-direction:column;
}
.lib-card:hover{box-shadow:var(--sh-md);transform:translateY(-3px);border-color:transparent}
.lib-thumb{
  height:110px;background:var(--s50);
  position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.lib-thumb img{width:100%;height:100%;object-fit:contain;padding:10px;transition:transform .2s}
.lib-card:hover .lib-thumb img{transform:scale(1.05)}
.lib-thumb-icon{font-size:36px;color:var(--s300)}
.lib-cat-pill{
  position:absolute;bottom:6px;left:6px;
  padding:2px 7px;border-radius:10px;
  font-size:9px;font-weight:700;color:#fff;letter-spacing:.3px;
  white-space:nowrap;max-width:120px;overflow:hidden;text-overflow:ellipsis;
  text-shadow:0 1px 3px rgba(0,0,0,.2);
}
.lib-body{padding:10px 12px;flex:1;display:flex;flex-direction:column}
.lib-title{font-size:12px;font-weight:700;color:var(--s800);margin-bottom:5px;line-height:1.4}
.lib-date{font-size:10px;color:var(--s400);margin-bottom:10px;display:flex;align-items:center;gap:4px}
.lib-actions{display:flex;gap:4px;flex-wrap:wrap;margin-top:auto}

/* Section inline empty (dans section peuplée) */
.lib-section-empty-inline{
  padding:16px 22px;
  display:flex;align-items:center;gap:8px;
  font-size:11px;color:var(--s400);
  border-top:1px dashed var(--s100);
}
.lib-section-empty-inline i{color:var(--s300)}
.lib-section-empty-inline a{color:var(--o);font-weight:600;text-decoration:none;margin-left:4px}

.workload-bars{display:flex;flex-direction:column;gap:10px}
.workload-row{
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;border-radius:var(--r);
  background:var(--s50);border:1px solid var(--s100);
  transition:all .15s;cursor:pointer;
}
.workload-row:hover{border-color:rgba(243,147,35,.25);background:var(--o-pale)}
.workload-row.selected{border-color:var(--o);background:rgba(243,147,35,.06)}
.workload-name{font-size:12px;font-weight:700;color:var(--s800);width:120px;flex-shrink:0}
.workload-bar-wrap{flex:1;background:var(--s100);border-radius:20px;height:6px;overflow:hidden}
.workload-bar-fill{height:100%;border-radius:20px;background:var(--o);transition:width .5s ease}
.workload-counts{display:flex;gap:6px;flex-shrink:0}


/* ── AFFECTATION ─────────────────────────────────────────────── */
.affect-doc-info{display:flex;align-items:center;gap:16px;background:var(--wh);border:1px solid var(--s100);border-radius:var(--r-lg);padding:16px 22px;margin-bottom:22px;box-shadow:var(--sh-xs)}
.affect-doc-icon{width:44px;height:44px;border-radius:10px;background:rgba(243,147,35,.12);color:var(--o);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.affect-doc-meta{flex:1;min-width:0}
.affect-doc-titre{font-size:14px;font-weight:800;color:var(--s800);margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.affect-doc-tags{display:flex;gap:6px;flex-wrap:wrap}
.affect-doc-code{text-align:right;flex-shrink:0}
.affect-doc-code span{font-size:10px;color:var(--s400);display:block;text-transform:uppercase;letter-spacing:.4px}
.affect-doc-code strong{font-size:11px;color:var(--s600);font-family:monospace}
.affect-layout{display:grid;grid-template-columns:280px 1fr;gap:20px;align-items:start}
.affect-legend{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:16px;padding:10px 14px;background:var(--wh);border-radius:var(--r);border:1px solid var(--s100)}
.affect-legend-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--s500);font-weight:600}
.affect-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.affect-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.affect-card{background:var(--wh);border-radius:var(--r-lg);border:2px solid var(--s100);padding:18px;cursor:pointer;transition:all .18s;position:relative;overflow:hidden}
.affect-card:hover{border-color:var(--o);box-shadow:var(--sh-md);transform:translateY(-2px)}
.affect-card.selected{border-color:var(--o);box-shadow:0 0 0 3px rgba(243,147,35,.15)}
.affect-card-hdr{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.affect-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--g),var(--g-dk));color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:800;flex-shrink:0}
.affect-card-info{flex:1;min-width:0}
.affect-card-name{font-size:13px;font-weight:800;color:var(--s800);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.affect-card-role{font-size:10px;color:var(--s400);font-weight:600;text-transform:uppercase;letter-spacing:.3px}
.affect-charge-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:.2px;border:1px solid;white-space:nowrap;flex-shrink:0}
.affect-charge-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.affect-bar-section{margin-bottom:14px}
.affect-bar-label{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--s500);margin-bottom:5px}
.affect-bar-track{height:7px;background:var(--s100);border-radius:20px;overflow:hidden}
.affect-bar-fill{height:100%;border-radius:20px;transition:width .5s ease}
.affect-stats{display:flex;align-items:center;background:var(--s50);border-radius:8px;padding:10px 8px;gap:0}
.affect-stat{flex:1;text-align:center}
.affect-stat-val{font-size:18px;font-weight:900;line-height:1}
.affect-stat-lbl{font-size:9px;color:var(--s400);font-weight:600;text-transform:uppercase;letter-spacing:.3px;margin-top:3px}
.affect-stat-sep{width:1px;height:30px;background:var(--s200);flex-shrink:0}
.affect-card-check{display:none;position:absolute;top:10px;right:10px;font-size:10px;font-weight:700;color:var(--o);background:rgba(243,147,35,.1);padding:2px 8px;border-radius:20px}
.affect-card.selected .affect-card-check{display:block}
.affect-selection{min-height:120px;display:flex;align-items:center;justify-content:center}
.affect-selection-empty{text-align:center;color:var(--s300);padding:20px}
.affect-selection-empty i{font-size:28px;display:block;margin-bottom:10px}
.affect-selection-empty p{font-size:11px;line-height:1.6}
.affect-selected-card{text-align:center;width:100%;padding:8px 0}
.affect-selected-name{font-size:14px;font-weight:800;color:var(--s800);margin-bottom:6px}
.affect-selected-stats{display:flex;gap:0;justify-content:center;background:var(--s50);border-radius:8px;padding:10px;margin-top:12px}
.affect-selected-stat{flex:1;text-align:center}
.affect-selected-stat strong{font-size:16px;font-weight:900;display:block}
.affect-selected-stat span{font-size:9px;color:var(--s400);font-weight:600;text-transform:uppercase}

/* ── UTILISATEURS ───────────────────────────────────────────── */
.user-avatar-sm{
  width:32px;height:32px;border-radius:50%;
  object-fit:cover;border:2px solid var(--s100);
}

/* ── PROFIL ─────────────────────────────────────────────────── */
.profile-hero{
  background:linear-gradient(135deg,var(--g-dkk),var(--g-dk));
  border-radius:var(--r-lg);padding:32px 28px;
  display:flex;align-items:center;gap:20px;
  border:1px solid rgba(255,255,255,.04);
  margin-bottom:20px;
}
.profile-avatar{
  width:80px;height:80px;border-radius:50%;
  object-fit:cover;border:3px solid var(--o);
  box-shadow:0 4px 18px rgba(243,147,35,.25);flex-shrink:0;
}
.profile-name{font-size:18px;font-weight:800;color:#fff;letter-spacing:-.3px}
.profile-role{font-size:11px;color:rgba(255,255,255,.40);font-weight:600;text-transform:uppercase;letter-spacing:.7px;margin-top:4px}
.profile-email{font-size:12px;color:rgba(255,255,255,.55);margin-top:6px}

/* ── LOGIN PAGE ─────────────────────────────────────────────── */
/* ── LOGIN ───────────────────────────────────────────────────── */
body.login-page{background:var(--g-dkk);display:flex;min-height:100vh}
.login-left{
  width:50%;position:fixed;top:0;left:0;bottom:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:48px;overflow:hidden;
  background:var(--g-dk);
}
.login-left::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 70% 55% at 30% 38%,rgba(243,147,35,.12) 0%,transparent 60%),
    radial-gradient(ellipse 55% 50% at 72% 68%,rgba(10,155,111,.08) 0%,transparent 55%);
}
.login-left::after{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);
  background-size:44px 44px;
}
.login-brand{position:relative;z-index:1;text-align:center}

/* Logo : fond blanc pour rester lisible sur fond sombre */
.login-logo-wrap{
  background:rgba(255,255,255,.96);
  border-radius:16px;
  padding:18px 28px;
  display:inline-block;
  margin:0 auto 28px;
  box-shadow:0 8px 32px rgba(0,0,0,.25);
}
#loginLogo{
  max-width:200px;max-height:80px;
  object-fit:contain;
  display:block;
}

.login-brand-name{
  font-size:22px;font-weight:900;
  color:rgba(255,255,255,.92);
  margin-bottom:8px;letter-spacing:-.3px;
  text-shadow:0 2px 12px rgba(0,0,0,.3);
}
.login-brand-sub{
  font-size:14px;font-weight:400;
  color:rgba(255,255,255,.55);
  letter-spacing:.3px;line-height:1.85;
}
.login-brand-divider{
  width:48px;height:3px;
  background:linear-gradient(90deg,var(--o),var(--o-lt));
  border-radius:2px;margin:22px auto;
}
.login-brand-tags{
  display:flex;gap:10px;justify-content:center;
  margin-top:26px;flex-wrap:wrap;
}
.login-tag{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  border-radius:20px;
  padding:5px 14px;
  font-size:11px;font-weight:600;
  color:rgba(255,255,255,.50);
  letter-spacing:.3px;
}
.login-tag i{color:var(--o);font-size:11px}
.login-right{
  width:50%;margin-left:50%;
  display:flex;align-items:center;justify-content:center;
  padding:40px 20px;min-height:100vh;
}
.login-box{
  width:420px;max-width:100%;
  background:var(--wh);border-radius:var(--r-xl);
  box-shadow:0 24px 64px rgba(0,0,0,.22);
  overflow:hidden;position:relative;
}
.login-box::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--o),var(--o-lt));
}
.login-form-area{padding:36px 38px 30px}
.login-title{font-size:20px;font-weight:900;color:var(--s800);letter-spacing:-.3px;margin-bottom:5px;display:flex;align-items:center;gap:10px}
.login-title i{color:var(--o)}
.login-sub{font-size:12px;color:var(--s400);padding-bottom:22px;border-bottom:1px solid var(--s100);margin-bottom:22px}
.login-extras{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.remember-me{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--s500);font-weight:500;cursor:pointer}
.remember-me input{accent-color:var(--o);width:14px;height:14px}
.forgot-link{font-size:11px;font-weight:700;color:var(--o)}
.forgot-link:hover{color:var(--o-dk);text-decoration:underline}
.login-footer{text-align:center;font-size:11px;color:var(--s300);padding-top:16px;border-top:1px solid var(--s100);margin-top:14px}

/* ── UTILITIES ──────────────────────────────────────────────── */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.mb-0{margin-bottom:0}.mb-1{margin-bottom:6px}.mb-2{margin-bottom:12px}
.mb-3{margin-bottom:18px}.mb-4{margin-bottom:24px}.mb-5{margin-bottom:32px}
.mt-1{margin-top:6px}.mt-2{margin-top:12px}.mt-3{margin-top:18px}.mt-4{margin-top:24px}
.p-0{padding:0}
.text-center{text-align:center}.text-right{text-align:right}.text-left{text-align:left}
.text-muted{color:var(--s400);font-size:11px}
.text-sm{font-size:11px}.text-xs{font-size:10px}
.text-orange{color:var(--o)}.text-green{color:var(--g-lt)}.text-red{color:var(--red)}
.fw-600{font-weight:600}.fw-700{font-weight:700}.fw-800{font-weight:800}
.d-flex{display:flex}.d-grid{display:grid}
.align-center{align-items:center}.justify-between{justify-content:space-between}
.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}
.flex-1{flex:1}.w-100{width:100%}.h-100{height:100%}
hr{border:none;border-top:1px solid var(--s100);margin:16px 0}
.rounded{border-radius:var(--r)}.rounded-lg{border-radius:var(--r-lg)}
.hidden{display:none}

/* ── RESPONSIVE ─────────────────────────────────────────────── */
@media(max-width:1280px){.kpi-strip{grid-template-columns:repeat(3,1fr)}.charts-row-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:1024px){.kpi-strip{grid-template-columns:repeat(3,1fr)}.charts-row{grid-template-columns:1fr}.pub-detail-grid{grid-template-columns:1fr}}
@media(max-width:768px){
  .app-sidebar{transform:translateX(-100%)}.app-sidebar.open{transform:translateX(0)}
  .sb-overlay{display:block;opacity:0;pointer-events:none;transition:opacity .25s}.sb-overlay.open{opacity:1;pointer-events:all}
  .app-content{margin-left:0;padding:16px}
  .app-header::after{left:0}.app-header__logo{border-right:none}
  .kpi-strip{grid-template-columns:repeat(2,1fr)}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .login-left{display:none}.login-right{width:100%;margin-left:0;background:var(--g-dkk)}
  .login-box{width:100%;border-radius:12px}
  .login-brand-name{font-size:28px}
  .lib-search input{width:130px}
  .charts-row-4{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){
  .kpi-strip{grid-template-columns:1fr 1fr}
  .charts-row-4{grid-template-columns:1fr}
  .lib-toolbar{flex-direction:column;align-items:stretch}
  .lib-search{width:100%}.lib-search input{flex:1;width:100%}
}
@media print{.app-header,.app-sidebar{display:none}.app-content{margin:0;padding:0}}

/* ══════════════════════════════════════════════════════════════
   PUBLICATIONS — styles spécifiques
   ══════════════════════════════════════════════════════════════ */

/* ── Pipeline statut ────────────────────────────────────────── */
.pub-pipeline{
  display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;
  scrollbar-width:thin;
}
.pipeline-step{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  padding:12px 16px;
  background:var(--wh);border:1.5px solid var(--s100);
  border-radius:var(--r-lg);cursor:pointer;
  transition:all .18s;white-space:nowrap;flex-shrink:0;
  text-decoration:none;color:var(--s500);min-width:80px;
}
.pipeline-step:hover{
  border-color:var(--step-color);
  background:color-mix(in srgb,var(--step-color) 6%,white);
  color:var(--s800);transform:translateY(-2px);box-shadow:var(--sh-sm);
}
.pipeline-step.active{
  border-color:var(--step-color);
  background:color-mix(in srgb,var(--step-color) 10%,white);
  color:var(--s800);box-shadow:0 0 0 3px color-mix(in srgb,var(--step-color) 18%,transparent);
}
.pipeline-step i{font-size:18px;color:var(--step-color)}
.pipeline-lbl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.pipeline-count{font-size:16px;font-weight:900;color:var(--step-color);line-height:1}

/* ── Barre outils ────────────────────────────────────────────── */
.pub-toolbar{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:14px 20px;border-bottom:1px solid var(--s100);flex-wrap:wrap;
}
.pub-search{
  display:flex;align-items:center;gap:8px;
  background:var(--s50);border:1.5px solid var(--s100);
  border-radius:var(--r);padding:8px 14px;flex:1;max-width:360px;
  transition:border-color .15s;
}
.pub-search:focus-within{border-color:var(--o);background:var(--wh);box-shadow:0 0 0 2px rgba(243,147,35,.10)}
.pub-search i{color:var(--s400);font-size:13px;flex-shrink:0}
.pub-search input{border:none;outline:none;background:transparent;font-family:var(--f);font-size:12px;color:var(--s800);width:100%}
.pub-search input::placeholder{color:var(--s300)}

/* ── Table publications ──────────────────────────────────────── */
.pub-table .pub-num{color:var(--s400)!important;font-size:11px!important;font-weight:600}
.pub-titre{font-size:12px;font-weight:700;color:var(--s800);line-height:1.3;margin-bottom:2px}
.pub-code{font-size:9px;color:var(--s400);font-weight:500;font-family:monospace;letter-spacing:.3px}
.pub-badge{font-size:9px!important}
.pub-row{cursor:default}
.pub-row:hover .pub-titre{color:var(--o)}

/* ── Vue cartes ──────────────────────────────────────────────── */
.pub-cards-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:16px;
}
.pub-card{
  background:var(--wh);border:1px solid var(--s100);
  border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--sh-xs);transition:all .2s;
  display:flex;flex-direction:column;
}
.pub-card:hover{box-shadow:var(--sh-md);transform:translateY(-2px);border-color:transparent}
.pub-card-header{
  display:flex;align-items:center;gap:6px;flex-wrap:wrap;
  padding:10px 14px;background:var(--s50);
  border-bottom:1px solid var(--s100);
}
.pub-card-body{padding:14px;flex:1}
.pub-card-title{font-size:13px;font-weight:700;color:var(--s800);margin-bottom:8px;line-height:1.4}
.pub-card-meta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:8px}
.pub-card-meta span{font-size:10px;color:var(--s400);font-weight:500;display:flex;align-items:center;gap:4px}
.pub-card-meta i{color:var(--s300)}
.pub-card-assignee{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--s600);font-weight:500;margin-top:6px}
.pub-card-comment{
  margin-top:8px;padding:8px 10px;
  background:rgba(230,168,23,.08);border-left:3px solid var(--amber);
  border-radius:0 var(--r) var(--r) 0;
  font-size:10px;color:#7A5200;line-height:1.5;
  display:flex;gap:6px;
}
.pub-card-comment i{flex-shrink:0;margin-top:1px;color:var(--amber)}
.pub-card-footer{
  display:flex;align-items:center;gap:6px;flex-wrap:wrap;
  padding:10px 14px;background:var(--s50);
  border-top:1px solid var(--s100);
}

/* ── Footer table ────────────────────────────────────────────── */
.pub-footer{
  padding:10px 20px;border-top:1px solid var(--s100);
  display:flex;align-items:center;gap:12px;
  font-size:11px;color:var(--s400);font-weight:500;
  background:var(--s50);
}

/* ══ RAPPORTS ═══════════════════════════════════════════════════ */
/* Barre filtres */
.rpt-filter-bar{
  display:flex;align-items:center;flex-wrap:wrap;gap:16px;
  background:var(--wh);border:1px solid var(--s100);border-radius:var(--r-lg);
  padding:14px 20px;margin-bottom:20px;box-shadow:var(--sh-xs);
}
.rpt-filter-form{display:flex;align-items:center;gap:16px;flex-wrap:wrap;flex:1}
.rpt-filter-group{display:flex;flex-direction:column;gap:4px}
.rpt-filter-group label{font-size:10px;font-weight:700;color:var(--s400);text-transform:uppercase;letter-spacing:.4px}
.rpt-filter-group .form-control{min-width:140px;height:34px;font-size:12px;padding:0 10px}
.rpt-periode-tabs{display:flex;gap:4px}
.rpt-periode-btn{
  display:flex;align-items:center;gap:6px;
  padding:6px 14px;border-radius:var(--r);border:1.5px solid var(--s200);
  background:var(--s50);color:var(--s500);font-size:11px;font-weight:700;
  cursor:pointer;transition:all .15s;
}
.rpt-periode-btn:hover{border-color:var(--o);color:var(--o);background:var(--o-pale)}
.rpt-periode-btn.active{background:var(--o);color:#fff;border-color:var(--o)}
.rpt-filter-selects{display:flex;gap:12px;align-items:flex-end}
.rpt-generated{font-size:10px;color:var(--s400);margin-left:auto;display:flex;align-items:center;gap:6px}

/* KPI strip */
.rpt-kpi-strip{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px;
  margin-bottom:24px;
}
.rpt-kpi{
  background:var(--wh);border:2px solid var(--s100);border-radius:var(--r-lg);
  padding:16px 12px;text-align:center;box-shadow:var(--sh-xs);
  transition:border-color .2s;
}
.rpt-kpi:hover{box-shadow:var(--sh-md)}
.rpt-kpi-val{font-size:28px;font-weight:900;color:var(--s700);line-height:1;margin-bottom:4px}
.rpt-kpi-lbl{font-size:10px;font-weight:700;color:var(--s400);text-transform:uppercase;letter-spacing:.4px}

/* Sections */
.rpt-section{
  background:var(--wh);border:1px solid var(--s100);border-radius:var(--r-lg);
  padding:24px;margin-bottom:20px;box-shadow:var(--sh-xs);
}
.rpt-section-hdr{display:flex;align-items:center;gap:14px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--s100)}
.rpt-section-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.rpt-section-title{font-size:15px;font-weight:800;color:var(--s800)}
.rpt-section-sub{font-size:11px;color:var(--s400);margin-top:2px}

/* Table directions */
.rpt-table-wrap{overflow-x:auto}
.rpt-table{width:100%;border-collapse:collapse;font-size:12px}
.rpt-table thead th{
  background:var(--s50);color:var(--s500);font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:.4px;
  padding:10px 12px;text-align:left;border-bottom:2px solid var(--s100);
  white-space:nowrap;
}
.rpt-table tbody tr{border-bottom:1px solid var(--s50);transition:background .12s}
.rpt-table tbody tr:hover{background:var(--s50)}
.rpt-table td{padding:10px 12px;vertical-align:middle}
.rpt-rank{font-size:11px;font-weight:800;color:var(--s300);width:28px;text-align:center}
.rpt-dir-name{font-size:12px;font-weight:800;color:var(--s800)}
.rpt-dir-libele{font-size:10px;color:var(--s400);margin-top:1px}
.rpt-num{text-align:center;font-size:13px;font-weight:700}

/* Barre taux conformité */
.rpt-taux-wrap{display:flex;align-items:center;gap:8px}
.rpt-taux-bar{flex:1;height:6px;background:var(--s100);border-radius:20px;overflow:hidden;min-width:60px}
.rpt-taux-fill{height:100%;border-radius:20px;transition:width .5s ease}
.rpt-taux-val{font-size:11px;font-weight:800;white-space:nowrap;min-width:34px;text-align:right}
.fill-green{background:var(--g-lt)}
.fill-orange{background:var(--o)}
.fill-red{background:var(--red)}
.text-green{color:var(--g-lt)}
.text-orange{color:var(--o)}
.text-red{color:var(--red)}
.text-amber{color:var(--amber)}

/* Barre volume relatif */
.rpt-vol-bar{height:8px;background:var(--s100);border-radius:20px;overflow:hidden}
.rpt-vol-fill{height:100%;background:linear-gradient(90deg,var(--o),var(--o-dk));border-radius:20px;transition:width .5s ease}

/* Vide */
.rpt-empty{text-align:center;padding:30px;color:var(--s300);font-style:italic}
.rpt-empty-block{text-align:center;padding:50px 20px;color:var(--s300)}
.rpt-empty-block i{font-size:36px;display:block;margin-bottom:12px;color:var(--s200)}
.rpt-empty-block p{font-size:12px}

/* Grille infographes */
.rpt-infographes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;margin-bottom:16px}
.rpt-inf-card{
  border:2px solid var(--s100);border-radius:var(--r-lg);
  padding:18px;transition:box-shadow .15s;
}
.rpt-inf-card:hover{box-shadow:var(--sh-md)}
.rpt-inf-top{border-color:var(--o);box-shadow:0 0 0 3px rgba(243,147,35,.1)}
.rpt-inf-hdr{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.rpt-inf-rank{
  width:26px;height:26px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:900;flex-shrink:0;
  background:var(--s100);color:var(--s500);
}
.rank-gold{background:#FFF3CD;color:#B8860B;border:1.5px solid #F0C040}
.rank-silver{background:#F4F4F4;color:#808080;border:1.5px solid #C0C0C0}
.rank-bronze{background:#FDF0E8;color:#CD7F32;border:1.5px solid #CD7F32}
.rpt-inf-avatar{
  width:36px;height:36px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--g),var(--g-dk));
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:800;
}
.rpt-inf-meta{flex:1;min-width:0}
.rpt-inf-nom{font-size:13px;font-weight:800;color:var(--s800)}
.rpt-inf-email{font-size:10px;color:var(--s400);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rpt-score-badge{
  font-size:18px;font-weight:900;padding:4px 10px;border-radius:8px;
  flex-shrink:0;line-height:1;
}
.rpt-score-badge span{font-size:9px;font-weight:600;vertical-align:super}
.score-green{background:#E8F8F1;color:#0A9B6F}
.score-orange{background:#FFF4E8;color:var(--o)}
.score-red{background:#FEE8E8;color:var(--red)}
.rpt-inf-bar-section{margin-bottom:12px}
.rpt-inf-bar-label{display:flex;justify-content:space-between;font-size:11px;color:var(--s500);margin-bottom:4px}
.rpt-inf-track{height:6px;background:var(--s100);border-radius:20px;overflow:hidden}
.rpt-inf-fill{height:100%;border-radius:20px;transition:width .5s ease}
.rpt-inf-stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:4px;
  background:var(--s50);border-radius:8px;padding:10px 8px;
}
.rpt-inf-stat{text-align:center;padding:4px}
.rpt-inf-stat-val{font-size:17px;font-weight:900;line-height:1}
.rpt-inf-stat-lbl{font-size:9px;color:var(--s400);font-weight:600;text-transform:uppercase;letter-spacing:.3px;margin-top:2px}
.rpt-inf-no-activity{text-align:center;padding:20px;color:var(--s300);font-size:11px;font-style:italic}

/* Note méthodologique */
.rpt-note{
  font-size:11px;color:var(--s400);
  background:var(--s50);border-radius:var(--r);
  padding:10px 14px;display:flex;gap:8px;align-items:flex-start;
}
.rpt-note i{margin-top:1px;color:var(--o);flex-shrink:0}

/* Types */
.rpt-types-grid{display:flex;flex-direction:column;gap:10px}
.rpt-type-row{display:flex;align-items:center;gap:10px}
.rpt-type-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.rpt-type-label{font-size:12px;font-weight:600;color:var(--s700);min-width:200px}
.rpt-type-bar-wrap{flex:1;height:10px;background:var(--s100);border-radius:20px;overflow:hidden}
.rpt-type-bar{height:100%;border-radius:20px;transition:width .5s ease;opacity:.85}
.rpt-type-count{font-size:13px;font-weight:800;color:var(--s700);min-width:30px;text-align:right}
.rpt-type-pct{font-size:11px;color:var(--s400);min-width:40px;text-align:right}

/* Print */
@media print {
  .sidebar,.app-header,.rpt-filter-bar,.page-hdr-right{display:none!important}
  .main-content{margin:0!important;padding:0!important}
  .rpt-section{box-shadow:none;border:1px solid #ddd}
  .rpt-kpi-strip{grid-template-columns:repeat(4,1fr)}
}

/* ── KPI enrichis (délai, sans-cor) */
.rpt-kpi-unit{font-size:14px;font-weight:700;vertical-align:baseline;margin-left:1px}
.rpt-kpi-note{font-size:9px;color:var(--s300);margin-top:2px;font-style:italic}

/* ── Infographe — ligne barres + badge délai */
.rpt-inf-bars-row{display:flex;gap:12px;align-items:flex-end;margin-bottom:12px}
.rpt-inf-delai-badge{
  flex-shrink:0;text-align:center;
  background:var(--s50);border-radius:8px;
  padding:6px 10px;min-width:52px;
}
.rpt-inf-delai-val{font-size:17px;font-weight:900;line-height:1}
.rpt-inf-delai-lbl{font-size:9px;color:var(--s400);font-weight:600;text-transform:uppercase;letter-spacing:.3px;margin-top:2px}
.delai-green{color:#0A9B6F}
.delai-orange{color:var(--o)}
.delai-red{color:var(--red)}
