/* V2 : widgets typés, groupes, grilles, designer, charts, timeline, chat */
details.fgroup{padding:0;overflow:hidden}
details.fgroup>summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:10px;padding:14px 20px;background:var(--white)}
details.fgroup>summary::-webkit-details-marker{display:none}
details.fgroup>summary::before{content:"\25B8";color:var(--teal);font-size:12px;transition:.15s}
details.fgroup[open]>summary::before{transform:rotate(90deg)}
details.fgroup>summary .gtitle{font-size:13px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:var(--teal-dark)}
details.fgroup>summary .gcount{margin-left:auto;font-size:11px;color:var(--text-soft);background:var(--bg);border-radius:20px;padding:2px 9px}
details.fgroup .gbody{padding:4px 20px 16px}
details.fgroup[open]>summary{border-bottom:1px solid var(--grey-light)}

.hint{display:inline-flex;color:var(--text-soft);cursor:help;margin-left:4px;vertical-align:-3px;width:15px;height:15px}
.hint svg.lucide{width:15px;height:15px}
.hint:hover{color:var(--teal)}
.inwrap{position:relative;display:flex;align-items:center}
.inwrap.has-suffix input{padding-right:38px}
.inwrap .suffix{position:absolute;right:12px;font-size:12px;color:var(--text-soft);font-weight:600;pointer-events:none}
/* alignement comptable des champs numeriques */
.fld input[inputmode="decimal"],.fld input[inputmode="numeric"]{text-align:right}
.frow.is-grid{grid-template-columns:1fr}
.frow.is-grid label{margin-bottom:8px}

.toggle{display:inline-flex;cursor:pointer}
.toggle input{display:none}
.toggle span{width:42px;height:24px;border-radius:20px;background:var(--grey-mid);position:relative;transition:.18s}
.toggle span::after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:.18s}
.toggle input:checked + span{background:var(--teal)}
.toggle input:checked + span::after{transform:translateX(18px)}

.gtbl{width:100%;border-collapse:collapse;font-size:13px}
.gtbl th{text-align:left;font-size:10.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-soft);padding:4px 8px}
.gtbl td{padding:3px 8px 3px 0}
.gtbl input{width:100%;padding:8px 10px;border:1px solid var(--grey-mid);border-radius:8px;font-family:inherit;font-size:13px}
.gtbl input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-soft)}
.gtbl .rm{border:none;background:var(--bg);color:var(--orange);border-radius:7px;width:30px;height:32px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}
.gtbl .rm svg.lucide{width:15px;height:15px}
.gtbl .rm:hover{background:#FBE7DD}

.countdown{font-weight:600;color:var(--teal-dark)}.countdown.urgent{color:var(--orange)}
.hero{display:flex;gap:24px;align-items:center;flex-wrap:wrap}
.hero .meta{display:flex;gap:18px;flex-wrap:wrap;margin-top:8px}
.hero .meta .m{font-size:12.5px;color:var(--text-soft)}.hero .meta .m b{color:var(--dark)}
.steps3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:18px 0}
.step3{background:var(--white);border:1px solid var(--grey-light);border-radius:13px;padding:15px;box-shadow:var(--shadow)}
.step3 .n{width:26px;height:26px;border-radius:50%;background:var(--teal-soft);color:var(--teal-dark);font-weight:700;display:flex;align-items:center;justify-content:center;font-size:13px;margin-bottom:8px}
.step3 .t{font-weight:600;font-size:13.5px;color:var(--dark)}.step3 .d{font-size:12px;color:var(--text-soft);margin-top:3px}
.badge-net{display:inline-flex;align-items:center;gap:8px;background:var(--teal-soft);color:var(--teal-dark);font-size:12.5px;font-weight:600;border-radius:20px;padding:6px 14px}

.chartcard{background:var(--white);border:1px solid var(--grey-light);border-radius:15px;padding:18px 20px;box-shadow:var(--shadow)}
.chartcard h3{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--teal-dark);margin-bottom:14px}
.chgrid{display:grid;grid-template-columns:1.3fr 1fr;gap:14px;margin-bottom:14px}
.hbar{display:flex;align-items:center;gap:10px;margin:8px 0;font-size:12.5px}
.hbar .lab{width:96px;color:var(--text-soft)}
.hbar .track{flex:1;height:14px;background:var(--bg);border-radius:7px;overflow:hidden}
.hbar .track i{display:block;height:100%;background:linear-gradient(90deg,var(--teal),var(--amber));border-radius:7px}
.hbar .val{width:34px;text-align:right;font-weight:600;color:var(--dark)}
.filters-bar{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.filters-bar select{padding:9px 12px;border:1px solid var(--grey-mid);border-radius:9px;font-family:inherit;font-size:13px}

.tl{position:relative;padding-left:22px}
.tl::before{content:"";position:absolute;left:6px;top:4px;bottom:4px;width:2px;background:var(--grey-light)}
.tl-item{position:relative;padding:6px 0 14px}
.tl-item::before{content:"";position:absolute;left:-19px;top:8px;width:10px;height:10px;border-radius:50%;background:var(--teal);border:2px solid #fff;box-shadow:0 0 0 2px var(--teal-soft)}
.tl-item .ev{font-weight:600;font-size:13px;color:var(--dark)}
.tl-item .meta{font-size:11.5px;color:var(--text-soft)}
.chat{display:flex;flex-direction:column;gap:11px;margin:6px 0 2px;max-height:360px;overflow-y:auto;padding-right:4px}
.chat-empty{display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center;color:var(--text-soft);padding:18px 8px;font-size:12.5px}
.chat-empty svg.lucide{width:26px;height:26px;color:var(--grey-mid)}
.msg{max-width:88%;padding:9px 12px;border-radius:13px;font-size:13px;line-height:1.45;word-break:break-word}
.msg .who{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;opacity:.6;margin-bottom:4px}
.msg.them{background:var(--bg);align-self:flex-start;border-bottom-left-radius:4px}
.msg.me{background:var(--teal-soft);color:var(--teal-dark);align-self:flex-end;border-bottom-right-radius:4px}
.chatform{display:flex;gap:8px;margin-top:12px;border-top:1px solid var(--grey-light);padding-top:12px}
.chatform input{flex:1;min-width:0;padding:10px 13px;border:1px solid var(--grey-mid);border-radius:10px;font-family:inherit;font-size:13px}
.chatform input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-soft)}
.chatform .btn{flex-shrink:0;padding:10px 13px}

/* ===== en-tete de page avec actions ===== */
.pagehead{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;flex-wrap:wrap}
.head-actions{display:flex;gap:10px;flex-wrap:wrap;flex-shrink:0}

/* ===== panneau de decision DAF ===== */
.decision{margin-bottom:22px}
.decision-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:16px}
.decision-head h2{font-size:17px}
.decision-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.decision-cell{display:flex;flex-direction:column;border:1px solid var(--grey-light);border-radius:13px;padding:16px;background:var(--bg)}
.decision-cell h3{font-size:13.5px;font-weight:700;color:var(--dark);margin-bottom:6px;display:flex;align-items:center;gap:8px}
.decision-cell h3 svg.lucide{width:17px;height:17px}
.decision-cell .ico-ok{color:var(--teal)}.decision-cell .ico-ret{color:var(--orange)}
.decision-cell p{font-size:12.5px;color:var(--text-soft);line-height:1.5;margin-bottom:13px;flex:1}
.decision-cell .btn{width:100%;justify-content:center}
.decision-cell input{width:100%;padding:9px 12px;border:1px solid var(--grey-mid);border-radius:9px;font-family:inherit;font-size:13px;margin-bottom:10px}
.decision-cell input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-soft)}
@media(max-width:760px){.decision-grid{grid-template-columns:1fr}}

.dz-bar{position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:12px;background:var(--white);border:1px solid var(--grey-light);border-radius:13px;padding:12px 16px;margin-bottom:18px;box-shadow:var(--shadow)}
.dz-bar .dirty{font-size:12.5px;font-weight:600;color:var(--orange)}
.dz-bar .clean{font-size:12.5px;color:var(--text-soft)}
.dz-sec{background:var(--white);border:1px solid var(--grey-light);border-radius:14px;margin-bottom:14px;box-shadow:var(--shadow);overflow:hidden}
.dz-sec-h{display:flex;align-items:center;gap:10px;padding:13px 16px;background:var(--bg);border-bottom:1px solid var(--grey-light)}
.dz-sec-h .ti{font-weight:600;color:var(--dark)}
.dz-sec-h .actions{margin-left:auto;display:flex;gap:6px}
.dz-field{display:flex;align-items:center;gap:10px;padding:9px 16px;border-bottom:1px dashed var(--grey-light)}
.dz-field:last-child{border-bottom:none}
.dz-field .handle{cursor:grab;color:var(--grey-mid)}
.dz-field .code{font-family:'DM Mono',monospace;font-size:11px;color:var(--teal-dark);background:var(--bg);padding:2px 7px;border-radius:5px}
.dz-field .lib{flex:1;font-size:13.5px}
.dz-field .ty{font-size:10.5px;font-weight:700;text-transform:uppercase;color:var(--text-soft);background:var(--bg);border-radius:20px;padding:2px 9px}
.dz-field .actions{display:flex;gap:6px}
.icon-btn{border:1px solid var(--grey-mid);background:#fff;border-radius:8px;width:30px;height:30px;cursor:pointer;color:var(--text-soft);display:inline-flex;align-items:center;justify-content:center}
.icon-btn:hover{background:var(--bg);color:var(--dark)}
.icon-btn.danger:hover{background:#FBE7DD;color:var(--orange);border-color:#F3C6B5}
.dz-bar .dirty,.dz-bar .clean{display:inline-flex;align-items:center;gap:7px}
.dz-bar .dirty svg.lucide,.dz-bar .clean svg.lucide{width:15px;height:15px}
.dz-bar .clean svg.lucide{color:var(--ok)}
.sortable-ghost{opacity:.4}
.modal{position:fixed;inset:0;background:rgba(40,42,40,.45);display:none;align-items:center;justify-content:center;z-index:50;padding:20px}
.modal.open{display:flex}
.modal .box{background:#fff;border-radius:16px;padding:24px;width:560px;max-width:100%;max-height:90vh;overflow:auto}
.modal h3{font-family:'DM Serif Display',serif;font-weight:400;font-size:20px;margin-bottom:14px}
.modal label{display:block;font-size:12px;font-weight:600;color:var(--text-soft);margin:12px 0 5px}
.modal input,.modal select,.modal textarea{width:100%;padding:10px 12px;border:1px solid var(--grey-mid);border-radius:9px;font-family:inherit;font-size:13.5px}
.modal .two{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.modal .foot{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}

@media print{.side,.topstrip,.no-print{display:none!important}.main{max-width:none;padding:0}}
.print-dossier h2{margin-top:22px}

/* ===== icônes Lucide ===== */
.nav a svg.lucide{width:18px;height:18px;flex-shrink:0}
.btn svg.lucide{width:16px;height:16px}
.seccard .ic svg.lucide{width:21px;height:21px;color:var(--teal)}
svg.lucide{stroke-width:2;vertical-align:middle}
.eyebrow svg.lucide,.lead svg.lucide{width:15px;height:15px;vertical-align:-2px}

/* ===== select custom ===== */
.cselect{position:relative}
select.cs-native{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none;clip:rect(0 0 0 0)}
.cs-btn{display:flex;align-items:center;gap:8px;width:100%;font-family:inherit;font-size:13.5px;text-align:left;
  padding:10px 12px;border:1px solid var(--grey-mid);border-radius:10px;background:var(--white);color:var(--text);cursor:pointer;transition:.14s}
.cs-btn:hover{border-color:var(--teal)}
.cselect.open .cs-btn{border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-soft)}
.cs-btn .cs-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cs-btn .cs-arrow{width:16px;height:16px;color:var(--text-soft);transition:.18s}
.cselect.open .cs-arrow{transform:rotate(180deg)}
.cs-panel{position:absolute;z-index:1000;top:calc(100% + 6px);left:0;right:0;background:var(--white);border:1px solid var(--grey-light);
  border-radius:12px;box-shadow:0 16px 40px -12px rgba(0,83,76,.22);padding:6px;display:none;max-height:300px;overflow:auto}
.cselect.open .cs-panel{display:block;animation:fadeup .14s ease}
.cs-search{width:100%;padding:9px 11px;border:1px solid var(--grey-light);border-radius:8px;font-family:inherit;font-size:13px;margin-bottom:6px}
.cs-search:focus{outline:none;border-color:var(--teal)}
.cs-opt{padding:9px 11px;border-radius:8px;font-size:13.5px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cs-opt:hover,.cs-opt.active{background:var(--bg)}
.cs-opt.sel{background:var(--teal-soft);color:var(--teal-dark);font-weight:600}
.cs-opt.sel.active{background:var(--teal-soft)}
.cs-label.placeholder{color:var(--text-soft)}

/* ===== toasts ===== */
.toasts{position:fixed;right:20px;bottom:20px;display:flex;flex-direction:column;gap:10px;z-index:100}
.toast{display:flex;align-items:center;gap:10px;background:var(--white);border:1px solid var(--grey-light);
  border-left:4px solid var(--teal);border-radius:12px;padding:12px 16px;font-size:13.5px;font-weight:500;color:var(--text);
  box-shadow:0 14px 40px -12px rgba(73,76,74,.3);min-width:240px;max-width:380px;
  opacity:0;transform:translateY(10px);transition:.26s}
.toast.show{opacity:1;transform:none}
.toast svg.lucide{width:18px;height:18px;flex-shrink:0;color:var(--teal)}
.toast.error{border-left-color:var(--orange)}.toast.error svg.lucide{color:var(--orange)}
.toast.info{border-left-color:var(--gold)}.toast.info svg.lucide{color:var(--gold)}

/* ===== dropzone import ===== */
.dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;border:2px dashed var(--grey-mid);border-radius:14px;padding:30px 20px;text-align:center;cursor:pointer;transition:.16s;background:var(--bg)}
.dropzone:hover,.dropzone.over{border-color:var(--teal);background:var(--teal-soft)}
.dropzone svg.lucide{width:36px;height:36px;color:var(--teal);margin-bottom:10px;display:block;flex-shrink:0}
.dropzone .dz-main{font-weight:600;color:var(--dark)}
.dropzone .dz-sub{font-size:12.5px;color:var(--text-soft);margin-top:4px}
.dropzone .dz-file{margin-top:10px;font-size:12.5px;color:var(--teal-dark);font-weight:600}
.dropzone input[type=file]{display:none}

/* ===== états vides ===== */
.empty{text-align:center;padding:48px 24px;color:var(--text-soft)}
.empty svg.lucide{width:42px;height:42px;color:var(--grey-mid);margin-bottom:12px}
.empty .et{font-weight:600;color:var(--dark);font-size:15px}
.empty .ed{font-size:13px;margin-top:5px}

/* anneau animé */
.ring{transition:--p .6s ease}
.modal .box{animation:fadeup .18s ease}

/* ===== modale de confirmation ===== */
.confirm-box{width:440px;max-width:100%;text-align:center}
.confirm-ic{width:56px;height:56px;border-radius:50%;background:#FBE7DD;color:var(--orange);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.confirm-box:not(.danger) .confirm-ic{background:var(--teal-soft);color:var(--teal)}
.confirm-ic svg.lucide{width:26px;height:26px}
.confirm-box h3{text-align:center}
.confirm-msg{color:var(--text-soft);font-size:14px;line-height:1.55;margin-top:2px}
.confirm-box .foot{justify-content:center;margin-top:22px}

/* ===== selecteur d'icones (designer) ===== */
.iconpick{position:relative}
.ip-btn{display:flex;align-items:center;gap:10px;width:100%;font-family:inherit;font-size:13.5px;padding:9px 12px;border:1px solid var(--grey-mid);border-radius:9px;background:#fff;cursor:pointer;transition:.14s}
.ip-btn:hover{border-color:var(--teal)}
.iconpick.open .ip-btn{border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-soft)}
.ip-btn .ip-preview{width:20px;height:20px;color:var(--teal);flex-shrink:0}
.ip-btn .ip-name{flex:1;text-align:left;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ip-btn .ip-arrow{width:16px;height:16px;color:var(--text-soft);transition:.18s;flex-shrink:0}
.iconpick.open .ip-arrow{transform:rotate(180deg)}
.ip-panel{position:absolute;z-index:1000;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid var(--grey-light);border-radius:12px;box-shadow:0 16px 40px -12px rgba(0,83,76,.22);padding:8px;display:none}
.iconpick.open .ip-panel{display:block;animation:fadeup .14s ease}
.ip-search{width:100%;padding:8px 11px;border:1px solid var(--grey-light);border-radius:8px;font-family:inherit;font-size:13px;margin-bottom:8px}
.ip-search:focus{outline:none;border-color:var(--teal)}
.ip-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:4px;max-height:228px;overflow:auto}
.ip-opt{display:flex;align-items:center;justify-content:center;height:38px;border:1px solid transparent;border-radius:9px;background:none;cursor:pointer;color:var(--text-soft)}
.ip-opt:hover{background:var(--bg);color:var(--dark)}
.ip-opt.sel{background:var(--teal-soft);color:var(--teal-dark)}
.ip-opt svg.lucide{width:18px;height:18px}

/* ===== liens retour + lignes de grille ===== */
.backlink{display:inline-flex;align-items:center;gap:5px;color:var(--teal)}
.backlink svg.lucide{width:14px;height:14px}
.gridrow{display:flex;align-items:center;gap:8px;padding:2px 0}
.gridrow::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--teal);flex-shrink:0}
