/* SUIVI PAPIER — charte alignee sur le projet MAINTENANCE (Power BI like) */
:root{--bg:#f3f2f1;--card:#fff;--ink:#252423;--muted:#605e5c;--line:#e1dfdd;
  --brand:#009FE2;--brand2:#007cb0;--head:#000;--magenta:#E6007D;--jaune:#FFED02;--grid:#edebe9;}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);
  font-family:'All Round Gothic','Montserrat',Calibri,Arial,sans-serif;font-size:12px}
.page{max-width:1320px;margin:0 auto;padding:10px}

/* --- en-tete noir --- */
header.bar{display:flex;align-items:center;gap:16px;background:var(--head);color:#fff;border-radius:6px;padding:10px 16px}
header.bar .logo{display:flex;align-items:center;gap:9px}
header.bar .logo img.logo-img{height:44px;width:auto;display:block}
header.bar h1{font-size:18px;margin:0;font-weight:700;flex:1;text-transform:uppercase;letter-spacing:.5px}
header.bar .meta{font-size:11px;opacity:.85;text-align:right;line-height:1.4}

/* bandeau utilisateur */
.userbox{display:flex;align-items:center;gap:10px;font-size:11px;color:#bbb}
.userbox .uemail{color:#fff;font-weight:600}
.userbox .uscope{background:#222;border:1px solid #444;border-radius:10px;padding:1px 8px;color:#9fd}
.userbox .ulink{color:var(--brand);font-weight:600;text-decoration:none}
.userbox .ulink:hover{filter:brightness(1.2)}

/* --- nav --- */
.nav{display:flex;gap:5px;margin:8px 0;flex-wrap:wrap}
.nav a{padding:7px 14px;border-radius:5px;text-decoration:none;color:var(--ink);background:var(--card);
  border:1px solid var(--line);font-size:12px;font-weight:600}
.nav a:hover{filter:brightness(.96);border-color:var(--brand)}
.nav a.active{background:var(--brand);color:#fff;border-color:var(--brand)}
.ban{height:4px;border-radius:3px;margin:6px 0 0;
  background:linear-gradient(90deg,var(--brand) 0 60%,var(--magenta) 60% 85%,var(--jaune) 85% 100%)}

/* --- slicers (deroulant multi-selection) --- */
.slicers{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0}
.slicer{position:relative;background:var(--card);border:1px solid var(--line);border-radius:5px;min-width:150px}
.slicer>button{width:100%;text-align:left;background:none;border:0;padding:7px 10px;cursor:pointer;
  font:inherit;color:var(--ink);display:flex;justify-content:space-between;align-items:center;gap:8px}
.slicer .lbl{font-size:10px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);display:block}
.slicer .sel{font-weight:600;font-size:12px}
.slicer .caret{color:var(--muted)}
.dropdown{display:none;position:absolute;z-index:30;top:calc(100% + 2px);left:0;right:0;background:#fff;
  border:1px solid var(--line);border-radius:5px;max-height:300px;overflow:auto;box-shadow:0 6px 18px rgba(0,0,0,.15);min-width:220px}
.slicer.open .dropdown{display:block}
.dropdown .search{padding:6px}
.dropdown .search input{width:100%;padding:5px 7px;border:1px solid var(--line);border-radius:4px;font:inherit}
.dropdown label{display:flex;gap:7px;align-items:center;padding:5px 10px;cursor:pointer;white-space:nowrap}
.dropdown label:hover{background:#f3f9ff}
.dropdown .opt-actions{display:flex;justify-content:space-between;padding:4px 10px;border-bottom:1px solid var(--line)}
.dropdown .opt-actions a{color:var(--brand);cursor:pointer;font-size:11px}

/* --- bandeau filtres actifs (clic) --- */
.crossinfo{margin:0 0 8px}
.crossinfo .ci-lbl{font-size:11px;color:var(--muted);margin-right:4px}
.crossinfo .chip{display:inline-block;background:#e7f1ff;border:1px solid #b9d6f7;color:#12239e;border-radius:12px;
  padding:3px 9px;font-size:11px;font-weight:600;cursor:pointer;margin:2px}
.crossinfo .chip:hover{background:#d7e7fb}

/* --- KPI --- */
.kpi{display:flex;gap:10px;margin-bottom:10px;flex-wrap:wrap}
.kpi .box{background:var(--card);border:1px solid var(--line);border-radius:6px;padding:8px 14px;min-width:130px}
.kpi .v{font-size:20px;font-weight:700;color:var(--brand2)}
.kpi .k{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}
.reset{background:var(--brand);color:#fff;border:0;border-radius:5px;padding:7px 12px;cursor:pointer;font:inherit;font-weight:600}
.reset:hover{background:#0f7ad6}

/* --- grilles / cartes --- */
.grid{display:grid;gap:10px}
.r2{grid-template-columns:1fr 1fr}.r3{grid-template-columns:1fr 1fr 1fr}
.r-2-1{grid-template-columns:1.4fr 1fr}.r-1-2{grid-template-columns:1fr 2fr}
@media(max-width:980px){.grid{grid-template-columns:1fr!important}}
.card{background:var(--card);border:1px solid var(--line);border-radius:6px;padding:10px;min-width:0;margin-bottom:10px}
.card h3{margin:0 0 6px;font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;
  letter-spacing:.4px;display:flex;justify-content:space-between;align-items:center;gap:8px}
.card h3 .sub{font-weight:400;color:var(--muted);text-transform:none}
.chartbox{position:relative;height:250px}

/* --- tableaux --- */
.tablewrap{overflow:auto;max-height:380px}
table{border-collapse:collapse;width:100%;font-size:11px}
th,td{padding:4px 8px;border-bottom:1px solid var(--grid);text-align:left;white-space:nowrap}
th{position:sticky;top:0;background:var(--head);color:#fff;cursor:pointer;font-weight:600;z-index:2}
th .arr{opacity:.6;font-size:9px}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}
td.neg{color:var(--magenta)}
/* colonnes longues : autoriser le retour a la ligne pour tout afficher sans scroll */
td.wrap{white-space:normal;word-break:break-word;min-width:220px;max-width:460px}
td.wrapq{white-space:normal;word-break:break-word;max-width:150px}
.kode{font-weight:700;color:#0a6;font-variant-numeric:tabular-nums}
tbody tr{cursor:pointer}
tbody tr:hover{background:#f3f9ff}
tbody tr.rowsel{background:#cfe8ff}
tbody tr.rowsel:hover{background:#bfdffb}
tfoot td{font-weight:700;background:#eef1f6;border-top:2px solid var(--head);position:sticky;bottom:0}

.foot{color:var(--muted);font-size:10px;text-align:center;margin:14px 0 4px}

/* --- accueil (tuiles) --- */
.sec{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin:18px 4px 8px}
.tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}
.tile{display:block;text-decoration:none;color:var(--ink);background:var(--card);border:1px solid var(--line);
  border-radius:8px;padding:16px;transition:.12s;position:relative;overflow:hidden}
.tile:hover{border-color:var(--brand);box-shadow:0 6px 16px rgba(0,0,0,.08);transform:translateY(-2px)}
.tile .ic{font-size:26px;display:block;margin-bottom:8px}
.tile .t{font-size:15px;font-weight:700;margin-bottom:3px}
.tile .d{font-size:11.5px;color:var(--muted);line-height:1.4}
.tile::after{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--brand)}
.tile.m::after{background:var(--magenta)}.tile.j::after{background:var(--jaune)}

/* --- login / admin --- */
.login,.gate{max-width:420px;margin:8vh auto;background:var(--card);border:1px solid var(--line);
  border-radius:10px;padding:26px 28px;box-shadow:0 6px 24px rgba(0,0,0,.08)}
.login h2,.gate h2{margin:0 0 4px;font-size:16px;text-transform:uppercase;letter-spacing:.5px}
.login p{margin:0 0 18px;color:var(--muted);font-size:12px}
.login label{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);font-weight:700;margin-bottom:4px}
.login input,.gate input{width:100%;padding:10px 12px;font-size:14px;border:1px solid var(--line);border-radius:6px}
.login button,.gate button{width:100%;margin-top:16px;background:var(--brand);color:#fff;border:0;padding:11px;border-radius:6px;font-size:14px;font-weight:700;cursor:pointer}
.login button:hover,.gate button:hover{filter:brightness(.93)}
.err{color:var(--magenta);font-size:12px;margin-top:12px;min-height:16px;font-weight:600}
.adminlink{display:block;text-align:center;margin-top:16px;font-size:11px;color:var(--muted)}

/* admin console */
.btn{background:var(--brand);color:#fff;border:0;padding:7px 12px;border-radius:5px;font-weight:600;cursor:pointer}
.btn.sec{background:#fff;color:var(--ink);border:1px solid var(--line)}
.btn.del{background:var(--magenta)}
.bar2{display:flex;gap:8px;align-items:center;margin:10px 0;flex-wrap:wrap}
.apps{display:flex;flex-wrap:wrap;gap:4px;max-height:120px;overflow:auto;border:1px solid var(--line);border-radius:6px;padding:6px;background:#fafafa}
.apps label{display:flex;align-items:center;gap:4px;font-size:11px;background:#fff;border:1px solid var(--line);border-radius:4px;padding:2px 6px;cursor:pointer}
.apps label.on{background:#dff3ff;border-color:var(--brand)}
.emailin{width:100%;min-width:200px;padding:6px 8px;border:1px solid var(--line);border-radius:5px;font:inherit}
.ok{color:#0a8a3a;font-weight:600;font-size:12px}
.chip-c{font-size:11px;background:#eef;border-radius:10px;padding:2px 8px}
td .star{font-size:11px;color:var(--muted)}
