/* ==========================================================================
   tokens.css — Design tokens (couleurs, typo, spacing, radius, shadows)
   Source de vérité unique pour le design system EVO MED.
   ========================================================================== */

:root {
  /* ----- Couleurs (palette validée) ----- */
  --color-bg-dark: #0B1A2F;
  --color-bg-light: #F7F5F2;
  --color-bg-white: #FFFFFF;

  --color-cta: #00BFA5;
  --color-cta-hover: #0094FF;

  --color-text: #1C1C1E;
  --color-text-muted: #6B7280;
  --color-text-on-dark: #F7F5F2;
  --color-text-on-cta: #FFFFFF;

  --color-badge-neuf: #22C55E;
  --color-badge-recond: #3B82F6;
  --color-badge-occasion: #F59E0B;

  --color-border: #E5E7EB;
  --color-border-strong: #D1D5DB;

  /* États fonctionnels (dérivés sobres) */
  --color-success: #22C55E;
  --color-danger: #DC2626;
  --color-focus: #0094FF;

  /* ----- Typographies ----- */
  --font-display: "Playfair Display", Georgia, "Times New Roman", serif;
  --font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

  --fw-regular: 400;
  --fw-medium: 500;
  --fw-semibold: 600;
  --fw-bold: 700;

  /* Échelle typographique (mobile-first ; ajustée en desktop dans base.css) */
  --fs-xs: 0.8125rem;   /* 13 */
  --fs-sm: 0.875rem;    /* 14 */
  --fs-base: 1rem;      /* 16 — minimum corps */
  --fs-md: 1.125rem;    /* 18 */
  --fs-lg: 1.25rem;     /* 20 */
  --fs-xl: 1.5rem;      /* 24 */
  --fs-2xl: 1.875rem;   /* 30 */
  --fs-3xl: 2.25rem;    /* 36 */
  --fs-4xl: 2.75rem;    /* 44 */
  --fs-5xl: 3.5rem;     /* 56 */

  --lh-tight: 1.2;
  --lh-snug: 1.35;
  --lh-base: 1.6;
  --lh-loose: 1.75;

  --ls-tight: -0.01em;
  --ls-normal: 0;
  --ls-wide: 0.04em;

  /* ----- Spacing scale (4 / 8 / 12 / 16 / 24 / 32 / 48 / 64 / 96) ----- */
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.5rem;
  --space-6: 2rem;
  --space-7: 3rem;
  --space-8: 4rem;
  --space-9: 6rem;

  /* ----- Radius ----- */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-pill: 999px;

  /* ----- Shadows (sobres, médical) ----- */
  --shadow-sm: 0 1px 2px rgba(11, 26, 47, 0.04), 0 1px 3px rgba(11, 26, 47, 0.04);
  --shadow-md: 0 2px 4px rgba(11, 26, 47, 0.04), 0 4px 12px rgba(11, 26, 47, 0.06);
  --shadow-lg: 0 8px 24px rgba(11, 26, 47, 0.08), 0 2px 8px rgba(11, 26, 47, 0.04);
  --shadow-focus: 0 0 0 3px rgba(0, 148, 255, 0.25);

  /* ----- Transitions ----- */
  --transition-fast: 120ms ease;
  --transition-base: 180ms ease;
  --transition-slow: 280ms ease;

  /* ----- Z-index scale ----- */
  --z-base: 1;
  --z-sticky: 100;
  --z-header: 200;
  --z-drawer: 300;
  --z-modal: 400;
  --z-toast: 500;
  --z-floating: 250;

  /* ----- Container ----- */
  --container-max: 1280px;
  --container-padding: var(--space-4);

  /* Breakpoints (référence, utilisés en media queries) :
     - sm  : 480px
     - md  : 768px  (tablette)
     - lg  : 1024px (desktop)
     - xl  : 1280px (large desktop)
  */
}

/* Padding container plus généreux à partir de tablette */
@media (min-width: 768px) {
  :root {
    --container-padding: var(--space-6);
  }
}
