/* ETHIC Import — Design System "Le Registre"
   Marine ETHIC structure + Corail Confiant comme unique accent d'action.
   Voir DESIGN.md à la racine du projet pour la référence complète des tokens. */

:root {
  /* Marque */
  --navy: oklch(29% 0.09 264);
  --navy-deep: oklch(19% 0.07 264);
  --blue-secondary: oklch(41% 0.12 264);
  --coral: oklch(62% 0.17 8);
  --coral-hover: oklch(54% 0.18 8);

  /* Neutres tintés (jamais de blanc/gris purs) */
  --paper: oklch(99% 0.004 264);
  --surface: oklch(97% 0.006 264);
  --border: oklch(88% 0.015 264);
  --muted: oklch(71% 0.045 264);
  --text: oklch(37% 0.02 300);
  --text-heading: oklch(22% 0.04 264);

  /* Statuts (indépendants de la marque) */
  --success: oklch(56% 0.13 155);
  --success-bg: oklch(93% 0.04 155);
  --error: oklch(52% 0.18 18);
  --error-bg: oklch(93% 0.04 18);
  --warning: oklch(58% 0.11 75);
  --warning-bg: oklch(93% 0.04 75);
  --pending: var(--blue-secondary);
  --pending-bg: oklch(92% 0.02 264);

  /* Forme */
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 16px;
  --radius-pill: 999px;

  /* Rythme */
  --space-xs: 4px;
  --space-sm: 8px;
  --space-md: 16px;
  --space-lg: 24px;
  --space-xl: 40px;

  /* Mouvement */
  --ease: cubic-bezier(0.16, 1, 0.3, 1);
  --duration: 150ms;

  --font: "Hanken Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }

html { -webkit-font-smoothing: antialiased; }

body {
  font-family: var(--font);
  margin: 0;
  background: var(--surface);
  color: var(--text);
  font-size: 1rem;
  line-height: 1.55;
}

/* ---------- Navigation ---------- */

header {
  background: var(--navy);
  color: var(--paper);
}

nav {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-lg);
  max-width: 1200px;
  margin: 0 auto;
  padding: var(--space-md) var(--space-lg);
}

nav a {
  color: var(--paper);
  text-decoration: none;
  font-weight: 600;
  font-size: 0.8125rem;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  padding-bottom: var(--space-xs);
  border-bottom: 2px solid transparent;
  transition: opacity var(--duration) var(--ease), border-color var(--duration) var(--ease);
  opacity: 0.85;
}

nav a:hover { opacity: 1; }

nav a.nav-active {
  border-bottom-color: var(--coral);
  opacity: 1;
}

nav .logo {
  font-weight: 700;
  font-size: 1.25rem;
  text-transform: none;
  letter-spacing: normal;
  border-bottom: none;
  opacity: 1;
}

nav .user {
  margin-left: auto;
  font-weight: 400;
  text-transform: none;
  letter-spacing: normal;
  opacity: 0.7;
  font-size: 0.875rem;
}

/* ---------- Panneau principal ---------- */

main {
  max-width: 1200px;
  margin: var(--space-xl) auto;
  background: var(--paper);
  padding: var(--space-xl);
  border-radius: var(--radius-lg);
  box-shadow: 0 1px 3px oklch(29% 0.09 264 / 0.06), 0 4px 16px oklch(29% 0.09 264 / 0.04);
}

@media (max-width: 768px) {
  main { padding: var(--space-lg); margin: var(--space-md); }
  nav { gap: var(--space-md); padding: var(--space-sm) var(--space-md); }
}

/* ---------- Typographie ---------- */

h1 {
  font-size: 1.75rem;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: -0.01em;
  color: var(--text-heading);
  margin-top: 0;
  margin-bottom: var(--space-lg);
}

h2 {
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 1.3;
  color: var(--text-heading);
  margin-top: var(--space-xl);
  margin-bottom: var(--space-md);
}

p { max-width: 75ch; }

a { color: var(--blue-secondary); }

/* ---------- Formulaires ---------- */

form p { margin: var(--space-md) 0; max-width: none; }

label {
  display: block;
  font-weight: 600;
  font-size: 0.9375rem;
  color: var(--text-heading);
  margin-bottom: var(--space-xs);
}

input[type="text"],
input[type="email"],
input[type="password"],
input[type="file"] {
  width: 100%;
  max-width: 400px;
  padding: 10px 14px;
  font-family: var(--font);
  font-size: 1rem;
  color: var(--text);
  background: var(--paper);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  transition: border-color var(--duration) var(--ease), box-shadow var(--duration) var(--ease);
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus {
  outline: none;
  border-color: var(--navy);
  box-shadow: 0 0 0 3px oklch(29% 0.09 264 / 0.12);
}

input[type="checkbox"] { accent-color: var(--navy); }

.error {
  color: var(--error);
  font-size: 0.875rem;
  margin-top: var(--space-xs);
}

/* ---------- Boutons ---------- */

button, .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--coral);
  color: var(--paper);
  border: none;
  padding: 12px 28px;
  border-radius: var(--radius-pill);
  font-family: var(--font);
  font-weight: 600;
  font-size: 1rem;
  text-decoration: none;
  cursor: pointer;
  transition: background-color var(--duration) var(--ease);
}

button:hover, .btn:hover { background: var(--coral-hover); }

button:focus-visible, .btn:focus-visible {
  outline: 2px solid oklch(62% 0.17 8 / 0.4);
  outline-offset: 2px;
}

button:disabled, .btn:disabled {
  background: var(--border);
  color: var(--muted);
  cursor: not-allowed;
}

.btn-ghost {
  background: transparent;
  color: var(--navy);
  border: 1px solid var(--border);
}

.btn-ghost:hover { background: var(--surface); }

.btn-sm {
  padding: 6px 16px;
  font-size: 0.875rem;
}

/* ---------- Badges de statut ---------- */

.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  padding: 4px 12px;
  border-radius: var(--radius-pill);
  font-weight: 600;
  font-size: 0.8125rem;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  white-space: nowrap;
}

.badge-success { background: var(--success-bg); color: var(--success); }
.badge-error { background: var(--error-bg); color: var(--error); }
.badge-warning { background: var(--warning-bg); color: var(--warning); }
.badge-pending { background: var(--pending-bg); color: var(--pending); }

/* ---------- Tableaux ---------- */

table {
  width: 100%;
  border-collapse: collapse;
  margin-top: var(--space-md);
  font-size: 0.9375rem;
}

th, td {
  padding: var(--space-sm) var(--space-md);
  text-align: left;
  border-bottom: 1px solid var(--border);
}

th {
  font-weight: 600;
  font-size: 0.8125rem;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--muted);
  background: transparent;
}

tbody tr {
  transition: background-color var(--duration) var(--ease);
}

tbody tr:hover { background: var(--surface); }

/* ---------- Messages flash ---------- */

.flash {
  padding: var(--space-md);
  margin: 0 0 var(--space-md) 0;
  border-radius: var(--radius-md);
  font-size: 0.9375rem;
}

.flash-error { background: var(--error-bg); color: var(--error); }
.flash-success { background: var(--success-bg); color: var(--success); }
.flash-info { background: var(--pending-bg); color: var(--pending); }
.flash-warning { background: var(--warning-bg); color: var(--warning); }
