:root{
    --purple:#6b2c91; --purple-d:#4a1d66; --magenta:#b0356f; --pink:#e0559b;
    --blue:#2f6fb0; --green:#2a9d6f; --orange:#d1782f;
    --ink:#2a2340; --muted:#7a7391; --line:#e7e2f0; --bg:#f6f4fb; --card:#fff;
    --grad:linear-gradient(120deg,#4a1d66 0%,#6b2c91 45%,#b0356f 100%);
    --radius:14px; --shadow:0 2px 10px rgba(74,29,102,.08);
}
*{box-sizing:border-box}
html,body{margin:0}
body{font:15px/1.5 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg)}
a{color:var(--magenta);text-decoration:none}
a:hover{text-decoration:underline}

/* Topbar */
.topbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;
    padding:.7rem 1.4rem;background:var(--grad);color:#fff;box-shadow:var(--shadow)}
.brand{color:#fff;display:flex;align-items:center;gap:.5rem;font-size:1.05rem}
.brand:hover{text-decoration:none}
.brand-mark{color:var(--pink)}
.brand-sub{opacity:.8;font-weight:400;font-size:.85rem}
.mainnav{display:flex;align-items:center;gap:.3rem;flex-wrap:wrap}
.mainnav a{color:#fff;opacity:.82;padding:.4rem .8rem;border-radius:8px;font-weight:500}
.mainnav a:hover{opacity:1;background:rgba(255,255,255,.12);text-decoration:none}
.mainnav a.on{opacity:1;background:rgba(255,255,255,.2)}
.mainnav .btn-new{background:#fff;color:var(--purple);opacity:1;font-weight:700;margin-left:.4rem}
.mainnav .btn-new:hover{background:#fdeef6}
.usermenu{color:#fff;opacity:.9;font-size:.85rem;margin-left:.6rem;display:inline-flex;align-items:center;gap:.35rem}
.usermenu a{color:#fff;background:rgba(255,255,255,.15);border-radius:6px;padding:.1rem .5rem;font-weight:700}
.usermenu a:hover{background:rgba(255,255,255,.3);text-decoration:none}

/* Login */
.loginbody{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--grad);margin:0}
.loginwrap{width:100%;max-width:380px;padding:1.5rem}
.logincard{background:#fff;border-radius:18px;box-shadow:0 12px 40px rgba(0,0,0,.25);padding:2rem}
.loginbrand{font-size:1.5rem;font-weight:800;color:var(--purple-d);text-align:center}
.loginbrand .brand-mark{color:var(--pink)}
.loginsub{text-align:center;color:var(--muted);margin:.2rem 0 1.4rem}
.logincard .field{margin-bottom:.9rem}

/* Filter bar */
.filterbar{display:flex;gap:.8rem;align-items:flex-end;flex-wrap:wrap;
    padding:.9rem 1.4rem;background:var(--card);border-bottom:1px solid var(--line)}
.filterbar label{display:flex;flex-direction:column;gap:.2rem;font-size:.72rem;
    text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:600}
.filterbar .grow{flex:1;min-width:200px}
.filterbar select,.filterbar input,.filterbar button{font-size:.92rem;padding:.45rem .6rem;
    border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);text-transform:none;font-weight:400}
.filterbar button{background:var(--purple);color:#fff;border:0;font-weight:600;cursor:pointer;padding:.5rem 1rem}
.filterbar button:hover{background:var(--purple-d)}
.filterbar .reset{align-self:center;font-size:.85rem;color:var(--muted)}

.wrap{max-width:1240px;margin:1.4rem auto;padding:0 1.4rem}
.foot{text-align:center;color:var(--muted);font-size:.8rem;padding:2rem 1rem}

h1.page{font-size:1.5rem;margin:.2rem 0 1.2rem}
.section-title{font-size:1.05rem;margin:1.8rem 0 .8rem;color:var(--purple-d);
    display:flex;align-items:center;gap:.5rem}

/* KPI cards */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}
.kpi{background:var(--card);border-radius:var(--radius);padding:1.1rem 1.2rem;box-shadow:var(--shadow);
    border-top:3px solid var(--purple)}
.kpi .v{font-size:1.9rem;font-weight:800;color:var(--purple-d);line-height:1}
.kpi .l{font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.03em;margin-top:.35rem}
.kpi.magenta{border-color:var(--magenta)} .kpi.magenta .v{color:var(--magenta)}
.kpi.blue{border-color:var(--blue)} .kpi.blue .v{color:var(--blue)}
.kpi.green{border-color:var(--green)} .kpi.green .v{color:var(--green)}
.kpi.orange{border-color:var(--orange)} .kpi.orange .v{color:var(--orange)}

/* Chart grid */
.charts{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;margin-top:1rem}
.charts .full{grid-column:1/-1}
.panel{background:var(--card);border-radius:var(--radius);padding:1.1rem 1.2rem;box-shadow:var(--shadow)}
.panel h3{margin:.1rem 0 .9rem;font-size:.95rem;color:var(--purple-d)}
.panel canvas{max-height:300px}
@media(max-width:820px){.charts{grid-template-columns:1fr}}

/* Mini bar lists */
.barlist{list-style:none;margin:0;padding:0}
.barlist li{display:grid;grid-template-columns:1fr auto;gap:.4rem;align-items:center;padding:.28rem 0;font-size:.9rem}
.barlist .bar{grid-column:1/-1;height:6px;border-radius:4px;background:var(--line);overflow:hidden}
.barlist .bar>span{display:block;height:100%;background:var(--grad)}
.barlist .lbl{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.barlist .num{font-variant-numeric:tabular-nums;color:var(--muted);font-weight:600}

/* Tables */
table.grid{width:100%;border-collapse:collapse;background:var(--card);font-size:.88rem}
table.grid th,table.grid td{padding:.5rem .6rem;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}
table.grid thead th{background:#faf8fd;color:var(--purple-d);font-weight:700;white-space:nowrap}
table.grid tbody tr:hover{background:#faf8fd}
.tag{display:inline-block;padding:.1rem .5rem;border-radius:20px;font-size:.75rem;font-weight:600;color:#fff;white-space:nowrap}
.pill{background:#efeaf7;color:var(--purple-d);border-radius:20px;padding:.1rem .55rem;font-size:.78rem;white-space:nowrap}
.miss{color:#c0392b;font-weight:700}
.actions a{margin-right:.4rem}

/* Forms */
.formcard{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.6rem;max-width:920px}
.formgrid{display:grid;grid-template-columns:1fr 1fr;gap:1rem 1.4rem}
.formgrid .full{grid-column:1/-1}
.field{display:flex;flex-direction:column;gap:.3rem}
.field label{font-size:.78rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}
.field input,.field select,.field textarea{padding:.5rem .6rem;border:1px solid var(--line);border-radius:8px;font-size:.95rem;font-family:inherit}
.field textarea{min-height:70px;resize:vertical}
.formactions{display:flex;gap:.8rem;margin-top:1.4rem;align-items:center}
.btn{padding:.6rem 1.3rem;border-radius:9px;border:0;font-weight:700;cursor:pointer;font-size:.95rem}
.btn.primary{background:var(--purple);color:#fff} .btn.primary:hover{background:var(--purple-d)}
.btn.ghost{background:#efeaf7;color:var(--purple-d)}
.btn.danger{background:#fff;color:#c0392b;border:1px solid #f0c9c4}

/* Fieldsets du formulaire */
fieldset.fs{border:1px solid var(--line);border-radius:12px;padding:1rem 1.2rem 1.2rem;margin:0 0 1.2rem}
fieldset.fs legend{padding:0 .5rem;font-weight:700;color:var(--purple-d);font-size:.9rem;text-transform:uppercase;letter-spacing:.03em}
.linkbtn{background:none;border:0;color:var(--magenta);cursor:pointer;font-size:.72rem;font-weight:600;padding:0 0 0 .4rem}
.linkbtn:hover{text-decoration:underline}
.formactions.sticky{position:sticky;bottom:0;background:linear-gradient(180deg,rgba(255,255,255,0),#fff 30%);
    padding:1rem 0 .4rem;margin-top:.4rem;border-top:1px solid var(--line)}
.formcard fieldset.fs .field label .hint{text-transform:none;font-weight:400}

/* Barre d'édition groupée */
.bulkbar{display:flex;align-items:flex-end;gap:.9rem;flex-wrap:wrap;background:var(--card);
    border:1px solid var(--line);border-radius:12px;padding:.7rem 1rem;margin-bottom:.9rem;box-shadow:var(--shadow)}
.bulkbar label{display:flex;flex-direction:column;gap:.2rem;font-size:.72rem;text-transform:uppercase;
    letter-spacing:.03em;color:var(--muted);font-weight:600}
.bulkbar select,.bulkbar input{padding:.4rem .55rem;border:1px solid var(--line);border-radius:8px;
    font-size:.9rem;text-transform:none;font-weight:400}
.bulkcount{align-self:center;font-size:.85rem;color:var(--muted)}
.bulkbar .btn{padding:.5rem 1rem}
.bulkbar .btn:disabled{opacity:.5;cursor:not-allowed}

.alert{padding:.9rem 1.1rem;border-radius:10px;margin-bottom:1.2rem}
.alert.ok{background:#e6f6ee;color:#1d7a4d;border:1px solid #b7e5cc}
.alert.err{background:#fdecea;color:#b93325;border:1px solid #f5c6c0}
.hint{color:var(--muted);font-size:.85rem}

.toolbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}
.summary{color:var(--muted);font-size:.9rem}
.summary b{color:var(--purple-d)}
