/* ═══════════════════════════════════════════════════════════════════
   Donna Vente — Sidepanel chrome
   Pour migration des modals "Nouveau X" en side-panel droit.
   À charger APRÈS modal.css (réutilise tokens, .field, .form-grid,
   .m-section, .check-list, .input-affix, .dpe-picker, .radio-strip,
   .link-card, .dropzone, .photo-grid, .btn).
   ═══════════════════════════════════════════════════════════════════ */

/* ── Overlay (léger, la liste reste visible) ─────────────── */
.sp-overlay{
  position:fixed; inset:0;
  background:rgba(20,22,31,.18);
  backdrop-filter:blur(1.5px);
  z-index:200;
  animation:spFade .16s ease-out;
}
:root[data-theme="noir"] .sp-overlay{ background:rgba(0,0,0,.45); }
@keyframes spFade{ from{opacity:0} to{opacity:1} }

/* ── Panel ──────────────────────────────────────────────── */
.sp{
  position:fixed;
  top:0; right:0; bottom:0;
  left:auto;
  width:520px; max-width:100vw;
  height:100vh; max-height:100vh;
  margin:0;
  background:var(--surface);
  border-left:1px solid var(--border);
  box-shadow:-16px 0 40px rgba(20,22,31,.12);
  display:flex; flex-direction:column;
  z-index:201;
  animation:spSlide .22s cubic-bezier(.2,.8,.3,1);
}
:root[data-theme="noir"] .sp{ box-shadow:-16px 0 40px rgba(0,0,0,.5); }
.sp[data-width="xl"]{ width:720px; }
.sp[data-width="md"]{ width:560px; }
@keyframes spSlide{ from{transform:translateX(40px); opacity:0} to{transform:translateX(0); opacity:1} }

/* ── Header ─────────────────────────────────────────────── */
.sp-head{
  flex-shrink: 0;  /* [v669] ne pas laisser le header s'écraser */
  padding:16px 22px 14px;
  border-bottom:1px solid var(--border);
  display:flex; align-items:flex-start; gap:12px;
  background:var(--surface);
}
.sp-title{ flex:1; min-width:0; display:flex; flex-direction:column; gap:2px; }
.sp-crumb{
  font-size:10.5px; font-weight:700; letter-spacing:.4px;
  text-transform:uppercase; color:var(--muted);
}
.sp-title h2{
  font-family:'Plus Jakarta Sans', sans-serif;
  font-size:18px; font-weight:700; letter-spacing:-.3px;
  margin:0; color:var(--text);
}
.sp-title p{
  font-size:12px; color:var(--text-dim);
  margin:0; line-height:1.4;
}
.sp-head-r{ display:flex; align-items:center; gap:8px; flex-shrink:0; }
.sp-autosave{
  display:inline-flex; align-items:center; gap:5px;
  font-size:10.5px; color:var(--muted); font-weight:500;
  padding:3px 7px; border-radius:999px;
  background:var(--s2);
}
.sp-autosave .dot{
  width:5px; height:5px; border-radius:50%;
  background:var(--green);
  animation:spPulse 2s ease-in-out infinite;
}
@keyframes spPulse{ 0%,100%{opacity:1} 50%{opacity:.4} }
.sp-close{
  width:28px; height:28px;
  display:grid; place-items:center;
  border:1px solid var(--border); border-radius:var(--radius);
  background:var(--surface); color:var(--text-dim);
  cursor:pointer; transition:all .12s;
}
.sp-close:hover{ background:var(--s2); color:var(--text); border-color:var(--border-hi); }

/* v779 — Bouton Import IA dans sp-head des modals (m-bien, etc.)
   Permet de pré-remplir le formulaire via analyse d'un screenshot
   (cf openBienImport() dans biens.js). [v781] Icône ✦ donna (cohérence avec
   tout le reste du code, cf instinct/chat/alerts/brief). */
.sp-import-ai{
  display:inline-flex; align-items:center; gap:6px;
  height:28px; padding:0 11px 0 10px;
  border:1px solid var(--border); border-radius:var(--radius);
  background:var(--surface); color:var(--text);
  font-family:inherit; font-size:11.5px; font-weight:500;
  cursor:pointer; transition:all .12s;
  white-space:nowrap;
}
.sp-import-ai:hover{
  background:var(--s2);
  border-color:color-mix(in srgb, var(--accent) 35%, var(--border));
  color:var(--text);
}
.sp-import-ai-mark{
  color:var(--accent);
  flex-shrink:0;
  transition:transform .25s;
}
.sp-import-ai:hover .sp-import-ai-mark{ transform:rotate(72deg); }
/* Mobile : on cache le label, on garde l'icône sparkle */
@media(max-width:600px){
  .sp-import-ai span:not(.sp-import-ai-mark){ display:none; }
  .sp-import-ai{ padding:0 9px; }
}

/* ── Split body : rail (vertical) + pane ────────────────── */

.sp[data-width="xl"] .sp-rail{ flex-basis:172px; }

.sp-rail .tab-ic{
  width:18px; height:18px;
  display:grid; place-items:center;
  color:var(--text-dim); flex-shrink:0;
}
.sp-rail button[data-active="true"] .tab-ic{ color:var(--accent); }
.sp-rail .tab-status{
  margin-left:auto;
  width:14px; height:14px;
  display:grid; place-items:center;
}
.sp-rail .tab-dot{
  width:6px; height:6px; border-radius:50%;
  background:var(--border-hi);
}
.sp-rail button[data-filled="partial"] .tab-dot{ background:var(--tiede); }
.sp-rail button[data-filled="true"] .tab-status{ color:var(--green); }

/* ── Single-pane body (sans rail, ex: Client, Dossiers) ── */
.sp-body{
  flex:1 1 auto;
  min-height:0;  /* nécessaire pour que overflow-y:auto fonctionne dans flex */
  overflow-y:auto;
  padding:16px 22px 22px;
  background:var(--surface);
  display:flex; flex-direction:column; gap:16px;
}

/* ── Segment-row (toggle sous le header, ex: Acq/Vend) ──── */
.sp-segment-row{
  flex-shrink: 0;  /* [v669] ne pas s'écraser */
  padding:10px 22px 12px;
  background:var(--surface);
  border-bottom:1px solid var(--border);
  display:flex; align-items:center; gap:10px;
}

/* ── Pane (zone scrollable) ─────────────────────────────── */

/* ── Footer ─────────────────────────────────────────────── */
.sp-foot{
  flex-shrink: 0;  /* [v669] CRUCIAL : sans ça le footer prenait 615px */
  border-top:1px solid var(--border);
  padding:12px 22px;
  display:flex; align-items:center; justify-content:space-between;
  gap:12px;
  background:var(--s2);
}
.sp-foot-meta{
  font-size:11px; color:var(--muted);
  display:flex; align-items:center; gap:6px;
}
.sp-foot-meta kbd{
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  padding:1px 5px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:3px;
  color:var(--text-dim);
}
.sp-foot-actions{ display:flex; gap:6px; align-items:center; }

/* ── Pane navigation (prev / next entre tabs) ───────────── */

.sp-pane-nav .spacer{ flex:1; }

/* ── Override modal-css width for inline forms (les .field
       gardent leur look natif, juste la grille colle au panel) — */
.sp .form-grid.cols-3{ grid-template-columns:repeat(3, 1fr); }
.sp .form-grid.cols-4{ grid-template-columns:repeat(2, 1fr); } /* 4 trop serré en panel 520 */
.sp[data-width="xl"] .form-grid.cols-4{ grid-template-columns:repeat(4, 1fr); }

/* Petits ajustements densité pour gagner de la place */
.sp .m-section{ padding:0; background:transparent; border:none; }
.sp .m-section-label{
  font-size:10px; font-weight:700; letter-spacing:.5px;
  text-transform:uppercase; color:var(--muted);
  margin:6px 0 8px; padding-bottom:6px;
  border-bottom:1px solid var(--border);
}
.sp .m-section-label::after{ display:none; }

/* ═══════════════════════════════════════════════════════════════════
   Re-styling des classes form-modal legacy (fm-section, fm-row, fm-group,
   fm-input/select/textarea, etc.) à l'intérieur d'un .sp.
   
   Les règles originales dans shell-v2.css sont scopées à ".form-modal
   .fm-body" → ne s'appliquent plus dans nos <aside class="sp">. On
   duplique ici les règles utiles en les scopant à .sp .sp-body.
   ═══════════════════════════════════════════════════════════════════ */

/* fm-section : titre de section avec ligne décorative */
.sp .sp-body .fm-section {
  font-size: 11px;
  color: var(--accent);
  letter-spacing: 1.2px;
  text-transform: uppercase;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
}
.sp .sp-body .fm-section::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--border);
  opacity: .6;
}
.sp .sp-body > .fm-section:first-of-type {
  margin-top: 0;
}

/* fm-row : grid de champs */
.sp .sp-body .fm-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.sp .sp-body .fm-row.three {
  grid-template-columns: 1fr 1fr 1fr;
}
.sp .sp-body .fm-row.full {
  grid-template-columns: 1fr;
}

/* fm-group : un champ avec label + input */
.sp .sp-body .fm-group {
  display: flex;
  flex-direction: column;
  gap: 5px;
  min-width: 0;
}
.sp .sp-body .fm-lbl {
  font-size: 10.5px;
  color: var(--muted);
  letter-spacing: .3px;
  text-transform: uppercase;
  font-weight: 600;
}

/* fm-input/select/textarea : style des champs de saisie */
.sp .sp-body .fm-input,
.sp .sp-body .fm-select,
.sp .sp-body .fm-textarea {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--text);
  padding: 8px 12px;
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  outline: none;
  transition: border-color .15s, box-shadow .15s;
  width: 100%;
}
.sp .sp-body .fm-input:focus,
.sp .sp-body .fm-select:focus,
.sp .sp-body .fm-textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 12%, transparent);
}
.sp .sp-body .fm-input::placeholder,
.sp .sp-body .fm-textarea::placeholder {
  color: var(--muted);
}
.sp .sp-body .fm-select {
  appearance: none;
  cursor: pointer;
}
.sp .sp-body .fm-textarea {
  resize: vertical;
  min-height: 65px;
}

/* fm-acq-fields & fm-vend-fields : wrapper des sections conditionnelles */
.sp .sp-body .fm-acq-fields,
.sp .sp-body .fm-vend-fields {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* sp-segment-row : positionnement du toggle 3-way sous le header */
.sp .sp-segment-row {
  padding: 12px 22px;
  border-bottom: 1px solid var(--border);
  background: var(--surface);
}
.sp .sp-segment-row .mg-type-toggle {
  display: flex;
  gap: 0;
  background: var(--s2);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 3px;
  width: 100%;
}
.sp .sp-segment-row .mg-type-toggle button {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 7px 10px;
  background: transparent;
  border: none;
  border-radius: 7px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: all .15s;
}
.sp .sp-segment-row .mg-type-toggle button:hover {
  color: var(--text);
}
.sp .sp-segment-row .mg-type-toggle button[data-active="true"] {
  background: var(--surface);
  color: var(--text);
  box-shadow: 0 1px 3px rgba(0,0,0,.08);
}
.sp .sp-segment-row .mg-type-toggle button[data-active="true"] svg {
  color: var(--accent);
}

/* mg-ai-import : bloc d'import IA */
/* [v1102] CSS .mg-ai-import dans sidepanel retiré (overrides obsolètes).
   shell-v2.css L2364+ gère maintenant proprement avec la refonte sobre + nouveau icon donna. */
.sp .sp-body .mg-parse-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 6px 12px;
  background: var(--accent);
  border: none;
  border-radius: 7px;
  color: #fff;
  font-size: 11.5px;
  font-weight: 600;
  cursor: pointer;
  transition: opacity .15s;
}
.sp .sp-body .mg-parse-btn:disabled {
  opacity: .5;
  cursor: not-allowed;
}

/* qtag (quartiers tags) */
.sp .sp-body .qtag-wrap {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  min-height: 38px;
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  padding: 4px 6px;
  align-items: center;
}
.sp .sp-body .qtag-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

/* Footer buttons : Annuler (ghost) + Créer/Enregistrer (primary) */
.sp-foot .sp-foot-actions .btn {
  padding: 8px 14px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: all .12s;
  border: 1px solid var(--border);
}
.sp-foot .sp-foot-actions .btn-ghost {
  background: var(--surface);
  color: var(--text);
}
.sp-foot .sp-foot-actions .btn-ghost:hover {
  background: var(--s2);
}

/* fm-acq-fields / fm-vend-fields : sections conditionnelles affichées
   selon le toggle 3-way (avSetKind). Visible sauf si display:none inline. */
.sp .sp-body > .fm-acq-fields:not([style*="display:none"]):not([style*="display: none"]),
.sp .sp-body > .fm-vend-fields:not([style*="display:none"]):not([style*="display: none"]) {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* Bouton primary footer (remplace l'ancien split-button) */
.sp-foot .btn-primary {
  background: var(--text);
  color: var(--surface);
  border: 1px solid var(--text);
  padding: 8px 16px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  transition: opacity .12s;
}
.sp-foot .btn-primary:hover {
  opacity: .9;
}

/* [v671] Support .sp.open pour les modals qui utilisent classList.add('open')
   au lieu de style.display='flex' (cas de ca-add-overlay). */
.sp.open {
  display: flex !important;
}
