/* ===================================
   Universal Color System
   Supports both light and dark themes
   ================================== */

   :root {



      /* === Primitive spacing scale (4px grid) === */
      --space-0: 0px;
      --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-14: 56px;
      --space-16: 64px;
      --space-20: 80px;

      /* === Semantic spacing tokens === */
      --gap-xxs: var(--space-1);
      /* 4px */
      --gap-xs: var(--space-2);
      /* 8px */
      --gap-sm: var(--space-4);
      /* 16px */
      --gap-md: var(--space-6);
      /* 24px */
      --gap-lg: var(--space-8);
      /* 32px */
      --gap-xl: var(--space-12);
      /* 48px */
      --gap-section: var(--space-14);
      /* 80px between big sections */

      --container-padding-sm: var(--space-4);
      /* 16px */
      --container-padding-md: var(--space-8);
      /* 32px */
      --container-padding-lg: var(--space-10);
      /* 40px */


      /* === Primitive typography scale === */
      --font-size-sm: 14px;
      --font-size-base: 16px;
      --font-size-lg: 18px;
      --font-size-xl: 20px;
      --font-size-2xl: 24px;
      --font-size-3xl: 32px;
      --font-size-4xl: 40px;
      --font-size-5xl: 60px;

      --line-height-tight: 1.2;
      --line-height-normal: 1.5;
      --line-height-relaxed: 1.75;

      /* === Semantic typography tokens === */
      --font-body: var(--font-size-base);
      --line-body: var(--line-height-normal);

      --font-heading-sm: var(--font-size-xl);
      --font-heading-md: var(--font-size-2xl);
      --font-heading-lg: var(--font-size-3xl);
      --font-heading-xl: var(--font-size-4xl);
      --font-hero: var(--font-size-5xl);

      --line-heading: var(--line-height-tight);

      /* === Component: Hero === */
      --hero-gap: var(--gap-xl);
      --hero-title-font: var(--font-hero);
      --hero-title-line: var(--line-heading);
      --hero-subtitle-font: var(--font-heading-md);
      --hero-subtitle-gap: var(--gap-xs);

      /* === Component: Section === */
      --section-padding-block: var(--gap-xl);
      --section-gap: var(--gap-md);
      --section-title-font: var(--font-heading-lg);
      --section-title-gap: var(--gap-sm);
      --section-subtitle-font: var(--font-heading-md);
      --section-subtitle-gap: var(--gap-xxs);
      --section-text-gap: var(--gap-xs);

      /* === Component: Card === */
      --card-padding: var(--gap-md);
      --card-gap: var(--gap-sm);
      --card-radius: 12px;
      --card-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);

      /* === Component: List === */
      --list-item-gap: var(--gap-xxs);
      --list-item-margin-bottom: var(--gap-md);
      --list-heading-font: var(--font-heading-sm);
      --list-text-font: var(--font-body);

      /* === Component: Author Block === */
      --author-gap: var(--gap-sm);
      --author-avatar-size: 48px;
      --author-name-font: var(--font-heading-sm);
      --author-info-font: var(--font-body);

      /* === Component: Divider === */
      --divider-margin-block: var(--gap-md);
      --divider-thickness: 1px;
      --divider-color: var(--color-text-muted);

      /* === Component: Discovery Header === */
      --discovery-gap: var(--gap-sm);
      --discovery-title-font: var(--font-heading-sm);
      --discovery-label-font: var(--font-body);


      --spacing-xs: 8px;
      --spacing-sm: 16px;
      --spacing-md: 24px;
      --spacing-lg: 40px;
      --spacing-xl: 60px;

      /* Container width tokens */
  --container-xs: 520px;
  --container-sm: 560px;
  --container-md: 680px;
  --container-lg: 860px;

    
    /* === Core Brand Colors === */
    --brand-primary: #0c8ce9;
    --brand-primary-hover: #0a7bc4;
    --brand-primary-pressed: #0967a3;
    
    /* === Neutral Palette === */
    --neutral-0: #ffffff;
    --neutral-50: #f9fafb;
    --neutral-100: #f3f4f6;
    --neutral-200: #e5e7eb;
    --neutral-300: #d1d5db;
    --neutral-400: #9ca3af;
    --neutral-500: #6b7280;
    --neutral-600: #4b5563;
    --neutral-700: #374151;
    --neutral-800: #1f2937;
    --neutral-900: #111827;
    --neutral-950: #030712;
    
    /* === Dark Theme Variations === */
    --dark-100: #2c2c2c;
    --dark-200: #1d1d1d;
    --dark-300: #0d0d0d;
    
    /* === Semantic Color Tokens - Light Mode === */
    --color-background-primary: var(--neutral-0);
    --color-background-secondary: var(--neutral-50);
    --color-background-tertiary: var(--neutral-100);
    --color-background-elevated: var(--neutral-0);
    --color-background-overlay: rgba(0, 0, 0, 0.8);
    
    --color-surface-default: var(--neutral-0);
    --color-surface-elevated: var(--neutral-50);
    --color-surface-interactive: var(--neutral-100);
    --color-surface-interactive-hover: var(--neutral-200);
    
    --color-text-primary: var(--neutral-900);
    --color-text-secondary: var(--neutral-700);
    --color-text-tertiary: var(--neutral-500);
    --color-text-muted: var(--neutral-400);
    --color-text-inverse: var(--neutral-0);
    --color-text-link: var(--brand-primary);
    --color-text-link-hover: var(--brand-primary-hover);
    
    --color-border-default: var(--neutral-200);
    --color-border-subtle: var(--neutral-100);
    --color-border-strong: var(--neutral-300);
    --color-border-interactive: var(--brand-primary);
    
    --color-interactive-primary: var(--brand-primary);
    --color-interactive-primary-hover: var(--brand-primary-hover);
    --color-interactive-primary-pressed: var(--brand-primary-pressed);
    --color-interactive-secondary: var(--neutral-100);
    --color-interactive-secondary-hover: var(--neutral-200);
    
    /* === Shadow System === */
    --shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.05);
    --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.1), 0 1px 2px rgba(0, 0, 0, 0.06);
    --shadow-md: 0 4px 6px rgba(0, 0, 0, 0.05), 0 2px 4px rgba(0, 0, 0, 0.06);
    --shadow-lg: 0 10px 25px rgba(0, 0, 0, 0.1), 0 4px 16px rgba(0, 0, 0, 0.05);
    --shadow-xl: 0 20px 25px rgba(0, 0, 0, 0.1), 0 10px 10px rgba(0, 0, 0, 0.04);
  }
  
/* === Dark Mode Color Overrides === */
[data-theme="dark"],
.dark-theme {
  /* Remove the @media (prefers-color-scheme: dark) selector */
  
  /* === Semantic Color Tokens - Dark Mode === */
  --color-background-primary: var(--dark-200);
  --color-background-secondary: var(--dark-100);
  --color-background-tertiary: var(--neutral-800);
  --color-background-elevated: var(--dark-100);
  --color-background-overlay: rgba(0, 0, 0, 0.9);
  
  --color-surface-default: var(--dark-200);
  --color-surface-elevated: var(--dark-100);
  --color-surface-interactive: var(--neutral-700);
  --color-surface-interactive-hover: var(--neutral-600);
  
  --color-text-primary: var(--neutral-0);
  --color-text-secondary: #e7e7e7;
  --color-text-tertiary: #d6d6d6;
  --color-text-muted: var(--neutral-400);
  --color-text-inverse: var(--neutral-900);
  --color-text-link: var(--brand-primary);
  --color-text-link-hover: var(--brand-primary-hover);
  
  --color-border-default: var(--neutral-700);
  --color-border-subtle: var(--neutral-800);
  --color-border-strong: var(--neutral-600);
  --color-border-interactive: var(--brand-primary);
  
  --color-interactive-primary: var(--brand-primary);
  --color-interactive-primary-hover: var(--brand-primary-hover);
  --color-interactive-primary-pressed: var(--brand-primary-pressed);
  --color-interactive-secondary: var(--neutral-700);
  --color-interactive-secondary-hover: var(--neutral-600);
  
  /* === Dark Mode Shadows === */
  --shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.3);
  --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.4), 0 1px 2px rgba(0, 0, 0, 0.3);
  --shadow-md: 0 4px 6px rgba(0, 0, 0, 0.4), 0 2px 4px rgba(0, 0, 0, 0.3);
  --shadow-lg: 0 10px 15px rgba(0, 0, 0, 0.5), 0 4px 6px rgba(0, 0, 0, 0.4);
  --shadow-xl: 0 20px 25px rgba(0, 0, 0, 0.6), 0 10px 10px rgba(0, 0, 0, 0.5);
}
  
  /* === Component-Specific Color Mappings === */
  
  /* Buttons */
  .btn-primary {
    background-color: var(--color-interactive-primary);
    color: var(--color-text-inverse);
    border-color: var(--color-interactive-primary);
  }
  
  .btn-primary:hover {
    background-color: var(--color-interactive-primary-hover);
    border-color: var(--color-interactive-primary-hover);
  }
  
  .btn-secondary {
    background-color: var(--color-interactive-secondary);
    color: var(--color-text-primary);
    border-color: var(--color-border-default);
  }
  
  .btn-secondary:hover {
    background-color: var(--color-interactive-secondary-hover);
  }
  
  /* Cards */
  .card {
    background-color: var(--color-surface-elevated);
    border-color: var(--color-border-subtle);
    box-shadow: var(--shadow-sm);
  }
  
  .card:hover {
    box-shadow: var(--shadow-md);
  }
  
  /* Navigation */
  .nav {
    background-color: var(--color-background-elevated);
    border-bottom-color: var(--color-border-default);
  }
  
  /* Form Elements */
  .input, .textarea, .select {
    background-color: var(--color-surface-default);
    border-color: var(--color-border-default);
    color: var(--color-text-primary);
  }
  
  .input:focus, .textarea:focus, .select:focus {
    border-color: var(--color-border-interactive);
    box-shadow: 0 0 0 3px rgba(12, 140, 233, 0.1);
  }
  
  /* Utility Classes */
  .bg-primary { background-color: var(--color-background-primary); }
  .bg-secondary { background-color: var(--color-background-secondary); }
  .bg-surface { background-color: var(--color-surface-default); }
  
  .text-primary { color: var(--color-text-primary); }
  .text-secondary { color: var(--color-text-secondary); }
  .text-muted { color: var(--color-text-muted); }
  .text-inverse { color: var(--color-text-inverse); }
  
  .border-default { border-color: var(--color-border-default); }
  .border-subtle { border-color: var(--color-border-subtle); }
  
  /* === Theme Toggle Utilities === */
  .theme-toggle {
    background: var(--color-interactive-secondary);
    border: 1px solid var(--color-border-default);
    color: var(--color-text-primary);
    border-radius: 6px;
    padding: 8px 12px;
    cursor: pointer;
    transition: all 0.2s ease;
  }
  
  .theme-toggle:hover {
    background: var(--color-interactive-secondary-hover);
  }