/* ==========================================================================
   TOKENS DE DESIGN — MEDISTANT
   Charte : bleu #4A90E2, blanc #F2F2F2, gris #64695F, accent rouge #BB3A0A
   Typos : Prompt (titres), Roboto (corps)
   ========================================================================== */

:root {
  /* Couleurs principales */
  --color-primary: #4A90E2;
  --color-primary-dark: #3A7BC8;
  --color-primary-light: #6AA5E8;
  --color-primary-soft: #E8F1FB;

  --color-bg: #F2F2F2;
  --color-bg-soft: #F8F9FA;
  --color-surface: #FFFFFF;

  --color-gray: #64695F;
  --color-gray-dark: #3A3E38;
  --color-gray-light: #9CA09A;
  --color-gray-lighter: #C8CBC7;
  --color-gray-border: #E4E6E2;

  /* Accent (à utiliser avec parcimonie) */
  --color-accent: #BB3A0A;
  --color-accent-dark: #8F2C08;
  --color-accent-soft: #FBE9E1;

  /* États */
  --color-success: #2D8A4E;
  --color-success-soft: #E3F4E8;
  --color-warning: #D99A2B;
  --color-warning-soft: #FBF1DD;
  --color-error: var(--color-accent);
  --color-error-soft: var(--color-accent-soft);
  --color-info: var(--color-primary);
  --color-info-soft: var(--color-primary-soft);

  /* Typographies */
  --font-heading: 'Prompt', 'Helvetica Neue', sans-serif;
  --font-body: 'Roboto', 'Helvetica Neue', sans-serif;

  --fs-xs: 11px;
  --fs-sm: 13px;
  --fs-base: 14px;
  --fs-md: 16px;
  --fs-lg: 18px;
  --fs-xl: 22px;
  --fs-2xl: 28px;
  --fs-3xl: 36px;
  --fs-4xl: 48px;
  --fs-5xl: 72px;
  --fs-6xl: 120px;

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

  /* Espacements */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;
  --space-12: 48px;
  --space-16: 64px;

  /* Rayons */
  --radius-xs: 4px;
  --radius-sm: 6px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-2xl: 24px;
  --radius-full: 9999px;

  /* Ombres */
  --shadow-xs: 0 1px 2px rgba(15, 23, 42, 0.04);
  --shadow-sm: 0 2px 6px rgba(15, 23, 42, 0.06);
  --shadow-md: 0 6px 18px rgba(15, 23, 42, 0.08);
  --shadow-lg: 0 14px 40px rgba(15, 23, 42, 0.12);
  --shadow-xl: 0 24px 60px rgba(15, 23, 42, 0.18);

  /* Durées d'animation */
  --dur-fast: 150ms;
  --dur-base: 250ms;
  --dur-slow: 400ms;
  --dur-slower: 600ms;

  /* Easings */
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);

  /* Dimensions du shell */
  --sidebar-width: 300px;
  --demo-bar-height: 72px;
}

/* Reset minimal */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
  font-family: var(--font-body);
  font-size: var(--fs-base);
  color: var(--color-gray-dark);
  background: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  height: 100vh;
  overflow: hidden;
}

button {
  font-family: inherit;
  cursor: pointer;
  border: none;
  background: none;
  padding: 0;
  color: inherit;
}

button:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

input,
textarea,
select {
  font-family: inherit;
  font-size: inherit;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  font-weight: var(--fw-semibold);
  margin: 0;
  line-height: 1.2;
  color: var(--color-gray-dark);
}

p {
  margin: 0;
  line-height: 1.5;
}

/* Scrollbar discrète */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

::-webkit-scrollbar-track {
  background: transparent;
}

::-webkit-scrollbar-thumb {
  background: var(--color-gray-lighter);
  border-radius: var(--radius-full);
}

::-webkit-scrollbar-thumb:hover {
  background: var(--color-gray-light);
}
