:root{
  --bleu:#1f4e79; --bleu2:#2e5e8c; --gris:#5b6470; --bord:#d8dde3; --fond:#f6f8fa;
  --mark:#fff3b0;
}
*{box-sizing:border-box}
body{font-family:Arial,Helvetica,sans-serif;color:#222;margin:0;background:#fff;line-height:1.45}
.wrap{max-width:1100px;margin:0 auto;padding:0 20px}
.top{background:var(--bleu);color:#fff}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;flex-wrap:wrap;gap:8px}
.brand{color:#fff;text-decoration:none;font-weight:bold;font-size:18px}
.commune{font-size:13px;opacity:.9}
main.wrap{padding-top:20px;padding-bottom:50px}
.search{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0 16px}
.search .q{flex:1 1 320px;min-width:220px;padding:9px 12px;border:1px solid var(--bord);border-radius:6px;font:inherit}
.search select{padding:9px 8px;border:1px solid var(--bord);border-radius:6px;font:inherit;background:#fff}
.search button{background:var(--bleu);color:#fff;border:0;border-radius:6px;padding:9px 16px;font:inherit;cursor:pointer}
.search button:hover{background:var(--bleu2)}
.search .reset{align-self:center;font-size:13px;color:var(--gris)}
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:0 0 10px;flex-wrap:wrap}
.count{color:var(--gris);font-size:14px}
.scanform{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--gris)}
.scanform button{background:#fff;color:var(--bleu);border:1px solid var(--bleu);border-radius:6px;padding:7px 12px;cursor:pointer;font:inherit}
.scanform button:hover{background:var(--fond)}
.flash{background:#e8f4ea;border:1px solid #bcdcc4;color:#1e5631;padding:9px 14px;border-radius:6px;margin:0 0 14px;font-size:14px}
.empty{color:var(--gris);background:var(--fond);border:1px solid var(--bord);border-radius:8px;padding:18px}
.empty code{font-size:12.5px;color:var(--bleu2)}
table.docs{border-collapse:collapse;width:100%;font-size:14px}
table.docs th,table.docs td{border-bottom:1px solid var(--bord);padding:9px 10px;text-align:left;vertical-align:top}
table.docs th{background:var(--fond);color:#173a57;font-size:12.5px;text-transform:uppercase;letter-spacing:.02em}
table.docs tr:hover td{background:#fafcfe}
td.name a{color:var(--bleu);text-decoration:none;font-weight:bold}
td.name a:hover{text-decoration:underline}
.rel{font-size:11.5px;color:var(--gris);font-family:monospace;margin-top:2px;word-break:break-all}
.snippet{font-size:12.5px;color:#333;margin-top:5px;background:var(--fond);border-left:3px solid var(--bleu);padding:4px 9px;border-radius:0 4px 4px 0}
mark{background:var(--mark);padding:0 1px}
.size{color:var(--gris);white-space:nowrap}
.open{color:var(--bleu2);text-decoration:none;font-size:13px;white-space:nowrap}
.open:hover{text-decoration:underline}
.open.big{display:inline-block;background:var(--bleu);color:#fff;padding:9px 16px;border-radius:6px;margin:6px 0}
.pole{display:inline-block;width:24px;height:24px;line-height:24px;text-align:center;border-radius:50%;color:#fff;font-weight:bold;font-size:13px;background:var(--bleu)}
.p-A{background:#1f4e79}.p-B{background:#6c3483}.p-C{background:#1e8449}.p-D{background:#b9770e}.p-E{background:#a04000}.p-F{background:#117a8b}.p-G{background:#922b21}
.back a{color:var(--bleu);text-decoration:none}
.doctitle{color:var(--bleu);font-size:21px;margin:6px 0 14px;word-break:break-word}
table.meta{border-collapse:collapse;margin:0 0 10px;font-size:14px}
table.meta td{border:1px solid var(--bord);padding:7px 12px}
table.meta td:first-child{background:#eef4f8;font-weight:bold;color:#173a57;width:140px}
.content{white-space:pre-wrap;font-size:13.5px;background:var(--fond);border:1px solid var(--bord);border-radius:8px;padding:16px;max-height:65vh;overflow:auto;line-height:1.55}
h2{color:var(--bleu2);font-size:16px;border-bottom:2px solid var(--bleu);padding-bottom:4px;margin-top:26px}
.foot{color:var(--gris);font-size:12px;border-top:1px solid var(--bord);padding:16px 20px;margin-top:30px}

/* ===== Navigation ===== */
.nav{display:flex;gap:6px;flex:1 1 auto;margin:0 12px}
.nav a{color:#dce8f2;text-decoration:none;padding:7px 12px;border-radius:6px;font-size:14px;font-weight:bold;display:inline-flex;align-items:center;gap:6px}
.nav a:hover{background:rgba(255,255,255,.12);color:#fff}
.nav a.on{background:#fff;color:var(--bleu)}
.nav .badge{background:rgba(255,255,255,.22);color:#fff;font-size:12px;padding:1px 7px;border-radius:10px;font-weight:bold}
.nav a.on .badge{background:var(--bleu);color:#fff}
.nav .badge.alert{background:#c0392b}

/* ===== En-tête de page & boutons ===== */
.page-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin:4px 0 12px}
.page-head h1{color:var(--bleu);font-size:21px;margin:0;word-break:break-word}
.btn{display:inline-block;background:#fff;color:var(--bleu);border:1px solid var(--bleu);border-radius:6px;padding:8px 14px;font:inherit;cursor:pointer;text-decoration:none}
.btn:hover{background:var(--fond)}
.btn.primary{background:var(--bleu);color:#fff}
.btn.primary:hover{background:var(--bleu2)}

/* ===== Badges ===== */
.badge{display:inline-block;font-size:12px;font-weight:bold;padding:2px 9px;border-radius:11px;background:#eef2f6;color:#334}
.prio-haute{background:#fdecea;color:#a01b0b;border:1px solid #f5b7b1}
.prio-moyenne{background:#fef5e7;color:#9c640c;border:1px solid #f8d79b}
.prio-basse{background:#eef2f6;color:#566;border:1px solid #d8dde3}
.st-instruire{background:#eef2f6;color:#445}
.st-cours{background:#e8f1fb;color:#1f4e79;border:1px solid #b7d3ee}
.st-attente{background:#fef5e7;color:#9c640c;border:1px solid #f8d79b}
.st-cloture{background:#e8f4ea;color:#1e5631;border:1px solid #bcdcc4}
.badge.alerte{color:#fff}
.alerte.a1{background:#b9b06b}.alerte.a2{background:#d68910}.alerte.a3{background:#cb4335}.alerte.a4{background:#922b21}
.badge.pole{color:#fff}
.cat{font-size:12px;color:var(--gris);background:var(--fond);border:1px solid var(--bord);padding:2px 9px;border-radius:11px}

/* ===== Cartes dossiers ===== */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:14px}
.card{border:1px solid var(--bord);border-left:5px solid var(--bord);border-radius:8px;padding:13px 15px;background:#fff}
.card.albar.a1{border-left-color:#b9b06b}.card.albar.a2{border-left-color:#d68910}
.card.albar.a3{border-left-color:#cb4335}.card.albar.a4{border-left-color:#922b21}
.card-top{display:flex;justify-content:space-between;gap:8px;align-items:baseline}
.card-title{color:var(--bleu);font-weight:bold;text-decoration:none;font-size:15px}
.card-title:hover{text-decoration:underline}
.ech{font-size:12px;color:var(--gris);white-space:nowrap}
.ech.soon{color:#9c640c;font-weight:bold}.ech.late{color:#c0392b;font-weight:bold}
.card-badges{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin:8px 0}
.card-badges.big{margin:2px 0 14px}
.card-resume{font-size:13px;color:#333;margin:6px 0 4px}
.card-next{font-size:12.5px;color:#444;background:var(--fond);border-radius:6px;padding:6px 9px;margin:6px 0 0}
td.late,.late{color:#c0392b}

/* ===== Journal des démarches ===== */
.action-form{background:var(--fond);border:1px solid var(--bord);border-radius:8px;padding:12px;margin:8px 0 16px}
.action-form .af-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px}
.action-form input[type=date],.action-form select{padding:8px;border:1px solid var(--bord);border-radius:6px;font:inherit}
.action-form textarea{width:100%;padding:9px;border:1px solid var(--bord);border-radius:6px;font:inherit;resize:vertical}
.action-form button{margin-top:8px;background:var(--bleu);color:#fff;border:0;border-radius:6px;padding:8px 14px;cursor:pointer;font:inherit}
.journal{list-style:none;padding:0;margin:0}
.journal li{border-left:3px solid var(--bleu);background:var(--fond);border-radius:0 6px 6px 0;padding:8px 12px;margin-bottom:8px}
.j-date{font-weight:bold;color:#173a57;font-size:13px;margin-right:8px}
.j-type{font-size:12px;background:#e8f1fb;color:var(--bleu);padding:1px 8px;border-radius:10px}
.j-txt{font-size:13.5px;margin-top:5px;white-space:pre-wrap}

/* ===== Formulaire dossier ===== */
.form{max-width:760px}
.form label{display:block;margin:10px 0;font-weight:bold;color:#173a57;font-size:14px}
.form input[type=text],.form input[type=date],.form select,.form textarea{display:block;width:100%;margin-top:5px;padding:9px;border:1px solid var(--bord);border-radius:6px;font:inherit;font-weight:normal}
.form textarea{resize:vertical}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:6px 14px}
.form-actions{display:flex;gap:10px;align-items:center;margin-top:16px}
.danger{margin-top:26px;border-top:1px solid var(--bord);padding-top:12px}
.link-danger{background:none;border:0;color:#c0392b;cursor:pointer;font:inherit;text-decoration:underline;padding:0}
@media(max-width:560px){.grid2{grid-template-columns:1fr}}

/* ===== Finances : tuiles, barres, check-list ===== */
.tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin:6px 0 8px}
.tile{background:var(--fond);border:1px solid var(--bord);border-radius:8px;padding:12px 14px;display:flex;flex-direction:column;gap:4px}
.tile.subv{border-left:4px solid #1e8449}
.tile.reste{border-left:4px solid #b9770e}
.t-lab{font-size:12px;color:var(--gris);text-transform:uppercase;letter-spacing:.02em}
.t-val{font-size:20px;font-weight:bold;color:var(--bleu)}
.note-prudence{font-size:12px;color:var(--gris);font-style:italic;margin:2px 0 8px}
.bars{display:flex;flex-direction:column;gap:7px;margin:6px 0}
.bar-row{display:grid;grid-template-columns:170px 1fr 120px;align-items:center;gap:10px;font-size:13px}
.bar-track{background:var(--fond);border:1px solid var(--bord);border-radius:5px;height:16px;overflow:hidden}
.bar-fill{display:block;height:100%;background:var(--bleu)}
.bar-val{text-align:right;color:#173a57;font-weight:bold}
table.fin td.num,table.fin th.num{text-align:right;white-space:nowrap}
.warn{color:#c0392b;cursor:help}
.warn-flash{background:#fdecea;border-color:#f5b7b1;color:#a01b0b}
.score{display:inline-block;font-weight:bold;font-size:12.5px;padding:1px 8px;border-radius:10px}
.score.ok{background:#e8f4ea;color:#1e5631}
.score.mid{background:#fef5e7;color:#9c640c}
.score.low{background:#fdecea;color:#a01b0b}
.checklist{list-style:none;padding:0;margin:8px 0;display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:6px}
.checklist li{font-size:13.5px;padding:6px 10px;border-radius:6px;border:1px solid var(--bord)}
.checklist li.ok{background:#f0f8f2;color:#1e5631;border-color:#bcdcc4}
.checklist li.ko{background:#fdecea;color:#a01b0b;border-color:#f5b7b1}
@media(max-width:560px){.bar-row{grid-template-columns:110px 1fr 90px}}

/* ===== Courriers ===== */
.card.modele{display:block;text-decoration:none}
.card.modele:hover{border-color:var(--bleu);background:#fafcfe}
.btnbar{display:flex;gap:8px;flex-wrap:wrap}
.hidden-plain{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.lettre{max-width:720px;background:#fff;border:1px solid var(--bord);border-radius:6px;padding:40px 48px;margin:12px 0;line-height:1.65;font-size:14px;color:#111}
.lettre .l-exp{margin-bottom:18px}
.lettre .l-dest{margin:6px 0 22px auto;width:62%;text-align:left}
.lettre .l-date{text-align:right;margin-bottom:26px}
.lettre .l-objet{margin-bottom:20px}
.lettre .l-corps{margin-bottom:8px}
.lettre .l-sign{margin-top:34px;margin-left:auto;width:55%}
@media print{
  .top,.foot,.no-print,.danger{display:none !important}
  main.wrap{padding:0;max-width:none}
  .lettre{border:0;border-radius:0;padding:0;max-width:none;margin:0;font-size:12pt}
  body{background:#fff}
}

/* ===== Budget / CFU ===== */
.muted{color:var(--gris);font-size:12px;font-weight:normal}
h3.sec{background:var(--bleu);color:#fff;padding:7px 12px;border-radius:6px;font-size:14px;margin:22px 0 8px}
h3.blk{color:var(--bleu2);font-size:14px;margin:14px 0 4px}
table.budget{font-size:13px}
table.budget td,table.budget th{padding:6px 9px}
table.budget tr.chap.ord td{color:var(--gris);background:#fbfbfc}
table.budget tfoot td{border-top:2px solid var(--bleu);font-weight:bold;background:var(--fond)}
table.budget tfoot tr.grand td{color:var(--bleu);font-size:14px}
table.budget details summary{cursor:pointer}
table.budget details[open] summary{margin-bottom:6px}
table.arts{width:100%;margin:4px 0 6px;font-size:12.5px;background:#fafcfe;border:1px solid var(--bord);border-radius:6px}
table.arts td{padding:3px 8px;border-bottom:1px solid #eef2f6}
table.arts td.ac{font-family:monospace;color:var(--bleu2);width:80px;white-space:nowrap}
.encours-form{background:var(--fond);border:1px solid var(--bord);border-radius:8px;padding:10px 14px;margin:6px 0;font-size:13px;display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.encours-form input{padding:7px 9px;border:1px solid var(--bord);border-radius:6px;font:inherit;width:160px}
.flash ul{margin:6px 0 0;padding-left:20px}
table.extract{font-size:12.5px}
table.extract td,table.extract th{padding:4px 6px}
table.extract input,table.extract select{padding:4px 6px;border:1px solid var(--bord);border-radius:4px;font:inherit;font-size:12.5px}
table.extract input[type=text],table.extract input[type=date]{max-width:100%}

/* ===== Tableau de bord (accueil) ===== */
.hero{text-align:center;padding:26px 16px 18px;background:linear-gradient(180deg,#eef4f9,#fff);border:1px solid var(--bord);border-radius:12px;margin:4px 0 22px}
.hero-logo{width:108px;height:auto;display:block;margin:0 auto 8px}
.hero h1{color:var(--bleu);font-size:32px;margin:0 0 4px}
.brand{display:inline-flex;align-items:center;gap:8px}
.brand-logo{height:30px;width:auto;background:#fff;border-radius:7px;padding:2px 3px}
.hero-sub{color:#334;font-size:15px;margin:0}
.hero-date{color:var(--gris);font-size:13px;margin:6px 0 0}
.dash-h{color:var(--bleu2);font-size:15px;border-bottom:2px solid var(--bleu);padding-bottom:5px;margin:24px 0 12px}
.todo-ok{background:#e8f4ea;border:1px solid #bcdcc4;color:#1e5631;padding:16px 18px;border-radius:10px;font-size:16px;font-weight:bold}
.todo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:12px}
.todo{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:10px;text-decoration:none;border:1px solid var(--bord)}
.todo .todo-n{font-size:30px;font-weight:bold;line-height:1}
.todo .todo-lib{font-size:13.5px;font-weight:bold}
.todo.rouge{background:#fdecea;border-color:#f5b7b1;color:#a01b0b}
.todo.orange{background:#fef5e7;border-color:#f8d79b;color:#9c640c}
.todo:hover{filter:brightness(.97)}
.mods{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:14px}
.mod{display:flex;flex-direction:column;align-items:center;text-align:center;gap:3px;padding:20px 14px;background:#fff;border:1px solid var(--bord);border-radius:12px;text-decoration:none;color:#222;transition:.1s}
.mod:hover{border-color:var(--bleu);box-shadow:0 2px 10px rgba(31,78,121,.10);transform:translateY(-1px)}
.mod-ico{font-size:30px}
.mod-t{font-weight:bold;color:var(--bleu);font-size:14px}
.mod-n{font-size:26px;font-weight:bold;color:#173a57;line-height:1.1;margin-top:2px}
.mod-s{font-size:12px;color:var(--gris)}
.dash-more{margin:12px 0 0}
.dash-more a{color:var(--bleu);text-decoration:none;font-weight:bold}
