:root{
  --jaune:#F2B705;--jaune-d:#d9a404;--navy:#0D1B3E;--navy-2:#16264f;--vert:#2E9E5B;--rouge:#c0392b;
  --bg:#eef1f7;--card:#fff;--line:#e4e8f0;--txt:#16203a;--muted:#717a8c;
  --r:12px;--r-sm:8px;--sh:0 1px 2px rgba(13,27,62,.05),0 4px 16px rgba(13,27,62,.05);
  --sh-lg:0 24px 60px rgba(7,15,40,.35);
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,"Segoe UI",-apple-system,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--txt);font-size:14px;line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:var(--navy);text-decoration:none}
.hidden{display:none!important}

/* ---------- LOGIN ---------- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;
  background:radial-gradient(1200px 600px at 80% -10%,#1d3268 0,transparent 60%),linear-gradient(135deg,#0b1733,#16264f)}
.login{background:#fff;border-radius:18px;padding:36px 34px;width:380px;box-shadow:var(--sh-lg);animation:rise .4s ease}
@keyframes rise{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.login h1{font-size:18px;letter-spacing:1.5px;margin:18px 0 2px;color:var(--navy);text-transform:uppercase}
.login p{color:var(--muted);font-size:12px;margin:0 0 18px}
.login .btn{box-shadow:0 6px 16px rgba(242,183,5,.35)}
.brand{display:flex;align-items:center;gap:10px}.brand b{font-weight:800}.brand span{font-weight:300}

/* ---------- SHELL ---------- */
.shell{display:flex;min-height:100vh}
.side{width:240px;background:linear-gradient(180deg,#0d1b3e,#0a1530);color:#c3cce3;display:flex;flex-direction:column;flex:none;position:sticky;top:0;height:100vh}
.side .top{padding:20px 20px 16px;border-bottom:1px solid rgba(255,255,255,.07)}
.side .brand{font-size:15px;letter-spacing:1.5px;color:#fff}
.side nav{padding:14px 12px;flex:1;overflow-y:auto}
.side nav a{display:flex;align-items:center;gap:8px;padding:11px 14px;border-radius:var(--r-sm);color:#c3cce3;cursor:pointer;font-weight:600;font-size:13.5px;margin-bottom:3px;position:relative;transition:background .15s,color .15s}
.side nav a:hover{background:rgba(255,255,255,.06);color:#fff}
.side nav a.on{background:var(--jaune);color:var(--navy);font-weight:700;box-shadow:0 4px 12px rgba(242,183,5,.25)}
.side .who{padding:14px 20px;border-top:1px solid rgba(255,255,255,.07);font-size:12px;color:#aab4cc}
.side .who .role{display:inline-block;background:rgba(255,255,255,.1);color:#fff;padding:2px 9px;border-radius:20px;font-size:10px;text-transform:uppercase;letter-spacing:.4px;margin-top:5px}
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.bar{background:rgba(255,255,255,.86);backdrop-filter:saturate(160%) blur(8px);border-bottom:1px solid var(--line);padding:15px 26px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:5}
.bar h2{margin:0;font-size:18px;font-weight:700;color:var(--navy);letter-spacing:-.2px}
.content{padding:24px 26px;max-width:1120px;width:100%}

/* ---------- CARDS ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:20px 22px;margin-bottom:18px;box-shadow:var(--sh)}
.card h3{margin:0 0 14px;font-size:12px;text-transform:uppercase;letter-spacing:.7px;color:var(--navy);display:flex;align-items:center;gap:8px;padding-bottom:10px;border-bottom:1px solid var(--line)}
.card h3::before{content:"";width:4px;height:14px;background:var(--jaune);border-radius:3px;display:inline-block}

/* ---------- FORMS ---------- */
label{display:block;font-weight:600;margin:12px 0 5px;font-size:12px;color:#3a4561;letter-spacing:.1px}
.hint{font-weight:400;color:var(--muted);font-size:11px}
input,select,textarea{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:var(--r-sm);font-size:14px;font-family:inherit;background:#fbfcfe;color:var(--txt);transition:border-color .15s,box-shadow .15s,background .15s}
input:hover,select:hover{border-color:#c9d1e1}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--jaune);background:#fff;box-shadow:0 0 0 3px rgba(242,183,5,.2)}
.row{display:grid;grid-template-columns:1fr 1fr;gap:13px}.row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:13px}
@media(max-width:760px){.row,.row3{grid-template-columns:1fr}.side{width:62px}.side .brand span,.side nav a .lbl,.side .who{display:none}}

/* ---------- BUTTONS ---------- */
.btn{background:var(--jaune);color:var(--navy);font-weight:800;border:none;padding:11px 17px;border-radius:var(--r-sm);cursor:pointer;font-size:14px;letter-spacing:.2px;transition:transform .08s,filter .15s,box-shadow .15s}
.btn:hover{filter:brightness(.97);box-shadow:0 4px 12px rgba(242,183,5,.3)}
.btn:active{transform:translateY(1px)}
.btn.sec{background:var(--navy);color:#fff}.btn.sec:hover{box-shadow:0 4px 12px rgba(13,27,62,.25)}
.btn.ghost{background:#fff;border:1px solid var(--line);color:var(--navy);font-weight:700}.btn.ghost:hover{border-color:#c9d1e1;box-shadow:none;background:#f8fafc}
.btn.sm{padding:7px 12px;font-size:12.5px}
.btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}

/* ---------- TABLES ---------- */
table{border-collapse:collapse;width:100%;font-size:13px}
th{background:var(--navy);color:#fff;text-align:left;padding:9px 11px;font-size:11.5px;font-weight:600;letter-spacing:.3px}
th:first-child{border-top-left-radius:var(--r-sm)}th:last-child{border-top-right-radius:var(--r-sm)}
td{border-bottom:1px solid var(--line);padding:9px 11px}
tbody tr:nth-child(even) td{background:#fafbfd}
tr.click{cursor:pointer;transition:background .12s}
tr.click:hover td{background:#fff7e6}
td.r,th.r{text-align:right}

/* ---------- KPIs ---------- */
.kpis{display:flex;gap:13px;flex-wrap:wrap}
.kpi{flex:1;min-width:135px;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:14px 16px;box-shadow:var(--sh)}
.kpi .l{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;font-weight:600}
.kpi .v{font-size:23px;font-weight:800;color:var(--navy);margin-top:3px;letter-spacing:-.5px}.kpi .v small{font-size:12px;color:var(--muted);font-weight:600;letter-spacing:0}
.kpi.hl{background:linear-gradient(135deg,#0d1b3e,#1a2d5c);border-color:transparent}.kpi.hl .l{color:#9fb0d6}.kpi.hl .v{color:#fff}
.kpi.green{background:linear-gradient(135deg,#f0f9f3,#eafaf0);border-color:#bfe6cd}.kpi.green .v{color:var(--vert)}

/* ---------- PILLS ---------- */
.pill{display:inline-block;padding:3px 11px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.2px}
.pill.g{background:#e7f6ee;color:var(--vert)}.pill.y{background:#fdf3d4;color:#9a7400}.pill.r{background:#fbe9e7;color:var(--rouge)}.pill.b{background:#e8f0fd;color:#1c4e80}.pill.grey{background:#eceff5;color:#566076}

/* ---------- MISC ---------- */
.toolbar{display:flex;gap:10px;align-items:center;margin-bottom:14px;flex-wrap:wrap}
.toolbar select{width:auto}
.flash{padding:10px 15px;border-radius:var(--r-sm);margin-bottom:13px;font-size:13px;font-weight:500}
.flash.ok{background:#eafaf0;color:#1d7a43;border:1px solid #bfe6cd}.flash.err{background:#fbe9e7;color:#b03a2e;border:1px solid #f1c7c0}
.muted{color:var(--muted);font-size:12px}
.check{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--line);font-size:13px}
.check input{width:auto;accent-color:var(--vert)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:18px}@media(max-width:840px){.grid2{grid-template-columns:1fr}}
.tag{display:inline-block;background:#eef1f7;border-radius:6px;padding:2px 8px;font-size:11px;color:#445;margin:1px}
