/**
 * Dilypse Design System
 * Variables globales et tokens de design
 */

@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&display=swap');

:root {
  /* ============================================
     COULEURS
     ============================================ */

  /* Couleurs principales */
  --dilypse-primary: #000421;
  --dilypse-secondary: #0080ff;
  --dilypse-accent: #e23d3e;
  --dilypse-light: #f8f9fa;
  --dilypse-gray: #6c757d;
  --dilypse-success: #10b981;
  --dilypse-warning: #f59e0b;
  --dilypse-danger: #ef4444;

  /* Couleurs de fond */
  --bg-body: #f8f9fa;
  --bg-card: #ffffff;
  --bg-section: #ffffff;

  /* Couleurs de texte */
  --text-primary: #000421;
  --text-secondary: #6c757d;
  --text-muted: #adb5bd;
  --text-inverse: #ffffff;

  /* Couleurs de bordure */
  --border-color: #e9ecef;
  --border-color-hover: #dee2e6;
  --border-color-focus: #0080ff;

  /* ============================================
     TYPOGRAPHIE
     ============================================ */

  /* Police */
  --font-family: 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  /* Tailles de police */
  --font-size-xs: 10px;
  --font-size-sm: 11px;
  --font-size-base: 14px;
  --font-size-md: 15px;
  --font-size-lg: 16px;
  --font-size-xl: 20px;
  --font-size-2xl: 24px;
  --font-size-3xl: 32px;

  /* Poids de police */
  --font-weight-light: 300;
  --font-weight-normal: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;

  /* Hauteur de ligne */
  --line-height-tight: 1.2;
  --line-height-normal: 1.5;
  --line-height-relaxed: 1.75;

  /* ============================================
     ESPACEMENT
     ============================================ */

  --space-xs: 4px;
  --space-sm: 8px;
  --space-md: 16px;
  --space-lg: 24px;
  --space-xl: 32px;
  --space-2xl: 48px;
  --space-3xl: 64px;

  /* ============================================
     BORDER RADIUS
     ============================================ */

  --radius-sm: 6px;
  --radius-md: 8px;
  --radius-lg: 10px;
  --radius-xl: 12px;
  --radius-2xl: 16px;
  --radius-full: 9999px;

  /* ============================================
     OMBRES
     ============================================ */

  --shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.05);
  --shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.08);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.08);
  --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.12);
  --shadow-xl: 0 12px 36px rgba(0, 0, 0, 0.16);

  /* Ombres colorées */
  --shadow-primary: 0 4px 12px rgba(0, 128, 255, 0.2);
  --shadow-success: 0 4px 12px rgba(16, 185, 129, 0.2);
  --shadow-danger: 0 4px 12px rgba(239, 68, 68, 0.2);

  /* ============================================
     TRANSITIONS
     ============================================ */

  --transition-fast: 0.15s ease;
  --transition-base: 0.3s ease;
  --transition-slow: 0.5s ease;

  /* ============================================
     Z-INDEX
     ============================================ */

  --z-dropdown: 1000;
  --z-sticky: 1020;
  --z-fixed: 1030;
  --z-modal-backdrop: 1040;
  --z-modal: 1050;
  --z-popover: 1060;
  --z-tooltip: 1070;

  /* ============================================
     BREAKPOINTS (pour référence)
     ============================================ */

  /*
  --breakpoint-xs: 480px;
  --breakpoint-sm: 640px;
  --breakpoint-md: 768px;
  --breakpoint-lg: 1024px;
  --breakpoint-xl: 1280px;
  --breakpoint-2xl: 1536px;
  */
}

/* ============================================
   RESET ET BASE
   ============================================ */

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: var(--font-family);
  font-size: var(--font-size-base);
  line-height: var(--line-height-normal);
  color: var(--text-primary);
  background: var(--bg-body);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ============================================
   CLASSES UTILITAIRES GLOBALES
   ============================================ */

/* Texte */
.text-primary { color: var(--dilypse-primary); }
.text-secondary { color: var(--dilypse-secondary); }
.text-accent { color: var(--dilypse-accent); }
.text-success { color: var(--dilypse-success); }
.text-danger { color: var(--dilypse-danger); }
.text-muted { color: var(--text-muted); }

/* Background */
.bg-primary { background-color: var(--dilypse-primary); }
.bg-secondary { background-color: var(--dilypse-secondary); }
.bg-accent { background-color: var(--dilypse-accent); }
.bg-light { background-color: var(--dilypse-light); }

/* Espacement */
.m-0 { margin: 0; }
.mt-sm { margin-top: var(--space-sm); }
.mt-md { margin-top: var(--space-md); }
.mt-lg { margin-top: var(--space-lg); }
.mb-sm { margin-bottom: var(--space-sm); }
.mb-md { margin-bottom: var(--space-md); }
.mb-lg { margin-bottom: var(--space-lg); }

/* Display */
.hidden { display: none; }
.block { display: block; }
.inline-block { display: inline-block; }
.flex { display: flex; }
.grid { display: grid; }

/* Flex */
.items-center { align-items: center; }
.justify-center { justify-content: center; }
.justify-between { justify-content: space-between; }
.gap-sm { gap: var(--space-sm); }
.gap-md { gap: var(--space-md); }
.gap-lg { gap: var(--space-lg); }
