/* ════════════════════════════════════════════════════════
   FAWRI DESIGN TOKENS
   Premium Fintech Design System — B3G
   ════════════════════════════════════════════════════════ */

:root {
    /* ── Brand Colors ─────────────────────────────── */
    --color-primary:       #2B8FCA;
    --color-primary-hover:  #2480B6;
    --color-primary-active: #1D6F9E;
    --color-primary-subtle: rgba(43, 143, 202, 0.08);
    --color-primary-muted:  rgba(43, 143, 202, 0.15);
    --color-on-primary:    #FFFFFF;

    --color-secondary:       #7AB630;
    --color-secondary-hover:  #6DA22A;
    --color-secondary-subtle: rgba(122, 182, 48, 0.08);
    --color-on-secondary:    #FFFFFF;

    --color-accent:        #D4A853;
    --color-accent-subtle: rgba(212, 168, 83, 0.10);

    /* ── Semantic Colors ──────────────────────────── */
    --color-success:       #22C55E;
    --color-success-subtle: rgba(34, 197, 94, 0.10);
    --color-warning:       #F59E0B;
    --color-warning-subtle: rgba(245, 158, 11, 0.10);
    --color-error:         #EF4444;
    --color-error-subtle:  rgba(239, 68, 68, 0.10);
    --color-info:          #3B82F6;
    --color-info-subtle:   rgba(59, 130, 246, 0.10);
    --color-purple:        #8B5CF6;
    --color-purple-subtle: rgba(139, 92, 246, 0.10);

    /* ── Spacing Scale (4px base) ─────────────────── */
    --sp-1:  0.25rem;   /*  4px */
    --sp-2:  0.5rem;    /*  8px */
    --sp-3:  0.75rem;   /* 12px */
    --sp-4:  1rem;      /* 16px */
    --sp-5:  1.25rem;   /* 20px */
    --sp-6:  1.5rem;    /* 24px */
    --sp-8:  2rem;      /* 32px */
    --sp-10: 2.5rem;    /* 40px */
    --sp-12: 3rem;      /* 48px */
    --sp-16: 4rem;      /* 64px */
    --sp-20: 5rem;      /* 80px */
    --sp-24: 6rem;      /* 96px */

    /* Legacy aliases */
    --space-xs:  var(--sp-1);
    --space-sm:  var(--sp-2);
    --space-md:  var(--sp-4);
    --space-lg:  var(--sp-6);
    --space-xl:  var(--sp-8);

    /* ── Typography ───────────────────────────────── */
    --font-sans:    'Outfit', system-ui, -apple-system, 'Segoe UI', sans-serif;
    --font-mono:    'JetBrains Mono', 'Fira Code', ui-monospace, monospace;
    --font-arabic:  'Noto Sans Arabic', 'Outfit', system-ui, sans-serif;

    --text-xs:   0.75rem;    /* 12px */
    --text-sm:   0.8125rem;  /* 13px */
    --text-base: 0.875rem;   /* 14px */
    --text-md:   0.9375rem;  /* 15px */
    --text-lg:   1.0625rem;  /* 17px */
    --text-xl:   1.25rem;    /* 20px */
    --text-2xl:  1.5rem;     /* 24px */
    --text-3xl:  1.875rem;   /* 30px */
    --text-4xl:  2.25rem;    /* 36px */
    --text-5xl:  3rem;       /* 48px */

    --weight-normal:   400;
    --weight-medium:   500;
    --weight-semibold: 600;
    --weight-bold:     700;
    --weight-black:    800;

    --leading-none:    1;
    --leading-tight:   1.25;
    --leading-snug:    1.375;
    --leading-normal:  1.5;
    --leading-relaxed: 1.625;

    --tracking-tight:  -0.025em;
    --tracking-normal: 0;
    --tracking-wide:   0.025em;
    --tracking-wider:  0.05em;
    --tracking-widest: 0.1em;

    /* Legacy aliases */
    --font-family-base: var(--font-sans);
    --font-family-mono: var(--font-mono);
    --font-size-xs:   var(--text-xs);
    --font-size-sm:   var(--text-sm);
    --font-size-base: var(--text-base);
    --font-size-lg:   var(--text-lg);
    --font-size-xl:   var(--text-xl);
    --font-size-2xl:  var(--text-2xl);
    --font-size-3xl:  var(--text-3xl);
    --font-weight-normal:   var(--weight-normal);
    --font-weight-medium:   var(--weight-medium);
    --font-weight-semibold: var(--weight-semibold);
    --font-weight-bold:     var(--weight-bold);
    --line-height-tight: var(--leading-tight);
    --line-height-base:  var(--leading-normal);

    /* ── Border Radius ────────────────────────────── */
    --radius-sm:   4px;
    --radius-md:   8px;
    --radius-lg:   12px;
    --radius-xl:   16px;
    --radius-2xl:  20px;
    --radius-full: 9999px;

    /* ── Shadows ──────────────────────────────────── */
    --shadow-xs:  0 1px 2px rgba(0, 0, 0, 0.04);
    --shadow-sm:  0 1px 3px rgba(0, 0, 0, 0.06), 0 1px 2px rgba(0, 0, 0, 0.04);
    --shadow-md:  0 4px 6px -1px rgba(0, 0, 0, 0.07), 0 2px 4px -2px rgba(0, 0, 0, 0.05);
    --shadow-lg:  0 10px 15px -3px rgba(0, 0, 0, 0.08), 0 4px 6px -4px rgba(0, 0, 0, 0.04);
    --shadow-xl:  0 20px 25px -5px rgba(0, 0, 0, 0.08), 0 8px 10px -6px rgba(0, 0, 0, 0.04);
    --shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.15);
    --shadow-ring: 0 0 0 3px var(--color-primary-muted);

    /* ── Transitions ──────────────────────────────── */
    --ease-out:  cubic-bezier(0.16, 1, 0.3, 1);
    --ease-in:   cubic-bezier(0.55, 0, 1, 0.45);
    --ease-both: cubic-bezier(0.45, 0, 0.55, 1);
    --dur-fast:  120ms;
    --dur-base:  200ms;
    --dur-slow:  300ms;
    --dur-slower: 500ms;

    --transition-fast: var(--dur-fast) var(--ease-out);
    --transition-base: var(--dur-base) var(--ease-out);
    --transition-slow: var(--dur-slow) var(--ease-out);

    /* ── Z-Index ──────────────────────────────────── */
    --z-base:      0;
    --z-raised:    1;
    --z-dropdown:  100;
    --z-sticky:    200;
    --z-overlay:   300;
    --z-modal:     400;
    --z-toast:     500;

    /* ── Layout ───────────────────────────────────── */
    --header-h:         56px;
    --sidebar-w:        240px;
    --sidebar-w-mini:   68px;
    --max-content-w:    1400px;

    /* Legacy aliases */
    --header-height: var(--header-h);
    --sidebar-width: var(--sidebar-w);
    --sidebar-collapsed-width: var(--sidebar-w-mini);
    --max-content-width: var(--max-content-w);

    /* ── Glass & Glow ────────────────────────────────── */
    --glass-bg:       rgba(255, 255, 255, 0.06);
    --glass-border:   rgba(255, 255, 255, 0.08);
    --glow-primary:   0 0 20px rgba(43, 143, 202, 0.15);
    --glow-success:   0 0 20px rgba(34, 197, 94, 0.15);
    --glow-error:     0 0 20px rgba(239, 68, 68, 0.15);
    --glow-warning:   0 0 20px rgba(245, 158, 11, 0.15);

    /* ── Chart Color Palette ─────────────────────────── */
    --chart-1: #3BA6E0;
    --chart-2: #8DC63F;
    --chart-3: #D4A853;
    --chart-4: #E06B9F;
    --chart-5: #7C6EE7;
    --chart-6: #34D399;

    /* ── Elevation (depth) ───────────────────────────── */
    --elevation-1: 0 1px 3px rgba(0,0,0,0.08);
    --elevation-2: 0 4px 12px rgba(0,0,0,0.10);
    --elevation-3: 0 8px 24px rgba(0,0,0,0.12);
    --elevation-4: 0 16px 48px rgba(0,0,0,0.16);

    /* ── Animation Easings ───────────────────────────── */
    --ease-spring:    cubic-bezier(0.34, 1.56, 0.64, 1);
    --ease-out-expo:  cubic-bezier(0.16, 1, 0.3, 1);
    --dur-chart:      600ms;

    /* ── Table Column Widths ─────────────────────────── */
    --col-uid:     120px;
    --col-status:  100px;
    --col-amount:  130px;
    --col-date:    150px;
    --col-name:    minmax(140px, 1fr);
    --col-actions: 80px;

    /* ── Dispute Type Colors ────────────────────────── */
    --color-type-refund:  #F97316;
    --color-type-confirm: #22C55E;
    --color-type-merge:   #3B82F6;
    --color-type-bulk:    #8B5CF6;
    --color-type-extourne: #a78bfa;
    --color-type-force:   var(--color-warning);

    /* ── Breakpoints (for reference in JS) ────────── */
    /* Phone:   0 – 767px                             */
    /* Tablet:  768px – 1199px                        */
    /* Desktop: 1200px +                              */
}

/* Arabic font override */
[lang="ar"],
[lang="ar-SA"] {
    --font-sans: 'Noto Sans Arabic', 'Outfit', system-ui, sans-serif;
}
