/* =========================================================================
   Skyblocks — Design Tokens (lifted from docs/design_handoff/prototype/src/tokens.css)
   Linear-leaning, dense-but-comfortable, dark-first.
   Single source of truth for colors, spacing, radii, motion.
   ========================================================================= */

:root {
  /* Accent — default brand blue (overridable via [data-accent]) */
  --accent-h: 222;
  --accent-s: 100%;
  --accent-l: 64%;
  --accent: hsl(var(--accent-h) var(--accent-s) var(--accent-l));
  --accent-hover: hsl(var(--accent-h) var(--accent-s) calc(var(--accent-l) + 6%));
  --accent-press: hsl(var(--accent-h) var(--accent-s) calc(var(--accent-l) - 6%));
  --accent-fg: #ffffff;
  --accent-soft: hsl(var(--accent-h) var(--accent-s) var(--accent-l) / 0.12);
  --accent-soft-hover: hsl(var(--accent-h) var(--accent-s) var(--accent-l) / 0.18);
  --accent-ring: hsl(var(--accent-h) var(--accent-s) var(--accent-l) / 0.35);

  /* Status */
  --success: #22c55e;
  --success-soft: rgba(34, 197, 94, 0.12);
  --warning: #f59e0b;
  --warning-soft: rgba(245, 158, 11, 0.12);
  --danger: #ef4444;
  --danger-soft: rgba(239, 68, 68, 0.12);
  --info: #06b6d4;
  --info-soft: rgba(6, 182, 212, 0.12);

  /* Spacing */
  --s-1: 4px;  --s-2: 8px;  --s-3: 12px; --s-4: 16px; --s-5: 20px;
  --s-6: 24px; --s-7: 32px; --s-8: 40px; --s-9: 48px; --s-10: 64px;

  /* Radius */
  --r-xs: 4px; --r-sm: 6px; --r-md: 8px; --r-lg: 10px;
  --r-xl: 14px; --r-2xl: 20px; --r-full: 999px;

  /* Type */
  --font-sans: "Geist", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  --font-mono: "Geist Mono", "JetBrains Mono", "SF Mono", Menlo, Consolas, monospace;

  --fs-display: clamp(28px, 3.2vw, 40px);
  --fs-h1: 24px;
  --fs-h2: 20px;
  --fs-h3: 16px;
  --fs-body: 14px;
  --fs-sm: 13px;
  --fs-xs: 12px;
  --fs-2xs: 11px;

  --lh-tight: 1.15;
  --lh-snug: 1.3;
  --lh-normal: 1.5;

  --fw-regular: 400;
  --fw-medium: 500;
  --fw-semibold: 600;
  --fw-bold: 700;

  /* Density */
  --row-h: 48px;
  --control-h: 36px;
  --control-h-sm: 30px;
  --control-h-lg: 42px;

  /* Layout */
  --sidebar-w: 248px;
  --sidebar-w-collapsed: 60px;
  --topbar-h: 56px;

  /* Motion */
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
  --dur-fast: 120ms;
  --dur: 180ms;
  --dur-slow: 240ms;

  --z-base: 1;
  --z-sticky: 20;
  --z-drawer: 50;
  --z-modal: 100;
  --z-toast: 200;
  --z-tweaks: 300;
}

/* Density */
[data-density="compact"] {
  --row-h: 36px;
  --control-h: 30px;
  --control-h-sm: 26px;
  --control-h-lg: 36px;
  --fs-body: 13px;
  --fs-sm: 12px;
}

/* Dark theme (default) */
:root,
[data-theme="dark"] {
  color-scheme: dark;

  --bg-base: #0a0a0c;
  --bg-canvas: #0c0c10;
  --bg-surface: #111114;
  --bg-surface-2: #16161b;
  --bg-surface-3: #1c1c22;
  --bg-overlay: rgba(10, 10, 12, 0.72);

  --border-subtle: #1c1c22;
  --border-default: #25252c;
  --border-strong: #35353f;
  --border-focus: var(--accent);

  --text-primary: #f4f4f5;
  --text-secondary: #a1a1aa;
  --text-tertiary: #71717a;
  --text-disabled: #52525b;
  --text-inverse: #0a0a0c;

  --row-hover: rgba(255, 255, 255, 0.025);
  --row-zebra: rgba(255, 255, 255, 0.012);
  --row-selected: hsl(var(--accent-h) var(--accent-s) var(--accent-l) / 0.08);

  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.4);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.5), 0 0 0 1px rgba(255, 255, 255, 0.04);
  --shadow-lg: 0 12px 32px rgba(0, 0, 0, 0.6), 0 0 0 1px rgba(255, 255, 255, 0.05);
  --shadow-pop: 0 8px 24px rgba(0, 0, 0, 0.55), 0 1px 2px rgba(0, 0, 0, 0.4);

  --glass-bg: rgba(17, 17, 20, 0.72);
  --glass-blur: saturate(140%) blur(12px);

  --success-bg: rgba(34, 197, 94, 0.08);
  --success-border: rgba(34, 197, 94, 0.22);
  --warning-bg: rgba(245, 158, 11, 0.08);
  --warning-border: rgba(245, 158, 11, 0.24);
  --danger-bg: rgba(239, 68, 68, 0.08);
  --danger-border: rgba(239, 68, 68, 0.24);
  --info-bg: rgba(6, 182, 212, 0.08);
  --info-border: rgba(6, 182, 212, 0.24);

  --chart-1: var(--accent);
  --chart-2: #22c55e;
  --chart-3: #f59e0b;
  --chart-4: #a78bfa;
  --chart-5: #06b6d4;
  --chart-grid: rgba(255, 255, 255, 0.05);
}

/* Light theme */
[data-theme="light"] {
  color-scheme: light;

  --bg-base: #fafafa;
  --bg-canvas: #f5f5f7;
  --bg-surface: #ffffff;
  --bg-surface-2: #fafafa;
  --bg-surface-3: #f4f4f5;
  --bg-overlay: rgba(0, 0, 0, 0.36);

  --border-subtle: #ececef;
  --border-default: #e4e4e7;
  --border-strong: #d4d4d8;
  --border-focus: var(--accent);

  --text-primary: #09090b;
  --text-secondary: #52525b;
  --text-tertiary: #71717a;
  --text-disabled: #a1a1aa;
  --text-inverse: #ffffff;

  --row-hover: rgba(0, 0, 0, 0.022);
  --row-zebra: rgba(0, 0, 0, 0.012);
  --row-selected: hsl(var(--accent-h) var(--accent-s) var(--accent-l) / 0.06);

  --shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.06);
  --shadow-md: 0 4px 12px rgba(15, 23, 42, 0.08), 0 0 0 1px rgba(15, 23, 42, 0.04);
  --shadow-lg: 0 12px 32px rgba(15, 23, 42, 0.12), 0 0 0 1px rgba(15, 23, 42, 0.04);
  --shadow-pop: 0 8px 24px rgba(15, 23, 42, 0.1), 0 1px 2px rgba(15, 23, 42, 0.06);

  --glass-bg: rgba(255, 255, 255, 0.78);
  --glass-blur: saturate(160%) blur(12px);

  --success-bg: rgba(22, 163, 74, 0.07);
  --success-border: rgba(22, 163, 74, 0.2);
  --warning-bg: rgba(217, 119, 6, 0.08);
  --warning-border: rgba(217, 119, 6, 0.24);
  --danger-bg: rgba(220, 38, 38, 0.07);
  --danger-border: rgba(220, 38, 38, 0.22);
  --info-bg: rgba(8, 145, 178, 0.07);
  --info-border: rgba(8, 145, 178, 0.2);

  --chart-1: var(--accent);
  --chart-2: #16a34a;
  --chart-3: #d97706;
  --chart-4: #7c3aed;
  --chart-5: #0891b2;
  --chart-grid: rgba(0, 0, 0, 0.06);
}

/* Accent presets */
[data-accent="sky"]     { --accent-h: 222; --accent-s: 100%; --accent-l: 64%; }
[data-accent="cobalt"]  { --accent-h: 218; --accent-s: 88%;  --accent-l: 56%; }
[data-accent="indigo"]  { --accent-h: 244; --accent-s: 76%;  --accent-l: 64%; }
[data-accent="emerald"] { --accent-h: 156; --accent-s: 65%;  --accent-l: 46%; }
