/* ===== SALOUMA 2026 — feuille de style (mobile-first) ===== */
:root{
  --vert:#1D5BBF; --vert-fonce:#0D3B8A; --vert-clair:#DAE8FF;
  --bleu:#2E80D8; --bleu-fonce:#1054A8;
  --ambre:#EF9F27; --rouge:#D85A30;
  --gris-bg:#F4F5F4; --gris-bord:#E2E4E1; --gris-txt:#5F5E5A; --noir:#26241F;
  --ombre:0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);
  --r:12px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,"Segoe UI",Roboto,sans-serif;background:var(--gris-bg);color:var(--noir);-webkit-text-size-adjust:100%}
.hidden{display:none !important}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit;font-size:16px}

/* ---- écran de connexion ---- */
#login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;
  background:linear-gradient(160deg,var(--vert-fonce),var(--vert))}
.login-card{background:#fff;border-radius:16px;padding:28px 24px;width:100%;max-width:380px;box-shadow:0 10px 40px rgba(0,0,0,.2)}
.login-logo{text-align:center;margin-bottom:12px}
.login-logo img{height:80px;width:auto;object-fit:contain}
.login-card h1{font-size:20px;color:var(--vert-fonce);text-align:center}
.login-card .sub{text-align:center;color:var(--gris-txt);font-size:13px;margin:4px 0 20px}
.field{margin-bottom:14px}
.field label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:var(--noir)}
.field input,.field select,.field textarea{width:100%;padding:11px 12px;border:1px solid var(--gris-bord);border-radius:10px;background:#fff}
.field input:focus,.field select:focus{outline:none;border-color:var(--vert)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:none;border-radius:10px;
  padding:12px 16px;font-size:15px;font-weight:600;background:var(--vert);color:#fff;width:100%}
.btn:active{transform:translateY(1px)}
.btn.sec{background:#fff;color:var(--vert-fonce);border:1px solid var(--vert)}
.btn.ghost{background:transparent;color:var(--gris-txt);width:auto;padding:8px 10px}
.btn.sm{width:auto;padding:8px 12px;font-size:13px}
.err{color:var(--rouge);font-size:13px;margin-top:10px;text-align:center;min-height:18px}

/* ---- structure appli ---- */
#app{max-width:760px;margin:0 auto;padding-bottom:78px}
.topbar{position:sticky;top:0;z-index:10;background:var(--vert-fonce);color:#fff;
  display:flex;align-items:center;justify-content:space-between;padding:8px 16px;gap:10px}
.topbar-logo{height:36px;width:auto;object-fit:contain;flex-shrink:0;background:#fff;border-radius:6px;padding:2px 5px}
.topbar .who{font-size:13px;line-height:1.3}
.topbar .who b{font-size:15px}
.badge{display:inline-block;font-size:11px;padding:2px 8px;border-radius:20px;background:rgba(255,255,255,.2);margin-top:2px}
.offline-bar{background:var(--ambre);color:#3a2a00;font-size:12.5px;text-align:center;padding:6px}

.view{padding:16px}
.view h2{font-size:17px;margin-bottom:12px}
.muted{color:var(--gris-txt);font-size:13px}

/* ---- cartes statistiques ---- */
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.stat{background:#fff;border:1px solid var(--gris-bord);border-radius:var(--r);padding:14px;box-shadow:var(--ombre)}
.stat .n{font-size:26px;font-weight:700;color:var(--vert-fonce)}
.stat .l{font-size:12.5px;color:var(--gris-txt);margin-top:2px}
.stat.b .n{color:var(--bleu-fonce)} .stat.a .n{color:var(--ambre)} .stat.r .n{color:var(--rouge)}

.card{background:#fff;border:1px solid var(--gris-bord);border-radius:var(--r);padding:14px;box-shadow:var(--ombre);margin-top:14px}
.card h3{font-size:14px;margin-bottom:10px}
.bar-row{display:flex;align-items:center;gap:8px;margin-bottom:7px;font-size:12.5px}
.bar-row .lab{width:34%;color:var(--noir);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bar-row .track{flex:1;background:var(--vert-clair);border-radius:6px;height:16px;overflow:hidden}
.bar-row .fill{height:100%;background:var(--vert)}
.bar-row .val{width:42px;text-align:right;color:var(--gris-txt)}

/* ---- listes ---- */
.toolbar{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}
.toolbar input,.toolbar select{flex:1;min-width:120px;padding:10px;border:1px solid var(--gris-bord);border-radius:10px;background:#fff}
.list-item{background:#fff;border:1px solid var(--gris-bord);border-radius:var(--r);padding:12px 14px;margin-bottom:8px;
  display:flex;align-items:center;justify-content:space-between;box-shadow:var(--ombre)}
.list-item .nom{font-weight:600;font-size:14.5px}
.list-item .meta{font-size:12px;color:var(--gris-txt);margin-top:2px}
.pill{font-size:11px;padding:2px 8px;border-radius:20px;background:var(--vert-clair);color:var(--vert-fonce);margin-left:5px}
.pill.h{background:#FAECE7;color:var(--rouge)}
.pill.f{background:#FBEAF0;color:#993556} .pill.m{background:#E6F1FB;color:var(--bleu-fonce)}

/* ---- pointage (présences) ---- */
.presence-item{background:#fff;border:1px solid var(--gris-bord);border-radius:var(--r);padding:10px 14px;margin-bottom:8px;
  display:flex;align-items:center;justify-content:space-between}
.toggle{position:relative;width:54px;height:30px;border-radius:30px;background:#ccc;border:none;transition:background .15s;flex:none}
.toggle.on{background:var(--vert)}
.toggle::after{content:"";position:absolute;top:3px;left:3px;width:24px;height:24px;border-radius:50%;background:#fff;transition:left .15s}
.toggle.on::after{left:27px}

/* ---- navigation basse ---- */
.bottomnav{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--gris-bord);
  display:flex;max-width:760px;margin:0 auto}
.bottomnav button{flex:1;background:none;border:none;padding:9px 4px 10px;color:var(--gris-txt);font-size:11px;display:flex;flex-direction:column;align-items:center;gap:3px}
.bottomnav button.active{color:var(--vert-fonce)}
.bottomnav button .ic{font-size:19px}

/* ---- modale ---- */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.4);display:flex;align-items:flex-end;justify-content:center;z-index:50}
.modal .sheet{background:#fff;border-radius:16px 16px 0 0;width:100%;max-width:760px;padding:18px;max-height:90vh;overflow:auto}
.modal h3{margin-bottom:14px}
.row2{display:flex;gap:10px}.row2>*{flex:1}
/* ---- arbre de sélection des participants (nouvelle séance) ---- */
.roster-tree{max-height:44vh;overflow:auto;border:1px solid var(--gris-bord);border-radius:10px;padding:4px}
.rt-row{display:flex;align-items:center;gap:8px;padding:6px 4px;border-radius:8px}
.rt-c-row{background:var(--vert-clair)}
.rt-c-row+.rt-villages{margin-bottom:4px}
.rt-commune{margin-bottom:4px}
.rt-row input[type=checkbox]{width:18px;height:18px;flex:none;accent-color:var(--vert)}
.rt-tog{flex:none;width:26px;height:26px;border:none;background:transparent;font-size:13px;color:var(--vert-fonce);cursor:pointer;padding:0}
.rt-name{flex:1;font-size:14px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rt-badge{flex:none;font-size:11px;color:var(--gris-txt);background:#fff;border:1px solid var(--gris-bord);border-radius:20px;padding:1px 8px}
.rt-villages{padding-left:18px}
.rt-v-row{background:var(--gris-bg)}
.rt-benes{padding-left:30px;padding-bottom:4px}
.rt-bene{display:flex;align-items:center;gap:8px;padding:5px 4px;font-size:13.5px;cursor:pointer}
.rt-bene input[type=checkbox]{width:17px;height:17px;flex:none;accent-color:var(--vert)}
.rt-count{font-size:13px;font-weight:600;color:var(--vert-fonce);margin:8px 0 10px;text-align:center}
.toast{position:fixed;bottom:90px;left:50%;transform:translateX(-50%);background:var(--noir);color:#fff;padding:10px 16px;border-radius:24px;font-size:13px;z-index:60;box-shadow:var(--ombre)}
/* ---- signature ---- */
.sigpad{border:2px dashed var(--gris-bord);border-radius:12px;background:#fff;touch-action:none;width:100%;height:200px;display:block}
.sig-actions{display:flex;gap:10px;margin-top:12px}
.sig-mini{width:54px;height:34px;object-fit:contain;border:1px solid var(--gris-bord);border-radius:6px;background:#fff}
.pen{flex:none;width:40px;height:40px;border-radius:10px;border:1px solid var(--gris-bord);background:#fff;font-size:17px;margin-right:8px}
.pen.signed{background:var(--vert-clair);border-color:var(--vert)}

/* ---- parcours bénéficiaire ---- */
.profile{background:#fff;border:1px solid var(--gris-bord);border-radius:var(--r);padding:14px;box-shadow:var(--ombre)}
.profile .big{font-size:18px;font-weight:700;color:var(--vert-fonce)}
.kv{display:grid;grid-template-columns:1fr 1fr;gap:6px 12px;margin-top:10px;font-size:13px}
.kv div span{color:var(--gris-txt)}
.chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.chip{font-size:11.5px;padding:4px 9px;border-radius:16px;border:1px solid var(--gris-bord);color:var(--gris-txt);background:#fff}
.chip.ok{background:var(--vert);color:#fff;border-color:var(--vert)}
.timeline{margin-top:6px}
.tl-item{display:flex;gap:10px;padding:10px 0;border-bottom:1px solid var(--gris-bord)}
.tl-dot{flex:none;width:10px;height:10px;border-radius:50%;background:var(--vert);margin-top:5px}
.tl-item .a{font-weight:600;font-size:14px}
.tl-item .m{font-size:12px;color:var(--gris-txt)}

/* ---- indicateurs vs cibles ---- */
.gauge{margin-bottom:18px}
.gauge .top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}
.gauge .top b{font-size:15px}.gauge .top .t{font-size:12px;color:var(--gris-txt)}
.gauge .track{position:relative;height:26px;background:var(--vert-clair);border-radius:8px;overflow:hidden}
.gauge .fill{height:100%;background:var(--vert);min-width:2px}
.gauge .fill.warn{background:var(--ambre)} .gauge .fill.ok{background:var(--vert)}
.gauge .target{position:absolute;top:-3px;bottom:-3px;width:3px;background:var(--noir)}
.gauge .pct{position:absolute;right:8px;top:4px;font-size:12.5px;font-weight:700;color:#fff;mix-blend-mode:difference}

@media(min-width:620px){.grid{grid-template-columns:repeat(4,1fr)}}
