:root {
  /* Colors */
  --color-primary: #1E3A8A;
  --color-primary-light: #2563EB;
  --color-primary-dark: #1E40AF;
  
  --color-secondary: #0D9488;
  --color-secondary-light: #14B8A6;
  --color-secondary-dark: #0F766E;
  
  --color-accent: #F59E0B;
  --color-accent-light: #FBBF24;
  --color-accent-dark: #D97706;
  
  --color-success: #10B981;
  --color-warning: #F59E0B;
  --color-error: #EF4444;
  
  /* Light Mode */
  --light-bg: #F9FAFB;
  --light-bg-alt: #F3F4F6;
  --light-text: #1F2937;
  --light-text-secondary: #4B5563;
  --light-border: #E5E7EB;
  --light-card: #FFFFFF;
  --light-shadow: rgba(0, 0, 0, 0.1);
  
  /* Dark Mode */
  --dark-bg: #111827;
  --dark-bg-alt: #1F2937;
  --dark-text: #F9FAFB;
  --dark-text-secondary: #D1D5DB;
  --dark-border: #374151;
  --dark-card: #1F2937;
  --dark-shadow: rgba(0, 0, 0, 0.3);
  
  /* Spacing */
  --space-xxs: 0.25rem;  /* 4px */
  --space-xs: 0.5rem;    /* 8px */
  --space-sm: 0.75rem;   /* 12px */
  --space-md: 1rem;      /* 16px */
  --space-lg: 1.5rem;    /* 24px */
  --space-xl: 2rem;      /* 32px */
  --space-xxl: 3rem;     /* 48px */
  
  /* Typography */
  --font-family-heading: 'Montserrat', sans-serif;
  --font-family-body: 'Source Sans Pro', sans-serif;
  
  --font-size-xs: 0.75rem;    /* 12px */
  --font-size-sm: 0.875rem;   /* 14px */
  --font-size-md: 1rem;       /* 16px */
  --font-size-lg: 1.125rem;   /* 18px */
  --font-size-xl: 1.25rem;    /* 20px */
  --font-size-2xl: 1.5rem;    /* 24px */
  --font-size-3xl: 1.875rem;  /* 30px */
  --font-size-4xl: 2.25rem;   /* 36px */
  --font-size-5xl: 3rem;      /* 48px */
  
  --font-weight-light: 300;
  --font-weight-normal: 400;
  --font-weight-medium: 500;
  --font-weight-bold: 700;
  
  --line-height-tight: 1.2;    /* headings */
  --line-height-normal: 1.5;   /* body text */
  --line-height-loose: 1.8;    /* larger paragraphs */
  
  /* Borders */
  --border-radius-sm: 0.25rem;  /* 4px */
  --border-radius-md: 0.5rem;   /* 8px */
  --border-radius-lg: 1rem;     /* 16px */
  --border-radius-full: 9999px;
  
  --border-width-thin: 1px;
  --border-width-medium: 2px;
  --border-width-thick: 4px;
  
  /* Transitions */
  --transition-fast: 0.2s ease;
  --transition-normal: 0.3s ease;
  --transition-slow: 0.5s ease;
  
  /* Other */
  --header-height: 4rem;
  --footer-height: 12rem;
  --container-max-width: 1200px;
  --section-padding: 5rem 0;
}

/* Default to light theme variables */
.theme-wrapper {
  --bg: var(--light-bg);
  --bg-alt: var(--light-bg-alt);
  --text: var(--light-text);
  --text-secondary: var(--light-text-secondary);
  --border: var(--light-border);
  --card: var(--light-card);
  --shadow: var(--light-shadow);
}

/* Dark theme variables */
.theme-wrapper.dark {
  --bg: var(--dark-bg);
  --bg-alt: var(--dark-bg-alt);
  --text: var(--dark-text);
  --text-secondary: var(--dark-text-secondary);
  --border: var(--dark-border);
  --card: var(--dark-card);
  --shadow: var(--dark-shadow);
}