/* ============================================================
   C'Event — Composants
   Construits exclusivement sur les tokens sémantiques (tokens.css).
   Aucun composant ne référence une primitive en dur (sauf cas
   de couleur fixe sur fond coloré, ex. texte blanc sur bouton).
   ============================================================ */

/* ---------- Base / reset léger ---------- */
*, *::before, *::after { box-sizing: border-box; }

body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--text-base);
  line-height: var(--leading-base);
  color: var(--color-text-primary);
  background: var(--color-bg-canvas);
  -webkit-font-smoothing: antialiased;
  transition: background var(--duration-base) var(--ease), color var(--duration-base) var(--ease);
}

a { color: var(--color-text-link); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ---------- Boutons ---------- */
.btn {
  --btn-bg: var(--color-brand-solid);
  --btn-fg: var(--color-text-on-brand);
  --btn-bg-hover: var(--color-brand-solid-hover);
  --btn-bg-active: var(--color-brand-solid-active);
  --btn-ring: var(--color-focus-ring);
  --btn-border: transparent;

  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  font-family: var(--font-sans); font-weight: var(--weight-semibold); font-size: var(--text-sm);
  line-height: 1; white-space: nowrap; cursor: pointer; user-select: none;
  height: 40px; padding: 0 var(--space-4); border-radius: var(--radius-md);
  background: var(--btn-bg); color: var(--btn-fg); border: 1px solid var(--btn-border);
  transition: background var(--duration-fast) var(--ease),
              border-color var(--duration-fast) var(--ease),
              box-shadow var(--duration-fast) var(--ease),
              transform var(--duration-fast) var(--ease);
}
.btn:hover { background: var(--btn-bg-hover); }
.btn:active { background: var(--btn-bg-active); transform: translateY(1px); }
.btn:focus-visible { outline: none; box-shadow: 0 0 0 3px var(--btn-ring); }
.btn:disabled { opacity: .5; cursor: not-allowed; transform: none; }

.btn--secondary { --btn-bg: var(--color-bg-surface); --btn-fg: var(--color-text-primary); --btn-bg-hover: var(--color-bg-subtle); --btn-bg-active: var(--color-bg-muted); --btn-border: var(--color-border-default); }
.btn--outline   { --btn-bg: transparent; --btn-fg: var(--color-brand-text); --btn-bg-hover: var(--color-brand-subtle); --btn-bg-active: var(--color-brand-subtle-hover); --btn-border: var(--color-brand-border); }
.btn--ghost     { --btn-bg: transparent; --btn-fg: var(--color-text-secondary); --btn-bg-hover: var(--color-bg-subtle); --btn-bg-active: var(--color-bg-muted); --btn-border: transparent; }
.btn--danger    { --btn-bg: var(--color-danger-solid); --btn-fg: var(--color-text-on-brand); --btn-bg-hover: var(--color-danger-solid-hover); --btn-bg-active: var(--color-danger-solid-hover); --btn-ring: var(--color-focus-ring-danger); --btn-border: transparent; }

.btn--sm { height: 32px; font-size: var(--text-xs); padding: 0 var(--space-3); border-radius: var(--radius-sm); }
.btn--lg { height: 48px; font-size: var(--text-base); padding: 0 var(--space-6); border-radius: var(--radius-lg); }
.btn--block { width: 100%; }

/* ---------- Formulaires ---------- */
.field { display: flex; flex-direction: column; gap: var(--space-2); }
.label { font-size: var(--text-sm); font-weight: var(--weight-medium); color: var(--color-text-primary); }

.input, .textarea, .select {
  font-family: var(--font-sans); font-size: var(--text-sm); color: var(--color-text-primary);
  background: var(--color-bg-surface); border: 1px solid var(--color-border-default);
  border-radius: var(--radius-md); width: 100%;
  transition: border-color var(--duration-fast) var(--ease), box-shadow var(--duration-fast) var(--ease);
}
.input, .select { height: 40px; padding: 0 var(--space-3); }
.textarea { padding: var(--space-3); min-height: 96px; resize: vertical; line-height: var(--leading-sm); }

.input::placeholder, .textarea::placeholder { color: var(--color-text-muted); }
.input:focus, .textarea:focus, .select:focus {
  outline: none; border-color: var(--color-brand-solid);
  box-shadow: 0 0 0 3px var(--color-focus-ring);
}
.input:disabled, .textarea:disabled, .select:disabled { background: var(--color-bg-muted); cursor: not-allowed; }

.select {
  appearance: none;
  padding-right: var(--space-8);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M6 9l6 6 6-6'/></svg>");
  background-repeat: no-repeat; background-position: right var(--space-3) center;
}
[data-theme="dark"] .select {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M6 9l6 6 6-6'/></svg>");
}

.helper { font-size: var(--text-xs); color: var(--color-text-muted); }
.field--error .input, .field--error .textarea, .field--error .select { border-color: var(--color-danger-solid); }
.field--error .helper { color: var(--color-danger-text); }

/* ---------- Carte ---------- */
.card {
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  overflow: hidden;
}
.card__header { padding: var(--space-5) var(--space-5) 0; }
.card__body   { padding: var(--space-5); }
.card__footer { padding: var(--space-4) var(--space-5); border-top: 1px solid var(--color-border-subtle); background: var(--color-bg-subtle); }
.card__title    { margin: 0; font-size: var(--text-lg); font-weight: var(--weight-semibold); color: var(--color-text-primary); }
.card__subtitle { margin: var(--space-1) 0 0; font-size: var(--text-sm); color: var(--color-text-muted); }

/* ---------- Badge / Tag ---------- */
.badge {
  display: inline-flex; align-items: center; gap: var(--space-1);
  font-size: var(--text-xs); font-weight: var(--weight-semibold); line-height: 1;
  padding: 4px var(--space-2); border-radius: var(--radius-full);
  background: var(--color-bg-muted); color: var(--color-text-secondary);
}
.badge--brand   { background: var(--color-brand-subtle);   color: var(--color-brand-text); }
.badge--success { background: var(--color-success-subtle);  color: var(--color-success-text); }
.badge--warning { background: var(--color-warning-subtle);  color: var(--color-warning-text); }
.badge--danger  { background: var(--color-danger-subtle);   color: var(--color-danger-text); }
.badge--dot::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }

/* ---------- Alerte ---------- */
.alert {
  display: flex; gap: var(--space-3); align-items: flex-start;
  padding: var(--space-4); border-radius: var(--radius-md);
  border: 1px solid var(--color-border-subtle); background: var(--color-bg-subtle);
}
.alert__icon { flex-shrink: 0; width: 20px; height: 20px; color: var(--color-text-secondary); }
.alert__title { margin: 0; font-size: var(--text-sm); font-weight: var(--weight-semibold); color: var(--color-text-primary); }
.alert__text  { margin: var(--space-1) 0 0; font-size: var(--text-sm); color: var(--color-text-secondary); }

.alert--info    { background: var(--color-brand-subtle);   border-color: var(--color-brand-border);   }
.alert--info    .alert__icon { color: var(--color-brand-text); }
.alert--success { background: var(--color-success-subtle); border-color: var(--color-success-border); }
.alert--success .alert__icon { color: var(--color-success-text); }
.alert--warning { background: var(--color-warning-subtle); border-color: var(--color-warning-border); }
.alert--warning .alert__icon { color: var(--color-warning-text); }
.alert--danger  { background: var(--color-danger-subtle);  border-color: var(--color-danger-border);  }
.alert--danger  .alert__icon { color: var(--color-danger-text); }

/* ---------- Avatar ---------- */
.avatar {
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; border-radius: var(--radius-full);
  background: var(--color-brand-solid); color: var(--color-text-on-brand);
  font-weight: var(--weight-semibold); font-size: var(--text-sm);
}
.avatar--sm { width: 28px; height: 28px; font-size: var(--text-xs); }
.avatar--lg { width: 56px; height: 56px; font-size: var(--text-lg); }

/* ---------- Tableau ---------- */
.table { width: 100%; border-collapse: collapse; font-size: var(--text-sm); }
.table th {
  text-align: left; font-weight: var(--weight-semibold); color: var(--color-text-muted);
  font-size: var(--text-xs); text-transform: uppercase; letter-spacing: var(--tracking-wide);
  padding: var(--space-3) var(--space-4); border-bottom: 1px solid var(--color-border-subtle);
}
.table td { padding: var(--space-3) var(--space-4); border-bottom: 1px solid var(--color-border-subtle); color: var(--color-text-primary); }
.table tbody tr:last-child td { border-bottom: none; }
.table tbody tr { transition: background var(--duration-fast) var(--ease); }
.table tbody tr:hover { background: var(--color-bg-subtle); }

/* ---------- Onglets ---------- */
.tabs { display: flex; gap: var(--space-1); border-bottom: 1px solid var(--color-border-subtle); }
.tab {
  appearance: none; background: none; border: none; cursor: pointer;
  font-family: var(--font-sans); font-size: var(--text-sm); font-weight: var(--weight-medium);
  color: var(--color-text-muted); padding: var(--space-3) var(--space-4);
  border-bottom: 2px solid transparent; margin-bottom: -1px;
  transition: color var(--duration-fast) var(--ease), border-color var(--duration-fast) var(--ease);
}
.tab:hover { color: var(--color-text-primary); }
.tab[aria-selected="true"] { color: var(--color-brand-text); border-bottom-color: var(--color-brand-solid); }
.tab:focus-visible { outline: none; box-shadow: 0 0 0 3px var(--color-focus-ring); border-radius: var(--radius-sm); }

/* ---------- Interrupteur (switch) ---------- */
.switch { position: relative; display: inline-block; width: 44px; height: 24px; }
.switch input { position: absolute; opacity: 0; width: 0; height: 0; }
.switch__slider {
  position: absolute; inset: 0; cursor: pointer;
  background: var(--color-border-strong); border-radius: var(--radius-full);
  transition: background var(--duration-base) var(--ease);
}
.switch__slider::before {
  content: ""; position: absolute; width: 18px; height: 18px; left: 3px; top: 3px;
  background: #fff; border-radius: 50%; box-shadow: var(--shadow-xs);
  transition: transform var(--duration-base) var(--ease);
}
.switch input:checked + .switch__slider { background: var(--color-brand-solid); }
.switch input:checked + .switch__slider::before { transform: translateX(20px); }
.switch input:focus-visible + .switch__slider { box-shadow: 0 0 0 3px var(--color-focus-ring); }

/* ---------- Accessibilité : respect du « reduce motion » ---------- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
  }
}
