:root{
  --bleu:#0D6EA5; --bleu-clair:#4290CE; --bleu-pale:#EAF3F9;
  --jaune:#F9B234; --jaune-pale:#FEF4E0;
  --magenta:#D41064; --magenta-pale:#FBE7F0;
  --prune:#8E2C5B; --prune-pale:#F4E8EE;
  --encre:#1C2B36; --gris:#5D6B76; --ligne:#E3E9ED; --fond:#F7FAFC;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'IBM Plex Sans',sans-serif;color:var(--encre);background:var(--fond);font-size:15.5px;line-height:1.6;min-height:100vh;display:flex;flex-direction:column}
h1,h2,h3,h4,.nav a,.tab{font-family:'Poppins',sans-serif}

/* ---------- En-tête ---------- */
header{background:#fff;border-bottom:1px solid var(--ligne);position:sticky;top:0;z-index:50}
.bar{max-width:1200px;margin:0 auto;padding:12px 20px;display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.logo img{height:52px;display:block;background:#fff}
.bar .titre{font-family:'Poppins',sans-serif;font-weight:600;font-size:.95rem;color:var(--bleu);border-left:2px solid var(--ligne);padding-left:18px;line-height:1.3}
.bar .titre span{display:block;font-size:.72rem;font-weight:500;color:var(--gris)}
.recherche{margin-left:auto;position:relative;flex:1;max-width:300px;min-width:180px}
.recherche input{width:100%;padding:9px 14px 9px 38px;border:1.5px solid var(--ligne);border-radius:24px;font:inherit;font-size:.88rem;background:var(--fond)}
.recherche input:focus{outline:2px solid var(--bleu-clair);border-color:transparent}
.recherche svg{position:absolute;left:13px;top:50%;transform:translateY(-50%);width:16px;height:16px;stroke:var(--gris)}
.compte{display:flex;align-items:center;gap:12px}
.compte .qui{font-size:.85rem;font-weight:600;color:var(--encre)}
.btn-sortie{font-size:.8rem;color:var(--bleu);text-decoration:none;border:1.5px solid var(--bleu);border-radius:20px;padding:5px 14px;font-family:'Poppins',sans-serif;font-weight:500}
.btn-sortie:hover{background:var(--bleu);color:#fff}

/* ---------- Navigation ---------- */
nav{background:var(--bleu);position:sticky;top:77px;z-index:49}
.nav{max-width:1200px;margin:0 auto;display:flex;overflow-x:auto;scrollbar-width:none}
.nav::-webkit-scrollbar{display:none}
.nav a{color:#fff;text-decoration:none;font-size:.82rem;font-weight:500;padding:11px 16px;white-space:nowrap;opacity:.85;border-bottom:3px solid transparent}
.nav a:hover,.nav a.actif{opacity:1;border-bottom-color:var(--jaune)}

/* ---------- Mise en page ---------- */
main{max-width:1200px;margin:0 auto;padding:28px 20px 80px;width:100%;flex:1}
.carte{background:#fff;border:1px solid var(--ligne);border-radius:14px;padding:26px 28px;margin-bottom:18px}
.carte h2{font-size:1.25rem;font-weight:600;color:var(--bleu);margin-bottom:4px}
.carte h3{font-size:1rem;font-weight:600;margin:20px 0 8px;color:var(--encre)}
.carte h3:first-of-type{margin-top:14px}
.carte p{margin:8px 0;color:var(--encre)}
.carte ul{margin:8px 0 8px 4px;list-style:none}
.carte ul li{padding:4px 0 4px 24px;position:relative}
.carte ul li::before{content:"";position:absolute;left:6px;top:13px;width:7px;height:7px;border-radius:50%;background:var(--jaune)}
.eyebrow{font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--gris);margin-bottom:2px;font-family:'Poppins',sans-serif}

/* Phases */
.phase-tete{display:flex;align-items:center;gap:14px;margin-bottom:6px}
.phase-num{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-family:'Poppins',sans-serif;font-weight:700;font-size:1.25rem;color:#fff;flex-shrink:0}
.p1 .phase-num{background:var(--bleu)} .p2 .phase-num{background:var(--jaune);color:var(--encre)} .p3 .phase-num{background:var(--magenta)}

/* Encadrés */
.alerte{border-left:4px solid var(--magenta);background:var(--magenta-pale);border-radius:8px;padding:12px 16px;margin:14px 0;font-size:.92rem}
.alerte strong{color:var(--magenta)}
.succes{border-left:4px solid #2E9E5B;background:#F0FAF4;border-radius:8px;padding:12px 16px;margin:14px 0;font-size:.92rem}
.succes strong{color:#2E9E5B}
.qualiopi{border-left:4px solid var(--prune);background:var(--prune-pale);border-radius:8px;padding:12px 16px;margin:14px 0;font-size:.88rem}
.qualiopi strong{color:var(--prune)}
.pill{display:inline-block;background:var(--prune);color:#fff;font-size:.7rem;font-weight:600;padding:2px 9px;border-radius:11px;margin:2px 4px 2px 0;font-family:'Poppins',sans-serif}

/* Tableaux */
table{width:100%;border-collapse:collapse;margin:12px 0;font-size:.88rem}
th{background:var(--bleu-pale);color:var(--bleu);text-align:left;padding:9px 12px;font-family:'Poppins',sans-serif;font-weight:600;font-size:.8rem}
td{padding:9px 12px;border-bottom:1px solid var(--ligne);vertical-align:top}
tr:last-child td{border-bottom:none}
.scroll-x{overflow-x:auto}

/* Accueil */
.hero{background:linear-gradient(120deg,var(--bleu) 0%,var(--bleu-clair) 100%);color:#fff;border-radius:14px;padding:34px 32px;margin-bottom:18px}
.hero h1{font-size:1.7rem;font-weight:700;line-height:1.25}
.hero p{margin-top:8px;max-width:640px;opacity:.95}
.parcours{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:22px}
.etape{background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.25);border-radius:12px;padding:16px;cursor:pointer;transition:background .15s;text-decoration:none;color:#fff;display:block}
.etape:hover{background:rgba(255,255,255,.22)}
.etape .num{font-family:'Poppins',sans-serif;font-weight:700;font-size:.78rem;color:var(--jaune);letter-spacing:.08em}
.etape h3{font-size:1rem;margin:4px 0 6px;font-weight:600;color:#fff}
.etape p{font-size:.82rem;opacity:.9;margin:0}
.etape .prog{height:5px;background:rgba(255,255,255,.25);border-radius:3px;margin-top:12px;overflow:hidden}
.etape .prog i{display:block;height:100%;background:var(--jaune);width:0;border-radius:3px;transition:width .3s}
.etape .pct{font-size:.72rem;margin-top:5px;opacity:.85}

/* Checklists */
.check-groupe{margin-bottom:8px}
.check-tete{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.barre{flex:1;min-width:140px;height:8px;background:var(--ligne);border-radius:4px;overflow:hidden}
.barre i{display:block;height:100%;width:0;border-radius:4px;transition:width .3s}
.b1 i{background:var(--bleu)} .b2 i{background:var(--jaune)} .b3 i{background:var(--magenta)}
.check-liste{margin-top:12px}
.check-item{display:flex;align-items:flex-start;gap:11px;padding:8px 10px;border-radius:8px;cursor:pointer}
.check-item:hover{background:var(--fond)}
.check-item input{width:19px;height:19px;margin-top:2px;accent-color:var(--bleu);cursor:pointer;flex-shrink:0}
.check-item input:checked + span{color:var(--gris);text-decoration:line-through}
.note{font-size:.82rem;color:var(--gris);font-style:italic;margin-top:10px}
.etat-sauvegarde{font-size:.78rem;color:var(--gris);margin-top:6px;min-height:1.2em}

/* Formulaires */
.champ{margin-bottom:16px}
.champ label{display:block;font-size:.85rem;font-weight:600;margin-bottom:5px;font-family:'Poppins',sans-serif}
.champ input[type=text],.champ input[type=email],.champ input[type=password],.champ input[type=file],.champ textarea,.champ select{width:100%;padding:10px 14px;border:1.5px solid var(--ligne);border-radius:10px;font:inherit;font-size:.92rem;background:#fff}
.champ input:focus,.champ textarea:focus,.champ select:focus{outline:2px solid var(--bleu-clair);border-color:transparent}
.champ .aide{font-size:.78rem;color:var(--gris);margin-top:4px}
.btn{background:var(--bleu);color:#fff;border:none;font:inherit;font-family:'Poppins',sans-serif;font-weight:600;font-size:.9rem;padding:11px 26px;border-radius:24px;cursor:pointer;text-decoration:none;display:inline-block}
.btn:hover{background:#0A5A88}
.btn.sec{background:#fff;color:var(--bleu);border:1.5px solid var(--bleu)}
.btn.danger{background:var(--magenta)}
.btn.petit{padding:6px 16px;font-size:.8rem}

/* Connexion */
.page-connexion{display:flex;align-items:center;justify-content:center;padding:60px 20px;flex:1}
.boite-connexion{background:#fff;border:1px solid var(--ligne);border-radius:16px;padding:38px 36px;width:100%;max-width:420px}
.boite-connexion .logo-co{display:block;margin:0 auto 22px;max-width:260px}
.boite-connexion h1{font-size:1.25rem;font-weight:600;color:var(--bleu);text-align:center;margin-bottom:4px}
.boite-connexion .sous{text-align:center;font-size:.85rem;color:var(--gris);margin-bottom:24px}
.boite-connexion .btn{width:100%;text-align:center}

/* Documents */
.depot{border:2px dashed var(--bleu-clair);border-radius:12px;padding:22px;background:var(--bleu-pale);margin:14px 0}
.fichier-icone{display:inline-flex;width:34px;height:34px;border-radius:8px;background:var(--bleu-pale);color:var(--bleu);align-items:center;justify-content:center;font-family:'Poppins',sans-serif;font-weight:600;font-size:.62rem;text-transform:uppercase;flex-shrink:0}
.lien-action{color:var(--bleu);text-decoration:none;font-weight:500}
.lien-action:hover{text-decoration:underline}
.lien-action.suppr{color:var(--magenta)}
.vide{text-align:center;color:var(--gris);padding:26px;font-size:.9rem}

/* Contacts */
.contacts{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;margin-top:14px}
.fiche{border:1px solid var(--ligne);border-radius:12px;padding:18px}
.fiche .role{font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--prune);font-family:'Poppins',sans-serif}
.fiche h3{margin:5px 0 9px !important;font-size:1.02rem}
.fiche a{display:inline-flex;align-items:center;gap:7px;color:var(--bleu);text-decoration:none;font-weight:500;font-size:.9rem;margin:3px 14px 3px 0}
.fiche a:hover{text-decoration:underline}
.fiche svg{width:15px;height:15px;stroke:var(--bleu);flex-shrink:0}

/* Recherche */
mark{background:var(--jaune);color:var(--encre);border-radius:3px;padding:0 2px}
.cache{display:none !important}
#sans-resultat{display:none;text-align:center;padding:40px;color:var(--gris)}

footer{border-top:1px solid var(--ligne);background:#fff;padding:22px 20px;text-align:center;font-size:.82rem;color:var(--gris)}

@media(max-width:760px){
  .parcours{grid-template-columns:1fr}
  .carte{padding:20px 18px}
  .bar .titre{display:none}
  nav{top:69px}
}
@media(prefers-reduced-motion:reduce){*{transition:none !important}html{scroll-behavior:auto}}
