:root {
  --bg: #f7fafc;
  --surface: #ffffff;
  --surface-2: #f1f5f9;
  --text: #0f172a;
  --muted: #475569;
  --border: #d7e1ec;
  --accent: #0e7490;
  --accent-soft: #e0f2fe;
  --danger: #b91c1c;
  --warning: #b45309;
  --sidebar-bg: #ffffff;
  --sidebar-text: #0f172a;
  --sidebar-text-muted: #475569;
  --topbar-bg: rgba(255, 255, 255, 0.9);

  --font-sans: "IBM Plex Sans", "Segoe UI", Tahoma, sans-serif;
  --font-mono: "IBM Plex Mono", "Cascadia Mono", Consolas, monospace;
  --fs-sm: 0.875rem;
  --fs-md: 1rem;
  --fs-lg: 1.25rem;
  --lh: 1.45;

  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.5rem;
  --space-6: 2rem;

  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --shadow-1: 0 4px 12px rgba(15, 23, 42, 0.06);
  --shadow-2: 0 16px 30px rgba(15, 23, 42, 0.1);
}

[data-theme="dark"] {
  --bg: #0f141a;
  --surface: #151d25;
  --surface-2: #1d2833;
  --text: #e5edf5;
  --muted: #9fb1c3;
  --border: #314152;
  --accent: #14b8a6;
  --accent-soft: #11312f;
  --danger: #f87171;
  --warning: #f59e0b;
  --sidebar-bg: #101922;
  --sidebar-text: #e5edf5;
  --sidebar-text-muted: #9fb1c3;
  --topbar-bg: rgba(21, 29, 37, 0.88);

  --shadow-1: 0 10px 24px rgba(0, 0, 0, 0.32);
  --shadow-2: 0 24px 46px rgba(0, 0, 0, 0.46);
}
