/* ==========================================================================
   LINKING DEVELOPMENT — Dashboards (holding & filiales)
   ========================================================================== */

.dash-layout {
  display: grid;
  grid-template-columns: 260px 1fr;
  min-height: 100vh;
}
@media (max-width: 980px) {
  .dash-layout { grid-template-columns: 1fr; }
}

/* ---------- Sidebar ---------- */
.dash-sidebar {
  background: var(--ink-950);
  border-right: 1px solid var(--line);
  padding: 1.6rem 1.1rem;
  display: flex;
  flex-direction: column;
  gap: 1.6rem;
  position: sticky;
  top: 0;
  height: 100vh;
  overflow-y: auto;
}
@media (max-width: 980px) {
  .dash-sidebar { position: static; height: auto; flex-direction: row; flex-wrap: wrap; align-items: center; }
}
.dash-brand { display: flex; align-items: center; gap: 0.75rem; padding-inline: 0.5rem; }
.dash-brand img { height: 36px; }
.dash-brand b { font: 620 0.8rem/1.2 var(--font-sans); letter-spacing: 0.06em; }
.dash-brand span { display: block; font: 500 0.6rem/1.2 var(--font-sans); letter-spacing: 0.24em; text-transform: uppercase; color: var(--accent); }

.dash-nav { display: grid; gap: 0.15rem; flex: 1; }
.dash-nav h6 {
  font: 600 0.62rem/1 var(--font-sans);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--fg-faint);
  padding: 1.1rem 0.7rem 0.5rem;
}
.dash-nav a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6rem;
  padding: 0.62rem 0.75rem;
  border-radius: var(--radius);
  font: 520 0.88rem/1.2 var(--font-sans);
  color: var(--fg-dim);
  transition: background 0.25s var(--ease), color 0.25s var(--ease);
}
.dash-nav a:hover { background: color-mix(in srgb, var(--ivory) 5%, transparent); color: var(--fg); }
.dash-nav a.is-active { background: color-mix(in srgb, var(--accent) 16%, transparent); color: var(--accent); }
.dash-nav .badge {
  min-width: 1.5rem;
  text-align: center;
  padding: 0.15rem 0.45rem;
  border-radius: 99px;
  background: var(--accent);
  color: var(--accent-contrast);
  font: 700 0.7rem/1.2 var(--font-sans);
}
.dash-side-foot { display: grid; gap: 0.4rem; }

/* ---------- Contenu ---------- */
.dash-main { padding: clamp(1.4rem, 3vw, 2.6rem); display: grid; gap: 1.8rem; align-content: start; }
.dash-topbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.dash-topbar h1 { font-size: clamp(1.5rem, 3vw, 2.1rem); }
.dash-topbar .meta { font-size: 0.85rem; color: var(--fg-dim); }
.scope-switch { display: flex; align-items: center; gap: 0.6rem; font-size: 0.85rem; color: var(--fg-dim); }
.scope-switch select { width: auto; padding: 0.5rem 0.8rem; }

/* ---------- Cartes stats ---------- */
.stat-cards { display: grid; gap: 1rem; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); }
.stat-card {
  padding: 1.4rem 1.5rem;
  background: var(--bg-raised);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  display: grid;
  gap: 0.3rem;
}
.stat-card .v { font: 460 2.2rem/1 var(--font-serif); font-variant-numeric: tabular-nums; }
.stat-card .k { font-size: 0.8rem; color: var(--fg-dim); }
.stat-card--accent { border-color: color-mix(in srgb, var(--accent) 40%, transparent); }
.stat-card--accent .v { color: var(--accent); }

.dash-panel {
  background: var(--bg-raised);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 1.6rem;
  display: grid;
  gap: 1.2rem;
}
.dash-panel > h2 { font-size: 1.2rem; font-family: var(--font-sans); font-weight: 620; letter-spacing: 0; }
.dash-grid-2 { display: grid; gap: 1.8rem; }
@media (min-width: 1200px) { .dash-grid-2 { grid-template-columns: 1.5fr 1fr; align-items: start; } }
.chart-wrap { position: relative; height: 290px; }

/* ---------- Tables ---------- */
.dash-table-wrap { overflow-x: auto; }
.dash-table { width: 100%; border-collapse: collapse; font-size: 0.88rem; }
.dash-table th {
  text-align: left;
  font: 600 0.68rem/1.3 var(--font-sans);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-faint);
  padding: 0.7rem 0.9rem;
  border-bottom: 1px solid var(--line-strong);
  white-space: nowrap;
}
.dash-table td { padding: 0.85rem 0.9rem; border-bottom: 1px solid var(--line); vertical-align: middle; }
.dash-table tr:hover td { background: color-mix(in srgb, var(--ivory) 3%, transparent); }
.dash-table .actions { display: flex; gap: 0.4rem; justify-content: flex-end; white-space: nowrap; }
.dash-table a.row-link { color: var(--fg); font-weight: 560; }
.dash-table a.row-link:hover { color: var(--accent); }

.pill {
  display: inline-block;
  padding: 0.22rem 0.7rem;
  border-radius: 99px;
  font: 600 0.7rem/1.4 var(--font-sans);
  letter-spacing: 0.04em;
}
.pill--published, .pill--done { background: rgba(63, 160, 110, 0.16); color: #7fd0a4; }
.pill--draft, .pill--new { background: rgba(200, 162, 75, 0.15); color: var(--gold-bright); }
.pill--in_progress { background: rgba(94, 144, 212, 0.16); color: #94b8e8; }
.pill--inactive { background: rgba(200, 90, 70, 0.14); color: #e09a87; }

/* ---------- Formulaires dashboard ---------- */
.dash-form { display: grid; gap: 0.2rem; max-width: 860px; }
.dash-form .form-grid { display: grid; gap: 0 1.4rem; }
@media (min-width: 900px) { .dash-form .form-grid { grid-template-columns: 1fr 1fr; } }
.dash-form .field--full { grid-column: 1 / -1; }
.form-actions { display: flex; gap: 0.8rem; margin-top: 1rem; align-items: center; }

/* ---------- Liste d'activité ---------- */
.activity-list { display: grid; gap: 0.1rem; }
.activity-item {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.7rem 0.4rem;
  border-bottom: 1px solid var(--line);
  font-size: 0.88rem;
}
.activity-item:last-child { border-bottom: none; }
.activity-item .t { color: var(--fg); font-weight: 540; }
.activity-item .t:hover { color: var(--accent); }
.activity-item .m { color: var(--fg-faint); font-size: 0.78rem; white-space: nowrap; }

/* ---------- Cartes entités (vue holding) ---------- */
.entity-cards { display: grid; gap: 1rem; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
.entity-card {
  border: 1px solid var(--line);
  border-left: 3px solid var(--ec, var(--accent));
  border-radius: var(--radius);
  background: var(--bg-raised);
  padding: 1.3rem 1.4rem;
  display: grid;
  gap: 0.7rem;
}
.entity-card h3 { font-size: 1.05rem; font-family: var(--font-sans); font-weight: 620; }
.entity-card .kpis { display: flex; gap: 1.4rem; font-size: 0.82rem; color: var(--fg-dim); }
.entity-card .kpis b { display: block; font-size: 1.3rem; color: var(--fg); font-variant-numeric: tabular-nums; }

/* ---------- Login ---------- */
.login-page {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: var(--gutter);
  background:
    radial-gradient(70% 60% at 80% 10%, color-mix(in srgb, var(--gold) 8%, transparent), transparent 65%),
    var(--ink-950);
}
.login-card {
  width: min(420px, 100%);
  background: var(--ink-800);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 2.6rem 2.4rem;
  display: grid;
  gap: 1.4rem;
}
.login-card .dash-brand { justify-content: center; padding: 0; }
.login-card h1 { font-size: 1.4rem; text-align: center; }
.login-card .small { text-align: center; }

/* ---------- Message detail ---------- */
.msg-detail { display: grid; gap: 1.5rem; }
@media (min-width: 1100px) { .msg-detail { grid-template-columns: 1.6fr 1fr; align-items: start; } }
.msg-body {
  background: var(--bg-raised);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 1.8rem;
  display: grid;
  gap: 1.1rem;
}
.msg-body .from { display: grid; gap: 0.15rem; }
.msg-body .from b { font-size: 1.05rem; }
.msg-body .text { white-space: pre-line; color: var(--fg-dim); border-top: 1px solid var(--line); padding-top: 1.1rem; }
