/* Theme CSS Custom Properties */
/* This file defines the CSS variables that will be dynamically populated by the theme system */

:root {
  /* Color Variables */
  --primary-color: #3B82F6;
  --primary-color-50: #EFF6FF;
  --primary-color-100: #DBEAFE;
  --primary-color-200: #BFDBFE;
  --primary-color-300: #93C5FD;
  --primary-color-400: #60A5FA;
  --primary-color-500: #3B82F6;
  --primary-color-600: #2563EB;
  --primary-color-700: #1D4ED8;
  --primary-color-800: #1E40AF;
  --primary-color-900: #1E3A8A;
  
  --secondary-color: #6B7280;
  --secondary-color-50: #F9FAFB;
  --secondary-color-100: #F3F4F6;
  --secondary-color-200: #E5E7EB;
  --secondary-color-300: #D1D5DB;
  --secondary-color-400: #9CA3AF;
  --secondary-color-500: #6B7280;
  --secondary-color-600: #4B5563;
  --secondary-color-700: #374151;
  --secondary-color-800: #1F2937;
  --secondary-color-900: #111827;
  
  --accent-color: #10B981;
  --accent-color-50: #ECFDF5;
  --accent-color-100: #D1FAE5;
  --accent-color-200: #A7F3D0;
  --accent-color-300: #6EE7B7;
  --accent-color-400: #34D399;
  --accent-color-500: #10B981;
  --accent-color-600: #059669;
  --accent-color-700: #047857;
  --accent-color-800: #065F46;
  --accent-color-900: #064E3B;
  
  --danger-color: #EF4444;
  --danger-color-50: #FEF2F2;
  --danger-color-100: #FEE2E2;
  --danger-color-200: #FECACA;
  --danger-color-300: #FCA5A5;
  --danger-color-400: #F87171;
  --danger-color-500: #EF4444;
  --danger-color-600: #DC2626;
  --danger-color-700: #B91C1C;
  --danger-color-800: #991B1B;
  --danger-color-900: #7F1D1D;
  
  --warning-color: #F59E0B;
  --warning-color-50: #FFFBEB;
  --warning-color-100: #FEF3C7;
  --warning-color-200: #FDE68A;
  --warning-color-300: #FCD34D;
  --warning-color-400: #FBBF24;
  --warning-color-500: #F59E0B;
  --warning-color-600: #D97706;
  --warning-color-700: #B45309;
  --warning-color-800: #92400E;
  --warning-color-900: #78350F;
  
  --success-color: var(--accent-color);
  --info-color: var(--primary-color);
  
  /* Background Colors */
  --background-color: #FFFFFF;
  --surface-color: #F9FAFB;
  --card-background: #FFFFFF;
  --modal-background: #FFFFFF;
  --overlay-background: rgba(0, 0, 0, 0.5);
  
  /* Text Colors */
  --text-primary-color: #111827;
  --text-secondary-color: #6B7280;
  --text-muted-color: #9CA3AF;
  --text-inverse-color: #FFFFFF;
  --text-link-color: var(--primary-color);
  --text-link-hover-color: var(--primary-color-700);
  
  /* Border Colors */
  --border-color: #E5E7EB;
  --border-color-light: #F3F4F6;
  --border-color-dark: #D1D5DB;
  --border-focus-color: var(--primary-color);
  --border-error-color: var(--danger-color);
  
  /* Typography Variables */
  --font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', 'Roboto', 'Helvetica Neue', Arial, sans-serif;
  --font-family-mono: 'Fira Code', 'Monaco', 'Cascadia Code', 'Roboto Mono', Consolas, 'Courier New', monospace;
  
  --font-size-xs: 0.75rem;     /* 12px */
  --font-size-sm: 0.875rem;    /* 14px */
  --font-size-base: 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-size-6xl: 3.75rem;    /* 60px */
  
  --font-weight-thin: 100;
  --font-weight-light: 300;
  --font-weight-normal: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;
  --font-weight-extrabold: 800;
  --font-weight-black: 900;
  
  --line-height-none: 1;
  --line-height-tight: 1.25;
  --line-height-snug: 1.375;
  --line-height-normal: 1.5;
  --line-height-relaxed: 1.625;
  --line-height-loose: 2;
  
  --letter-spacing-tighter: -0.05em;
  --letter-spacing-tight: -0.025em;
  --letter-spacing-normal: 0em;
  --letter-spacing-wide: 0.025em;
  --letter-spacing-wider: 0.05em;
  --letter-spacing-widest: 0.1em;
  
  /* Layout Variables */
  --border-radius-none: 0px;
  --border-radius-sm: 0.125rem;   /* 2px */
  --border-radius: 0.25rem;       /* 4px */
  --border-radius-md: 0.375rem;   /* 6px */
  --border-radius-lg: 0.5rem;     /* 8px */
  --border-radius-xl: 0.75rem;    /* 12px */
  --border-radius-2xl: 1rem;      /* 16px */
  --border-radius-3xl: 1.5rem;    /* 24px */
  --border-radius-full: 9999px;
  
  --border-width: 1px;
  --border-width-0: 0px;
  --border-width-2: 2px;
  --border-width-4: 4px;
  --border-width-8: 8px;
  
  /* Spacing Variables */
  --spacing-0: 0px;
  --spacing-1: 0.25rem;   /* 4px */
  --spacing-2: 0.5rem;    /* 8px */
  --spacing-3: 0.75rem;   /* 12px */
  --spacing-4: 1rem;      /* 16px */
  --spacing-5: 1.25rem;   /* 20px */
  --spacing-6: 1.5rem;    /* 24px */
  --spacing-8: 2rem;      /* 32px */
  --spacing-10: 2.5rem;   /* 40px */
  --spacing-12: 3rem;     /* 48px */
  --spacing-16: 4rem;     /* 64px */
  --spacing-20: 5rem;     /* 80px */
  --spacing-24: 6rem;     /* 96px */
  --spacing-32: 8rem;     /* 128px */
  
  /* Shadow Variables */
  --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
  --shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
  --shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, 0.06);
  --shadow-none: 0 0 #0000;
  
  /* Animation Variables */
  --transition-duration-75: 75ms;
  --transition-duration-100: 100ms;
  --transition-duration-150: 150ms;
  --transition-duration-200: 200ms;
  --transition-duration-300: 300ms;
  --transition-duration-500: 500ms;
  --transition-duration-700: 700ms;
  --transition-duration-1000: 1000ms;
  
  --transition-timing-linear: linear;
  --transition-timing-in: cubic-bezier(0.4, 0, 1, 1);
  --transition-timing-out: cubic-bezier(0, 0, 0.2, 1);
  --transition-timing-in-out: cubic-bezier(0.4, 0, 0.2, 1);
  
  /* Z-Index Variables */
  --z-index-dropdown: 1000;
  --z-index-sticky: 1020;
  --z-index-fixed: 1030;
  --z-index-modal-backdrop: 1040;
  --z-index-modal: 1050;
  --z-index-popover: 1060;
  --z-index-tooltip: 1070;
  --z-index-toast: 1080;
}

/* Dark mode variables (for future implementation) */
@media (prefers-color-scheme: dark) {
  :root {
    --background-color: #111827;
    --surface-color: #1F2937;
    --card-background: #1F2937;
    --modal-background: #1F2937;
    --text-primary-color: #F9FAFB;
    --text-secondary-color: #D1D5DB;
    --text-muted-color: #9CA3AF;
    --border-color: #374151;
    --border-color-light: #4B5563;
    --border-color-dark: #6B7280;
  }
}

/* High contrast mode support */
@media (prefers-contrast: high) {
  :root {
    --border-width: 2px;
    --shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.3);
    --shadow-md: 0 6px 8px -1px rgba(0, 0, 0, 0.3);
  }
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce) {
  :root {
    --transition-duration-75: 0ms;
    --transition-duration-100: 0ms;
    --transition-duration-150: 0ms;
    --transition-duration-200: 0ms;
    --transition-duration-300: 0ms;
    --transition-duration-500: 0ms;
    --transition-duration-700: 0ms;
    --transition-duration-1000: 0ms;
  }
}

/* Utility classes using CSS variables */
.theme-primary {
  color: var(--primary-color);
}

.theme-bg-primary {
  background-color: var(--primary-color);
}

.theme-border-primary {
  border-color: var(--primary-color);
}

.theme-secondary {
  color: var(--secondary-color);
}

.theme-bg-secondary {
  background-color: var(--secondary-color);
}

.theme-accent {
  color: var(--accent-color);
}

.theme-bg-accent {
  background-color: var(--accent-color);
}

.theme-danger {
  color: var(--danger-color);
}

.theme-bg-danger {
  background-color: var(--danger-color);
}

.theme-warning {
  color: var(--warning-color);
}

.theme-bg-warning {
  background-color: var(--warning-color);
}

.theme-text-primary {
  color: var(--text-primary-color);
}

.theme-text-secondary {
  color: var(--text-secondary-color);
}

.theme-bg-surface {
  background-color: var(--surface-color);
}

.theme-border {
  border-color: var(--border-color);
}

.theme-rounded {
  border-radius: var(--border-radius);
}

.theme-font {
  font-family: var(--font-family);
}

.theme-font-size {
  font-size: var(--font-size-base);
}

.theme-line-height {
  line-height: var(--line-height-normal);
}

/* Component-specific theme classes */
.btn-theme-primary {
  background-color: var(--primary-color);
  border-color: var(--primary-color);
  color: var(--text-inverse-color);
}

.btn-theme-primary:hover {
  background-color: var(--primary-color-700);
  border-color: var(--primary-color-700);
}

.btn-theme-secondary {
  background-color: var(--secondary-color);
  border-color: var(--secondary-color);
  color: var(--text-inverse-color);
}

.btn-theme-secondary:hover {
  background-color: var(--secondary-color-700);
  border-color: var(--secondary-color-700);
}

.card-theme {
  background-color: var(--card-background);
  border-color: var(--border-color);
  border-radius: var(--border-radius-lg);
  box-shadow: var(--shadow);
}

.input-theme {
  background-color: var(--background-color);
  border-color: var(--border-color);
  color: var(--text-primary-color);
  border-radius: var(--border-radius);
  font-family: var(--font-family);
  font-size: var(--font-size-base);
}

.input-theme:focus {
  border-color: var(--border-focus-color);
  box-shadow: 0 0 0 3px rgba(var(--primary-color), 0.1);
}

.modal-theme {
  background-color: var(--modal-background);
  border-radius: var(--border-radius-lg);
  box-shadow: var(--shadow-2xl);
}

.table-theme {
  background-color: var(--background-color);
  color: var(--text-primary-color);
}

.table-theme th {
  background-color: var(--surface-color);
  color: var(--text-secondary-color);
  border-bottom-color: var(--border-color);
}

.table-theme td {
  border-bottom-color: var(--border-color-light);
}

.navbar-theme {
  background-color: var(--surface-color);
  border-bottom-color: var(--border-color);
}

.sidebar-theme {
  background-color: var(--surface-color);
  border-right-color: var(--border-color);
}

/* Print styles */
@media print {
  :root {
    --background-color: white;
    --text-primary-color: black;
    --text-secondary-color: #666;
    --border-color: #ccc;
  }
}