/* ===== PEPG-CI — Back-office ===== */
:root{
  --vert:#0a6b3b; --vert-d:#075330; --or:#c8991f; --or-l:#e0a81f;
  --bleu:#173b6b; --ink:#16211c; --muted:#66756c; --line:#e5ebe7;
  --bg:#eef2ef; --card:#fff; --shadow:0 6px 22px rgba(12,45,28,.08);
  --sans:'Plus Jakarta Sans',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--sans),system-ui,sans-serif;color:var(--ink);background:var(--bg);font-size:15px;line-height:1.5}
a{color:inherit;text-decoration:none}
input,button,select{font-family:inherit;font-size:1rem}

/* ---- Buttons ---- */
.a-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;padding:.6em 1.1em;border-radius:10px;font-weight:700;font-size:.92rem;cursor:pointer;border:1.5px solid var(--line);background:#fff;color:var(--ink);transition:.15s}
.a-btn:hover{border-color:#cdd9d1;background:#f7faf8}
.a-btn-primary{background:var(--vert);color:#fff;border-color:var(--vert)}
.a-btn-primary:hover{background:var(--vert-d);border-color:var(--vert-d)}
.a-btn-ghost{background:transparent}
.a-btn-block{width:100%}
#logoutBtn{background:#fbeceb;border-color:#f3cfcb;color:#b23b30}
#logoutBtn:hover{background:#f7ddda}

/* ---- Login ---- */
.login-body{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;
  background:linear-gradient(160deg,#0d2a1c,#0a6b3b)}
.login-card{background:#fff;width:100%;max-width:400px;border-radius:20px;padding:38px 34px;box-shadow:0 30px 70px rgba(0,0,0,.3);text-align:center}
.login-logo{height:70px;margin:0 auto 16px}
.login-card h1{font-size:1.5rem;margin-bottom:2px}
.login-sub{color:var(--muted);font-size:.92rem;margin-bottom:24px}
.login-card form{text-align:left}
.login-card label{display:block;font-weight:600;font-size:.85rem;margin:12px 0 6px}
.login-card input{width:100%;padding:.75em .9em;border:1.5px solid var(--line);border-radius:10px;background:#fbfdfb}
.login-card input:focus{outline:none;border-color:var(--vert);box-shadow:0 0 0 3px rgba(10,107,59,.12)}
.login-card button{margin-top:20px}
.login-err{color:#c0392b;font-weight:600;font-size:.9rem;text-align:center;margin-top:12px;min-height:1.1em}
.login-back{display:block;margin-top:18px;color:var(--muted);font-size:.88rem}
.login-back:hover{color:var(--vert)}

/* ---- App layout ---- */
.app{display:grid;grid-template-columns:250px 1fr;min-height:100vh}
.sidebar{background:#0b1f15;color:#cfe0d5;display:flex;flex-direction:column;padding:22px 18px;position:sticky;top:0;height:100vh}
.side-brand{display:flex;align-items:center;gap:10px;padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:18px}
.side-brand img{height:40px;background:#fff;border-radius:8px;padding:5px}
.side-brand span{font-weight:700;color:#fff}
.side-nav{flex:1}
.side-nav a{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:10px;color:#cfe0d5;font-weight:600;font-size:.95rem}
.side-nav a.active,.side-nav a:hover{background:rgba(255,255,255,.09);color:#fff}
.side-foot{display:flex;flex-direction:column;gap:10px}
.side-foot .a-btn{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.14);color:#eaf4ee}
.side-foot .a-btn:hover{background:rgba(255,255,255,.12)}

.main{padding:26px 30px;min-width:0}
.topbar{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}
.topbar h1{font-size:1.6rem}
.topbar .sub{color:var(--muted);font-size:.94rem}
.topbar-right{display:flex;align-items:center;gap:14px}
.who{color:var(--muted);font-size:.9rem}
.who b{color:var(--vert)}

/* ---- Stats ---- */
.stats{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin-bottom:24px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:2px}
.stat-n{font-size:1.9rem;font-weight:800;line-height:1;color:var(--ink)}
.stat-l{font-size:.82rem;color:var(--muted);font-weight:600}
.stat.s-nouveau{border-left:4px solid var(--or)}
.stat.s-cours{border-left:4px solid var(--bleu)}
.stat.s-valide{border-left:4px solid var(--vert)}
.stat.s-refuse{border-left:4px solid #c0392b}
.stat.s-week{border-left:4px solid #7a5cf0}

/* ---- Toolbar ---- */
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:16px;flex-wrap:wrap}
.filters{display:flex;gap:8px;flex-wrap:wrap}
.chip{padding:.5em 1em;border-radius:999px;border:1.5px solid var(--line);background:#fff;color:var(--muted);font-weight:600;font-size:.88rem;cursor:pointer;transition:.15s}
.chip:hover{border-color:#cdd9d1}
.chip.active{background:var(--vert);border-color:var(--vert);color:#fff}
#search{padding:.6em 1em;border:1.5px solid var(--line);border-radius:10px;min-width:260px;background:#fff}
#search:focus{outline:none;border-color:var(--vert);box-shadow:0 0 0 3px rgba(10,107,59,.1)}

/* ---- Table ---- */
.table-wrap{background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);overflow-x:auto}
.tbl{width:100%;border-collapse:collapse;min-width:760px}
.tbl th{text-align:left;font-size:.76rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:14px 18px;border-bottom:1px solid var(--line);background:#f7faf8}
.tbl td{padding:14px 18px;border-bottom:1px solid #f0f4f1;vertical-align:middle}
.tbl tr:last-child td{border-bottom:0}
.tbl tr:hover td{background:#fafcfa}
.cand{font-weight:700}
.cand small{display:block;font-weight:500;color:var(--muted);font-size:.82rem}
.contact a{color:var(--vert)}
.contact small{display:block;color:var(--muted)}
.date{color:var(--muted);font-size:.88rem;white-space:nowrap}
.badge{display:inline-block;padding:.3em .7em;border-radius:999px;font-size:.78rem;font-weight:700}
.b-nouveau{background:#fdf3d7;color:#8a6a00}
.b-en_cours{background:#e0ebfa;color:#1f4d8a}
.b-valide{background:#d9f2e4;color:#0a6b3b}
.b-refuse{background:#fbe0dd;color:#b23b30}
.row-act{display:flex;gap:6px;justify-content:flex-end}
.icon-btn{border:1.5px solid var(--line);background:#fff;border-radius:8px;width:34px;height:34px;cursor:pointer;font-size:1rem;display:inline-flex;align-items:center;justify-content:center}
.icon-btn:hover{border-color:#cdd9d1;background:#f7faf8}
.icon-btn.del:hover{border-color:#f3cfcb;background:#fbeceb}
.empty{padding:40px;text-align:center;color:var(--muted)}

/* ---- Modal ---- */
.modal{position:fixed;inset:0;background:rgba(10,25,17,.55);display:flex;align-items:center;justify-content:center;padding:20px;z-index:100}
.modal-box{background:#fff;border-radius:18px;padding:30px;width:100%;max-width:520px;position:relative;box-shadow:0 30px 70px rgba(0,0,0,.3);max-height:90vh;overflow:auto}
.modal-x{position:absolute;top:14px;right:16px;border:0;background:none;font-size:1.8rem;line-height:1;cursor:pointer;color:var(--muted)}
.modal-box h2{font-size:1.35rem;margin-bottom:18px;padding-right:30px}
.m-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:16px}
.m-grid .it{display:flex;flex-direction:column}
.m-grid .k{font-size:.76rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:700}
.m-grid .v{font-size:1rem}
.m-msg{background:#f7faf8;border:1px solid var(--line);border-radius:12px;padding:14px;color:#374a40;white-space:pre-wrap;margin-bottom:18px;font-family:'Manrope',sans-serif}
.m-actions{display:flex;gap:8px;flex-wrap:wrap}
.m-actions label{font-size:.8rem;color:var(--muted);width:100%;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.modal-box form label{display:block;font-weight:600;font-size:.85rem;margin:12px 0 6px}
.modal-box form input{width:100%;padding:.7em .9em;border:1.5px solid var(--line);border-radius:10px;background:#fbfdfb}
.modal-box form input:focus{outline:none;border-color:var(--vert);box-shadow:0 0 0 3px rgba(10,107,59,.12)}
.modal-box form button{margin-top:18px}

/* ---- Responsive ---- */
@media (max-width:860px){
  .app{grid-template-columns:1fr}
  .sidebar{position:static;height:auto;flex-direction:row;flex-wrap:wrap;align-items:center;gap:12px}
  .side-brand{border:0;margin:0;padding:0;flex:1}
  .side-nav{display:none}
  .side-foot{flex-direction:row}
  .stats{grid-template-columns:repeat(3,1fr)}
  .m-grid{grid-template-columns:1fr}
}
@media (max-width:520px){
  .stats{grid-template-columns:repeat(2,1fr)}
  .main{padding:18px}
}
