/* ============================================================
   MathGyro — Design Tokens & Custom Properties
   "Precision Engineering meets Modern Elegance"
   Dark theme default. Ocean Blue accent.
   ============================================================ */

/* --- Google Fonts (loaded in base.njk) --- */
/* Space Grotesk: headings & UI
   JetBrains Mono: numbers & code */

:root {
  /* ---- COLOR SCALE: Blue (accent) ---- */
  --blue-50:  #f0f9ff;
  --blue-100: #e0f2fe;
  --blue-200: #bae6fd;
  --blue-300: #7dd3fc;
  --blue-400: #38bdf8;
  --blue-500: #0ea5e9;
  --blue-600: #0284c7;
  --blue-700: #0369a1;
  --blue-800: #075985;
  --blue-900: #0c4a6e;

  /* ---- COLOR SCALE: Slate (neutrals) ---- */
  --slate-50:  #f8fafc;
  --slate-100: #f1f5f9;
  --slate-200: #e2e8f0;
  --slate-300: #cbd5e1;
  --slate-400: #94a3b8;
  --slate-500: #64748b;
  --slate-600: #475569;
  --slate-700: #334155;
  --slate-800: #1e293b;
  --slate-850: #172033;
  --slate-900: #0f172a;
  --slate-950: #020617;

  /* ---- COLOR SCALE: Amber (secondary/warning) ---- */
  --amber-50:  #fffbeb;
  --amber-100: #fef3c7;
  --amber-200: #fde68a;
  --amber-300: #fcd34d;
  --amber-400: #fbbf24;
  --amber-500: #f59e0b;
  --amber-600: #d97706;
  --amber-700: #b45309;
  --amber-800: #92400e;
  --amber-900: #78350f;

  /* ---- COLOR SCALE: Emerald (success) ---- */
  --emerald-50:  #ecfdf5;
  --emerald-100: #d1fae5;
  --emerald-200: #a7f3d0;
  --emerald-300: #6ee7b7;
  --emerald-400: #34d399;
  --emerald-500: #10b981;
  --emerald-600: #059669;
  --emerald-700: #047857;
  --emerald-800: #065f46;
  --emerald-900: #064e3b;

  /* ---- COLOR SCALE: Red (danger) ---- */
  --red-50:  #fef2f2;
  --red-100: #fee2e2;
  --red-200: #fecaca;
  --red-300: #fca5a5;
  --red-400: #f87171;
  --red-500: #ef4444;
  --red-600: #dc2626;
  --red-700: #b91c1c;
  --red-800: #991b1b;
  --red-900: #7f1d1d;

  /* ---- TYPOGRAPHY ---- */
  --font-heading: 'Space Grotesk', system-ui, -apple-system, sans-serif;
  --font-body:    'Space Grotesk', system-ui, -apple-system, sans-serif;
  --font-mono:    'JetBrains Mono', 'Fira Code', 'Cascadia Code', monospace;

  --text-xs:   0.75rem;
  --text-sm:   0.875rem;
  --text-base: 1rem;
  --text-lg:   1.125rem;
  --text-xl:   1.25rem;
  --text-2xl:  1.5rem;
  --text-3xl:  1.875rem;
  --text-4xl:  2.25rem;
  --text-5xl:  3rem;

  --leading-tight:   1.25;
  --leading-snug:    1.375;
  --leading-normal:  1.5;
  --leading-relaxed: 1.65;
  --leading-loose:   1.8;

  --tracking-tight:  -0.025em;
  --tracking-normal:  0;
  --tracking-wide:    0.025em;

  /* ---- SPACING ---- */
  --space-0:   0;
  --space-1:   0.25rem;
  --space-2:   0.5rem;
  --space-3:   0.75rem;
  --space-4:   1rem;
  --space-5:   1.25rem;
  --space-6:   1.5rem;
  --space-8:   2rem;
  --space-10:  2.5rem;
  --space-12:  3rem;
  --space-16:  4rem;
  --space-20:  5rem;
  --space-24:  6rem;

  /* ---- LAYOUT ---- */
  --container-max: 1200px;
  --container-narrow: 800px;
  --header-height: 64px;
  --sidebar-width: 280px;

  /* ---- RADIUS ---- */
  --radius-sm:   4px;
  --radius-md:   8px;
  --radius-lg:   12px;
  --radius-xl:   16px;
  --radius-2xl:  24px;
  --radius-full: 9999px;

  /* ---- SHADOWS ---- */
  --shadow-xs:  0 1px 2px rgba(0,0,0,0.06);
  --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 -1px rgba(0,0,0,0.1), 0 2px 4px -2px rgba(0,0,0,0.1);
  --shadow-lg:  0 10px 15px -3px rgba(0,0,0,0.1), 0 4px 6px -4px rgba(0,0,0,0.1);
  --shadow-xl:  0 20px 25px -5px rgba(0,0,0,0.1), 0 8px 10px -6px rgba(0,0,0,0.1);
  --shadow-glow: 0 0 20px rgba(14, 165, 233, 0.15);

  /* ---- TRANSITIONS ---- */
  --ease-out:   cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in:    cubic-bezier(0.55, 0.055, 0.675, 0.19);
  --ease-in-out: cubic-bezier(0.87, 0, 0.13, 1);
  --duration-fast:   150ms;
  --duration-base:   250ms;
  --duration-slow:   400ms;
  --duration-slower: 600ms;

  /* ---- Z-INDEX ---- */
  --z-dropdown:  100;
  --z-sticky:    200;
  --z-overlay:   300;
  --z-modal:     400;
  --z-toast:     500;
}

/* ============================================================
   DARK THEME (default)
   ============================================================ */
:root,
[data-theme="dark"] {
  --bg-primary:    var(--slate-900);
  --bg-secondary:  var(--slate-850);
  --bg-tertiary:   var(--slate-800);
  --bg-elevated:   var(--slate-700);

  --text-primary:   #f0f4f8;
  --text-secondary: var(--slate-400);
  --text-tertiary:  var(--slate-500);
  --text-inverse:   var(--slate-900);

  --accent-primary:   var(--blue-500);
  --accent-hover:     var(--blue-400);
  --accent-active:    var(--blue-600);
  --accent-subtle:    rgba(14, 165, 233, 0.1);
  --accent-muted:     rgba(14, 165, 233, 0.2);

  --accent-secondary: var(--amber-500);

  --border-primary:   var(--slate-700);
  --border-secondary: var(--slate-800);
  --border-subtle:    rgba(148, 163, 184, 0.08);
  --border-accent:    rgba(14, 165, 233, 0.3);

  --success:      var(--emerald-500);
  --success-bg:   rgba(16, 185, 129, 0.1);
  --warning:      var(--amber-500);
  --warning-bg:   rgba(245, 158, 11, 0.1);
  --danger:       var(--red-500);
  --danger-bg:    rgba(239, 68, 68, 0.1);
  --info:         var(--blue-400);
  --info-bg:      rgba(14, 165, 233, 0.1);

  --shadow-card:   0 2px 8px rgba(0,0,0,0.3), 0 1px 3px rgba(0,0,0,0.2);
  --shadow-card-hover: 0 8px 24px rgba(0,0,0,0.35), 0 2px 6px rgba(0,0,0,0.25);
  --header-bg:     rgba(15, 23, 42, 0.82);
  --overlay-bg:    rgba(2, 6, 23, 0.7);
  --scrollbar-track: var(--slate-900);
  --scrollbar-thumb: var(--slate-700);
  --selection-bg:  rgba(14, 165, 233, 0.3);
}

/* ============================================================
   LIGHT THEME
   ============================================================ */
[data-theme="light"] {
  --bg-primary:    #fafbfd;
  --bg-secondary:  #ffffff;
  --bg-tertiary:   var(--slate-100);
  --bg-elevated:   var(--slate-200);

  --text-primary:   var(--slate-900);
  --text-secondary: var(--slate-600);
  --text-tertiary:  var(--slate-500);
  --text-inverse:   #ffffff;

  --accent-primary:   var(--blue-600);
  --accent-hover:     var(--blue-700);
  --accent-active:    var(--blue-800);
  --accent-subtle:    rgba(2, 132, 199, 0.06);
  --accent-muted:     rgba(2, 132, 199, 0.12);

  --accent-secondary: var(--amber-600);

  --border-primary:   var(--slate-200);
  --border-secondary: var(--slate-100);
  --border-subtle:    rgba(0, 0, 0, 0.04);
  --border-accent:    rgba(2, 132, 199, 0.25);

  --success:      var(--emerald-600);
  --success-bg:   rgba(5, 150, 105, 0.08);
  --warning:      var(--amber-600);
  --warning-bg:   rgba(217, 119, 6, 0.08);
  --danger:       var(--red-600);
  --danger-bg:    rgba(220, 38, 38, 0.08);
  --info:         var(--blue-600);
  --info-bg:      rgba(2, 132, 199, 0.08);

  --shadow-card:   0 1px 3px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
  --shadow-card-hover: 0 10px 20px rgba(0,0,0,0.08), 0 4px 8px rgba(0,0,0,0.06);
  --header-bg:     rgba(250, 251, 253, 0.85);
  --overlay-bg:    rgba(15, 23, 42, 0.4);
  --scrollbar-track: var(--slate-100);
  --scrollbar-thumb: var(--slate-300);
  --selection-bg:  rgba(2, 132, 199, 0.2);
}
