/* ──────────────────────────────────────────────────────────────────
   Module 18 — Fournisseurs & Achats
   Design system : teal/gold/obsidian, Cormorant + Montserrat, grille 4px
   Charte raffinée : underlines plutôt que pills pleins, tags discrets.
   ────────────────────────────────────────────────────────────────── */

.four-view,
.four-modal-scrim {           /* modales téléportées dans <body> : redéfinir les vars hors .four-view */
  --four-border:   var(--border, rgba(255,255,255,.08));
  --four-bg-card:  var(--bg-secondary, rgba(255,255,255,.02));
  --four-bg-hover: rgba(34,118,102,.06);
  --four-txm:      var(--txm, rgba(255,255,255,.55));
  --four-txh:      var(--txh, rgba(255,255,255,.92));
  --four-red:      #e57373;
}

/* ─── Header ────────────────────────────────────────────────────── */
.four-header {
  padding: 28px 32px 16px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 24px;
  flex-wrap: wrap;
}
.four-header-titles { min-width: 320px; max-width: 720px; }
.four-title {
  margin: 0 0 6px;
  font-family: 'Cormorant Garamond', serif;
  font-weight: 500;
  font-size: 32px;
  letter-spacing: -.01em;
  color: var(--four-txh);
}
.four-subtitle {
  margin: 0;
  font-family: 'Montserrat', sans-serif;
  font-size: 12.5px;
  color: var(--four-txm);
  line-height: 1.5;
  max-width: 640px;
}
.four-header-actions {
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
}

/* ─── Pills entité (segmented) ──────────────────────────────────── */
.four-entity-pills {
  display: inline-flex;
  background: var(--four-bg-card);
  border: 1px solid var(--four-border);
  border-radius: 6px;
  padding: 2px;
  gap: 1px;
}
.four-entity-pill {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .04em;
  padding: 6px 12px;
  background: transparent;
  border: 0;
  border-radius: 4px;
  color: var(--four-txm);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: all .15s ease;
}
.four-entity-pill:hover { color: var(--four-txh); }
.four-entity-pill .four-entity-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--four-txm);
  transition: background .15s ease;
}
.four-entity-pill[data-code="astorm"] .four-entity-dot     { background: var(--teal); }
.four-entity-pill[data-code="sateliance"] .four-entity-dot { background: var(--gold); }
.four-entity-pill[data-code="astorm_mea"] .four-entity-dot { background: #a78bfa; }
.four-entity-pill.active {
  background: rgba(255,255,255,.04);
  color: var(--four-txh);
  box-shadow: inset 0 0 0 1px var(--four-border);
}

/* ─── Bouton primaire/secondaire ────────────────────────────────── */
.four-btn {
  font-family: 'Montserrat', sans-serif;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .02em;
  padding: 9px 14px;
  border-radius: 4px;
  border: 1px solid transparent;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: all .15s ease;
  white-space: nowrap;
}
.four-btn-primary {
  background: var(--teal);
  color: #fff;
}
.four-btn-primary:hover { filter: brightness(1.08); }
.four-btn-secondary {
  background: transparent;
  color: var(--four-txh);
  border-color: var(--four-border);
}
.four-btn-secondary:hover {
  background: var(--four-bg-card);
  border-color: rgba(255,255,255,.18);
}

/* ─── Body & KPIs ───────────────────────────────────────────────── */
.four-body { padding: 0 32px 48px; }

.four-kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 24px;
}
@media (max-width: 1100px) {
  .four-kpi-grid { grid-template-columns: repeat(2, 1fr); }
}
.four-kpi {
  background: var(--four-bg-card);
  border: 1px solid var(--four-border);
  border-radius: 8px;
  padding: 18px 20px;
  position: relative;
  transition: border-color .15s ease;
}
.four-kpi:hover { border-color: rgba(255,255,255,.14); }
.four-kpi.four-alert { border-color: rgba(229,115,115,.35); }
.four-kpi-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--four-txm);
  margin-bottom: 8px;
}
.four-kpi-value {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 500;
  font-size: 32px;
  line-height: 1;
  letter-spacing: -.01em;
}
.four-v-teal { color: var(--teal); }
.four-v-gold { color: var(--gold); }
.four-v-red  { color: var(--four-red); }
.four-kpi-sub {
  margin-top: 6px;
  font-size: 11px;
  color: var(--four-txm);
}

/* ─── Tabs ──────────────────────────────────────────────────────── */
.four-tabs {
  display: flex;
  gap: 4px;
  border-bottom: 1px solid var(--four-border);
  margin-bottom: 20px;
  overflow-x: auto;
}
.four-tab {
  background: transparent;
  border: 0;
  border-bottom: 2px solid transparent;
  font-family: 'Montserrat', sans-serif;
  font-size: 12.5px;
  font-weight: 500;
  letter-spacing: .01em;
  color: var(--four-txm);
  padding: 12px 16px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: color .15s ease, border-color .15s ease;
  white-space: nowrap;
}
.four-tab:hover { color: var(--four-txh); }
.four-tab.active {
  color: var(--gold);
  border-bottom-color: var(--gold);
  font-weight: 600;
}
.four-tab-count {
  display: inline-block;
  font-size: 10px;
  font-weight: 600;
  padding: 2px 7px;
  border-radius: 10px;
  background: rgba(255,255,255,.06);
  color: var(--four-txm);
  min-width: 18px;
  text-align: center;
}
.four-tab.active .four-tab-count {
  background: rgba(201,168,76,.16);
  color: var(--gold);
}
.four-tab-count-red {
  background: rgba(229,115,115,.16) !important;
  color: var(--four-red) !important;
}

/* ─── Toolbar (search + filtres) ────────────────────────────────── */
.four-pane { animation: fourFade .18s ease; }
@keyframes fourFade { from { opacity: 0; transform: translateY(2px); } to { opacity: 1; transform: none; } }

.four-toolbar {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: 16px;
}
.four-search {
  flex: 1;
  min-width: 240px;
  position: relative;
  display: flex;
  align-items: center;
  background: var(--four-bg-card);
  border: 1px solid var(--four-border);
  border-radius: 4px;
  padding: 0 12px;
  transition: border-color .15s ease;
}
.four-search:focus-within { border-color: var(--teal); }
.four-search svg { color: var(--four-txm); flex-shrink: 0; }
.four-search input {
  background: transparent;
  border: 0;
  outline: 0;
  padding: 10px 10px;
  font-family: 'Montserrat', sans-serif;
  font-size: 13px;
  color: var(--four-txh);
  flex: 1;
}
.four-search input::placeholder { color: var(--four-txm); }

.four-select {
  background: var(--four-bg-card);
  border: 1px solid var(--four-border);
  border-radius: 4px;
  padding: 9px 12px;
  font-family: 'Montserrat', sans-serif;
  font-size: 12.5px;
  color: var(--four-txh);
  cursor: pointer;
  transition: border-color .15s ease;
}
.four-select:hover, .four-select:focus { border-color: rgba(255,255,255,.18); outline: 0; }

.four-check {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: 'Montserrat', sans-serif;
  font-size: 12px;
  color: var(--four-txm);
  cursor: pointer;
  user-select: none;
}
.four-check input { accent-color: var(--teal); cursor: pointer; }

/* ─── Table ─────────────────────────────────────────────────────── */
.four-table {
  background: var(--four-bg-card);
  border: 1px solid var(--four-border);
  border-radius: 8px;
  overflow: hidden;
}
.four-thead,
.four-row {
  display: grid;
  grid-template-columns: 130px 1fr 180px 110px 100px 120px;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
}
.four-thead {
  background: rgba(255,255,255,.02);
  border-bottom: 1px solid var(--four-border);
  font-family: 'Montserrat', sans-serif;
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--four-txm);
}
.four-row {
  border-bottom: 1px solid rgba(255,255,255,.03);
  cursor: pointer;
  transition: background .12s ease;
  font-family: 'Montserrat', sans-serif;
  font-size: 13px;
  color: var(--four-txh);
}
.four-row:last-child { border-bottom: 0; }
.four-row:hover { background: var(--four-bg-hover); }
.four-row-title { font-weight: 600; }
.four-row-sub {
  font-size: 10.5px;
  color: var(--four-txm);
  margin-top: 2px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.four-row-sub-red  { color: var(--four-red); }
.four-row-sub-gold { color: var(--gold); }

/* Typo data : Outfit Light tabular (charte CEO mai 2026) — jamais de monospace. */
.four-num {
  font-family: 'Outfit', sans-serif;
  font-weight: 300;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1, "lnum" 1;
  letter-spacing: 0;
}
.four-c-code  { font-family: 'Outfit', sans-serif; font-weight: 300; font-variant-numeric: tabular-nums; font-size: 12.5px; }
.four-c-ca    { font-family: 'Outfit', sans-serif; font-weight: 300; font-variant-numeric: tabular-nums; font-size: 13px; text-align: right; }
.four-c-iban, .four-c-statut, .four-c-cat { display: flex; }

.four-code-pill {
  display: inline-block;
  padding: 3px 8px;
  background: rgba(34,118,102,.10);
  color: var(--teal);
  border-radius: 4px;
  font-weight: 600;
  letter-spacing: .02em;
}

/* ─── Tags (discrets, pas de fills criards) ─────────────────────── */
.four-tag {
  display: inline-block;
  font-family: 'Montserrat', sans-serif;
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: .04em;
  padding: 3px 9px;
  border-radius: 20px;
  border: 1px solid transparent;
}
.four-tag-teal {
  background: rgba(34,118,102,.10);
  color: var(--teal);
  border-color: rgba(34,118,102,.25);
}
.four-tag-gold {
  background: rgba(201,168,76,.10);
  color: var(--gold);
  border-color: rgba(201,168,76,.25);
}
.four-tag-red {
  background: rgba(229,115,115,.10);
  color: var(--four-red);
  border-color: rgba(229,115,115,.30);
}
.four-tag-mute {
  background: rgba(255,255,255,.04);
  color: var(--four-txm);
  border-color: rgba(255,255,255,.08);
}

/* ─── Empty states ──────────────────────────────────────────────── */
.four-empty {
  padding: 56px 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: var(--four-txm);
  gap: 8px;
}
.four-empty-icon {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: rgba(255,255,255,.025);
  border: 1px solid var(--four-border);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--four-txm);
  margin-bottom: 8px;
}
.four-empty-icon-ok { color: var(--teal); border-color: rgba(34,118,102,.25); background: rgba(34,118,102,.06); }
.four-empty-title {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 500;
  font-size: 22px;
  color: var(--four-txh);
  margin: 0;
}
.four-empty-text {
  font-family: 'Montserrat', sans-serif;
  font-size: 13px;
  color: var(--four-txm);
  max-width: 380px;
  line-height: 1.5;
  margin-bottom: 8px;
}

/* ─── Foot ──────────────────────────────────────────────────────── */
.four-foot {
  margin-top: 12px;
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  color: var(--four-txm);
  text-align: right;
}

/* ─── Factures (table à 7 colonnes) ─────────────────────────────── */
.four-table .four-thead:has(.four-fc-num),
.four-table .four-row:has(.four-fc-num) {
  grid-template-columns: 140px 1fr 110px 110px 120px 120px 180px;
}
.four-fc-num   { font-family: 'Outfit', sans-serif; font-weight: 300; font-variant-numeric: tabular-nums; font-size: 12.5px; }
.four-fc-date  { font-size: 12px; }
.four-fc-amt   { font-family: 'Outfit', sans-serif; font-weight: 300; font-variant-numeric: tabular-nums; font-size: 13.5px; text-align: right; }
.four-amt-due  { color: var(--gold); }
.four-amt-ok   { color: var(--teal); }
.four-late     { color: var(--four-red); font-weight: 600; }
.four-fc-statut { display: flex; gap: 4px; align-items: center; }

/* ─── Alertes IBAN cards ────────────────────────────────────────── */
.four-alert-card {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px 20px;
  background: rgba(229,115,115,.04);
  border: 1px solid rgba(229,115,115,.18);
  border-left: 3px solid var(--four-red);
  border-radius: 6px;
  margin-bottom: 10px;
}
.four-alert-icon {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: rgba(229,115,115,.10);
  color: var(--four-red);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.four-alert-body { flex: 1; }
.four-alert-title {
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-size: 14px;
  color: var(--four-txh);
}
.four-alert-meta {
  font-size: 11px;
  color: var(--four-txm);
  margin-top: 2px;
}
.four-alert-iban {
  font-family: 'Outfit', sans-serif;
  font-weight: 300;
  font-variant-numeric: tabular-nums;
  font-size: 12.5px;
  text-align: right;
}
.four-alert-iban-row { line-height: 1.6; }
.four-mute { color: var(--four-txm); }
.four-gold { color: var(--gold); }
.four-red  { color: var(--four-red); }

/* ════════════════════════════════════════════════════════════════════
   DRAWER FICHE FOURNISSEUR — refonte premium (sortie du skin Bloomberg)
   Air France La Première : panneau latéral silencieux, généreux, posé.
   ════════════════════════════════════════════════════════════════════ */
.four-scrim {
  position: fixed; inset: 0; z-index: 1200;
  display: flex; justify-content: flex-end;
  background: rgba(8, 10, 10, .58);
  backdrop-filter: blur(6px) saturate(130%);
  -webkit-backdrop-filter: blur(6px) saturate(130%);
}
.four-drawer {
  width: min(820px, 92vw);
  height: 100%;
  display: flex; flex-direction: column;
  background: var(--obs, #0b0d0d);
  border-left: 1px solid var(--four-border);
  box-shadow: -40px 0 90px -30px rgba(0, 0, 0, .7);
}

/* En-tête */
.four-drawer-head {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 20px;
  padding: 28px 32px 18px;
  border-bottom: 1px solid var(--four-border);
}
.four-eyebrow {
  font-family: 'Montserrat', sans-serif;
  font-size: 10px; font-weight: 600; letter-spacing: .14em;
  text-transform: uppercase; color: var(--four-txm);
  margin-bottom: 6px;
}
.four-drawer-title {
  margin: 0 0 12px;
  font-family: 'Cormorant Garamond', serif;
  font-weight: 500; font-size: 30px; line-height: 1.05;
  letter-spacing: -.01em; color: var(--four-txh);
}
.four-drawer-chips { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.four-drawer-head-actions { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }

.four-icon-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 34px; height: 34px;
  border-radius: 6px; border: 1px solid var(--four-border);
  background: transparent; color: var(--four-txm);
  cursor: pointer; transition: all .15s ease;
}
.four-icon-btn:hover { color: var(--four-txh); background: var(--four-bg-card); border-color: rgba(255,255,255,.18); }
.four-icon-btn-danger:hover { color: var(--four-red); border-color: rgba(229,115,115,.4); background: rgba(229,115,115,.08); }

/* Sous-onglets */
.four-subtabs {
  display: flex; gap: 2px;
  padding: 0 32px;
  border-bottom: 1px solid var(--four-border);
  overflow-x: auto;
}
.four-subtab {
  background: transparent; border: 0;
  border-bottom: 2px solid transparent;
  font-family: 'Montserrat', sans-serif;
  font-size: 12px; font-weight: 500; letter-spacing: .02em;
  color: var(--four-txm);
  padding: 13px 14px; cursor: pointer;
  white-space: nowrap;
  transition: color .15s ease, border-color .15s ease;
}
.four-subtab:hover { color: var(--four-txh); }
.four-subtab.active { color: var(--teal); border-bottom-color: var(--teal); font-weight: 600; }

/* Corps scrollable */
.four-drawer-body { flex: 1; overflow-y: auto; padding: 24px 32px 32px; }

/* Pied sticky */
.four-drawer-foot {
  display: flex; justify-content: flex-end; gap: 10px;
  padding: 16px 32px;
  border-top: 1px solid var(--four-border);
  background: rgba(255,255,255,.012);
}

/* Sections de formulaire */
.four-fieldset { margin-bottom: 28px; }
.four-fieldset:last-child { margin-bottom: 0; }
.four-fieldset-legend {
  font-family: 'Montserrat', sans-serif;
  font-size: 10px; font-weight: 600; letter-spacing: .12em;
  text-transform: uppercase; color: var(--gold);
  padding-bottom: 10px; margin-bottom: 16px;
  border-bottom: 1px solid var(--four-border);
}
.four-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px 20px; }
.four-field { display: flex; flex-direction: column; gap: 6px; }
.four-field .nx-input,
.four-field .nx-select,
.four-field .nx-textarea { width: 100%; }

/* Lectures seules (Compta) */
.four-readouts {
  display: grid; grid-template-columns: 1fr 1fr; gap: 1px;
  background: var(--four-border);
  border: 1px solid var(--four-border);
  border-radius: 8px; overflow: hidden;
}
.four-readout {
  display: flex; flex-direction: column; gap: 6px;
  padding: 16px 18px;
  background: var(--four-bg-card);
}
.four-readout-l {
  font-family: 'Montserrat', sans-serif;
  font-size: 10px; font-weight: 600; letter-spacing: .08em;
  text-transform: uppercase; color: var(--four-txm);
}
.four-readout-v { font-size: 19px; color: var(--four-txh); }

/* Mini-tables (banques / factures / historique) */
.four-section-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 14px;
}
.four-section-count {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px; letter-spacing: .04em; color: var(--four-txm);
}
.four-mtable {
  border: 1px solid var(--four-border);
  border-radius: 8px; overflow: hidden;
}
.four-mhead, .four-mrow {
  display: grid; align-items: center; gap: 12px;
  padding: 11px 16px;
}
.four-mhead {
  background: rgba(255,255,255,.02);
  border-bottom: 1px solid var(--four-border);
  font-family: 'Montserrat', sans-serif;
  font-size: 10px; font-weight: 600; letter-spacing: .08em;
  text-transform: uppercase; color: var(--four-txm);
}
.four-mrow {
  border-bottom: 1px solid rgba(255,255,255,.03);
  font-family: 'Montserrat', sans-serif;
  font-size: 12.5px; color: var(--four-txh);
}
.four-mrow:last-child { border-bottom: 0; }
.four-mrow-click { cursor: pointer; transition: background .12s ease; }
.four-mrow-click:hover { background: var(--four-bg-hover); }
.four-mrow-title { font-weight: 600; }
.four-mrow-sub { font-size: 11px; color: var(--four-txm); margin-top: 2px; }
.four-mtable .cc { text-align: center; justify-self: center; }
.four-mtable .cr { text-align: right; justify-self: end; }
.four-mtable-banques .four-mhead,
.four-mtable-banques .four-mrow { grid-template-columns: 1fr 130px 110px 90px 100px 80px; }
.four-mtable-fact .four-mhead,
.four-mtable-fact .four-mrow { grid-template-columns: 130px 110px 1fr 120px 120px 130px; }
.four-mtable-hist .four-mhead,
.four-mtable-hist .four-mrow { grid-template-columns: 120px 130px 110px 1fr 120px; }
.four-mempty {
  padding: 32px 16px; text-align: center;
  font-family: 'Cormorant Garamond', serif; font-style: italic;
  font-size: 15px; color: var(--four-txm);
}

/* Encadré alerte fraude dans le drawer */
.four-alert-box {
  margin-top: 18px; padding: 16px 18px;
  background: rgba(229,115,115,.06);
  border: 1px solid rgba(229,115,115,.20);
  border-left: 3px solid var(--four-red);
  border-radius: 8px;
}
.four-alert-box-title {
  display: flex; align-items: center; gap: 8px;
  font-family: 'Montserrat', sans-serif; font-weight: 600; font-size: 13px;
  color: var(--four-red);
}
.four-alert-box-text { font-size: 12.5px; color: var(--four-txh); margin: 8px 0 4px; }
.four-alert-box-iban { font-size: 12px; color: var(--four-txm); margin-bottom: 12px; }

/* Couleurs texte utilitaires */
.four-text-teal { color: var(--teal); }
.four-text-gold { color: var(--gold); }
.four-text-red  { color: var(--four-red); }
.four-text-mute { color: var(--four-txm); }

/* Boutons complémentaires */
.four-btn-ghost {
  background: transparent; color: var(--four-txh);
  border-color: var(--four-border);
}
.four-btn-ghost:hover { background: var(--four-bg-card); border-color: rgba(255,255,255,.18); }
.four-btn-danger {
  background: rgba(229,115,115,.12); color: var(--four-red);
  border-color: rgba(229,115,115,.35);
}
.four-btn-danger:hover { background: rgba(229,115,115,.2); }
.four-btn-sm { padding: 6px 11px; font-size: 11px; }
.four-check-lg { font-size: 13px; color: var(--four-txh); padding: 4px 0; }

/* ════════════════════════════════════════════════════════════════════
   MODALES PREMIUM (nouveau fournisseur, IBAN, résoudre alerte)
   Pas de fermeture au clic extérieur (saisie) — croix + Annuler + Échap.
   ════════════════════════════════════════════════════════════════════ */
.four-modal-scrim {
  position: fixed; inset: 0; z-index: 1300;
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  background: rgba(8, 10, 10, .6);
  backdrop-filter: blur(8px) saturate(140%);
  -webkit-backdrop-filter: blur(8px) saturate(140%);
}
.four-modal {
  width: 100%; max-width: 560px;
  max-height: 90vh; display: flex; flex-direction: column;
  background: var(--obs, #0b0d0d);
  border: 1px solid var(--four-border);
  border-radius: 16px; overflow: hidden;
  box-shadow: 0 40px 90px -30px rgba(0,0,0,.7);
}
.four-modal-danger { border-color: rgba(229,115,115,.4); }
.four-modal-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; padding: 22px 24px 16px;
  border-bottom: 1px solid var(--four-border);
}
.four-modal-title {
  margin: 0; display: flex; align-items: center; gap: 8px;
  font-family: 'Cormorant Garamond', serif;
  font-weight: 500; font-size: 23px; letter-spacing: -.01em;
  color: var(--four-txh);
}
.four-modal-body {
  padding: 22px 24px; overflow-y: auto;
  display: flex; flex-direction: column; gap: 14px;
}
.four-modal-foot {
  display: flex; justify-content: flex-end; gap: 10px;
  padding: 16px 24px; border-top: 1px solid var(--four-border);
}
.four-modal-lead {
  margin: 0; font-family: 'Montserrat', sans-serif;
  font-size: 12.5px; line-height: 1.55; color: var(--four-txm);
}
.four-hint-gold {
  font-size: 11.5px; color: var(--gold);
  padding: 8px 12px; border-radius: 6px;
  background: rgba(201,168,76,.08);
  border: 1px solid rgba(201,168,76,.18);
}
.four-iban-check {
  font-size: 11.5px; padding: 8px 12px; border-radius: 6px;
}
.four-iban-check.ok { color: var(--teal); background: rgba(34,118,102,.10); border: 1px solid rgba(34,118,102,.22); }
.four-iban-check.ko { color: var(--four-red); background: rgba(229,115,115,.10); border: 1px solid rgba(229,115,115,.25); }
.four-iban-diff {
  font-size: 12.5px; line-height: 1.8;
  padding: 12px 14px; border-radius: 8px;
  background: rgba(255,255,255,.02); border: 1px solid var(--four-border);
}

/* Transitions */
.four-drawer-anim-enter-active, .four-drawer-anim-leave-active { transition: opacity .2s ease; }
.four-drawer-anim-enter-active .four-drawer,
.four-drawer-anim-leave-active .four-drawer { transition: transform .28s cubic-bezier(.25,.46,.45,.94); }
.four-drawer-anim-enter-from, .four-drawer-anim-leave-to { opacity: 0; }
.four-drawer-anim-enter-from .four-drawer,
.four-drawer-anim-leave-to .four-drawer { transform: translateX(24px); }

.four-modal-anim-enter-active, .four-modal-anim-leave-active { transition: opacity .2s ease; }
.four-modal-anim-enter-active .four-modal,
.four-modal-anim-leave-active .four-modal { transition: transform .28s cubic-bezier(.16,1,.3,1); }
.four-modal-anim-enter-from, .four-modal-anim-leave-to { opacity: 0; }
.four-modal-anim-enter-from .four-modal,
.four-modal-anim-leave-to .four-modal { transform: translateY(14px) scale(.98); }

/* ════════════════════════════════════════════════════════════════════
   SYNTHÈSE 360 (onglet Factures) + PANNEAU DÉTAIL FACTURE
   ════════════════════════════════════════════════════════════════════ */
.four-360 {
  margin-bottom: 24px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--four-border);
}
.four-360-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; margin-bottom: 16px;
}
.four-year-pills {
  display: inline-flex; gap: 2px;
  background: var(--four-bg-card);
  border: 1px solid var(--four-border);
  border-radius: 6px; padding: 2px;
}
.four-year-pill {
  font-family: 'Outfit', sans-serif; font-weight: 300;
  font-variant-numeric: tabular-nums; font-size: 12px;
  padding: 5px 12px; border: 0; border-radius: 4px;
  background: transparent; color: var(--four-txm);
  cursor: pointer; transition: all .15s ease;
}
.four-year-pill:hover { color: var(--four-txh); }
.four-year-pill.active { background: rgba(255,255,255,.05); color: var(--teal); box-shadow: inset 0 0 0 1px var(--four-border); }

.four-360-kpis {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 12px; margin-bottom: 18px;
}
.four-360-kpi {
  background: var(--four-bg-card);
  border: 1px solid var(--four-border);
  border-radius: 8px; padding: 14px 16px;
}
.four-360-kpi-l {
  font-family: 'Montserrat', sans-serif; font-size: 9.5px; font-weight: 600;
  letter-spacing: .08em; text-transform: uppercase; color: var(--four-txm);
  margin-bottom: 8px;
}
.four-360-kpi-v { font-size: 22px; color: var(--four-txh); line-height: 1; }
.four-360-kpi-s { margin-top: 6px; font-size: 10.5px; color: var(--four-txm); }
.four-360-bars { margin-top: 4px; }

/* Détail facture */
.four-modal-wide { max-width: 760px; }

/* Aperçu PDF inline : modale 2 panneaux (données | PDF) */
.four-fdetail { display: flex; flex-direction: column; flex: 1; min-height: 0; }
.four-fdetail.has-preview { flex-direction: row; }
.four-fdetail-main { flex: 1; min-height: 0; }
.four-fdetail.has-preview .four-fdetail-main {
  flex: 0 0 440px; max-width: 440px;
  border-right: 1px solid var(--four-border);
}
.four-modal-preview { max-width: min(1180px, 95vw); width: 100%; height: 88vh; }
.four-fdetail-preview {
  flex: 1; min-width: 0;
  display: flex; flex-direction: column;
  background: #14171a;
}
.four-preview-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; padding: 11px 16px;
  border-bottom: 1px solid var(--four-border);
}
.four-preview-name {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: 'Montserrat', sans-serif; font-size: 12px; color: var(--four-txh);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.four-preview-frame { flex: 1; width: 100%; border: 0; background: #3a3d40; overflow: auto; position: relative; }
.four-pdf-pages { padding: 12px; display: flex; flex-direction: column; align-items: center; gap: 10px; }
.four-pdf-page { display: block; max-width: 100%; box-shadow: 0 4px 18px -6px rgba(0,0,0,.6); border-radius: 2px; background: #fff; }
.four-preview-msg {
  padding: 16px 20px; text-align: center;
  font-family: 'Montserrat', sans-serif; font-size: 12px; color: rgba(255,255,255,.75);
}
.four-pj-item.is-active { color: var(--teal); border-color: rgba(34,118,102,.5); background: rgba(34,118,102,.12); }

.four-readouts-3 { grid-template-columns: repeat(3, 1fr); }
.four-readout-v.four-rv-sm { font-size: 14px; }
.four-mt-8 { margin-top: 8px; }
.four-mtable-lignes .four-mhead,
.four-mtable-lignes .four-mrow { grid-template-columns: 1fr 60px 110px 70px 90px; }
.four-mtable-regl .four-mhead,
.four-mtable-regl .four-mrow { grid-template-columns: 120px 120px 1fr 120px; }

.four-totaux {
  margin-top: 16px; margin-left: auto;
  width: min(340px, 100%);
  border: 1px solid var(--four-border); border-radius: 8px;
  background: var(--four-bg-card); overflow: hidden;
}
.four-totaux-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 9px 16px;
  font-family: 'Montserrat', sans-serif; font-size: 12px; color: var(--four-txm);
  border-bottom: 1px solid rgba(255,255,255,.03);
}
.four-totaux-row span:last-child { font-size: 13.5px; color: var(--four-txh); }
.four-totaux-row:last-child { border-bottom: 0; }
.four-totaux-ttc {
  background: rgba(34,118,102,.06);
  border-top: 1px solid var(--four-border);
  border-bottom: 1px solid var(--four-border);
}
.four-totaux-ttc span { color: var(--four-txh) !important; font-weight: 600; }
.four-totaux-ttc span:last-child { font-size: 16px !important; color: var(--teal) !important; }

.four-pj {
  display: flex; align-items: center; flex-wrap: wrap; gap: 8px;
  margin-top: 16px; color: var(--four-txm); font-size: 11.5px;
}
.four-pj-item {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 12px; border-radius: 14px;
  background: rgba(255,255,255,.04); border: 1px solid var(--four-border);
  color: var(--four-txh);
  font-family: 'Montserrat', sans-serif; font-size: 11.5px;
}
.four-pj-link { cursor: pointer; transition: all .15s ease; }
.four-pj-link:hover { color: var(--teal); border-color: rgba(34,118,102,.4); background: rgba(34,118,102,.08); }
.four-pj-item:disabled { opacity: .55; cursor: not-allowed; }

/* ─── Responsive (tablette / mobile) ────────────────────────────── */
@media (max-width: 900px) {
  .four-header { padding: 20px 16px 12px; flex-direction: column; align-items: stretch; }
  .four-body   { padding: 0 16px 32px; }
  .four-thead, .four-row { grid-template-columns: 100px 1fr 100px; gap: 8px; padding: 10px 12px; font-size: 12px; }
  .four-c-cat, .four-c-statut, .four-c-ca { display: none; }

  .four-drawer { width: 100vw; }
  .four-drawer-head, .four-subtabs, .four-drawer-body, .four-drawer-foot { padding-left: 18px; padding-right: 18px; }
  .four-grid-2, .four-readouts, .four-readouts-3 { grid-template-columns: 1fr; }
  .four-360-kpis { grid-template-columns: 1fr 1fr; }
  .four-360-head { flex-direction: column; align-items: stretch; gap: 10px; }
  .four-totaux { width: 100%; }
  .four-mhead { display: none; }

  .four-modal-preview { height: 92vh; }
  .four-fdetail.has-preview { flex-direction: column; }
  .four-fdetail.has-preview .four-fdetail-main {
    flex: 0 0 auto; max-width: none;
    border-right: 0; border-bottom: 1px solid var(--four-border);
    max-height: 45%;
  }
  .four-fdetail-preview { min-height: 50%; }
  .four-mtable-banques .four-mrow,
  .four-mtable-fact .four-mrow,
  .four-mtable-hist .four-mrow { grid-template-columns: 1fr 1fr; gap: 6px 12px; }
  .four-mtable .cc, .four-mtable .cr { justify-self: start; text-align: left; }
}
