/* ════════════════════════════════════════════════════════════════════
   PrimoPlan — Agents conversationnels (branche-agents look)
   Système chaud parchemin + corail, PT Serif + Roboto. Re-skin de la
   surface conversations + hub dossier 3 colonnes. Class names conservés
   pour les vues chat/cartes existantes.
   ════════════════════════════════════════════════════════════════════ */
:root {
  --agent-bg:           #F6F1EA;
  --agent-bg-deep:      #EFE8DD;
  --agent-surface:      #FFFFFF;
  --agent-surface-alt:  #FBF8F3;
  --agent-ink:          #1A1A1A;
  --agent-ink-soft:     #6E6A66;
  --agent-ink-faint:    #9A938B;
  --agent-coral:        #C4543F;
  --agent-coral-dark:   #8E3A29;
  --agent-coral-light:  #F8E0D9;
  --agent-coral-wash:   #FBEEE9;
  --agent-line:         #E4DCD0;
  --agent-line-strong:  #CAC4D0;
  --agent-success:      #3E7B47;
  --agent-success-light:#E3EFE2;
  --agent-info:         #1F4E5F;
  --agent-info-light:   #E0EBEC;
  --agent-ui:      'Roboto', 'Google Sans Text', system-ui, sans-serif;
  --agent-display: 'PT Serif', 'Times New Roman', Georgia, serif;
  --agent-mono:    'Roboto Mono', ui-monospace, Menlo, monospace;
  --agent-shadow-sm: 0 1px 2px rgba(40,30,20,.05), 0 4px 14px rgba(40,30,20,.04);
  --agent-shadow-md: 0 1px 2px rgba(40,30,20,.05), 0 10px 30px rgba(40,30,20,.07);
  --agent-shadow-lg: 0 20px 60px rgba(40,30,20,.16);
}

/* Scoped to the agents surface (this stylesheet only loads on the agents layout):
   make width include padding + border so full-width inputs don't overflow. */
.agents-shell *, .agents-shell *::before, .agents-shell *::after,
.modal-overlay *, .modal-overlay *::before, .modal-overlay *::after { box-sizing: border-box; }

@keyframes pp-bounce { 0%, 80%, 100% { transform: translateY(0); opacity: .5; } 40% { transform: translateY(-5px); opacity: 1; } }

/* ── 3-column shell ──────────────────────────────────────────────────── */
.agents-shell {
  display: flex; height: 100vh; height: 100dvh; width: 100%;
  overflow: hidden; background: var(--agent-bg);
  font-family: var(--agent-ui); color: var(--agent-ink);
}
.agents-center { flex: 1; min-width: 0; display: flex; flex-direction: column; height: 100%; }

/* ── Left rail ───────────────────────────────────────────────────────── */
.agents-rail {
  width: 274px; flex-shrink: 0; background: var(--agent-bg-deep);
  border-right: 1px solid var(--agent-line); display: flex; flex-direction: column; height: 100%;
}
.agents-rail__brand { display: flex; align-items: center; gap: 10px; padding: 20px 18px 14px; }
.agents-rail__mark { width: 30px; height: 30px; border-radius: 8px; background: var(--agent-coral);
  display: flex; align-items: center; justify-content: center; color: #fff; }
.agents-rail__name { font-family: var(--agent-display); font-size: 19px; }
.agents-rail__pro { font-size: 9.5px; font-weight: 700; letter-spacing: .6px; color: var(--agent-coral-dark);
  background: var(--agent-coral-wash); padding: 2px 6px; border-radius: 100px; margin-left: auto; }
.agents-rail__search { margin: 4px 14px 12px; display: flex; align-items: center; gap: 8px;
  background: var(--agent-surface); border: 1px solid var(--agent-line); border-radius: 10px; padding: 8px 12px;
  color: var(--agent-ink-faint); font-size: 13px; }
.agents-rail__search:focus-within { border-color: var(--agent-coral); }
.agents-rail__search-input { flex: 1; min-width: 0; border: none; background: transparent; outline: none;
  font-family: var(--agent-ui); font-size: 13px; color: var(--agent-ink); padding: 0; }
.agents-rail__search-input::placeholder { color: var(--agent-ink-faint); }
.agents-rail__label { padding: 4px 18px 6px; font-size: 10.5px; color: var(--agent-ink-soft);
  letter-spacing: .7px; text-transform: uppercase; font-weight: 600; }
.agents-rail__list { flex: 1; overflow-y: auto; padding: 0 10px; }
.agents-rail__foot { padding: 12px; border-top: 1px solid var(--agent-line); }
.rail-patient { display: flex; align-items: center; gap: 11px; padding: 10px; border-radius: 12px;
  margin-bottom: 2px; text-decoration: none; color: inherit; }
.rail-patient:hover { background: rgba(255,255,255,.5); }
.rail-patient--active { background: var(--agent-surface); box-shadow: var(--agent-shadow-sm); }
.rail-patient--disabled { opacity: .5; pointer-events: none; }
.rail-patient__name { font-size: 13.5px; font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.rail-patient__plan { display: flex; align-items: center; gap: 6px; font-size: 11.5px; color: var(--agent-ink-soft); }
.rail-patient__plan-name { min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
/* Existing state-change notification (unseen document event) — rail, list & hub */
.notif-dot { flex-shrink: 0; display: inline-flex; align-items: center; }
.rail-count { flex-shrink: 0; min-width: 16px; height: 16px; padding: 0 4px; border-radius: 100px;
  background: #B3261E; color: #fff; font-size: 10px; font-weight: 700; line-height: 1;
  display: inline-flex; align-items: center; justify-content: center; }
.rail-status { flex-shrink: 0; font-size: 9.5px; font-weight: 700; letter-spacing: .2px; padding: 1px 6px; border-radius: 100px; white-space: nowrap; }
.rail-status--coral   { background: var(--agent-coral-light);   color: var(--agent-coral-dark); }
.rail-status--success { background: var(--agent-success-light); color: var(--agent-success); }
.rail-status--info    { background: var(--agent-info-light);    color: var(--agent-info); }
.rail-status--done    { background: var(--agent-bg-deep);       color: var(--agent-ink-soft); }
.rail-status--muted   { background: var(--agent-bg-deep);       color: var(--agent-ink-faint); }
.rail-account { display: flex; align-items: center; gap: 10px; padding: 10px 6px; margin-top: 4px;
  border-radius: 10px; text-decoration: none; color: inherit; }
.rail-account:hover { background: rgba(255,255,255,.5); }

/* ── Monogram + agent avatar ─────────────────────────────────────────── */
.monogram { border-radius: 50%; background: var(--agent-ink); color: #fff;
  display: inline-flex; align-items: center; justify-content: center; font-weight: 600; flex-shrink: 0; }
.monogram--coral { background: var(--agent-coral); }
.agent-avatar { position: relative; border-radius: 32%; background: var(--agent-coral); color: #fff; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center; }
.agent-avatar::after { content: ""; position: absolute; right: -2px; bottom: -2px;
  width: 34%; height: 34%; min-width: 11px; min-height: 11px; border-radius: 50%;
  background: #fff; border: 1.5px solid var(--agent-bg);
  background-image: radial-gradient(var(--agent-coral) 30%, transparent 32%); background-size: 60% 60%;
  background-repeat: no-repeat; background-position: center; }

/* ── Hub (center) ────────────────────────────────────────────────────── */
.hub-header { display: flex; align-items: center; gap: 14px; padding: 20px 28px;
  border-bottom: 1px solid var(--agent-line); background: var(--agent-surface); flex-shrink: 0; }
.hub-header__name { font-family: var(--agent-display); font-size: 24px; white-space: nowrap; }
.hub-header__meta { font-size: 13px; color: var(--agent-ink-soft); margin-top: 2px; }
.hub-header__ref { display: flex; align-items: center; gap: 7px; margin-top: 7px; font-size: 12.5px; color: var(--agent-ink-soft); }
.hub-body { flex: 1; overflow-y: auto; padding: 24px 28px 40px; }
.hub-label { font-size: 11px; color: var(--agent-ink-soft); letter-spacing: .8px; text-transform: uppercase;
  font-weight: 600; margin: 0 0 12px 2px; }
.hub-sublabel { font-size: 11.5px; color: var(--agent-ink-soft); margin: -8px 0 12px 2px; }
.hub-cols { display: grid; grid-template-columns: 1.3fr 1fr; gap: 14px; align-items: start; }

/* ── Agent grid ──────────────────────────────────────────────────────── */
.agent-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; margin-bottom: 30px; }
.agent-grid__card { display: flex; flex-direction: column; gap: 12px; padding: 18px; text-align: left;
  background: var(--agent-surface); border: 1px solid var(--agent-line); border-radius: 18px;
  text-decoration: none; color: inherit; cursor: pointer; transition: box-shadow .15s, transform .15s; }
.agent-grid__card:hover { box-shadow: var(--agent-shadow-md); transform: translateY(-2px); }
.agent-grid__top { display: flex; align-items: center; gap: 12px; }
.agent-grid__name { font-size: 16px; font-weight: 600; }
.agent-grid__tag { font-size: 9.5px; font-weight: 700; letter-spacing: .5px; color: var(--agent-coral-dark);
  background: var(--agent-coral-wash); padding: 1px 6px; border-radius: 100px; }
.agent-grid__role { font-size: 12.5px; color: var(--agent-ink-soft); margin-top: 1px; }
.agent-grid__teaser { font-size: 13.5px; line-height: 1.5; min-height: 40px; }

/* ── Stat + plan card ────────────────────────────────────────────────── */
.panel-card { background: var(--agent-surface); border: 1px solid var(--agent-line); border-radius: 18px; padding: 20px; }

/* Hub "Actions à mener" rows (continue a conversation / launch a proposed action) */
.hub-action { display: flex; align-items: center; gap: 12px; width: 100%; padding: 14px 16px;
  text-decoration: none; color: inherit; cursor: pointer; font-family: var(--agent-ui); text-align: left; }
a.hub-action:hover, button.hub-action:hover { background: var(--agent-surface-alt); }
.hub-action__title { display: block; font-size: 14px; font-weight: 600; color: var(--agent-ink); }
.hub-action__sub { display: block; font-size: 12px; color: var(--agent-ink-soft); margin-top: 2px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.hub-action__tag { font-size: 9px; font-weight: 700; letter-spacing: .5px; padding: 1px 6px; border-radius: 100px;
  margin-left: 6px; vertical-align: middle; background: var(--agent-coral-light); color: var(--agent-coral-dark); }
.hub-action__tag--cours { background: var(--agent-success-light); color: var(--agent-success); }
.hub-action__tag--suggest { display: inline-flex; align-items: center; gap: 3px;
  background: var(--agent-coral-wash); color: var(--agent-coral-dark); }
.stat__label { font-size: 10.5px; color: var(--agent-ink-soft); text-transform: uppercase; letter-spacing: .4px; }
.stat__value { font-family: var(--agent-display); font-size: 22px; margin-top: 2px; }
.stat__value--accent { color: var(--agent-coral-dark); }

/* ── Activity feed ───────────────────────────────────────────────────── */
.activity { background: var(--agent-surface); border: 1px solid var(--agent-line); border-radius: 18px; padding: 4px 16px; }
.activity__row { display: flex; align-items: center; gap: 11px; padding: 11px 0; border-bottom: 1px solid var(--agent-line); }
.activity__row:last-child { border-bottom: none; }
.activity__tile { width: 32px; height: 32px; border-radius: 9px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; }
.activity__text { font-size: 13px; line-height: 1.4; }
.activity__when { font-size: 11px; color: var(--agent-ink-faint); margin-top: 1px; }

/* ── Conversation pane (re-skin of existing .agent-chat) ─────────────── */
.agent-chat { display: flex; flex-direction: column; height: 100%; background: var(--agent-bg); min-height: 0; }
.agent-chat__topbar { display: flex; align-items: center; gap: 10px; padding: 12px 20px;
  border-bottom: 1px solid var(--agent-line); background: var(--agent-bg); flex-shrink: 0; }
.agent-chat__back { display: inline-flex; align-items: center; gap: 6px; border: none; background: transparent;
  cursor: pointer; font-family: var(--agent-ui); font-size: 13px; color: var(--agent-ink-soft); text-decoration: none; }
.agent-chat__header { display: flex; align-items: center; gap: 12px; padding: 12px 16px;
  background: var(--agent-surface); border-bottom: 1px solid var(--agent-line); flex-shrink: 0; }
.agent-chat__title { font-size: 15.5px; font-weight: 600; }
.agent-chat__tag { font-size: 10.5px; font-weight: 600; letter-spacing: .5px; text-transform: uppercase;
  color: var(--agent-coral-dark); background: var(--agent-coral-wash); padding: 2px 7px; border-radius: 100px; }
.agent-chat__subtitle { font-size: 12.5px; color: var(--agent-ink-soft); margin-top: 1px; }
.agent-chat__thread { flex: 1; overflow-y: auto; padding: 18px 16px 8px; min-height: 0; }
.agent-thread-inner { display: flex; flex-direction: column; gap: 14px; max-width: 720px; margin: 0 auto; }

/* messages */
.agent-msg { display: flex; gap: 10px; }
.agent-msg--user { justify-content: flex-end; }
.agent-msg--assistant { justify-content: flex-start; }
.agent-msg__avatar { width: 32px; flex-shrink: 0; display: flex; align-items: flex-end; }
.agent-msg__col { display: flex; flex-direction: column; max-width: 560px; }
.agent-msg--user .agent-msg__col { align-items: flex-end; }
.agent-msg__bubble { padding: 11px 15px; font-size: 15px; line-height: 1.5; white-space: pre-wrap; word-wrap: break-word; }
.agent-msg--assistant .agent-msg__bubble { background: var(--agent-surface); color: var(--agent-ink);
  border: 1px solid var(--agent-line); box-shadow: var(--agent-shadow-sm); border-radius: 18px 18px 18px 4px; }
.agent-msg--user .agent-msg__bubble { background: var(--agent-ink); color: #fff; border-radius: 18px 18px 4px 18px; }
.agent-msg__card { width: 100%; margin-top: 8px; }

/* typing */
.agent-typing { align-self: flex-start; display: inline-flex; gap: 4px; align-items: center; padding: 12px 16px;
  background: var(--agent-surface); border: 1px solid var(--agent-line); box-shadow: var(--agent-shadow-sm);
  border-radius: 18px 18px 18px 4px; }
.agent-typing span { width: 7px; height: 7px; border-radius: 50%; background: var(--agent-ink-faint); animation: pp-bounce 1.2s infinite ease-in-out; }
.agent-typing span:nth-child(2) { animation-delay: .18s; }
.agent-typing span:nth-child(3) { animation-delay: .36s; }

/* quick replies */
.quick-replies { display: flex; flex-wrap: wrap; gap: 8px; padding: 4px 16px 10px; max-width: 720px; margin: 0 auto; width: 100%; box-sizing: border-box; }
.quick-reply { padding: 9px 14px; border-radius: 100px; border: 1px solid var(--agent-coral);
  background: var(--agent-surface); color: var(--agent-coral-dark); font-family: var(--agent-ui);
  font-size: 13.5px; font-weight: 500; cursor: pointer; white-space: nowrap; }
.quick-reply:hover { background: var(--agent-coral-wash); }

/* In-thread "agent called" divider (unified multi-agent conversation) */
.agent-divider { display: flex; align-items: center; justify-content: center; gap: 7px; margin: 12px 0;
  color: var(--agent-ink-soft); font-size: 12px; font-weight: 500; }
.agent-divider::before, .agent-divider::after { content: ""; flex: 1; height: 1px; background: var(--agent-line); }

/* Agent dock — call an agent into the conversation */
.agent-dock { display: flex; align-items: center; flex-wrap: wrap; gap: 7px; padding: 10px 16px 0; }
.agent-dock__label { font-size: 11px; color: var(--agent-ink-soft); font-weight: 600; letter-spacing: .4px; margin-right: 2px; }
.agent-dock__form { margin: 0; }
.agent-dock__chip { display: inline-flex; align-items: center; gap: 7px; padding: 5px 12px 5px 6px; border-radius: 100px;
  border: 1px solid var(--agent-line-strong); background: var(--agent-surface); cursor: pointer;
  font-family: var(--agent-ui); font-size: 13px; font-weight: 500; color: var(--agent-ink); }
.agent-dock__chip:hover { background: var(--agent-coral-wash); }
.agent-dock__chip--active { border-color: var(--agent-coral); background: var(--agent-coral-wash); }
.agent-starters { display: flex; flex-wrap: wrap; gap: 8px; padding: 10px 16px 0; }

/* composer */
.agent-composer { display: flex; align-items: flex-end; gap: 8px; padding: 12px;
  background: var(--agent-surface); border-top: 1px solid var(--agent-line);
  max-width: 720px; margin: 0 auto; width: 100%; box-sizing: border-box; }
.agent-composer__input { flex: 1; background: var(--agent-bg); border: 1px solid var(--agent-line); border-radius: 20px;
  padding: 11px 16px; font-family: var(--agent-ui); font-size: 15px; color: var(--agent-ink);
  resize: none; outline: none; max-height: 96px; line-height: 1.4; }
.agent-composer__input:focus { border-color: var(--agent-coral); }
.agent-composer__send { width: 42px; height: 42px; border-radius: 50%; border: none; flex-shrink: 0;
  background: var(--agent-coral); color: #fff; cursor: pointer; display: flex; align-items: center; justify-content: center; }
.agent-composer__send:disabled { background: var(--agent-line); cursor: default; }

.agent-empty { margin: auto; text-align: center; color: var(--agent-ink-soft); max-width: 360px; padding: 24px; line-height: 1.55; }

/* Coral form fields (new dossier) */
.a-field { margin-bottom: 14px; }
.a-label { display: block; font-size: 12.5px; color: var(--agent-ink-soft); margin-bottom: 5px; font-weight: 500; }
.a-input { width: 100%; box-sizing: border-box; padding: 11px 14px; border: 1px solid var(--agent-line); border-radius: 12px;
  background: var(--agent-surface); font-family: var(--agent-ui); font-size: 14px; color: var(--agent-ink); outline: none; }
.a-input:focus { border-color: var(--agent-coral); }
/* File inputs: tighten padding (text-input padding makes the native control too
   tall) and restyle the file-selector button so it matches sibling text fields */
.a-input[type="file"] { padding: 6px 10px; font-size: 13px; line-height: 1.6; cursor: pointer; }
.a-input[type="file"]::file-selector-button { margin-right: 12px; padding: 6px 13px;
  border: none; border-radius: 8px; background: var(--agent-coral-wash);
  color: var(--agent-coral-dark); font-family: var(--agent-ui); font-size: 12.5px;
  font-weight: 600; cursor: pointer; }
.a-input[type="file"]::file-selector-button:hover { background: var(--agent-coral-light); }
.a-row { display: flex; gap: 12px; }

/* Search box on the Dossiers patients page (reuses the rail-search controller) */
.dossiers-search { display: flex; align-items: center; gap: 8px; padding: 10px 14px; margin-bottom: 14px;
  background: var(--agent-surface); border: 1px solid var(--agent-line); border-radius: 12px; }
.dossiers-search:focus-within { border-color: var(--agent-coral); }
.dossiers-search__input { flex: 1; min-width: 0; border: none; background: transparent; outline: none;
  font-family: var(--agent-ui); font-size: 14px; color: var(--agent-ink); }

/* Plan decision/archive actions (Accepter / Refuser / Archiver) */
.plan-actions { display: flex; gap: 8px; flex-wrap: wrap; align-items: flex-start; margin-bottom: 24px; }
.plan-actions form { margin: 0; }
.plan-action { display: inline-flex; }
/* Action cluster in the plan header (top-right), no bottom margin. */
.plan-actions--header { margin-bottom: 0; justify-content: flex-end; flex: 0 1 auto; max-width: 60%; }
.hub-header--plan { align-items: flex-start; }

/* Plan actions dropdown (single "Actions ▾" button in the header). */
.plan-menu-wrap { position: relative; display: inline-flex; flex-shrink: 0; }
.plan-menu-wrap > .btn-agent { gap: 4px; }
.plan-menu { position: absolute; top: calc(100% + 6px); right: 0; z-index: 50; min-width: 246px;
  background: var(--agent-surface); border: 1px solid var(--agent-line); border-radius: 14px;
  box-shadow: var(--agent-shadow-md); padding: 6px; display: flex; flex-direction: column; gap: 1px; }
.plan-menu[hidden] { display: none; }
.plan-menu__item-wrap { display: block; }
.plan-menu__form { margin: 0; display: block; }
.plan-menu__item { display: flex; align-items: center; gap: 10px; width: 100%; padding: 9px 11px;
  border: 0; background: transparent; border-radius: 9px; cursor: pointer; text-align: left;
  text-decoration: none; font-family: var(--agent-ui); font-size: 13.5px; font-weight: 500; color: var(--agent-ink); }
.plan-menu__item:hover { background: var(--agent-coral-wash); }
.plan-menu__item .material-symbols-outlined { font-size: 18px; color: var(--agent-ink-soft); flex-shrink: 0; }
.plan-menu__item--danger { color: #B3261E; }
.plan-menu__item--danger .material-symbols-outlined { color: #B3261E; }
.plan-menu__sep { height: 1px; background: var(--agent-line); margin: 6px 4px; }

/* ── Acts & rendez-vous ─────────────────────────────────────────────── */
.act-card { padding: 14px 16px; }
.act-card__head { display: flex; align-items: center; gap: 12px; }
.act-card__icon { display: inline-flex; align-items: center; justify-content: center; width: 34px; height: 34px;
  flex-shrink: 0; border-radius: 10px; background: var(--agent-coral-wash); color: var(--agent-coral-dark); }
.act-card__title { font-size: 14.5px; font-weight: 600; color: var(--agent-ink); }
.act-card__sub { font-size: 12px; color: var(--agent-ink-soft); margin-top: 1px; }
.act-card__price { font-weight: 600; color: var(--agent-ink); white-space: nowrap; }
.act-card__rdv { margin-top: 10px; padding-top: 10px; border-top: 1px dashed var(--agent-line);
  display: flex; flex-direction: column; gap: 6px; }
.rdv-row { display: flex; align-items: center; gap: 8px; }
.rdv-row form { margin: 0; }
.rdv-row__when { font-size: 13px; color: var(--agent-ink); }
.rdv-row__title { font-size: 12px; color: var(--agent-ink-soft); }
.rdv-add { display: inline-flex; align-items: center; gap: 5px; align-self: flex-start; padding: 5px 10px;
  border: 1px dashed var(--agent-line-strong); border-radius: 100px; background: transparent; cursor: pointer;
  font-family: var(--agent-ui); font-size: 12.5px; font-weight: 500; color: var(--agent-coral-dark); }
.rdv-add:hover { background: var(--agent-coral-wash); }

/* ── Lifecycle state banner (Flow 01) ───────────────────────────────── */
.state-banner { display: flex; align-items: center; gap: 13px; padding: 14px 18px; border-radius: 16px;
  border: 1px solid var(--agent-line); background: var(--agent-surface); }
.state-banner > .material-symbols-outlined { font-size: 22px; flex-shrink: 0; }
.state-banner__t { font-size: 14.5px; font-weight: 600; color: var(--agent-ink); }
.state-banner__s { font-size: 12.5px; color: var(--agent-ink-soft); margin-top: 2px; }
.state-banner--draft { background: var(--agent-bg); border-style: dashed; border-color: var(--agent-line-strong); }
.state-banner--draft > .material-symbols-outlined { color: var(--agent-ink-soft); }
.state-banner--sign { background: var(--agent-coral-wash); border-color: var(--agent-coral-light); }
.state-banner--sign > .material-symbols-outlined { color: var(--agent-coral-dark); }
.state-banner--ok { background: var(--agent-success-light); border-color: var(--agent-success-light); }
.state-banner--ok > .material-symbols-outlined { color: var(--agent-success); }
.state-banner--muted { background: var(--agent-bg); }
.state-banner--muted > .material-symbols-outlined { color: var(--agent-ink-faint); }
.state-banner form { margin: 0; }

/* ── Devis builder (Flow 01) ────────────────────────────────────────── */
.devis-builder { padding: 16px; }
/* overflow: visible so the CCAM autocomplete dropdown isn't clipped. The
   table fits the panel-card on every supported viewport (the columns are
   sized to wrap their inputs). */
.devis-table-wrap { overflow: visible; }
.devis-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.devis-table th { text-align: left; font-size: 10.5px; font-weight: 600; letter-spacing: .4px; text-transform: uppercase;
  color: var(--agent-ink-soft); padding: 0 6px 8px; white-space: nowrap; }
.devis-table td { padding: 3px 4px; vertical-align: middle; }
.devis-table .a-input { padding: 7px 8px; font-size: 13px; width: 100%; min-width: 56px; }
.devis-table td:first-child .a-input { min-width: 150px; }
.devis-sub { font-variant-numeric: tabular-nums; color: var(--agent-ink); white-space: nowrap; }
.devis-builder__foot { display: flex; align-items: center; justify-content: space-between; gap: 12px;
  margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--agent-line); flex-wrap: wrap; }
.devis-total { font-size: 13.5px; color: var(--agent-ink-soft); }
.devis-total strong { font-family: var(--agent-display); font-size: 19px; color: var(--agent-ink); margin-left: 8px; }
.devis-entente { margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--agent-line); }

/* CCAM autocomplete on either the description OR the ccam-code cell.
   Dropdown anchors to whichever cell hosts the focused input. */
.devis-cell--desc { position: relative; }
.devis-cell--ccam { position: relative; }
.ccam-results { position: absolute; top: 100%; left: 0; z-index: 50;
  background: var(--agent-surface); border: 1px solid var(--agent-line); border-radius: 12px;
  box-shadow: var(--agent-shadow-md, 0 8px 20px rgba(0,0,0,.08)); margin-top: 4px;
  max-height: 320px; overflow-y: auto; padding: 4px;
  min-width: 420px; max-width: 560px; }
.ccam-item { display: grid; grid-template-columns: 78px 1fr 130px; align-items: center; gap: 10px;
  width: 100%; padding: 8px 10px; border: 0; background: transparent; border-radius: 8px;
  font-family: var(--agent-ui); font-size: 12.5px; text-align: left; cursor: pointer; }
.ccam-item:hover, .ccam-item--active { background: var(--agent-bg-deep); }
.ccam-item__code { font-family: var(--agent-mono, monospace); font-weight: 600; color: var(--agent-coral-dark); font-size: 11.5px; letter-spacing: .3px; }
.ccam-item__desc { color: var(--agent-ink); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ccam-item__base { font-size: 11px; color: var(--agent-ink-soft); text-align: right; font-variant-numeric: tabular-nums; }

/* Flow 01 brouillon — 2-column layout: devis table left, RAC summary +
   step timeline right. Mirrors the design handoff
   (branche-agents/flows/01-creation-plan.html, Plate 1). */
/* Brouillon wizard: devis full-width, RAC card + steps below side by side. */
.brouillon-grid { display: grid; grid-template-columns: 1fr; gap: 18px; align-items: start; }
.brouillon-main { min-width: 0; }
.brouillon-aside { display: flex; flex-direction: row; gap: 12px; align-items: start; }

/* Panel toggle button icons: show "close" when panel open, "open" when collapsed. */
.icon-panel-open { display: none; }
.icon-panel-close { display: inline-flex; }
[data-panel-collapsed] .icon-panel-open { display: inline-flex; }
[data-panel-collapsed] .icon-panel-close { display: none; }

/* When right panel is collapsed: hide it and move the brouillon aside to the right. */
[data-panel-collapsed] .agents-dossier { display: none; }
[data-panel-collapsed] .brouillon-grid { grid-template-columns: 1fr 280px; }
[data-panel-collapsed] .brouillon-aside { flex-direction: column; flex: none; width: 280px; position: sticky; top: 8px; }

/* Dark RAC summary card. */
.rac-summary { flex: 0 0 260px; background: var(--agent-ink); color: #fff; border-radius: 16px; padding: 20px; }
.rac-summary__label { font-size: 10.5px; letter-spacing: .6px; text-transform: uppercase; opacity: .7; }
.rac-summary__amount { font-family: var(--agent-display); font-size: 30px; margin-top: 4px; line-height: 1; }
.rac-summary__sep { height: 1px; background: rgba(255,255,255,.18); margin: 14px 0; }
.rac-summary__row { display: flex; justify-content: space-between; font-size: 13px; opacity: .9; margin-top: 7px;
  font-variant-numeric: tabular-nums; }
.rac-summary__row:first-of-type { margin-top: 0; }

/* Step timeline card. */
.brouillon-steps { flex: 1; min-width: 0; background: var(--agent-surface); border: 1px solid var(--agent-line); border-radius: 16px; padding: 18px; }
.steps-list { display: flex; flex-direction: column; }
.step { display: flex; gap: 12px; }
.step__rail { display: flex; flex-direction: column; align-items: center; }
.step__num { width: 26px; height: 26px; border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-size: 12.5px; font-weight: 600; flex-shrink: 0; background: var(--agent-bg-deep); color: var(--agent-ink-soft); }
.step--done .step__num { background: var(--agent-success, #3E7B47); color: #fff; }
.step--now  .step__num { background: var(--agent-coral); color: #fff; }
.step__line { width: 2px; flex: 1; background: var(--agent-line); margin: 4px 0; }
.step:last-child .step__line { display: none; }
.step__body { padding-bottom: 14px; padding-top: 2px; }
.step:last-child .step__body { padding-bottom: 0; }
.step__t { font-size: 13.5px; font-weight: 500; color: var(--agent-ink); }
.step__s { font-size: 12px; color: var(--agent-ink-soft); margin-top: 1px; }

@media (max-width: 760px) {
  .brouillon-aside { flex-direction: column; }
  .rac-summary { flex: none; width: 100%; }
}

/* Segmented échéancier picker. */
.seg { display: inline-flex; background: var(--agent-bg-deep); border-radius: 12px; padding: 4px; gap: 3px; }
.seg-btn { border: 0; background: transparent; cursor: pointer; padding: 8px 14px; border-radius: 9px;
  font-family: var(--agent-ui); font-size: 13px; font-weight: 500; color: var(--agent-ink-soft); white-space: nowrap; }
.seg-btn--on { background: var(--agent-surface); color: var(--agent-ink); box-shadow: var(--agent-shadow-sm); }
.ech-recap { display: flex; align-items: center; justify-content: space-between; gap: 14px;
  margin-top: 16px; padding: 16px; border-radius: 14px; background: var(--agent-surface-alt); }
.muted-cap { font-size: 10.5px; letter-spacing: .5px; text-transform: uppercase; color: var(--agent-ink-soft); }
.ech-amount { font-family: var(--agent-display); font-size: 24px; margin-top: 2px; }
.ech-amount--coral { color: var(--agent-coral-dark); }

/* Brouillon wizard — step footer (back / continue button row). */
.brouillon-step__foot { display: flex; align-items: center; justify-content: space-between; gap: 12px;
  margin-top: 18px; padding-top: 14px; border-top: 1px solid var(--agent-line); }

/* Step 2 — Entente RAC → mensualité card. */
.ent-card { display: flex; align-items: center; justify-content: space-between; gap: 14px;
  margin-top: 4px; padding: 16px; border-radius: 14px; background: var(--agent-surface-alt, var(--agent-bg-deep)); }
.ent-card__col { display: flex; flex-direction: column; }
.ent-card__divider { height: 1px; background: var(--agent-line); margin: 14px 0 10px; }
.ent-card__row { display: flex; align-items: center; justify-content: space-between; font-size: 13.5px; color: var(--agent-ink);
  margin-top: 7px; }
.ent-card__row:first-of-type { margin-top: 0; }
.ent-card__row .muted { color: var(--agent-ink-soft); }

/* Step 3 — consentement preview + pièce row. */
.consent-preview { font-family: var(--agent-display); font-size: 12.5px; line-height: 1.65;
  padding: 16px 18px; max-height: 180px; overflow: hidden; color: #33302c; background: var(--agent-surface);
  -webkit-mask-image: linear-gradient(#000 70%, transparent);
  mask-image: linear-gradient(#000 70%, transparent); }
.consent-foot { display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 11px 16px; border-top: 1px solid var(--agent-line); background: var(--agent-surface-alt, var(--agent-bg-deep)); }
.piece-row, .envoi-row { display: flex; align-items: center; gap: 13px; padding: 12px 0; border-bottom: 1px solid var(--agent-line); }
.piece-row:last-child, .envoi-row:last-child { border-bottom: 0; }
.piece-row__icon, .envoi-row__icon { width: 36px; height: 36px; border-radius: 11px; display: flex;
  align-items: center; justify-content: center; flex-shrink: 0; }
.piece-row__icon { background: var(--agent-success-light, #E4EFE4); color: var(--agent-success, #3E7B47); }
.envoi-row__icon { background: var(--agent-coral-wash); color: var(--agent-coral-dark); }
.piece-row__body, .envoi-row__body { flex: 1; min-width: 0; }
.piece-row__t, .envoi-row__t { font-size: 13.5px; font-weight: 500; color: var(--agent-ink); }
.piece-row__s, .envoi-row__s { font-size: 12.5px; color: var(--agent-ink-soft); margin-top: 1px; }

/* Step 4 — hero title row. */
.hub-display { font-family: var(--agent-display); margin-top: 4px; }
.hub-display__hl { font-size: 22px; color: var(--agent-ink); font-weight: 400; }

/* Step indicator: link state — keep cursor pointer + subtle hover on the body. */
.steps-list .step { cursor: pointer; padding: 2px 0; }
.steps-list .step:hover .step__t { color: var(--agent-coral-dark); }

/* "Vérifier & envoyer" document rows in the Envoi dialog. */
.send-doc { display: flex; align-items: center; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--agent-line); }
.send-doc:last-of-type { border-bottom: 0; }
.send-doc__i { display: inline-flex; align-items: center; justify-content: center; width: 34px; height: 34px;
  flex-shrink: 0; border-radius: 10px; background: var(--agent-coral-wash); color: var(--agent-coral-dark); }
.send-doc__t { font-size: 14px; font-weight: 600; color: var(--agent-ink); }
.send-doc__s { font-size: 12px; color: var(--agent-ink-soft); margin-top: 1px; }

/* ── Séance editor (Flow 02) ────────────────────────────────────────── */
.seance-card { padding: 15px 16px; }
.seance-card form { margin: 0; }
.seance-del { position: absolute; top: 10px; right: 10px; }
.seance-num { display: inline-flex; align-items: center; justify-content: center; width: 30px; height: 30px;
  flex-shrink: 0; border-radius: 8px; background: var(--agent-coral); color: #fff;
  font-family: var(--agent-display); font-size: 14px; }
.seance-head { display: flex; align-items: center; gap: 12px; padding-right: 30px; }
.seance-title { flex: 1; min-width: 0; font-weight: 500; }
.seance-dur { display: flex; align-items: center; gap: 6px; flex-shrink: 0; }
.seance-acts { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; padding-left: 42px; }
.seance-act { display: inline-flex; align-items: center; gap: 7px; padding: 6px 12px; border-radius: 100px;
  border: 1px solid var(--agent-line-strong); background: var(--agent-surface); cursor: pointer;
  font-size: 12.5px; color: var(--agent-ink); }
.seance-act:hover { background: var(--agent-coral-wash); }
.seance-act--on { border-color: var(--agent-coral); background: var(--agent-coral-wash); color: var(--agent-coral-dark); font-weight: 500; }
.seance-act input { accent-color: var(--agent-coral); }

/* ── Suivi des paiements (Flow 08) — encaissé / solde cards ──────────── */
.suivi-summary { display: flex; gap: 12px; }
.suivi-stat { flex: 1; background: var(--agent-surface); border: 1px solid var(--agent-line);
  border-radius: 14px; padding: 14px 16px; }
.suivi-stat__l { font-size: 10.5px; letter-spacing: .5px; text-transform: uppercase; color: var(--agent-ink-soft); }
.suivi-stat__v { font-family: var(--agent-display); font-size: 23px; color: var(--agent-ink); margin-top: 2px; }
.suivi-stat__v--ok { color: var(--agent-success); }
.suivi-stat__s { font-size: 11.5px; color: var(--agent-ink-soft); margin-top: 1px; }

/* ── Global cabinet calendar (Flow 07) ──────────────────────────────── */
.agenda-nav { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.cal { display: grid; grid-template-columns: 52px repeat(6, 1fr); background: var(--agent-surface);
  border: 1px solid var(--agent-line); border-radius: 16px; overflow: hidden; }
.cal__corner { border-bottom: 1px solid var(--agent-line); }
.cal__dayhead { padding: 10px 4px; text-align: center; border-bottom: 1px solid var(--agent-line);
  border-left: 1px solid var(--agent-line); }
.cal__dayname { display: block; font-size: 11px; color: var(--agent-ink-soft); text-transform: uppercase; letter-spacing: .4px; }
.cal__daynum { display: block; font-family: var(--agent-display); font-size: 17px; color: var(--agent-ink); margin-top: 1px; }
.cal__dayhead--today .cal__daynum { color: var(--agent-coral-dark); }
.cal__dayhead--today { background: var(--agent-coral-wash); }
.cal__hour { padding: 6px 8px 0; font-size: 10.5px; color: var(--agent-ink-faint); text-align: right; border-bottom: 1px solid var(--agent-line); }
.cal__cell { border-bottom: 1px solid var(--agent-line); border-left: 1px solid var(--agent-line);
  min-height: 46px; padding: 3px; display: flex; flex-direction: column; gap: 3px; }
.cal__ev { display: block; border-radius: 8px; padding: 4px 7px; text-decoration: none; line-height: 1.25; overflow: hidden; }
.cal__ev-t { display: block; font-size: 10.5px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cal__ev-s { display: block; font-size: 10px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; opacity: .9; }
.cal__ev--confirmed { background: var(--agent-coral); color: #fff; }
.cal__ev--proposed { background: var(--agent-coral-wash); color: var(--agent-coral-dark); border: 1px dashed var(--agent-coral); }
.cal__legend { width: 12px; height: 12px; border-radius: 4px; display: inline-block; }
.cal__legend--confirmed { background: var(--agent-coral); }
.cal__legend--proposed { background: var(--agent-coral-wash); border: 1px dashed var(--agent-coral); }

/* Coral modal (native <dialog>): signature, refusal, archive validation, entente financière */
.pp-dialog { border: none; border-radius: 18px; padding: 0; width: 460px; max-width: 92vw;
  background: var(--agent-surface); color: var(--agent-ink); box-shadow: var(--agent-shadow-lg); }
.pp-dialog::backdrop { background: rgba(26, 20, 14, .42); }
.pp-dialog__card { font-family: var(--agent-ui); }
.pp-dialog__head { display: flex; align-items: center; gap: 10px; padding: 15px 18px;
  border-bottom: 1px solid var(--agent-line); font-family: var(--agent-display); font-size: 17px; color: var(--agent-ink); }
.pp-dialog__head .icon-btn { margin-left: auto; width: 32px; height: 32px; }
.pp-dialog__body { padding: 16px 18px; font-size: 14px; color: var(--agent-ink); line-height: 1.55; }
.pp-dialog__foot { display: flex; justify-content: flex-end; gap: 8px; padding: 14px 18px; border-top: 1px solid var(--agent-line); }

/* ── Schedule modal (wide pp-dialog with embedded weekly calendar) ── */
.sched-dialog { width: 940px; max-width: 96vw; }
.sched-dialog__body { display: flex; min-height: 340px; max-height: 72vh; overflow: hidden; }
.sched-dialog__cal  { flex: 1; min-width: 0; padding: 14px 16px; border-right: 1px solid var(--agent-line);
  overflow-y: auto; overflow-x: auto; }
.sched-dialog__side { width: 290px; flex-shrink: 0; padding: 16px 18px; display: flex;
  flex-direction: column; overflow-y: auto; gap: 0; }

/* Calendar inside the modal — compact 30-min rows */
.sched-cal { display: flex; flex-direction: column; }
.sched-cal__nav  { display: flex; align-items: center; gap: 6px; margin-bottom: 10px; }
.sched-cal__week { flex: 1; text-align: center; font-size: 13px; font-weight: 600; color: var(--agent-ink); }
.sched-cal__grid { font-size: 11px; }
.sched-cal-loading { display: flex; flex-direction: column; align-items: center;
  justify-content: center; min-height: 260px; gap: 4px; }
/* 15-min quarter-hour rows */
.cal__hour--quarter { font-size: 9.5px; padding: 1px 5px 0; color: var(--agent-ink-faint); line-height: 1; }
.cal__hour--major   { font-size: 10px; color: var(--agent-ink-soft); font-weight: 500; }
.cal__hour--minor   { color: var(--agent-ink-faint); }
.cal__hour--tick    { color: transparent; }   /* :15 and :45 — invisible label, row still exists */
.cal__cell--quarter { min-height: 18px; }
/* Stronger top border on full-hour rows to visually chunk the grid */
.cal__cell--quarter.cal__hour--major-row,
.cal__hour--quarter.cal__hour--major { border-top: 1px solid var(--agent-line) !important; }

/* Selectable / past / selected cells */
.cal__cell--selectable { cursor: crosshair; user-select: none; touch-action: none; }
.cal__cell--selectable:hover { background: var(--agent-coral-wash); }
.cal__cell--past  { opacity: .38; cursor: default; }

/* Drag-in-progress highlight */
.cal__cell--drag { background: var(--agent-coral-wash) !important; }
/* End cell of drag: shows computed end-time + duration as a tooltip-style label */
.cal__cell--drag-end { background: var(--agent-coral-light) !important; position: relative; overflow: visible; z-index: 2; }
.cal__cell--drag-end::after { content: attr(data-drag-end);
  position: absolute; bottom: -22px; left: 50%; transform: translateX(-50%);
  white-space: nowrap; background: var(--agent-ink); color: #fff;
  font-size: 10px; padding: 2px 6px; border-radius: 6px; z-index: 10; }
/* Existing appointment chips must not intercept pointer events during drag */
.sched-cal__grid .cal__ev { pointer-events: none; }

/* Selected span: consecutive cells fuse into one continuous séance block.
   Side borders on every cell; top only on the first row, bottom only on the
   last, so internal row lines disappear and the slot reads as a single block. */
.cal__cell--selected { background: var(--agent-coral-light) !important;
  border-left: 2px solid var(--agent-coral); border-right: 2px solid var(--agent-coral);
  border-bottom-color: transparent; position: relative; }
.cal__cell--selected:not(.cal__cell--selected-start) { border-top-color: transparent !important; }
.cal__cell--selected-start { border-top: 2px solid var(--agent-coral) !important;
  border-top-left-radius: 8px; border-top-right-radius: 8px; }
.cal__cell--selected-end { border-bottom: 2px solid var(--agent-coral) !important;
  border-bottom-left-radius: 8px; border-bottom-right-radius: 8px; }
.cal__cell--selected-n::before { content: attr(data-slot-num);
  position: absolute; top: 2px; right: 3px; width: 14px; height: 14px;
  border-radius: 50%; background: var(--agent-coral); color: #fff; z-index: 2;
  font-size: 9px; font-weight: 700; display: flex; align-items: center; justify-content: center; }
/* Act names shown inside the merged séance block (start cell only) */
.cal__sel-label { font-size: 9.5px; font-weight: 600; line-height: 1.2;
  color: var(--agent-coral-dark); padding-right: 16px; overflow: hidden;
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; }
.sched-legend--selected { width: 12px; height: 12px; border-radius: 4px; display: inline-block;
  background: var(--agent-coral-light); border: 2px solid var(--agent-coral); }

/* Proposed slots list */
.sched-slots { display: flex; flex-direction: column; gap: 6px; margin-bottom: 4px; min-height: 32px; }
.sched-slot  { display: flex; align-items: center; gap: 6px; background: var(--agent-surface-alt);
  border: 1px solid var(--agent-line); border-radius: 10px; padding: 6px 8px; }
.sched-slot__num { width: 20px; height: 20px; border-radius: 50%; background: var(--agent-coral);
  color: #fff; font-size: 10px; font-weight: 700; display: inline-flex;
  align-items: center; justify-content: center; flex-shrink: 0; }
.sched-slot__label { font-size: 12px; font-weight: 500; color: var(--agent-ink); flex: 1; min-width: 0;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sched-slot__time  { max-width: 90px; padding: 4px 6px; font-size: 12px; border-radius: 8px; flex-shrink: 0; }
.sched-slot__remove { width: 24px; height: 24px; flex-shrink: 0; }
.sched-slots__hint { font-size: 11px; color: var(--agent-ink-faint); font-weight: 400; }
.sched-slots__mode { font-size: 11.5px; color: var(--agent-ink-soft); min-height: 16px; }

/* Acts checklist */
.sched-acts { display: flex; flex-direction: column; gap: 3px; max-height: 180px; overflow-y: auto; }
.sched-act  { display: flex; align-items: flex-start; gap: 8px; padding: 6px 8px;
  border-radius: 8px; cursor: pointer; border: 1px solid transparent; }
.sched-act:hover { background: var(--agent-surface-alt); }
.sched-act input[type="checkbox"] { margin-top: 2px; flex-shrink: 0;
  width: 14px; height: 14px; accent-color: var(--agent-coral); cursor: pointer; }
.sched-act__body { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.sched-act__name { font-size: 12.5px; font-weight: 500; color: var(--agent-ink); line-height: 1.3; }
.sched-act__meta { font-size: 11px; color: var(--agent-ink-soft); }

.reason-checks { display: flex; flex-wrap: wrap; gap: 8px 18px; margin: 6px 0; }
.reason-check { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; color: var(--agent-ink); cursor: pointer; }
.a-row > * { flex: 1; }
.a-form-alert { background: #FDECEA; border: 1px solid #F5C6C0; border-radius: 10px;
  padding: 10px 12px; font-size: 13px; color: #9B2C20; margin-bottom: 14px; }

/* New-dossier patient search */
.dossier-results { margin-top: 8px; display: flex; flex-direction: column; gap: 4px; }
.dossier-result { display: flex; flex-direction: column; align-items: flex-start; gap: 1px;
  width: 100%; text-align: left; padding: 9px 12px; border: 1px solid var(--agent-line);
  border-radius: 10px; background: var(--agent-surface); cursor: pointer; font-family: var(--agent-ui); }
.dossier-result:hover { background: var(--agent-coral-wash); border-color: var(--agent-coral-light); }
.dossier-result__name { font-size: 14px; font-weight: 500; color: var(--agent-ink); }
.dossier-result__sub { font-size: 12px; color: var(--agent-ink-soft); }
.dossier-result--empty { color: var(--agent-ink-soft); font-size: 13px; cursor: default; background: transparent; border-style: dashed; }
.dossier-result--empty:hover { background: transparent; border-color: var(--agent-line); }
.dossier-or { display: flex; align-items: center; gap: 12px; margin: 14px 2px; color: var(--agent-ink-faint); font-size: 12px; }
.dossier-or::before, .dossier-or::after { content: ""; flex: 1; height: 1px; background: var(--agent-line); }

/* Account settings (coral re-skin) */
/* Section group label — introduces a cluster of related setting cards */
.settings-group { display: flex; align-items: center; gap: 7px; margin: 28px 2px 12px;
  font-size: 11.5px; font-weight: 700; letter-spacing: .7px; text-transform: uppercase;
  color: var(--agent-ink-faint); }
.settings-group:first-of-type { margin-top: 6px; }
.settings-group .material-symbols-outlined { font-size: 16px; color: var(--agent-coral-dark); }
.settings-head { display: flex; align-items: center; gap: 8px; font-family: var(--agent-display); font-size: 17px; margin-bottom: 12px; }
.settings-head .material-symbols-outlined { color: var(--agent-coral-dark); font-size: 20px; }
.settings-desc { color: var(--agent-ink-soft); font-size: 13px; margin: -4px 0 14px; line-height: 1.5; }
.settings-rows { display: flex; flex-direction: column; }
.s-row { display: flex; gap: 12px; padding: 8px 0; border-top: 1px solid var(--agent-line); font-size: 13.5px; }
.s-row:first-child { border-top: none; }
.s-row__k { width: 130px; flex-shrink: 0; color: var(--agent-ink-soft); }
.s-row__v { color: var(--agent-ink); min-width: 0; overflow-wrap: anywhere; }
.s-banner { display: flex; align-items: flex-start; gap: 8px; border-radius: 12px; padding: 10px 12px; font-size: 13px; line-height: 1.5; margin-bottom: 14px; }
.s-banner--ok { background: var(--agent-success-light); color: var(--agent-success); }
.s-banner--info { background: var(--agent-info-light); color: var(--agent-info); }
.s-banner--warn { background: #FCEEDD; color: #8A5A1E; }
.settings-sub { border: 1px solid var(--agent-line); border-radius: 12px; padding: 14px; background: var(--agent-bg); margin-top: 10px; }

/* Health-data confidentiality notice in the chat */
.agent-privacy-note { display: flex; align-items: flex-start; gap: 8px; flex-shrink: 0;
  padding: 8px 16px; background: var(--agent-coral-wash); border-bottom: 1px solid var(--agent-line);
  color: var(--agent-coral-dark); font-size: 12px; line-height: 1.45; }
.agent-privacy-note strong { font-weight: 600; }

/* ── Rich cards (.quote-card kept for existing partials) ─────────────── */
.quote-card { background: var(--agent-surface); border-radius: 18px; border: 1px solid var(--agent-line);
  box-shadow: var(--agent-shadow-sm); overflow: hidden; font-family: var(--agent-ui); }
.quote-card--accent { border-color: var(--agent-coral-light); }
.quote-card__head { display: flex; align-items: center; gap: 10px; padding: 14px 16px;
  border-bottom: 1px solid var(--agent-line); background: var(--agent-surface-alt); }
.quote-card--accent .quote-card__head { background: var(--agent-coral-wash); }
.quote-card__icon { width: 30px; height: 30px; border-radius: 9px; background: var(--agent-coral-light);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0; color: var(--agent-coral-dark); }
.quote-card--accent .quote-card__icon { background: var(--agent-coral); color: #fff; }
.quote-card__eyebrow { font-size: 10.5px; letter-spacing: .7px; text-transform: uppercase; color: var(--agent-coral-dark); font-weight: 600; }
.quote-card__title { font-size: 15px; font-weight: 500; margin-top: 1px; }
.quote-card__body { padding: 16px; }
.quote-card__actions { display: flex; gap: 8px; border-top: 1px solid var(--agent-line); padding: 12px; }
.quote-line { display: flex; justify-content: space-between; gap: 12px; padding: 8px 0; border-top: 1px solid var(--agent-line); font-size: 13.5px; }
.quote-line:first-child { border-top: none; }
.quote-line__label { color: var(--agent-ink); }
.quote-line__tooth { color: var(--agent-ink-soft); font-size: 11.5px; margin-top: 1px; }
.quote-line__price { font-family: var(--agent-display); white-space: nowrap; }
.quote-totals { margin-top: 12px; padding-top: 12px; border-top: 2px solid var(--agent-line); display: flex; flex-direction: column; gap: 4px; }
.quote-total-row { display: flex; justify-content: space-between; font-size: 14px; }
.quote-total-row--rac { font-size: 16px; font-weight: 700; color: var(--agent-coral-dark); font-family: var(--agent-display); }
.quote-finalized { align-self: flex-start; display: flex; align-items: center; gap: 12px;
  background: var(--agent-success-light); border: 1px solid #B7DFC1; border-radius: 16px; padding: 14px 16px; }
.quote-finalized .material-symbols-outlined { color: var(--agent-success); }

/* ── Pills + buttons ─────────────────────────────────────────────────── */
.pill { display: inline-flex; align-items: center; gap: 5px; padding: 4px 10px; border-radius: 100px;
  font-size: 11px; font-weight: 600; letter-spacing: .3px; white-space: nowrap; background: var(--agent-bg-deep); color: var(--agent-ink-soft); }
.pill--coral { background: var(--agent-coral-light); color: var(--agent-coral-dark); }
.pill--success { background: var(--agent-success-light); color: var(--agent-success); }
.pill--info { background: var(--agent-info-light); color: var(--agent-info); }
.pill--ink { background: var(--agent-ink); color: #fff; }

.btn-agent { display: inline-flex; align-items: center; justify-content: center; gap: 8px; height: 42px;
  padding: 0 18px; border-radius: 12px; border: none; background: var(--agent-coral); color: #fff;
  font-family: var(--agent-ui); font-size: 14px; font-weight: 500; cursor: pointer; text-decoration: none; white-space: nowrap; }
.btn-agent--ink { background: var(--agent-ink); }
.btn-agent--soft { background: var(--agent-coral-light); color: var(--agent-coral-dark); }
.btn-agent--outline { background: transparent; color: var(--agent-ink); box-shadow: inset 0 0 0 1px var(--agent-line-strong); }
.btn-agent--ghost { background: transparent; color: var(--agent-ink-soft); }
.btn-agent--danger { background: var(--agent-coral-dark); }
.btn-agent--sm { height: 36px; font-size: 13px; padding: 0 14px; }
.btn-agent--full { width: 100%; }

/* ── Electronic signature card (reuses the shared `signature-pad` controller) ── */
.sig-block .hidden { display: none !important; }
.sig-agreement { background: var(--agent-coral-wash); border-radius: 12px; padding: 10px 12px; margin-bottom: 12px; }
.sig-agreement__text { font-size: 13px; font-weight: 600; color: var(--agent-coral-dark); }
.sig-agreement__meta { font-size: 11.5px; color: var(--agent-ink-faint); margin-top: 2px; }
.sig-toggle { display: flex; gap: 6px; margin-bottom: 8px; }
.sig-toggle button { height: 30px; padding: 0 12px; border-radius: 100px; cursor: pointer;
  font-family: var(--agent-ui); font-size: 12.5px; color: var(--agent-coral-dark);
  background: transparent; border: 1px solid var(--agent-coral); }
.sig-toggle button.active { background: var(--agent-coral); color: #fff; border-color: var(--agent-coral); }
.sig-text-input { width: 100%; box-sizing: border-box; height: 38px; padding: 0 12px; margin-bottom: 8px;
  border: 1px solid var(--agent-line-strong); border-radius: 10px; font-family: var(--agent-ui); font-size: 14px; }
.sig-canvas-wrap { border: 1px dashed var(--agent-line-strong); border-radius: 12px; background: #fff; height: 120px; overflow: hidden; }
.sig-canvas { display: block; width: 100%; height: 120px; touch-action: none; cursor: crosshair; }
.sig-actions { display: flex; justify-content: flex-end; margin-top: 6px; }

/* ── Plan detail (documents + financial agreement) ───────────────────── */
.icon-btn { display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px;
  border-radius: 10px; border: none; background: transparent; color: var(--agent-ink-soft); cursor: pointer; flex-shrink: 0; text-decoration: none; }
.icon-btn:hover { background: var(--agent-bg-deep); color: var(--agent-ink); }
.plan-card__link { display: block; text-decoration: none; color: inherit; }
.plan-card__link:hover { color: var(--agent-coral-dark); }
.doc-row--link { text-decoration: none; color: var(--agent-ink); border-radius: 8px; padding: 7px 6px; margin: 0 -6px; }
.doc-row--link:hover { background: var(--agent-coral-wash); }
.plan-doc { display: flex; align-items: center; gap: 12px; background: var(--agent-surface);
  border: 1px solid var(--agent-line); border-radius: 16px; padding: 14px 16px; }
.plan-doc__icon { width: 38px; height: 38px; flex-shrink: 0; border-radius: 10px; background: var(--agent-coral-light);
  color: var(--agent-coral-dark); display: flex; align-items: center; justify-content: center; }
.plan-doc__main { flex: 1; min-width: 0; }
.plan-doc__name { font-size: 14.5px; font-weight: 500; color: var(--agent-ink); }
.plan-doc__meta { font-size: 12px; color: var(--agent-ink-soft); margin-top: 2px; }
.plan-doc__actions { flex-shrink: 0; }

/* PDF viewer modal (coral re-skin of the shared pdf-viewer--component) */
.pdf-modal { position: fixed; inset: 0; background: rgba(26,20,14,.55); z-index: 200; }
.pdf-modal__panel { width: 880px; max-width: calc(100% - 36px); height: 92vh; margin: 4vh auto;
  background: var(--agent-bg); border-radius: 20px; display: flex; flex-direction: column; overflow: hidden;
  box-shadow: 0 24px 60px rgba(0,0,0,.32); }
.pdf-modal__head { display: flex; align-items: center; gap: 12px; padding: 12px 14px;
  background: var(--agent-surface); border-bottom: 1px solid var(--agent-line); }
.pdf-modal__title { font-family: var(--agent-display); font-size: 15px; }
.pdf-modal__nav { display: flex; align-items: center; gap: 4px; margin-left: auto; }
.pdf-modal__page { font-size: 12.5px; color: var(--agent-ink-soft); min-width: 54px; text-align: center; font-variant-numeric: tabular-nums; }
.pdf-modal__canvas { flex: 1; overflow: auto; padding: 18px; display: flex; justify-content: center; background: var(--agent-bg-deep); }
.pdf-modal__canvas canvas { box-shadow: 0 6px 20px rgba(0,0,0,.16); border-radius: 4px; height: max-content; }

/* ── Dossier panel (right) ───────────────────────────────────────────── */
.agents-dossier { width: 322px; flex-shrink: 0; background: var(--agent-surface);
  border-left: 1px solid var(--agent-line); height: 100%;
  display: flex; flex-direction: column; overflow: hidden; }
/* Panes fill the height below the tabs; Patient scrolls as a block, Assistant
   is a flex column so its chat thread scrolls and the composer pins. */
.agents-dossier > [data-panel-tabs-target="pane"] { flex: 1; min-height: 0; }
[data-pane="patient"]:not([hidden]) { overflow-y: auto; }
[data-pane="assistant"]:not([hidden]) { display: flex; flex-direction: column; }
.d-pane--chat[hidden] { display: none; }
/* Compact agent header above the embedded conversation. */
.d-asst-head { display: flex; align-items: center; gap: 10px; padding: 12px 14px; flex-shrink: 0;
  border-bottom: 1px solid var(--agent-line); background: var(--agent-surface); }
.d-asst-head__name { font-size: 14px; font-weight: 600; color: var(--agent-ink); }
.d-asst-head__sub { font-size: 11.5px; color: var(--agent-ink-soft); margin-top: 1px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
/* Embedded chat region (shared by the standalone screen + the panel). */
.agent-chat__body { flex: 1; min-height: 0; display: flex; flex-direction: column; }
.dossier-head { padding: 22px 20px; border-bottom: 1px solid var(--agent-line); text-align: center; }
.dossier-head__name { font-family: var(--agent-display); font-size: 20px; margin-top: 10px; }
.dossier-head__meta { font-size: 12.5px; color: var(--agent-ink-soft); margin-top: 2px; }
.dossier-head__ref { display: inline-flex; align-items: center; gap: 6px; margin-top: 10px; padding: 5px 11px;
  background: var(--agent-bg); border: 1px solid var(--agent-line); border-radius: 100px; font-size: 12px; }
.dossier-body { padding: 18px; }
.d-label { font-size: 10.5px; color: var(--agent-ink-soft); letter-spacing: .7px; text-transform: uppercase; font-weight: 600; margin: 0 0 10px; }
.d-label--mt { margin-top: 20px; }

/* Right-panel tab navigation: Assistant ⇆ Patient */
.d-tabs { flex-shrink: 0; z-index: 2; padding: 12px; background: var(--agent-surface); border-bottom: 1px solid var(--agent-line); }
.d-tabs__seg { display: flex; gap: 4px; padding: 4px; background: var(--agent-bg-deep); border-radius: 12px; }
.d-tab { flex: 1; display: inline-flex; align-items: center; justify-content: center; gap: 6px; padding: 8px 10px;
  border: none; border-radius: 9px; background: transparent; cursor: pointer;
  font-family: var(--agent-ui); font-size: 13px; font-weight: 500; color: var(--agent-ink-soft); }
.d-tab--active { background: var(--agent-surface); color: var(--agent-ink); box-shadow: var(--agent-shadow-sm); }
.d-tab .material-symbols-outlined { color: inherit; }

/* Assistant pane — agent launchers */
.d-asst-list { display: flex; flex-direction: column; gap: 8px; }
.d-asst-form { margin: 0; }
.d-asst { display: flex; align-items: center; gap: 11px; width: 100%; padding: 11px 12px;
  border: 1px solid var(--agent-line); border-radius: 14px; background: var(--agent-surface); cursor: pointer; text-align: left; }
.d-asst:hover { background: var(--agent-surface-alt); }
.d-asst__text { flex: 1; min-width: 0; }
.d-asst__name { display: block; font-size: 14px; font-weight: 600; color: var(--agent-ink); }
.d-asst__tag { font-size: 9px; font-weight: 700; letter-spacing: .5px; color: var(--agent-coral-dark);
  background: var(--agent-coral-light); padding: 1px 5px; border-radius: 100px; margin-left: 6px; vertical-align: middle; }
.d-asst__teaser { display: block; font-size: 12px; color: var(--agent-ink-soft); margin-top: 2px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.d-row { display: flex; align-items: center; gap: 10px; padding: 5px 0; font-size: 13px; }
.d-row__v { flex: 1; }
.d-actions { display: flex; gap: 8px; margin-top: 12px; }
.act-btn { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 5px; padding: 10px 4px;
  border-radius: 12px; border: 1px solid var(--agent-line); background: var(--agent-surface); cursor: pointer;
  font-family: var(--agent-ui); color: var(--agent-coral-dark); text-decoration: none; }
.act-btn:hover { background: var(--agent-coral-wash); }
.act-btn span { font-size: 11.5px; color: var(--agent-ink); font-weight: 500; }
/* Inline edit (patient info) — <details>/<summary> toggle. */
.d-edit { margin-top: 10px; }
.d-edit__summary { display: inline-flex; align-items: center; gap: 5px; cursor: pointer; list-style: none;
  font-size: 12px; font-weight: 500; color: var(--agent-coral-dark); }
.d-edit__summary::-webkit-details-marker { display: none; }
.d-edit[open] .d-edit__summary { margin-bottom: 10px; }
.d-edit__form { background: var(--agent-bg); border: 1px solid var(--agent-line); border-radius: 12px; padding: 12px; }
/* Patient notes textarea (panel + hub). */
.patient-notes__area { width: 100%; resize: vertical; min-height: 76px; }
.mutuelle-card { background: #E8DDD4; border-radius: 14px; padding: 14px; }
.mutuelle-card__num { font-family: var(--agent-mono); font-size: 14px; letter-spacing: 1px; }
.tp-box { border: 1px solid var(--agent-line); border-radius: 12px; overflow: hidden; }
.tp-row { display: flex; align-items: center; justify-content: space-between; gap: 8px; padding: 10px 12px; border-bottom: 1px solid var(--agent-line); font-size: 12.5px; }
.tp-row:last-child { border-bottom: none; }
.doc-row { display: flex; align-items: center; gap: 9px; padding: 7px 0; font-size: 13px; }
.doc-row--done span { text-decoration: line-through; color: var(--agent-ink-soft); }

/* ── Compose modal ───────────────────────────────────────────────────── */
.modal-overlay { position: fixed; inset: 0; background: rgba(26,20,14,.42); z-index: 100;
  display: flex; align-items: center; justify-content: center; padding: 24px; }
.modal { width: 540px; max-width: 100%; max-height: 88vh; background: var(--agent-bg); border-radius: 22px;
  box-shadow: var(--agent-shadow-lg); display: flex; flex-direction: column; overflow: hidden; font-family: var(--agent-ui); }
.modal__head { display: flex; align-items: center; gap: 12px; padding: 16px 18px; background: var(--agent-surface); border-bottom: 1px solid var(--agent-line); }
.modal__body { flex: 1; overflow-y: auto; padding: 18px; }
.modal__foot { display: flex; gap: 8px; padding: 14px; border-top: 1px solid var(--agent-line); background: var(--agent-surface); }
.intent-chip { padding: 8px 13px; border-radius: 100px; cursor: pointer; font-family: var(--agent-ui); font-size: 13px; font-weight: 500;
  border: 1px solid var(--agent-line-strong); background: var(--agent-surface); color: var(--agent-ink); }
.intent-chip--sel { border-color: var(--agent-coral); background: var(--agent-coral); color: #fff; }
.draft-field { width: 100%; padding: 12px 14px; border-radius: 12px; border: 1px solid var(--agent-line);
  background: var(--agent-surface); font-family: var(--agent-ui); font-size: 14px; color: var(--agent-ink); line-height: 1.55; outline: none; }

/* ── Responsive ──────────────────────────────────────────────────────── */
@media (max-width: 1100px) {
  .agents-dossier { display: none; }
  .hub-cols { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  .agents-rail { display: none; }
  .agent-grid { grid-template-columns: 1fr; }
}

/* ── Pilotage du cabinet (cabinet-steering dashboard) ────────────────── */
/* Rail navigation (Pilotage / Dossiers) */
.agents-rail__nav { display: flex; flex-direction: column; gap: 2px; padding: 6px 10px 4px; }
.rail-nav { display: flex; align-items: center; gap: 10px; padding: 8px 12px; border-radius: 10px;
  color: var(--agent-ink-soft); text-decoration: none; font-size: 13.5px; font-weight: 500; }
.rail-nav:hover { background: var(--agent-bg-deep); color: var(--agent-ink); }
.rail-nav--active { background: var(--agent-coral-light); color: var(--agent-coral-dark); font-weight: 600; }
.rail-nav .material-symbols-outlined { color: inherit; }

/* Header + month picker */
.pilot { background: var(--agent-bg); }
.pilot-head { display: flex; align-items: center; gap: 14px; flex-shrink: 0;
  padding: 18px 32px; border-bottom: 1px solid var(--agent-line); background: var(--agent-surface); }
.pilot-head__title { font-family: var(--agent-display); font-size: 25px; color: var(--agent-ink); }
.pilot-head__sub { font-size: 13px; color: var(--agent-ink-soft); margin-top: 2px; }
/* Period navigation (prev/next anchor) + granularity select */
.pilot-nav { margin-left: auto; display: flex; align-items: center; gap: 6px; }
.pilot-nav__btn { width: 34px; height: 34px; border-radius: 10px; border: 1px solid var(--agent-line-strong);
  background: var(--agent-surface); display: inline-flex; align-items: center; justify-content: center;
  color: var(--agent-ink); text-decoration: none; }
.pilot-nav__btn:hover { background: var(--agent-surface-alt); }
.pilot-nav__btn--off { opacity: .3; pointer-events: none; }
.pilot-nav__range { min-width: 124px; text-align: center; font-family: var(--agent-display); font-size: 15px; color: var(--agent-ink); }
.period-pick { display: inline-flex; align-items: center; gap: 8px; padding: 7px 12px; margin-left: 4px;
  border-radius: 10px; border: 1px solid var(--agent-line-strong); background: var(--agent-surface); cursor: pointer; }
.period-pick:focus-within { border-color: var(--agent-coral); }
.period-pick__select { border: none; background: transparent; outline: none; cursor: pointer;
  font-family: var(--agent-ui); font-size: 13.5px; font-weight: 500; color: var(--agent-ink);
  -webkit-appearance: none; -moz-appearance: none; appearance: none; }

/* Scroll body — every block centred to 1200px with even vertical rhythm */
.pilot-body { flex: 1; min-height: 0; overflow-y: auto; padding: 22px 32px 52px; }
.pilot-body > * { max-width: 1200px; margin: 0 auto 18px; }

/* Agent insight banner */
.pilot-banner { display: flex; align-items: center; gap: 14px; padding: 15px 18px;
  background: var(--agent-coral-wash); border: 1px solid var(--agent-coral-light); border-radius: 16px; }
.pilot-banner__head { display: flex; align-items: center; gap: 7px; margin-bottom: 2px; }
.pilot-banner__name { font-size: 14.5px; font-weight: 600; color: var(--agent-ink); }
.pilot-banner__tag { font-size: 9.5px; font-weight: 700; letter-spacing: .5px; color: var(--agent-coral-dark);
  background: #fff; padding: 1px 6px; border-radius: 100px; }
.pilot-banner__text { font-size: 13.5px; color: var(--agent-ink); line-height: 1.5; }

/* Grids */
.pilot-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.pilot-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }

/* KPI cards */
.kpi-card { background: var(--agent-surface); border: 1px solid var(--agent-line); border-radius: 18px;
  padding: 18px 20px; box-shadow: var(--agent-shadow-sm); }
.kpi-label { font-size: 11px; color: var(--agent-ink-soft); letter-spacing: .5px; text-transform: uppercase; font-weight: 600; }
.kpi-value-row { display: flex; align-items: baseline; gap: 4px; margin-top: 9px; }
.kpi-value { font-family: var(--agent-display); font-size: 34px; color: var(--agent-ink); line-height: 1; }
.kpi-unit { font-family: var(--agent-display); font-size: 19px; color: var(--agent-ink-soft); }
.kpi-foot { display: flex; align-items: center; gap: 8px; margin-top: 12px; }
.kpi-sub { font-size: 12px; color: var(--agent-ink-soft); }
.delta-pill { display: inline-flex; align-items: center; padding: 3px 9px; border-radius: 100px;
  font-size: 11.5px; font-weight: 600; white-space: nowrap; }
.delta-pill--success { background: var(--agent-success-light); color: var(--agent-success); }
.delta-pill--coral { background: var(--agent-coral-light); color: var(--agent-coral-dark); }

/* Panels */
.pilot-panel { background: var(--agent-surface); border: 1px solid var(--agent-line); border-radius: 18px;
  padding: 20px; box-shadow: var(--agent-shadow-sm); }
.pilot-panel__head { display: flex; align-items: center; gap: 11px; margin-bottom: 18px; }
.pilot-panel__icon { width: 30px; height: 30px; border-radius: 9px; background: var(--agent-coral-light);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.pilot-panel__title { font-family: var(--agent-display); font-size: 18px; color: var(--agent-ink); }
.pilot-panel__right { margin-left: auto; }
.pilot-stat { font-family: var(--agent-display); font-size: 17px; color: var(--agent-ink); }
.pilot-stat__u { font-family: var(--agent-ui); font-size: 12px; color: var(--agent-ink-soft); }
.pilot-caption { font-size: 12.5px; color: var(--agent-ink-soft); margin-bottom: 8px; }
.pilot-sublabel { font-size: 10.5px; color: var(--agent-ink-soft); letter-spacing: .7px; text-transform: uppercase;
  font-weight: 600; margin: 18px 0 6px 1px; }
.pilot-empty { font-size: 13px; color: var(--agent-ink-soft); padding: 10px 0; }

/* Donut + legend */
.donut-row { display: flex; align-items: center; gap: 24px; }
.donut { position: relative; flex-shrink: 0; }
.donut__center { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; }
.donut__num { font-family: var(--agent-display); font-size: 38px; color: var(--agent-ink); line-height: 1; }
.donut__cap { font-size: 11.5px; color: var(--agent-ink-soft); margin-top: 3px; }
.legend { flex: 1; min-width: 0; }
.legend-row { display: flex; align-items: center; gap: 11px; padding: 9px 0; border-bottom: 1px solid var(--agent-line); }
.legend-row:last-child { border-bottom: none; }
.legend-dot { width: 11px; height: 11px; border-radius: 3px; flex-shrink: 0; }
.legend-label { font-size: 13.5px; color: var(--agent-ink); font-weight: 500; }
.legend-pct { font-size: 12.5px; color: var(--agent-ink-soft); }
.legend-n { font-family: var(--agent-display); font-size: 17px; color: var(--agent-ink); line-height: 1.1; }
.legend-fees { font-size: 11px; color: var(--agent-ink-soft); }

/* Encaissement */
.enc-big { display: flex; align-items: baseline; gap: 8px; }
.enc-big__num { font-family: var(--agent-display); font-size: 38px; color: var(--agent-ink); line-height: 1; }
.enc-big__cap { font-size: 13px; color: var(--agent-ink-soft); }
.bar-track { flex: 1; height: 11px; background: var(--agent-bg-deep); border-radius: 100px; overflow: hidden; }
.bar-fill { height: 100%; background: var(--agent-coral); border-radius: 100px; }
.bar-fill--success { background: var(--agent-success); }
.bar-legend { display: flex; justify-content: space-between; margin-top: 7px; font-size: 12px; color: var(--agent-ink-soft); }
.enc-rest { display: flex; align-items: center; gap: 8px; margin-top: 14px; padding: 9px 12px;
  background: var(--agent-surface-alt); border: 1px solid var(--agent-line); border-radius: 11px; font-size: 13px; color: var(--agent-ink); }
.enc-rest__amt { margin-left: auto; font-family: var(--agent-display); font-size: 15px; color: var(--agent-coral-dark); }
.method-row { display: flex; align-items: center; gap: 12px; padding: 8px 0; }
.method-row__label { width: 118px; font-size: 12.5px; color: var(--agent-ink); flex-shrink: 0; }
.method-row__amt { width: 64px; text-align: right; font-family: var(--agent-display); font-size: 14px; color: var(--agent-ink); flex-shrink: 0; }

/* Délai distribution */
.dist-row { display: flex; align-items: center; gap: 12px; padding: 8px 0; }
.dist-row__label { width: 70px; font-size: 12.5px; color: var(--agent-ink-soft); flex-shrink: 0; }
.dist-row__n { width: 26px; text-align: right; font-size: 12.5px; color: var(--agent-ink); font-weight: 600; flex-shrink: 0; }

/* Motifs de refus */
.reason-row { display: flex; align-items: center; gap: 12px; padding: 8px 0; }
.reason-row__label { width: 200px; font-size: 12.5px; color: var(--agent-ink); flex-shrink: 0;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.reason-row__pct { width: 52px; text-align: right; font-family: var(--agent-display); font-size: 14px; color: var(--agent-ink); flex-shrink: 0; }

/* Backlog list */
.backlog-row { display: flex; align-items: center; gap: 11px; padding: 9px 6px; border-radius: 12px;
  text-decoration: none; color: inherit; }
.backlog-row:hover { background: var(--agent-surface-alt); }
.backlog-row__name { font-size: 13.5px; color: var(--agent-ink); font-weight: 500; }
.backlog-row__plan { font-size: 12px; color: var(--agent-ink-soft); }
.backlog-row__fees { font-size: 11.5px; color: var(--agent-ink-soft); margin-top: 2px; }

/* Trend bars */
.trend { display: flex; align-items: flex-end; gap: 16px; height: 168px; }
.trend-col { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 9px; height: 100%; justify-content: flex-end; }
.trend-col__v { font-size: 11.5px; color: var(--agent-ink-soft); font-weight: 500; }
.trend-col__v--cur { color: var(--agent-coral-dark); font-weight: 700; }
.trend-bar { width: 100%; max-width: 50px; background: var(--agent-bg-deep); border-radius: 8px 8px 0 0; }
.trend-bar--cur { background: var(--agent-coral); }
.trend-col__m { font-size: 12px; color: var(--agent-ink-soft); }
.trend-col__m--cur { color: var(--agent-ink); font-weight: 600; }

@media (max-width: 1100px) {
  .pilot-grid-4 { grid-template-columns: repeat(2, 1fr); }
  .pilot-grid-2 { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  .pilot-grid-4 { grid-template-columns: 1fr; }
  .pilot-head { padding: 16px 18px; }
  .pilot-body { padding: 16px 18px 40px; }
  .donut-row { flex-direction: column; align-items: stretch; }
}

/* ── Plan de traitement · state-based page layouts ─────────────────────── */

/* Section header: icon-box + display title + subtitle + optional right slot */
.plan-sh { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.plan-sh__icon { width: 36px; height: 36px; border-radius: 11px; flex-shrink: 0;
  background: var(--agent-coral-wash); display: flex; align-items: center; justify-content: center; }
.plan-sh__icon .material-symbols-outlined { font-size: 20px; color: var(--agent-coral-dark); }
.plan-sh__title { font-family: var(--agent-display); font-size: 19px; color: var(--agent-ink); line-height: 1.15; }
.plan-sh__sub { font-size: 12.5px; color: var(--agent-ink-soft); margin-top: 1px; }
.plan-sh + .plan-sh-block { margin-top: 0; }

/* 2-column state grids */
.plan-2col { display: grid; gap: 22px; align-items: start; }
.plan-2col--1210 { grid-template-columns: 1.25fr 1fr; }
.plan-2col--1410 { grid-template-columns: 1.4fr 1fr; }

/* Coloured callout (plan note) — success / neutral tones */
.plan-note { display: flex; align-items: flex-start; gap: 10px; font-size: 12.5px;
  line-height: 1.5; border-radius: 12px; padding: 11px 13px; }
.plan-note--success { color: var(--agent-success); background: var(--agent-success-light); }
.plan-note--neutral { color: var(--agent-ink-soft); background: var(--agent-surface-alt);
  border: 1px solid var(--agent-line); }
.plan-note .material-symbols-outlined { font-size: 17px; flex-shrink: 0; margin-top: 1px; }

/* Séance progress strip */
.plan-progress { display: flex; align-items: center; gap: 12px; }
.plan-progress__bar { flex: 1; height: 8px; border-radius: 4px; background: var(--agent-bg-deep); overflow: hidden; }
.plan-progress__fill { height: 100%; background: var(--agent-coral); border-radius: 4px; }
.plan-progress__label { font-size: 12.5px; color: var(--agent-ink-soft); font-weight: 500; white-space: nowrap; }

/* Consultation row (En cours / Terminé) */
.consult-row { display: flex; align-items: center; gap: 14px; padding: 14px 16px; cursor: pointer; }
.consult-row:hover { background: var(--agent-surface-alt); }
.consult-row__icon { width: 40px; height: 40px; border-radius: 12px; display: flex; align-items: center;
  justify-content: center; flex-shrink: 0; position: relative; }
.consult-row__num { position: absolute; bottom: -5px; right: -5px; width: 18px; height: 18px;
  border-radius: 50%; background: var(--agent-surface); border: 1px solid var(--agent-line);
  font-family: var(--agent-display); font-size: 11px; color: var(--agent-ink-soft);
  display: flex; align-items: center; justify-content: center; }
.consult-row__title { font-size: 14.5px; font-weight: 600; color: var(--agent-ink); }
.consult-row__meta { display: flex; align-items: center; gap: 12px; margin-top: 4px;
  font-size: 12.5px; color: var(--agent-ink-soft); flex-wrap: wrap; }
.consult-row__meta span { display: inline-flex; align-items: center; gap: 5px; }
.consult-row__meta .material-symbols-outlined { font-size: 14px; }

/* Act chips inside consultation rows */
.act-chip { font-size: 12px; color: var(--agent-ink); background: var(--agent-bg-deep);
  border-radius: 7px; padding: 4px 9px; display: inline-block; white-space: nowrap; }

/* Compte rendu (notes) on a réalisée séance — collapsible block under the row */
.seance-report { padding: 0 16px 14px 70px; }
.seance-report__summary { display: flex; align-items: center; gap: 8px; cursor: pointer;
  list-style: none; font-size: 13px; font-weight: 600; color: var(--agent-ink-soft);
  padding: 6px 0; user-select: none; }
.seance-report__summary::-webkit-details-marker { display: none; }
.seance-report__summary .material-symbols-outlined { color: var(--agent-coral-dark); }
.seance-report__label { flex-shrink: 0; }
.seance-report__preview { font-weight: 400; color: var(--agent-ink-faint); min-width: 0;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.seance-report__hint { font-weight: 400; color: var(--agent-ink-faint); font-style: italic; }
.seance-report__area { width: 100%; resize: vertical; }

/* Plan financial hero card (dark, top of hub-body) */
.plan-fin-card { width: 240px; flex-shrink: 0; background: var(--agent-ink); color: #fff;
  border-radius: 16px; padding: 16px 18px; }

@media (max-width: 900px) {
  .plan-2col--1210, .plan-2col--1410 { grid-template-columns: 1fr; }
  .plan-fin-card { width: 100%; }
}
