/* ═══════════════════════════════════════════════════════════════════════════
   LuckyJet Simulator — Design Tokens
   Style: Linear / Vercel dark with light mode fallback
   ═══════════════════════════════════════════════════════════════════════════ */

:root {
  /* ── Surfaces (dark) ──────────────────────────────────────────────────── */
  --bg-base:        #0D1117;   /* page background */
  --bg-elev-1:      #161B22;   /* cards, banner, banner-alt */
  --bg-elev-2:      #1C2128;   /* hover, table row */
  --bg-elev-3:      #22272E;   /* pressed, active filter */

  /* ── Borders ─────────────────────────────────────────────────────────── */
  --border-subtle:  rgba(255, 255, 255, 0.08);
  --border-default: rgba(255, 255, 255, 0.12);
  --border-strong:  rgba(255, 255, 255, 0.20);

  /* ── Text ────────────────────────────────────────────────────────────── */
  --text-primary:   #E6EDF3;   /* main headings, balance */
  --text-secondary: #9DA7B3;   /* labels, descriptions */
  --text-tertiary:  #6E7681;   /* timestamps, helper text */
  --text-inverse:   #0D1117;   /* on accent backgrounds */

  /* ── Accent (violet/blue Linear) ─────────────────────────────────────── */
  --accent:         #7C5CFF;   /* primary purple-blue */
  --accent-hover:   #8F73FF;
  --accent-muted:   rgba(124, 92, 255, 0.15);
  --accent-fg:      #FFFFFF;

  /* ── Semantic ────────────────────────────────────────────────────────── */
  --success:        #3FB950;   /* wins, positive P&L */
  --success-muted:  rgba(63, 185, 80, 0.12);
  --danger:         #F85149;   /* losses, negative P&L */
  --danger-muted:   rgba(248, 81, 73, 0.12);
  --warning:        #D29922;   /* freeze, martingale active */
  --warning-muted:  rgba(210, 153, 34, 0.12);
  --info:           #58A6FF;   /* neutral info, double purple */
  --info-muted:     rgba(88, 166, 255, 0.12);

  /* ── Typography ──────────────────────────────────────────────────────── */
  --font-sans: -apple-system, BlinkMacSystemFont, "Inter", "Segoe UI",
               Roboto, "Helvetica Neue", Arial, sans-serif;
  --font-mono: ui-monospace, "SF Mono", Menlo, Monaco, "Cascadia Code",
               "Roboto Mono", Consolas, monospace;

  --fs-xs:    11px;   /* labels uppercase, helper */
  --fs-sm:    12px;   /* secondary text */
  --fs-base:  13px;   /* body, table cells */
  --fs-md:    14px;   /* subheads */
  --fs-lg:    16px;   /* section titles */
  --fs-xl:    20px;   /* KPI values */
  --fs-2xl:   28px;   /* big balance */
  --fs-3xl:   36px;   /* hero number */

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

  --lh-tight:   1.2;
  --lh-normal:  1.45;
  --lh-loose:   1.6;

  /* ── Spacing (4/8 grid) ─────────────────────────────────────────────── */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;
  --space-12: 48px;

  /* ── Radius ──────────────────────────────────────────────────────────── */
  --radius-sm:  4px;
  --radius-md:  6px;
  --radius-lg:  8px;
  --radius-xl:  12px;
  --radius-pill: 999px;

  /* ── Shadows (very subtle, dark mode) ────────────────────────────────── */
  --shadow-sm:  0 1px 2px rgba(0, 0, 0, 0.30);
  --shadow-md:  0 4px 12px rgba(0, 0, 0, 0.40);

  /* ── Motion ──────────────────────────────────────────────────────────── */
  --transition-fast:  120ms ease;
  --transition-base:  180ms ease;
  --transition-slow:  260ms cubic-bezier(0.16, 1, 0.3, 1);

  /* ── Layout ──────────────────────────────────────────────────────────── */
  --container-max: 1280px;
  --grid-gap:      var(--space-3);
}

/* ═══════════════════════════════════════════════════════════════════════════
   Light mode (auto via prefers-color-scheme + manual override)
   ═══════════════════════════════════════════════════════════════════════════ */
@media (prefers-color-scheme: light) {
  :root:not(.dark) {
    --bg-base:        #FFFFFF;
    --bg-elev-1:      #F6F8FA;
    --bg-elev-2:      #F0F3F6;
    --bg-elev-3:      #E8ECEF;
    --border-subtle:  rgba(0, 0, 0, 0.08);
    --border-default: rgba(0, 0, 0, 0.12);
    --border-strong:  rgba(0, 0, 0, 0.20);
    --text-primary:   #1F2328;
    --text-secondary: #59636E;
    --text-tertiary:  #818B98;
    --text-inverse:   #FFFFFF;
    --accent-muted:   rgba(124, 92, 255, 0.10);
    --success-muted:  rgba(63, 185, 80, 0.10);
    --danger-muted:   rgba(248, 81, 73, 0.10);
    --warning-muted:  rgba(210, 153, 34, 0.10);
    --info-muted:     rgba(88, 166, 255, 0.10);
  }
}

:root.light {
  --bg-base:        #FFFFFF;
  --bg-elev-1:      #F6F8FA;
  --bg-elev-2:      #F0F3F6;
  --bg-elev-3:      #E8ECEF;
  --border-subtle:  rgba(0, 0, 0, 0.08);
  --border-default: rgba(0, 0, 0, 0.12);
  --border-strong:  rgba(0, 0, 0, 0.20);
  --text-primary:   #1F2328;
  --text-secondary: #59636E;
  --text-tertiary:  #818B98;
  --text-inverse:   #FFFFFF;
  --accent-muted:   rgba(124, 92, 255, 0.10);
  --success-muted:  rgba(63, 185, 80, 0.10);
  --danger-muted:   rgba(248, 81, 73, 0.10);
  --warning-muted:  rgba(210, 153, 34, 0.10);
  --info-muted:     rgba(88, 166, 255, 0.10);
}