/**
 * 3dmaterial.fr — design tokens (charte claire, technique)
 * Base réutilisable pour l’ensemble du site
 */

:root {
  /* ——— Couleurs (palette courte) ——— */
  --color-bg: #f7f8fa;
  --color-surface: #ffffff;
  --color-surface-elevated: #fafbfc;
  --color-border: #e5e7eb;
  --color-text: #1f2937;
  --color-accent: #e67e22;
  --color-accent-hover: #c96a16;
  --color-accent-soft: #fff3e8;
  /* Texte secondaire — contraste lisible */
  --text-secondary: #5f6b7a;
  --color-text-muted: var(--text-secondary);
  /* Alias sémantiques */
  --primary: var(--color-accent);
  --primary-light: var(--color-accent-soft);
  /* Liens : même famille que l’accent, lisibles sur fond clair */
  --color-link: #b45309;
  --color-link-hover: var(--color-accent-hover);
  --color-focus: #c96a16;
  --color-on-accent: #ffffff;

  /* ——— Typographie ——— */
  --font-sans: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --font-mono: ui-monospace, "Cascadia Code", "SF Mono", Consolas, monospace;

  --fs-xs: 0.8125rem; /* 13px */
  --fs-sm: 0.9375rem; /* 15px */
  --fs-base: 1.125rem; /* 18px — corps principal */
  --fs-lg: 1.25rem; /* 20px */
  --fs-xl: 1.375rem; /* 22px */
  --fs-2xl: clamp(1.75rem, 2.5vw, 2.5rem); /* H2 ~28–40px */
  --fs-3xl: clamp(2rem, 3vw, 2.75rem); /* intermédiaire */
  --fs-hero: clamp(2.25rem, 4.5vw, 3.5rem); /* H1 hero ~36–56px */

  --lh-tight: 1.2;
  --lh-snug: 1.35;
  --lh-normal: 1.6;
  --lh-relaxed: 1.7;

  /* ——— Espacements ——— */
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;
  --space-20: 5rem;
  --space-24: 6rem;

  --section-y: clamp(4rem, 6vw, 6rem); /* 64–96px sections */
  --section-y-tight: clamp(3rem, 4vw, 4rem);

  /* ——— Rayons & ombres ——— */
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 16px;
  --radius-xl: 20px;
  --radius-pill: 999px;

  --shadow-xs: 0 1px 2px rgba(31, 41, 55, 0.04);
  --shadow-sm: 0 1px 3px rgba(31, 41, 55, 0.06), 0 1px 2px rgba(31, 41, 55, 0.04);
  --shadow-md: 0 4px 12px rgba(31, 41, 55, 0.07), 0 2px 4px rgba(31, 41, 55, 0.04);
  --shadow-lg: 0 12px 32px rgba(31, 41, 55, 0.09);
  --shadow-xl: 0 20px 40px rgba(31, 41, 55, 0.1);
  /* Bandes / sections — légère variation sur fond #F7F8FA */
  --color-bg-section-alt: #f0f2f5;
  --color-bg-warm: #fdf8f4;

  --max-width: 75rem; /* ~1200px */
  --max-width-prose: 42rem;
  --header-height: 4rem;

  --transition-fast: 0.15s ease;
  --transition-base: 0.2s ease;
  --transition-ui: all 0.2s ease;
  --transition-card: all 0.25s ease;
  --ease-out-smooth: cubic-bezier(0.22, 1, 0.36, 1);
}
