/* [TDM-CSS] — Design system TDM studio v1.1
 * Trigger    : importé par toutes les pages HTML du projet
 * Étapes     : définit les variables CSS, la typographie, les composants de base
 * Cas limites: voir PROJET_LordOfTheRushs.md
 */

@import url('https://fonts.googleapis.com/css2?family=Spectral:ital,wght@0,300;0,400;0,500;1,300;1,400&family=Source+Sans+3:wght@300;400;600&family=DM+Mono:wght@300;400;500&display=swap');

/* ─── Variables ───────────────────────────────────────────── */
:root {
  --encre:        #1C1C1C;
  --accent:       #A63020;   /* brique cinabre — seule couleur d'accent */
  --fond-chaud:   #FBF9F7;
  --separateur:   #EEE8E2;
  --blanc:        #FFFFFF;
  --gris-sec:     #767676;   /* texte secondaire >= 14px */
  --gris-discret: #595959;   /* texte secondaire <= 13px */
  --gris-leger:   #F5F0EC;

  /* Badges statut prise */
  --badge-ok-fond:  #D4EDDA;
  --badge-ok-texte: #1A4731;
  --badge-ng-fond:  #FADADD;
  --badge-ng-texte: #6B1A1A;
}

/* ─── Reset minimal ───────────────────────────────────────── */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

/* ─── Base ────────────────────────────────────────────────── */
html {
  font-size: 16px;
  background-color: var(--fond-chaud);
  color: var(--encre);
}

body {
  font-family: 'Source Sans 3', sans-serif;
  font-weight: 400;
  line-height: 1.6;
  background-color: var(--fond-chaud);
  color: var(--encre);
  min-height: 100vh;
}

/* ─── Typographie ─────────────────────────────────────────── */

/* Titres — Spectral */
h1, h2, h3, h4, h5, h6 {
  font-family: 'Spectral', serif;
  font-weight: 400;
  line-height: 1.25;
  color: var(--encre);
}

h1 { font-size: 2rem; }
h2 { font-size: 1.5rem; }
h3 { font-size: 1.25rem; }

/* Marque / logo */
.marque {
  font-family: 'Spectral', serif;
  font-weight: 300;
  font-style: italic;
  color: var(--accent);
}

/* Corps — Source Sans 3 (implicite via body) */
p { margin-bottom: 0.75rem; }

/* Données / références / noms de fichiers / codes séquence — DM Mono */
code, .mono, .nom-fichier, .code-sequence, .ref {
  font-family: 'DM Mono', monospace;
  font-weight: 400;
  color: var(--accent);
  font-size: 0.875em;
}

/* Texte secondaire */
.texte-secondaire {
  color: var(--gris-sec);
  font-size: 0.9rem;
}

.texte-discret {
  color: var(--gris-discret);
  font-size: 0.8rem;
}

/* ─── Liens ───────────────────────────────────────────────── */
a {
  color: var(--accent);
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}

/* ─── Layout ──────────────────────────────────────────────── */
.conteneur {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1.5rem;
}

.conteneur-etroit {
  max-width: 640px;
  margin: 0 auto;
  padding: 0 1.5rem;
}

/* ─── En-tête ─────────────────────────────────────────────── */
.entete {
  background-color: var(--blanc);
  border-bottom: 1px solid var(--separateur);
  padding: 1rem 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.entete-titre {
  font-family: 'Spectral', serif;
  font-weight: 300;
  font-size: 1.25rem;
  color: var(--encre);
}

/* ─── Navigation ──────────────────────────────────────────── */
.nav {
  display: flex;
  gap: 1.5rem;
  align-items: center;
}

.nav a {
  font-size: 0.9rem;
  color: var(--gris-discret);
  font-weight: 400;
}

.nav a:hover,
.nav a.actif {
  color: var(--accent);
  text-decoration: none;
}

/* ─── Séparateur ──────────────────────────────────────────── */
hr {
  border: none;
  border-top: 1px solid var(--separateur);
  margin: 1.5rem 0;
}

/* ─── Formulaires ─────────────────────────────────────────── */
label {
  display: block;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--gris-discret);
  margin-bottom: 0.35rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
select,
textarea {
  width: 100%;
  padding: 0.6rem 0.85rem;
  border: 1px solid var(--separateur);
  border-radius: 4px;
  background-color: var(--blanc);
  color: var(--encre);
  font-family: 'Source Sans 3', sans-serif;
  font-size: 1rem;
  transition: border-color 0.15s;
}

input:focus,
select:focus,
textarea:focus {
  outline: none;
  border-color: var(--accent);
}

.groupe-champ {
  margin-bottom: 1.25rem;
}

/* ─── Boutons ─────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.55rem 1.25rem;
  border: none;
  border-radius: 4px;
  font-family: 'Source Sans 3', sans-serif;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  transition: opacity 0.15s;
  text-decoration: none;
}

.btn:hover { opacity: 0.85; text-decoration: none; }
.btn:disabled { opacity: 0.45; cursor: not-allowed; }

.btn-principal {
  background-color: var(--accent);
  color: var(--blanc);
}

.btn-secondaire {
  background-color: var(--gris-leger);
  color: var(--encre);
}

.btn-fantome {
  background-color: transparent;
  border: 1px solid var(--separateur);
  color: var(--gris-discret);
}

.btn-danger {
  background-color: var(--badge-ng-fond);
  color: var(--badge-ng-texte);
}

/* ─── Badges statut ───────────────────────────────────────── */
.badge {
  display: inline-block;
  padding: 0.2rem 0.55rem;
  border-radius: 3px;
  font-family: 'DM Mono', monospace;
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.05em;
}

.badge-ok {
  background-color: var(--badge-ok-fond);
  color: var(--badge-ok-texte);
}

.badge-ng {
  background-color: var(--badge-ng-fond);
  color: var(--badge-ng-texte);
}

.badge-dir {
  background-color: var(--accent);
  color: var(--blanc);
}

.badge-attente {
  background-color: var(--gris-leger);
  color: var(--gris-sec);
}

/* Badges d'alerte interface */
.badge-incomplet {
  background-color: #FFF3CD;
  color: #856404;
}

.badge-a-verifier {
  background-color: #FFF3CD;
  color: #856404;
}

.badge-non-reconnu {
  background-color: #FADADD;
  color: var(--badge-ng-texte);
}

/* ─── Cartes ──────────────────────────────────────────────── */
.carte {
  background-color: var(--blanc);
  border: 1px solid var(--separateur);
  border-radius: 6px;
  padding: 1.25rem 1.5rem;
}

.carte + .carte {
  margin-top: 1rem;
}

/* ─── Tableaux ────────────────────────────────────────────── */
table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}

th {
  text-align: left;
  font-family: 'Source Sans 3', sans-serif;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--gris-discret);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 0.5rem 0.75rem;
  border-bottom: 2px solid var(--separateur);
}

td {
  padding: 0.65rem 0.75rem;
  border-bottom: 1px solid var(--separateur);
  vertical-align: middle;
}

tr:last-child td {
  border-bottom: none;
}

tr:hover td {
  background-color: var(--gris-leger);
}

/* ─── Messages ────────────────────────────────────────────── */
.message {
  padding: 0.75rem 1rem;
  border-radius: 4px;
  margin-bottom: 1rem;
  font-size: 0.9rem;
}

.message-erreur {
  background-color: var(--badge-ng-fond);
  color: var(--badge-ng-texte);
  border-left: 3px solid var(--accent);
}

.message-succes {
  background-color: var(--badge-ok-fond);
  color: var(--badge-ok-texte);
  border-left: 3px solid #2D7A4F;
}

.message-info {
  background-color: var(--gris-leger);
  color: var(--gris-discret);
  border-left: 3px solid var(--separateur);
}

/* ─── Progress bar upload ─────────────────────────────────── */
.barre-progression {
  width: 100%;
  height: 6px;
  background-color: var(--separateur);
  border-radius: 3px;
  overflow: hidden;
}

.barre-progression-remplie {
  height: 100%;
  background-color: var(--accent);
  border-radius: 3px;
  transition: width 0.2s ease;
}

/* ─── Utilitaires ─────────────────────────────────────────── */
.masque { display: none !important; }
.flex { display: flex; }
.flex-centre { display: flex; align-items: center; }
.flex-entre { display: flex; justify-content: space-between; align-items: center; }
.gap-1 { gap: 0.5rem; }
.gap-2 { gap: 1rem; }
.marge-bas { margin-bottom: 1.5rem; }
.marge-bas-sm { margin-bottom: 0.75rem; }
.texte-droite { text-align: right; }
