/* ============================================================
   RIVAL PROP FIRM — DESIGN TOKENS
   Dual-theme: light (default) + dark
   Brand-first: kék = primary, zöld/piros = semantic only
   ============================================================ */

:root {
  /* ---------- BRAND (téma-független) ----------
     A logo színei. NE használd direkt UI elemekre, kivéve
     ahol a "branded surface" a cél (pl. logo háttér).
     Action színeknek a --color-primary-*-t használd. */
  --brand-blue: #1e5fff;
  --brand-blue-dark: #1748cc;
  --brand-navy: #0a1f44;

  /* ---------- TIPOGRÁFIA ---------- */
  --font-sans: 'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-mono: 'JetBrains Mono', ui-monospace, 'SF Mono', Consolas, monospace;

  /* Type scale — dashboard-density default 14px */
  --text-xs: 12px;
  --text-sm: 13px;
  --text-base: 14px;
  --text-md: 16px;
  --text-lg: 18px;
  --text-xl: 22px;
  --text-2xl: 28px;
  --text-3xl: 36px;
  --text-display: 56px;

  --leading-tight: 1.2;
  --leading-snug: 1.35;
  --leading-normal: 1.5;
  --leading-relaxed: 1.65;

  --tracking-tight: -0.01em;
  --tracking-normal: 0;
  --tracking-wide: 0.04em;     /* uppercase eyebrows */

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

  /* ---------- SPACING — 4px scale ---------- */
  --space-0: 0;
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 24px;
  --space-6: 32px;
  --space-7: 48px;
  --space-8: 64px;
  --space-9: 96px;

  /* ---------- RADIUS ---------- */
  --radius-xs: 4px;
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 16px;
  --radius-xl: 20px;
  --radius-full: 9999px;

  /* ---------- LAYOUT ---------- */
  --sidebar-width: 256px;
  --sidebar-width-collapsed: 64px;
  --topbar-height: 64px;
  --container-max: 1280px;
  --logo-height: 22px;             /* 80% of the original 28px brand-mark height */

  /* ---------- TRANSITIONS ---------- */
  --transition-fast: 120ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-base: 180ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-slow: 240ms cubic-bezier(0.4, 0, 0.2, 1);

  /* ---------- Z-INDEX ---------- */
  --z-sidebar: 10;
  --z-topbar: 20;
  --z-dropdown: 30;
  --z-modal: 40;
  --z-toast: 50;
}

/* ============================================================
   LIGHT THEME (default)
   ============================================================ */
:root,
[data-theme="light"] {
  /* Surfaces — alulról felfelé: canvas → surface → elevated */
  --bg-canvas: #f7f8fa;          /* page background */
  --bg-surface: #ffffff;         /* cards, sidebar, topbar */
  --bg-elevated: #ffffff;        /* modals, popovers */
  --bg-subtle: #f1f3f6;          /* hover states, table stripes */
  --bg-muted: #e5e8ec;           /* disabled, skeleton */

  /* Borders */
  --border-subtle: #e5e8ec;      /* default card/input borders */
  --border-strong: #cdd2d9;      /* hovered borders, dividers */
  --border-focus: var(--brand-blue);

  /* Text */
  --text-primary: #0e1116;       /* headlines, primary copy */
  --text-secondary: #4a5260;     /* body copy, labels */
  --text-tertiary: #6b7280;      /* captions, helper text */
  --text-disabled: #9ca3af;
  --text-on-primary: #ffffff;    /* text on blue/colored bg */

  /* Primary (action) — brand kék */
  --color-primary: var(--brand-blue);
  --color-primary-hover: var(--brand-blue-dark);
  --color-primary-active: #1340b8;
  --color-primary-subtle: #e8efff;       /* tint bg, eg. active nav */
  --color-primary-subtle-hover: #d6e2ff;

  /* Semantic — light-kalibrált */
  --color-success: #0d9f5e;              /* profit, win */
  --color-success-hover: #0a8550;
  --color-success-subtle: #e3f7ee;
  --color-success-text: #066d40;         /* AA on white */

  --color-danger: #d92d20;               /* loss, drawdown breach */
  --color-danger-hover: #b9251a;
  --color-danger-subtle: #fdecea;
  --color-danger-text: #a51e15;

  --color-warning: #b54708;              /* approaching limit */
  --color-warning-hover: #93390a;
  --color-warning-subtle: #fef4e6;
  --color-warning-text: #93390a;

  --color-info: #0b6bcb;                 /* neutral notice */
  --color-info-subtle: #e6f1fb;
  --color-info-text: #084c91;

  /* Elevation — light shadows */
  --shadow-xs: 0 1px 2px rgba(15, 23, 42, 0.04);
  --shadow-sm: 0 1px 3px rgba(15, 23, 42, 0.06), 0 1px 2px rgba(15, 23, 42, 0.04);
  --shadow-md: 0 4px 12px rgba(15, 23, 42, 0.08), 0 2px 4px rgba(15, 23, 42, 0.04);
  --shadow-lg: 0 12px 32px rgba(15, 23, 42, 0.12), 0 4px 8px rgba(15, 23, 42, 0.06);

  /* Focus ring */
  --focus-ring: 0 0 0 3px rgba(30, 95, 255, 0.32);
}

/* ============================================================
   DARK THEME
   ============================================================ */
[data-theme="dark"] {
  --bg-canvas: #0a0c10;
  --bg-surface: #131720;
  --bg-elevated: #1a1f2b;
  --bg-subtle: #1e2330;
  --bg-muted: #2a3041;

  --border-subtle: #232936;
  --border-strong: #353d4d;
  --border-focus: #4d8bff;

  --text-primary: #f1f3f6;
  --text-secondary: #a8b0bd;
  --text-tertiary: #7c8593;
  --text-disabled: #4a5260;
  --text-on-primary: #ffffff;

  /* Brand kék dark-on enyhén világosítva a kontraszt miatt */
  --color-primary: #4d8bff;
  --color-primary-hover: #6ba0ff;
  --color-primary-active: #84b1ff;
  --color-primary-subtle: rgba(77, 139, 255, 0.14);
  --color-primary-subtle-hover: rgba(77, 139, 255, 0.22);

  --color-success: #22c55e;
  --color-success-hover: #34d570;
  --color-success-subtle: rgba(34, 197, 94, 0.14);
  --color-success-text: #6ee094;

  --color-danger: #f04438;
  --color-danger-hover: #f56b60;
  --color-danger-subtle: rgba(240, 68, 56, 0.14);
  --color-danger-text: #ff8a80;

  --color-warning: #f5a623;
  --color-warning-hover: #f7b850;
  --color-warning-subtle: rgba(245, 166, 35, 0.14);
  --color-warning-text: #fbc669;

  --color-info: #4d8bff;
  --color-info-subtle: rgba(77, 139, 255, 0.14);
  --color-info-text: #84b1ff;

  --shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.4);
  --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.5), 0 1px 2px rgba(0, 0, 0, 0.3);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.5), 0 2px 4px rgba(0, 0, 0, 0.3);
  --shadow-lg: 0 12px 32px rgba(0, 0, 0, 0.6), 0 4px 8px rgba(0, 0, 0, 0.4);

  --focus-ring: 0 0 0 3px rgba(77, 139, 255, 0.4);
}

/* ============================================================
   AUTO-DETECT (ha a user nem váltott explicit témát,
   kövessük a system preference-t)
   ============================================================ */
@media (prefers-color-scheme: dark) {
  :root.__rp_never_match__ {
    --bg-canvas: #0a0c10;
    --bg-surface: #131720;
    --bg-elevated: #1a1f2b;
    --bg-subtle: #1e2330;
    --bg-muted: #2a3041;

    --border-subtle: #232936;
    --border-strong: #353d4d;
    --border-focus: #4d8bff;

    --text-primary: #f1f3f6;
    --text-secondary: #a8b0bd;
    --text-tertiary: #7c8593;
    --text-disabled: #4a5260;

    --color-primary: #4d8bff;
    --color-primary-hover: #6ba0ff;
    --color-primary-active: #84b1ff;
    --color-primary-subtle: rgba(77, 139, 255, 0.14);
    --color-primary-subtle-hover: rgba(77, 139, 255, 0.22);

    --color-success: #22c55e;
    --color-success-hover: #34d570;
    --color-success-subtle: rgba(34, 197, 94, 0.14);
    --color-success-text: #6ee094;

    --color-danger: #f04438;
    --color-danger-hover: #f56b60;
    --color-danger-subtle: rgba(240, 68, 56, 0.14);
    --color-danger-text: #ff8a80;

    --color-warning: #f5a623;
    --color-warning-hover: #f7b850;
    --color-warning-subtle: rgba(245, 166, 35, 0.14);
    --color-warning-text: #fbc669;

    --color-info: #4d8bff;
    --color-info-subtle: rgba(77, 139, 255, 0.14);
    --color-info-text: #84b1ff;

    --shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.4);
    --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.5), 0 1px 2px rgba(0, 0, 0, 0.3);
    --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.5), 0 2px 4px rgba(0, 0, 0, 0.3);
    --shadow-lg: 0 12px 32px rgba(0, 0, 0, 0.6), 0 4px 8px rgba(0, 0, 0, 0.4);

    --focus-ring: 0 0 0 3px rgba(77, 139, 255, 0.4);
  }
}
