/* ============================================================
   DentalDevis — styles scopés .dv (FRONT-A)
   Contrat visuel : maquettes/maquette-devis-reference.html (V4 validée),
   reproduite à l'identique. Tokens DS hérités de styles.css (:root) —
   styles.css n'est JAMAIS modifié, tout vit ici sous le scope .dv
   (même convention que stock.css / .s2).
   ============================================================ */

/* ── Icônes filaires iso-prod ── */
.dv .dv-icn { width: 15px; height: 15px; stroke: currentColor; stroke-width: 1.6; fill: none; stroke-linecap: round; stroke-linejoin: round; vertical-align: -2px; flex-shrink: 0; }

/* ── Header éditorial ── */
.dv .dv-header { background: var(--ivory-soft); border-bottom: 1px solid var(--rule); padding: 24px 48px 20px; position: relative; }
.dv .dv-header::after { content: ''; position: absolute; left: 48px; right: 48px; bottom: -1px; height: 1px; background: linear-gradient(90deg, var(--terracotta) 0 40px, var(--rule) 40px); }
.dv .dv-version-badge { font-size: 11px; font-weight: 600; letter-spacing: .18em; text-transform: uppercase; color: var(--terracotta); }
.dv .dv-header h1 { font-family: var(--serif); font-size: 30px; font-weight: 300; font-style: italic; letter-spacing: -.01em; margin: 5px 0 0; color: var(--ink); }
.dv .dv-header h1 .dv-amp { color: var(--terracotta); font-style: normal; }

/* ── Onglets pill (iso .s2-tab) ── */
.dv .dv-tabs { display: flex; gap: 8px; background: var(--ivory-soft); border-bottom: 1px solid var(--rule); padding: 13px 48px; flex-wrap: wrap; position: sticky; top: 0; z-index: 300; align-items: center; }
.dv .dv-tab { background: var(--paper); border: 1px solid var(--rule); border-radius: 99px; padding: 10px 20px; font-family: var(--serif); font-size: 15px; color: var(--ink-mute); display: inline-flex; align-items: center; gap: 9px; cursor: pointer; white-space: nowrap; transition: all .2s; font-style: normal; font-weight: 400; }
.dv .dv-tab:hover { background: var(--ivory-deep); color: var(--ink); border-color: var(--ink-mute); }
.dv .dv-tab.active { background: var(--terracotta); color: var(--paper); border-color: var(--terracotta); box-shadow: 0 6px 16px rgba(184, 89, 64, .25); font-style: italic; font-weight: 500; }
.dv .dv-tab-badge { display: inline-block; background: var(--terracotta); color: var(--paper); font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 99px; min-width: 21px; text-align: center; font-family: var(--sans); font-style: normal; }
.dv .dv-tab.active .dv-tab-badge { background: var(--paper); color: var(--terracotta); }
.dv .dv-tab-badge.amber { background: var(--warn); }
.dv .dv-tab.active .dv-tab-badge.amber { background: var(--paper); color: var(--warn); }
.dv .dv-tabs-actions { margin-left: auto; display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.dv .dv-tbtn { display: inline-flex; align-items: center; gap: 7px; font-family: var(--sans); font-size: 12.5px; font-weight: 600; color: var(--ink-soft); background: var(--paper); border: 1px solid var(--rule); border-radius: 99px; padding: 8px 14px; cursor: pointer; transition: all .2s; }
.dv .dv-tbtn:hover { border-color: var(--ink-mute); transform: translateY(-1px); }
.dv .dv-tbtn.active { background: var(--terracotta); color: var(--paper); border-color: var(--terracotta); box-shadow: 0 4px 10px rgba(184, 89, 64, .22); }

/* ── Contrôles ── */
.dv .dv-controls { padding: 16px 48px; background: var(--paper); border-bottom: 1px solid var(--rule-soft); display: flex; flex-direction: column; gap: 12px; }
.dv .dv-controls-row { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; }
.dv .dv-search { flex: 1; min-width: 260px; position: relative; }
.dv .dv-search input { width: 100%; padding: 11px 14px 11px 42px; border: 1px solid var(--rule); border-radius: 99px; font-size: 14px; background: var(--paper); color: var(--ink); transition: all .2s; font-family: var(--sans); }
.dv .dv-search input::placeholder { color: var(--ink-faint); font-style: italic; }
.dv .dv-search input:focus { outline: none; border-color: var(--terracotta); box-shadow: 0 0 0 3px var(--terracotta-mist); }
.dv .dv-search .dv-icn { position: absolute; left: 16px; top: 50%; transform: translateY(-50%); color: var(--ink-faint); }
/* width:auto : neutralise le select{width:100%} global de styles.css (l.263)
   qui étirait le filtre praticien pleine largeur et faisait wrapper la rangée
   — même calque que .agenda-filter-select et .stock-filters select. */
.dv .dv-controls select { width: auto; min-width: 170px; padding: 10px 14px; border: 1px solid var(--rule); border-radius: 99px; font-size: 13px; background: var(--paper); color: var(--ink-soft); cursor: pointer; font-family: var(--sans); }
.dv .dv-content { padding: 28px 48px 40px; min-height: 480px; background: var(--paper); }

/* ── Boutons ── */
.dv .dv-btn { background: var(--paper); border: 1px solid var(--rule); color: var(--ink-soft); padding: 9px 16px; border-radius: var(--radius); font-size: 13px; font-weight: 500; display: inline-flex; align-items: center; gap: 6px; font-family: var(--sans); white-space: nowrap; transition: all .2s; cursor: pointer; }
.dv .dv-btn:hover { background: var(--ivory-deep); color: var(--ink); border-color: var(--ink-mute); }
.dv .dv-btn:disabled { opacity: .55; cursor: not-allowed; }
.dv .dv-btn.success { background: var(--sage); border-color: var(--sage); color: var(--paper); }
.dv .dv-btn.success:hover { background: var(--sage-deep); border-color: var(--sage-deep); }
.dv .dv-btn.orange { background: var(--warn); border-color: var(--warn); color: var(--paper); }
.dv .dv-btn.orange:hover { background: #a87520; border-color: #a87520; }
.dv .dv-btn.danger { background: var(--paper); border-color: var(--danger); color: var(--danger); }
.dv .dv-btn.danger:hover { background: var(--danger); color: var(--paper); }
.dv .dv-btn.primary { background: var(--terracotta); border-color: var(--terracotta); color: var(--paper); }
.dv .dv-btn.primary:hover { background: var(--terracotta-deep); border-color: var(--terracotta-deep); }
.dv .dv-btn.sm { padding: 6px 12px; font-size: 12px; }
/* Ghost : action secondaire sobre (sans bordure, gris) — ex. « Supprimer » une
   ligne de quarantaine, distinct du bouton bordé « Rattacher », jamais rouge. */
.dv .dv-btn.ghost { background: transparent; border-color: transparent; color: var(--ink-mute); }
.dv .dv-btn.ghost:hover { background: var(--ivory-deep); color: var(--ink); }

/* ── Pills / badges statut ── */
.dv .dv-pill { display: inline-block; background: var(--ivory-deep); border: 1px solid var(--rule); padding: 2px 10px; border-radius: 99px; font-weight: 500; font-size: 11px; color: var(--ink-soft); }
.dv .dv-badge { display: inline-flex; align-items: center; gap: 5px; padding: 3px 10px; border-radius: 99px; font-size: 11px; font-weight: 600; letter-spacing: .04em; border: 1px solid transparent; white-space: nowrap; }
.dv .dv-badge::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.dv .st-veille    { color: var(--ink-mute);  background: var(--ivory-soft); border-color: var(--rule); }
.dv .st-aenvoyer  { color: #7a5715;          background: var(--warn-bg); border-color: var(--warn); }
.dv .st-rappeler  { color: var(--sage-deep); background: var(--sage-bg); border-color: var(--sage); }
.dv .st-envoye    { color: #7a5715;          background: var(--warn-bg); }
.dv .st-reporte   { color: var(--warn);      background: var(--warn-bg); }
.dv .st-non       { color: var(--danger);    background: var(--danger-bg); }
.dv .st-accepte   { color: var(--paper);     background: var(--sage); }
.dv .st-accepte::before { background: var(--paper); }
.dv .st-refuse    { color: var(--danger);    background: var(--danger-bg); opacity: .7; }
.dv .st-abandonne { color: var(--ink-faint); background: var(--ivory-deep); }
.dv .st-expire    { color: var(--ink-mute);  background: var(--ivory-deep); }
.dv .dv-chip { display: inline-flex; align-items: center; gap: 4px; padding: 2px 9px; border-radius: 99px; font-size: 10.5px; font-weight: 600; }
.dv .dv-chip.urgent { background: var(--danger-bg); color: var(--danger); }
.dv .dv-chip.soon { background: var(--warn-bg); color: #7a5715; }
.dv .dv-chip.info { background: var(--ivory-deep); color: var(--ink-mute); }
.dv .dv-chip.groupe { background: var(--terracotta-mist); color: var(--terracotta-deep); border: 1px solid var(--terracotta-bg); }
.dv .dv-chip.archive { background: var(--ivory-deep); color: var(--ink-mute); border: 1px dashed var(--rule); }

/* ── Cartes de file (les 2 gestes) ── */
.dv .dv-queue-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 22px; }
.dv .dv-queue-card { display: flex; align-items: center; gap: 16px; border-radius: var(--radius-lg); padding: 16px 20px; cursor: pointer; border: 1px solid; transition: all .15s; background: var(--paper); }
.dv .dv-queue-card:hover { transform: translateY(-1px); box-shadow: var(--shadow-md); }
.dv .dv-queue-card.envoyer { border-color: var(--warn); background: var(--warn-bg); }
.dv .dv-queue-card.rappeler { border-color: var(--sage); background: var(--sage-bg); }
.dv .dv-qc-n { font-family: var(--serif); font-size: 34px; font-weight: 300; line-height: 1; min-width: 44px; text-align: center; }
.dv .dv-queue-card.envoyer .dv-qc-n { color: var(--warn); }
.dv .dv-queue-card.rappeler .dv-qc-n { color: var(--sage-deep); }
.dv .dv-qc-t { font-weight: 700; font-size: 14px; color: var(--ink); display: flex; align-items: center; gap: 7px; }
.dv .dv-qc-s { font-size: 12px; color: var(--ink-soft); font-style: italic; margin-top: 2px; }
.dv .dv-qc-go { margin-left: auto; font-size: 18px; color: var(--ink-mute); }
.dv .dv-queue-card.off { opacity: .55; border-style: dashed; background: var(--paper); }
.dv .dv-queue-card.off .dv-qc-n { color: var(--ink-faint); }

/* ── Chips de filtre + groupes ── */
.dv .dv-fchips { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.dv .dv-fchip { background: var(--paper); border: 1px solid var(--rule); border-radius: 99px; padding: 6px 14px; font-size: 12.5px; font-weight: 500; color: var(--ink-mute); cursor: pointer; transition: all .15s; display: inline-flex; align-items: center; gap: 6px; font-family: var(--sans); }
.dv .dv-fchip:hover { background: var(--ivory-deep); color: var(--ink); }
.dv .dv-fchip.active { background: var(--terracotta); border-color: var(--terracotta); color: var(--paper); font-weight: 600; box-shadow: 0 3px 8px rgba(184, 89, 64, .22); }
.dv .dv-fchip .n { font-size: 10.5px; font-weight: 700; background: var(--ivory-deep); color: var(--ink-soft); padding: 0 7px; border-radius: 99px; }
.dv .dv-fchip.active .n { background: var(--paper); color: var(--terracotta); }
.dv .dv-fchip.amber .n { background: var(--warn-bg); color: #7a5715; }
.dv .dv-fchip.sage .n { background: var(--sage-bg); color: var(--sage-deep); }
.dv .dv-fchip.active.amber .n, .dv .dv-fchip.active.sage .n { background: var(--paper); color: var(--terracotta); }
.dv .dv-chips-label { font-size: 9.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .14em; color: var(--ink-faint); margin-right: 2px; }
.dv .dv-chips-divider { width: 1px; height: 22px; background: var(--rule); margin: 0 8px; flex-shrink: 0; }
.dv .dv-chips-note { font-size: 11.5px; font-style: italic; color: var(--ink-mute); width: 100%; }
.dv .dv-chips-note b { color: var(--ink-soft); font-style: normal; }

/* ── Maître-détail ── */
.dv .dv-md { display: grid; grid-template-columns: minmax(370px, 2fr) 3fr; border: 1px solid var(--rule); border-radius: var(--radius-lg); overflow: hidden; background: var(--paper); margin-top: 18px; }
.dv .dv-list { border-right: 1px solid var(--rule); max-height: 74vh; overflow-y: auto; background: var(--paper); }
.dv .dv-row { padding: 11px 14px 11px 16px; border-bottom: 1px solid var(--rule-soft); border-left: 4px solid var(--prat-color, transparent); cursor: pointer; transition: background .12s; }
.dv .dv-row:hover { background: var(--ivory-soft); }
.dv .dv-row.active { background: var(--terracotta-mist); box-shadow: inset -3px 0 0 var(--terracotta); }
.dv .dv-row.sub { padding-left: 30px; position: relative; }
.dv .dv-row.sub::before { content: '└'; position: absolute; left: 14px; top: 12px; color: var(--ink-faint); font-size: 11px; }
.dv .dv-row-top { display: flex; justify-content: space-between; gap: 10px; align-items: baseline; }
.dv .dv-row-name { font-weight: 600; font-size: 13.5px; color: var(--ink); }
.dv .dv-row-montant { font-family: var(--serif); font-size: 16px; white-space: nowrap; color: var(--ink); }
.dv .dv-row-sub { display: flex; justify-content: space-between; align-items: center; gap: 8px; margin-top: 3px; }
.dv .dv-row-meta { font-size: 11.5px; color: var(--ink-mute); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dv .dv-grouphead { padding: 7px 14px; background: var(--ivory-soft); border-bottom: 1px solid var(--rule-soft); font-size: 11px; font-weight: 600; color: var(--terracotta-deep); letter-spacing: .04em; display: flex; align-items: center; gap: 8px; }
.dv .dv-detail { padding: 24px 28px; max-height: 74vh; overflow-y: auto; background: var(--paper); }
.dv .dv-empty { text-align: center; padding: 48px 20px; color: var(--ink-mute); font-style: italic; font-weight: 300; }
.dv .dv-detail .dv-empty { padding-top: 120px; }

/* ── Fiche ── */
.dv .dv-fiche-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; flex-wrap: wrap; margin-bottom: 4px; }
.dv .dv-fiche-patient { font-family: var(--serif); font-size: 26px; font-weight: 300; font-style: italic; line-height: 1.15; color: var(--ink); }
.dv .dv-fiche-montant { font-family: var(--serif); font-size: 32px; font-weight: 300; white-space: nowrap; color: var(--ink); }
.dv .dv-fiche-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 18px; }
.dv .dv-bloc { background: var(--ivory-soft); border: 1px solid var(--rule-soft); border-radius: var(--radius); padding: 14px 16px; }
.dv .dv-bloc h4 { font-size: 10px; font-weight: 600; font-family: var(--sans); text-transform: uppercase; letter-spacing: .14em; color: var(--ink-mute); margin: 0 0 10px; font-style: normal; }
.dv .dv-line { display: flex; justify-content: space-between; gap: 12px; font-size: 13px; padding: 4px 0; }
.dv .dv-line .k { color: var(--ink-mute); }
.dv .dv-line .v { color: var(--ink); font-weight: 500; text-align: right; }
.dv .dv-reponse { border: 1px solid var(--sage); background: var(--sage-bg); border-radius: var(--radius); padding: 14px 16px; margin-top: 18px; }
.dv .dv-reponse.non { border-color: var(--danger); background: var(--danger-bg); }
.dv .dv-reponse.reporte { border-color: var(--warn); background: var(--warn-bg); }
.dv .dv-reponse h4 { font-size: 10px; font-family: var(--sans); font-weight: 600; text-transform: uppercase; letter-spacing: .14em; margin: 0 0 6px; color: var(--ink-soft); font-style: normal; }
.dv .dv-reponse p { font-size: 13.5px; color: var(--ink); margin: 0; }
.dv .dv-actions { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 18px; padding-top: 16px; border-top: 1px solid var(--rule-soft); align-items: center; }
.dv .dv-groupe { margin-top: 18px; border: 1px solid var(--terracotta-bg); background: var(--terracotta-mist); border-radius: var(--radius); padding: 14px 16px; }
.dv .dv-groupe h4 { font-size: 10px; font-family: var(--sans); font-weight: 600; text-transform: uppercase; letter-spacing: .14em; color: var(--terracotta-deep); margin: 0 0 8px; font-style: normal; }
.dv .dv-fg-row { display: flex; justify-content: space-between; align-items: center; gap: 10px; padding: 7px 2px; border-bottom: 1px dashed var(--terracotta-bg); font-size: 13px; cursor: pointer; border-radius: 4px; }
.dv .dv-fg-row:hover { background: rgba(255, 252, 245, .6); }
.dv .dv-fg-row:last-child { border-bottom: none; }
.dv .dv-fg-row.current { font-weight: 700; }
.dv .dv-fg-row b { font-family: var(--serif); font-weight: 400; white-space: nowrap; }
.dv .dv-note { font-size: 11.5px; font-style: italic; color: var(--ink-mute); margin-top: 8px; }

/* ── Timeline registre ── */
.dv .dv-tl { margin-top: 10px; }
.dv .dv-tl-item { display: flex; gap: 12px; padding: 5px 0; font-size: 12.5px; align-items: flex-start; }
.dv .dv-tl-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--rule); margin-top: 5px; flex-shrink: 0; box-shadow: 0 0 0 2px var(--ivory-soft); }
.dv .dv-tl-item.ok .dv-tl-dot { background: var(--sage); }
.dv .dv-tl-item.ko .dv-tl-dot { background: var(--danger); }
.dv .dv-tl-item.accent .dv-tl-dot { background: var(--terracotta); }
.dv .dv-tl-date { color: var(--ink-mute); min-width: 76px; font-variant-numeric: tabular-nums; }
.dv .dv-tl-text { color: var(--ink-soft); flex: 1; }

/* ── Bandeaux + tables des files ── */
.dv .dv-banner { display: flex; align-items: center; gap: 12px; border-radius: var(--radius); padding: 12px 18px; font-size: 13px; color: var(--ink-soft); margin-bottom: 18px; border: 1px solid; }
.dv .dv-banner.warn { background: var(--warn-bg); border-color: var(--warn); }
.dv .dv-banner.sage { background: var(--sage-bg); border-color: var(--sage); }
.dv .dv-banner b { color: var(--ink); }
.dv .dv-banner .dv-icn { width: 18px; height: 18px; flex-shrink: 0; }
.dv .dv-banner.warn .dv-icn { color: var(--warn); }
.dv .dv-banner.sage .dv-icn { color: var(--sage-deep); }
.dv .dv-twrap { overflow-x: auto; border: 1px solid var(--rule); border-radius: var(--radius); background: var(--paper); }
.dv .dv-twrap table { width: 100%; border-collapse: collapse; font-size: 13.5px; }
.dv .dv-twrap th { text-align: left; padding: 12px 10px; font-size: 10px; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-mute); background: var(--paper); white-space: nowrap; border-bottom: 1px solid var(--rule); font-family: var(--sans); }
.dv .dv-twrap td { padding: 11px 10px; color: var(--ink-soft); vertical-align: middle; border-bottom: 1px solid var(--rule-soft); }
.dv .dv-twrap tbody tr:last-child td { border-bottom: none; }
.dv .dv-twrap tbody tr:hover { background: var(--ivory-soft); }
.dv .dv-twrap tbody tr.prat { background-image: linear-gradient(90deg, color-mix(in srgb, var(--prat-color, transparent) 12%, transparent) 0%, transparent 70%); }
.dv .dv-twrap tbody tr.prat td:first-child { position: relative; padding-left: 18px; }
.dv .dv-twrap tbody tr.prat td:first-child::before { content: ''; position: absolute; left: 0; top: 3px; bottom: 3px; width: 5px; border-radius: 3px; background: var(--prat-color, var(--ink-mute)); }
.dv input[type="checkbox"] { width: 16px; height: 16px; accent-color: var(--terracotta); cursor: pointer; }
.dv .dv-batch-bar { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; background: var(--ivory-soft); border: 1px solid var(--rule); border-radius: var(--radius); padding: 12px 18px; margin-top: 16px; }
.dv .dv-batch-bar .bb { font-size: 13px; color: var(--ink-soft); }
.dv .dv-section-title { font-family: var(--serif); font-size: 22px; font-weight: 300; font-style: italic; color: var(--ink); margin: 36px 0 20px; padding-bottom: 14px; border-bottom: 1px solid var(--rule); display: flex; align-items: baseline; gap: 14px; position: relative; }
.dv .dv-section-title::before { content: ''; position: absolute; bottom: -1px; left: 0; width: 40px; height: 2px; background: var(--terracotta); }
.dv .dv-section-title:first-child { margin-top: 0; }

/* ── Modales (scopées .dv-modal pour ne pas dépendre des modales d'app.js) ── */
.dv-modal { display: none; position: fixed; inset: 0; background: rgba(42, 31, 24, .55); z-index: 1000; overflow-y: auto; backdrop-filter: blur(3px); }
.dv-modal.show { display: block; animation: dvFadeIn .18s ease; }
@keyframes dvFadeIn { from { opacity: 0; } to { opacity: 1; } }
.dv-modal .dv-modal-content { background: var(--paper); max-width: 560px; margin: 60px auto; border: 1px solid var(--rule); border-radius: var(--radius-lg); max-height: 88vh; overflow-y: auto; box-shadow: var(--shadow-lg); animation: dvSlideIn .22s ease; font-family: var(--sans); }
@keyframes dvSlideIn { from { transform: translateY(-14px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
.dv-modal .dv-modal-head { display: flex; justify-content: space-between; align-items: flex-start; padding: 22px 30px 16px; border-bottom: 1px solid var(--rule-soft); background: var(--ivory-soft); border-radius: var(--radius-lg) var(--radius-lg) 0 0; }
.dv-modal .dv-modal-head h2 { font-family: var(--serif); font-size: 22px; font-weight: 300; font-style: italic; color: var(--ink); margin: 0; }
.dv-modal .dv-close { background: none; border: none; font-size: 24px; cursor: pointer; color: var(--ink-mute); line-height: 1; width: 30px; height: 30px; border-radius: 50%; }
.dv-modal .dv-close:hover { background: var(--ivory-deep); color: var(--ink); }
.dv-modal .dv-modal-body { padding: 22px 30px; }
.dv-modal .dv-modal-actions { display: flex; gap: 10px; justify-content: flex-end; padding: 16px 30px 22px; border-top: 1px solid var(--rule-soft); background: var(--ivory-soft); border-radius: 0 0 var(--radius-lg) var(--radius-lg); }
.dv-modal .dv-field { margin-bottom: 16px; }
.dv-modal .dv-field label { display: block; margin-bottom: 7px; font-weight: 600; color: var(--ink-mute); font-size: 10px; text-transform: uppercase; letter-spacing: .14em; }
.dv-modal .dv-field label .req { color: var(--terracotta); font-size: 12px; }
.dv-modal .dv-field input, .dv-modal .dv-field select { width: 100%; padding: 10px 12px; border: 1px solid var(--rule); border-radius: var(--radius); font-size: 14px; font-family: var(--sans); background: var(--paper); color: var(--ink); box-sizing: border-box; }
.dv-modal .dv-field input:focus, .dv-modal .dv-field select:focus { outline: none; border-color: var(--terracotta); box-shadow: 0 0 0 3px var(--terracotta-mist); }
.dv-modal .dv-field input.invalid { border-color: var(--danger); background: var(--danger-bg); }
.dv-modal .dv-hint { font-size: 11px; font-style: italic; color: var(--ink-mute); margin-top: 5px; }
.dv-modal .dv-frow { display: flex; gap: 16px; }
.dv-modal .dv-frow .dv-field { flex: 1; }
.dv-modal .dv-warnbox { background: var(--warn-bg); border: 1px solid var(--warn); border-radius: var(--radius); padding: 11px 15px; font-size: 12.5px; color: var(--ink-soft); }
/* autocomplete patient */
.dv-modal .dv-ac { position: relative; }
.dv-modal .dv-ac-list { position: absolute; left: 0; right: 0; top: calc(100% + 4px); background: var(--paper); border: 1px solid var(--rule); border-radius: var(--radius); box-shadow: var(--shadow-md); z-index: 50; max-height: 220px; overflow-y: auto; }
.dv-modal .dv-ac-item { padding: 10px 14px; cursor: pointer; border-bottom: 1px solid var(--rule-soft); font-size: 13.5px; display: flex; justify-content: space-between; gap: 10px; }
.dv-modal .dv-ac-item:last-child { border-bottom: none; }
.dv-modal .dv-ac-item:hover, .dv-modal .dv-ac-item.sel { background: var(--ivory-soft); }
.dv-modal .dv-ac-item .mail { color: var(--ink-mute); font-size: 12px; font-style: italic; }

/* ── Toasts (avec undo) ── */
.dv-toasts { position: fixed; bottom: 24px; right: 24px; z-index: 10001; display: flex; flex-direction: column-reverse; gap: 10px; max-width: 380px; pointer-events: none; }
.dv-toast { pointer-events: auto; background: var(--paper); padding: 13px 18px; border-radius: var(--radius-lg); border: 1px solid var(--rule); border-left: 3px solid var(--sage); box-shadow: var(--shadow-lg); font-size: 13.5px; display: flex; align-items: center; gap: 10px; min-width: 280px; opacity: 0; transform: translateX(400px); transition: opacity .3s, transform .3s; font-family: var(--sans); color: var(--ink); }
.dv-toast.show { opacity: 1; transform: translateX(0); }
.dv-toast.warn { border-left-color: var(--warn); }
.dv-toast.err { border-left-color: var(--danger); }
.dv-toast .dv-undo { background: none; border: none; color: var(--terracotta); font-weight: 700; font-size: 13px; font-family: var(--sans); text-decoration: underline; text-underline-offset: 3px; cursor: pointer; white-space: nowrap; }
.dv-toast .dv-undo:hover { color: var(--terracotta-deep); }

/* ── Import CSV (FRONT-B) ── */
.dv .dv-import-grid { display: grid; grid-template-columns: 340px 1fr; gap: 28px; align-items: start; }
.dv .dv-logiciels { display: flex; gap: 10px; flex-wrap: wrap; }
.dv .dv-logiciel { display: flex; align-items: center; gap: 10px; border: 1px solid var(--rule); border-radius: var(--radius); background: var(--paper); padding: 11px 16px; cursor: pointer; transition: all .15s; min-width: 140px; font-family: var(--sans); }
.dv .dv-logiciel:hover { border-color: var(--ink-mute); }
.dv .dv-logiciel.selected { border-color: var(--terracotta); background: var(--terracotta-mist); box-shadow: 0 0 0 3px var(--terracotta-mist); }
.dv .dv-logiciel.disabled { opacity: .55; cursor: not-allowed; border-style: dashed; background: var(--ivory-soft); }
.dv .dv-logiciel .lr { width: 16px; height: 16px; border: 2px solid var(--rule); border-radius: 50%; flex-shrink: 0; position: relative; background: var(--paper); }
.dv .dv-logiciel.selected .lr { border-color: var(--terracotta); }
.dv .dv-logiciel.selected .lr::after { content: ''; position: absolute; inset: 2.5px; border-radius: 50%; background: var(--terracotta); }
.dv .dv-logiciel .ln { font-weight: 700; font-size: 13.5px; color: var(--ink); }
.dv .dv-logiciel .ls { font-size: 10.5px; font-style: italic; color: var(--ink-mute); }
.dv .dv-step { margin-bottom: 18px; }
.dv .dv-step > label { display: block; margin-bottom: 8px; font-weight: 600; color: var(--ink-mute); font-size: 10px; text-transform: uppercase; letter-spacing: .14em; }
.dv .dv-step select { width: 100%; padding: 10px 12px; border: 1px solid var(--rule); border-radius: var(--radius); font-size: 14px; background: var(--paper); color: var(--ink); font-family: var(--sans); }
.dv .dv-dropzone { border: 2px dashed var(--rule); border-radius: var(--radius-lg); background: var(--ivory-soft); padding: 36px 24px; text-align: center; cursor: pointer; transition: all .2s; color: var(--ink-mute); }
.dv .dv-dropzone:hover, .dv .dv-dropzone.over { border-color: var(--terracotta); background: var(--terracotta-mist); color: var(--ink); }
.dv .dv-dropzone.ready { border-color: var(--sage); background: var(--sage-bg); cursor: default; }
.dv .dv-dropzone .dz-icn { display: block; margin: 0 auto 10px; width: 34px; height: 34px; stroke-width: 1.3; }
.dv .dv-dropzone .dz-main { font-family: var(--serif); font-style: italic; font-size: 16px; color: var(--ink); }
.dv .dv-dropzone .dz-sub { font-size: 11.5px; font-style: italic; margin-top: 6px; }
.dv .dv-filechip { display: inline-flex; align-items: center; gap: 8px; background: var(--paper); border: 1px solid var(--sage); color: var(--sage-deep); border-radius: 99px; padding: 7px 16px; font-size: 13px; font-weight: 600; margin-top: 14px; max-width: 100%; overflow: hidden; text-overflow: ellipsis; }
.dv .dv-is-chips { display: flex; gap: 10px; flex-wrap: wrap; margin: 4px 0 18px; }
.dv .dv-is { display: inline-flex; align-items: center; gap: 8px; border-radius: 99px; padding: 7px 16px; font-size: 13px; font-weight: 600; border: 1px solid transparent; font-family: var(--sans); }
.dv .dv-is .big { font-family: var(--serif); font-size: 19px; font-weight: 400; }
.dv .dv-is.ok   { background: var(--sage-bg); color: var(--sage-deep); border-color: var(--sage); }
.dv .dv-is.mute { background: var(--ivory-deep); color: var(--ink-mute); }
.dv .dv-is.warn { background: var(--warn-bg); color: #7a5715; border-color: var(--warn); }
.dv .dv-is.dang { background: var(--danger-bg); color: var(--danger); border-color: var(--danger); }
.dv .dv-raison { display: inline-flex; align-items: center; padding: 2px 10px; border-radius: 99px; font-size: 10.5px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; }
.dv .dv-raison.introuvable { background: var(--danger-bg); color: var(--danger); }
.dv .dv-raison.ambigu { background: var(--warn-bg); color: #7a5715; }
.dv .dv-banner.terra { background: var(--terracotta-mist); border-color: var(--terracotta-bg); }
.dv .dv-banner.terra .dv-icn { color: var(--terracotta); }
.dv-modal .dv-candidat { font-size: 11px; background: var(--terracotta-mist); color: var(--terracotta-deep); border: 1px solid var(--terracotta-bg); border-radius: 99px; padding: 1px 8px; font-weight: 700; white-space: nowrap; }

/* ── Archives + registre (FRONT-C) ── */
.dv .dv-verbe { display: inline-flex; align-items: center; padding: 2px 10px; border-radius: 99px; font-size: 10.5px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; white-space: nowrap; }
.dv .rv-add      { background: var(--terracotta-bg); color: var(--terracotta-deep); }
.dv .rv-send     { background: var(--warn-bg); color: #7a5715; }
.dv .rv-validate { background: var(--terracotta-mist); color: var(--terracotta-deep); border: 1px solid var(--terracotta-bg); }
.dv .rv-accept   { background: var(--sage-bg); color: var(--sage-deep); }
.dv .rv-refuse   { background: var(--danger-bg); color: var(--danger); }
.dv .rv-expire   { background: var(--danger-bg); color: var(--danger); opacity: .75; }
.dv .rv-archive  { background: var(--ivory-soft); color: var(--ink-mute); border: 1px dashed var(--rule); }
.dv .rv-restore  { background: var(--ivory-soft); color: var(--ink-mute); border: 1px dashed var(--rule); }
.dv .rv-edit     { background: var(--ivory-deep); color: var(--ink-soft); }
.dv .dv-reg-search { padding: 7px 14px; border: 1px solid var(--rule); border-radius: 99px; font-size: 12.5px; background: var(--paper); width: 200px; font-family: var(--sans); }
.dv .dv-reg-search:focus { outline: none; border-color: var(--terracotta); box-shadow: 0 0 0 3px var(--terracotta-mist); }
.dv .dv-reg-verbe { padding: 7px 12px; border: 1px solid var(--rule); border-radius: 99px; font-size: 12.5px; background: var(--paper); font-family: var(--sans); cursor: pointer; }

/* ── Pilotage (FRONT-D) — KPI cards iso-DS ── */
.dv .dv-kpi-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1px; margin-bottom: 32px; border: 1px solid var(--rule); border-radius: var(--radius-lg); overflow: hidden; background-color: var(--rule-soft); }
.dv .dv-kpi { padding: 22px 24px; background: var(--ivory-soft); color: var(--ink); position: relative; display: flex; flex-direction: column; gap: 8px; }
.dv .dv-kpi::before { content: ''; position: absolute; top: 22px; left: 0; width: 3px; height: 28px; background: var(--ink-mute); opacity: .4; }
.dv .dv-kpi.purple  { background: var(--terracotta-mist); } .dv .dv-kpi.purple::before  { background: var(--terracotta); opacity: 1; }
.dv .dv-kpi.warning { background: var(--warn-bg); }         .dv .dv-kpi.warning::before { background: var(--warn); opacity: 1; }
.dv .dv-kpi.success { background: var(--sage-bg); }         .dv .dv-kpi.success::before { background: var(--sage); opacity: 1; }
.dv .dv-kpi-label { font-size: 10px; font-weight: 600; color: var(--ink-mute); text-transform: uppercase; letter-spacing: .14em; }
.dv .dv-kpi-value { font-family: var(--serif); font-size: 38px; font-weight: 300; color: var(--ink); letter-spacing: -.01em; line-height: 1; }
.dv .dv-kpi.purple .dv-kpi-value { color: var(--terracotta-deep); }
.dv .dv-kpi.warning .dv-kpi-value { color: var(--warn); }
.dv .dv-kpi.success .dv-kpi-value { color: var(--sage-deep); }
.dv .dv-kpi-sub { font-size: 11px; color: var(--ink-mute); font-style: italic; }
.dv .dv-kpi-sub b { color: var(--ink-soft); font-style: normal; }

/* ── Réglages + éditeur de mail (FRONT-E) ── */
.dv .dv-regl-grid { display: grid; grid-template-columns: 1fr 1.3fr; gap: 28px; align-items: start; }
.dv .dv-regl-card { background: var(--ivory-soft); border: 1px solid var(--rule-soft); border-radius: var(--radius-lg); padding: 22px 24px; margin-bottom: 22px; }
.dv .dv-regl-card h3 { font-family: var(--serif); font-size: 17px; font-weight: 300; font-style: italic; margin: 0 0 16px; color: var(--ink); display: flex; align-items: center; gap: 10px; }
.dv .dv-regl-row { display: flex; gap: 18px; }
.dv .dv-regl-row .dv-regl-field { flex: 1; }
.dv .dv-regl-field { margin-bottom: 16px; }
.dv .dv-regl-field label { display: block; margin-bottom: 7px; font-weight: 600; color: var(--ink-mute); font-size: 10px; text-transform: uppercase; letter-spacing: .14em; }
.dv .dv-regl-field input { width: 100%; padding: 10px 12px; border: 1px solid var(--rule); border-radius: var(--radius); font-size: 14px; font-family: var(--sans); background: var(--paper); color: var(--ink); box-sizing: border-box; }
.dv .dv-regl-field input:focus { outline: none; border-color: var(--terracotta); box-shadow: 0 0 0 3px var(--terracotta-mist); }
.dv .dv-regl-field input:disabled { background: var(--ivory-deep); color: var(--ink-mute); cursor: not-allowed; }
.dv .dv-regl-field input.invalid { border-color: var(--danger); background: var(--danger-bg); }
.dv .dv-regl-field .hint { font-size: 11px; font-style: italic; color: var(--ink-mute); margin-top: 5px; }
.dv .dv-zone-edit { border: 1.5px dashed var(--terracotta-light); border-radius: var(--radius); padding: 12px 14px; background: var(--paper); margin-bottom: 14px; }
.dv .dv-zone-edit > label { display: block; font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: .14em; color: var(--terracotta-deep); margin-bottom: 6px; }
.dv .dv-zone-edit input, .dv .dv-zone-edit textarea { width: 100%; border: 1px solid var(--rule); border-radius: var(--radius-sm); padding: 8px 10px; font-size: 13px; font-family: var(--sans); background: var(--paper); color: var(--ink); resize: vertical; box-sizing: border-box; }
.dv .dv-zone-edit input:focus, .dv .dv-zone-edit textarea:focus { outline: none; border-color: var(--terracotta); box-shadow: 0 0 0 3px var(--terracotta-mist); }
.dv .dv-zone-edit input:disabled, .dv .dv-zone-edit textarea:disabled { background: var(--ivory-deep); color: var(--ink-mute); cursor: not-allowed; }
.dv .dv-zone-lock { border: 1px solid var(--rule); border-radius: var(--radius); padding: 12px 14px; background: var(--ivory-soft); margin-bottom: 14px; }
.dv .dv-zone-lock > label { display: flex; align-items: center; gap: 6px; font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: .14em; color: var(--ink-mute); margin-bottom: 6px; }
.dv .dv-zone-lock p { font-size: 12.5px; color: var(--ink-mute); font-style: italic; margin: 0; }
.dv .dv-logo-box { display: flex; align-items: center; gap: 14px; }
.dv .dv-logo-apercu { width: 54px; height: 54px; border-radius: 50%; object-fit: cover; flex-shrink: 0; box-shadow: var(--shadow-sm); background: var(--paper); }
.dv .dv-logo-vide { width: 54px; height: 54px; border-radius: 50%; background: var(--ivory-deep); color: var(--ink-faint); border: 1.5px dashed var(--rule); font-size: 10px; display: flex; align-items: center; justify-content: center; text-align: center; flex-shrink: 0; }
/* aperçu live du mail rendu */
.dv .dv-mail-render { border: 1px solid var(--rule); border-radius: var(--radius-lg); overflow: hidden; background: #fff; box-shadow: var(--shadow-md); position: sticky; top: 80px; }
.dv .dv-mr-bar { background: var(--ivory-soft); border-bottom: 1px solid var(--rule-soft); padding: 10px 18px; font-size: 11px; color: var(--ink-mute); font-style: italic; }
.dv .dv-mr-head { padding: 22px 26px 16px; text-align: center; border-bottom: 1px solid var(--rule-soft); }
.dv .dv-mr-cabinet { font-family: var(--serif); font-size: 18px; font-style: italic; color: var(--ink); margin-top: 8px; }
.dv .dv-mr-body { padding: 20px 26px; font-size: 13.5px; color: var(--ink-soft); line-height: 1.65; }
.dv .dv-mr-body p { margin: 0 0 10px; white-space: pre-line; }
.dv .dv-mr-core { border: 1px solid var(--rule-soft); background: var(--ivory); border-radius: var(--radius); padding: 16px 18px; text-align: center; margin: 14px 0; }
.dv .dv-mr-btn { display: inline-block; background: var(--terracotta); color: var(--paper); padding: 10px 24px; border-radius: 99px; font-size: 13px; font-weight: 700; }
.dv .dv-mr-mention { font-size: 11px; font-style: italic; color: var(--ink-mute); margin: 10px 0 0; }
.dv .dv-mr-sign { font-size: 13px; color: var(--ink); margin-top: 14px; white-space: pre-line; }
.dv .dv-mr-logo { width: 46px; height: 46px; border-radius: 50%; object-fit: cover; }

/* ── Placeholders lots suivants ── */
.dv .dv-soon { text-align: center; padding: 70px 20px; color: var(--ink-mute); font-style: italic; }
.dv .dv-soon b { font-family: var(--serif); font-size: 19px; font-weight: 300; display: block; margin-bottom: 8px; color: var(--ink); }

@media (max-width: 1024px) {
  .dv .dv-header, .dv .dv-tabs, .dv .dv-controls, .dv .dv-content { padding-left: 24px; padding-right: 24px; }
  .dv .dv-md { grid-template-columns: 1fr; }
  .dv .dv-list { border-right: none; border-bottom: 1px solid var(--rule); max-height: 40vh; }
  .dv .dv-fiche-grid, .dv .dv-queue-cards { grid-template-columns: 1fr; }
}
