/* GEVA Dashboard — styles BASIQUES et isolés.
   Objectif Phase 4 : lisible et fonctionnel. Re-skin futur (style Global Essor) =
   modifier ce fichier (variables + classes), sans toucher au HTML ni à la logique. */

:root {
  /* Le shell hérite désormais des design tokens (tokens.css / charte Global Essor). */
  --bg: var(--ge-bg-soft);
  --surface: var(--ge-surface);
  --border: var(--ge-border);
  --text: var(--ge-text);
  --muted: var(--ge-text-muted);
  --primary: var(--ge-blue);
  --radius: var(--ge-radius-sm);
}

* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: var(--ge-font);
  background: var(--bg);
  color: var(--text);
}

/* Layout */
.container { max-width: 960px; margin: 0 auto; padding: 24px 16px; }

/* Nav */
.nav {
  display: flex; align-items: center; gap: 16px;
  padding: 12px 16px; background: var(--surface); border-bottom: 1px solid var(--border);
}
.nav__brand { font-weight: 700; color: var(--primary); text-decoration: none; }
.nav__links { flex: 1; }
.nav__links a { color: var(--text); text-decoration: none; }
.nav__logout { display: flex; align-items: center; gap: 10px; }
.nav__user { color: var(--muted); font-size: 0.9rem; }

/* Cards & pages */
.card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 24px; margin-top: 16px;
}
.card--narrow { max-width: 380px; margin: 48px auto; }
.card__title, .page__title { margin: 0 0 16px; font-size: 1.4rem; }

/* Form */
.form { display: flex; flex-direction: column; gap: 14px; }
.form__field { display: flex; flex-direction: column; gap: 4px; font-size: 0.9rem; }
.form__field input {
  padding: 9px 11px; border: 1px solid var(--border); border-radius: 6px; font-size: 1rem;
}
.btn {
  padding: 10px 14px; border: none; border-radius: 6px; font-size: 1rem; cursor: pointer;
}
.btn--primary { background: var(--primary); color: #fff; }
.nav__logout button {
  padding: 6px 10px; border: 1px solid var(--border); background: var(--surface);
  border-radius: 6px; cursor: pointer;
}

/* Table */
.table { width: 100%; border-collapse: collapse; background: var(--surface);
  border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
.table th, .table td { padding: 10px 12px; text-align: left; border-bottom: 1px solid var(--border); }
.table th { background: var(--ge-bg-soft); font-size: 0.8rem; text-transform: uppercase; color: var(--muted); }
.table__besoin { max-width: 280px; }

/* Detail */
.detail { display: grid; grid-template-columns: 180px 1fr; gap: 8px 16px; margin: 0; }
.detail dt { color: var(--muted); }
.detail dd { margin: 0; }

/* Bits */
.link { color: var(--primary); text-decoration: none; }
.empty { color: var(--muted); }
.alert { padding: 10px 12px; border-radius: 6px; font-size: 0.9rem; }
.alert--error { background: var(--ge-danger-bg); color: var(--ge-danger-text); }
.badge { padding: 2px 8px; border-radius: 999px; font-size: 0.78rem; background: var(--ge-gradient-soft); color: var(--ge-blue); }
.badge--complete { background: var(--ge-success-bg); color: var(--ge-success-text); }
.badge--incomplete { background: var(--ge-warn-bg); color: var(--ge-warn-text); }
.badge--en_cours { background: var(--ge-gradient-soft); color: var(--ge-blue); }
