:root {
  --color-brand: #2e3192;
  --color-brand-muted: #7278b9;
  --color-brand-dark: #1f2266;
  --color-brand-light: #4549b0;
  --color-brand-subtle: #eeeef8;
  --color-text: #1a1a2e;
  --color-text-secondary: #4a4a6a;
  --color-text-muted: #8585a0;
  --color-text-on-brand: #f8f8ff;
  --color-text-on-brand-secondary: #c8c8e0;
  --color-border: #dddde8;
  --color-error: #dc2626;
  --color-error-bg: #fef2f2;
  --color-error-border: #fecaca;
  --color-success: #16a34a;

  --shadow-sm: 0 2px 8px rgba(46,49,146,0.06);
  --shadow-md: 0 6px 24px rgba(46,49,146,0.1);
  --shadow-btn-brand: 0 6px 24px rgba(46,49,146,0.3);

  --space-xs: 0.25rem;
  --space-sm: 0.5rem;
  --space-md: 1rem;
  --space-lg: 1.5rem;
  --space-xl: 2rem;
  --space-2xl: 3rem;

  --font-display: 'Raleway', sans-serif;
  --font-body: 'Raleway', sans-serif;
  --font-mono: ui-monospace, 'SF Mono', monospace;

  --text-xs: 0.75rem;
  --text-sm: 0.875rem;
  --text-base: 1rem;
  --text-lg: 1.125rem;
  --text-xl: 1.333rem;
  --text-2xl: 1.777rem;

  --ease-out: cubic-bezier(0.23, 1, 0.32, 1);
  --ease-out-expo: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);

  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 16px;
  --radius-xl: 24px;
}
