/* ============================================================
   Design Token System — Jama Dashboard
   2-layer: primitives → semantic (light + dark)
   ============================================================ */

/* ── Primitive tokens ─────────────────────────────────────── */
:root {
  /* Slate palette */
  --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-900: #0f172a;
  --slate-950: #020617;

  /* Blue palette */
  --blue-50:  #eff6ff;
  --blue-100: #dbeafe;
  --blue-200: #bfdbfe;
  --blue-300: #93c5fd;
  --blue-400: #60a5fa;
  --blue-500: #3b82f6;
  --blue-600: #2563eb;
  --blue-700: #1d4ed8;
  --blue-800: #1e40af;
  --blue-900: #1e3a5f;

  /* Green palette */
  --green-50:  #f0fdf4;
  --green-100: #dcfce7;
  --green-200: #bbf7d0;
  --green-300: #86efac;
  --green-400: #4ade80;
  --green-500: #22c55e;
  --green-600: #16a34a;
  --green-700: #15803d;
  --green-800: #166534;
  --green-900: #14532d;
  --emerald-700: #047857;
  --emerald-800: #065f46;

  /* Red palette */
  --red-50:  #fef2f2;
  --red-100: #fee2e2;
  --red-200: #fecaca;
  --red-400: #f87171;
  --red-500: #ef4444;
  --red-600: #dc2626;
  --red-700: #b91c1c;
  --red-800: #991b1b;

  /* Amber palette */
  --amber-50:  #fffbeb;
  --amber-100: #fef3c7;
  --amber-200: #fde68a;
  --amber-500: #f59e0b;
  --amber-600: #d97706;
  --amber-700: #b45309;
  --amber-800: #92400e;

  /* Pink palette */
  --pink-50:  #fdf2f8;
  --pink-100: #fce7f3;
  --pink-200: #fbcfe8;
  --pink-300: #f9a8d4;
  --pink-800: #9d174d;

  /* Teal/Emerald for commissions */
  --teal-50:  #f0fdfa;
  --teal-100: #ccfbf1;

  /* Spacing scale (4px base) */
  --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;

  /* Radii */
  --radius-sm:   6px;
  --radius-md:   8px;
  --radius-lg:  12px;
  --radius-xl:  16px;
  --radius-full: 999px;

  /* Shadows */
  --shadow-xs:  0 1px 2px rgba(0,0,0,0.05);
  --shadow-sm:  0 1px 3px rgba(0,0,0,0.08);
  --shadow-md:  0 4px 12px rgba(0,0,0,0.1);
  --shadow-lg:  0 10px 30px rgba(0,0,0,0.12);
  --shadow-xl:  0 20px 60px rgba(0,0,0,0.15);

  /* Transitions */
  --transition-fast:   0.15s ease;
  --transition-normal: 0.2s ease;
  --transition-slow:   0.3s ease;

  /* Layout */
  --sidebar-width:     256px;
  --sidebar-collapsed:  64px;
  --topbar-height:      56px;
}

/* ── Semantic tokens (light) ──────────────────────────────── */
:root {
  /* Backgrounds */
  --bg-page:     var(--slate-50);
  --bg-surface:  #ffffff;
  --bg-sidebar:  var(--slate-900);
  --bg-sidebar-hover: var(--slate-800);
  --bg-sidebar-active: rgba(59,130,246,0.15);
  --bg-topbar:   #ffffff;
  --bg-muted:    var(--slate-100);

  /* Text */
  --text-primary:   var(--slate-900);
  --text-secondary: var(--slate-500);
  --text-muted:     var(--slate-400);
  --text-inverse:   #ffffff;
  --text-sidebar:   var(--slate-300);
  --text-sidebar-active: #ffffff;

  /* Borders */
  --border-default: var(--slate-200);
  --border-muted:   var(--slate-100);

  /* Accent */
  --accent:       var(--blue-500);
  --accent-hover: var(--blue-600);
  --accent-muted: var(--blue-100);

  /* Table headers */
  --th-summary-from: #003DA5;
  --th-summary-to:   #0052D4;
  --th-summary-proj-from: var(--blue-900);
  --th-summary-proj-to:   #2D4A6F;
  --th-commission-from: var(--emerald-800);
  --th-commission-to:   var(--emerald-700);

  /* Group total rows */
  --total-abl-bg:       var(--blue-100);
  --total-abl-text:     var(--blue-800);
  --total-abl-border:   var(--blue-300);
  --total-confites-bg:   var(--pink-100);
  --total-confites-text: var(--pink-800);
  --total-confites-border: var(--pink-300);
  --total-general-bg:   var(--blue-900);
  --total-general-text: #ffffff;
  --total-general-border: var(--blue-600);
  --total-general-comm-bg: var(--emerald-800);
  --total-general-comm-border: var(--green-500);

  /* Badges - compliance */
  --badge-over-bg:   #d1fae5;
  --badge-over-text: var(--emerald-800);
  --badge-high-bg:   var(--green-100);
  --badge-high-text: var(--green-800);
  --badge-mid-bg:    var(--amber-100);
  --badge-mid-text:  var(--amber-800);
  --badge-low-bg:    var(--red-100);
  --badge-low-text:  var(--red-800);
  --badge-zero-bg:   var(--slate-100);
  --badge-zero-text: var(--slate-500);

  /* Badges - tier */
  --tier-basico-bg:    var(--red-100);
  --tier-basico-text:  var(--red-800);
  --tier-bueno-bg:     var(--amber-100);
  --tier-bueno-text:   var(--amber-800);
  --tier-muybueno-bg:  var(--green-100);
  --tier-muybueno-text: var(--green-800);
  --tier-excelente-bg: var(--blue-100);
  --tier-excelente-text: var(--blue-800);
  --tier-sobre-bg:     #d1fae5;
  --tier-sobre-text:   var(--emerald-800);
  --tier-none-bg:      var(--slate-100);
  --tier-none-text:    var(--slate-400);

  /* Visit badges */
  --vbadge-sin-bg:    var(--red-100);
  --vbadge-sin-text:  var(--red-800);
  --vbadge-antes-bg:  var(--amber-100);
  --vbadge-antes-text: var(--amber-800);
  --vbadge-ok-bg:     var(--green-50);
  --vbadge-ok-text:   var(--green-800);

  /* Freshness bar */
  --fresh-ok-bg:     #d1fae5;
  --fresh-ok-text:   var(--emerald-800);
  --fresh-ok-border: #a7f3d0;
  --fresh-stale-bg:     var(--amber-100);
  --fresh-stale-text:   var(--amber-800);
  --fresh-stale-border: var(--amber-200);

  /* KPI cards */
  --kpi-bg: var(--bg-surface);
  --kpi-label-color: var(--slate-500);
  --kpi-value-color: var(--slate-800);

  /* Vendor card */
  --vendor-card-bg:   var(--bg-surface);
  --vendor-card-border: var(--blue-500);

  /* Visit table */
  --vtable-th-bg:   var(--slate-100);
  --vtable-th-text: var(--slate-600);
  --vtable-td-text: var(--slate-700);
  --vtable-hover:   var(--slate-50);

  /* Skeleton loading */
  --skeleton-bg:    var(--slate-200);
  --skeleton-shine: var(--slate-100);
}

/* ── Semantic tokens (dark) ───────────────────────────────── */
[data-bs-theme="dark"] {
  /* Backgrounds */
  --bg-page:     #0b1121;
  --bg-surface:  var(--slate-800);
  --bg-sidebar:  #070d1a;
  --bg-sidebar-hover: var(--slate-800);
  --bg-topbar:   var(--slate-800);
  --bg-muted:    var(--slate-700);

  /* Text */
  --text-primary:   var(--slate-100);
  --text-secondary: var(--slate-400);
  --text-muted:     var(--slate-500);

  /* Borders */
  --border-default: var(--slate-700);
  --border-muted:   var(--slate-800);

  /* Accent */
  --accent-muted: rgba(59,130,246,0.2);

  /* Table headers (muted gradients) */
  --th-summary-from: #1a2d4d;
  --th-summary-to:   #1e3a5f;
  --th-summary-proj-from: #0f1f33;
  --th-summary-proj-to:   #162a42;
  --th-commission-from: #0a2620;
  --th-commission-to:   #0d3028;

  /* Group total rows */
  --total-abl-bg:       rgba(30,64,175,0.2);
  --total-abl-text:     var(--blue-300);
  --total-abl-border:   rgba(59,130,246,0.3);
  --total-confites-bg:   rgba(157,23,77,0.2);
  --total-confites-text: var(--pink-300);
  --total-confites-border: rgba(249,168,212,0.3);
  --total-general-bg:   #0f1f33;
  --total-general-text: var(--slate-100);
  --total-general-border: rgba(59,130,246,0.4);
  --total-general-comm-bg: #0a2620;
  --total-general-comm-border: rgba(16,185,129,0.4);

  /* Badges - compliance (muted for dark) */
  --badge-over-bg:   rgba(5,95,70,0.3);
  --badge-over-text: var(--green-300);
  --badge-high-bg:   rgba(22,101,52,0.25);
  --badge-high-text: var(--green-300);
  --badge-mid-bg:    rgba(146,64,14,0.25);
  --badge-mid-text:  var(--amber-200);
  --badge-low-bg:    rgba(153,27,27,0.25);
  --badge-low-text:  var(--red-200);
  --badge-zero-bg:   var(--slate-700);
  --badge-zero-text: var(--slate-400);

  /* Tier badges */
  --tier-basico-bg:    rgba(153,27,27,0.25);
  --tier-basico-text:  var(--red-200);
  --tier-bueno-bg:     rgba(146,64,14,0.25);
  --tier-bueno-text:   var(--amber-200);
  --tier-muybueno-bg:  rgba(22,101,52,0.25);
  --tier-muybueno-text: var(--green-300);
  --tier-excelente-bg: rgba(30,64,175,0.25);
  --tier-excelente-text: var(--blue-300);
  --tier-sobre-bg:     rgba(5,95,70,0.3);
  --tier-sobre-text:   var(--green-300);
  --tier-none-bg:      var(--slate-700);
  --tier-none-text:    var(--slate-500);

  /* Visit badges */
  --vbadge-sin-bg:    rgba(153,27,27,0.25);
  --vbadge-sin-text:  var(--red-200);
  --vbadge-antes-bg:  rgba(146,64,14,0.25);
  --vbadge-antes-text: var(--amber-200);
  --vbadge-ok-bg:     rgba(22,101,52,0.2);
  --vbadge-ok-text:   var(--green-300);

  /* Freshness */
  --fresh-ok-bg:     rgba(5,95,70,0.2);
  --fresh-ok-text:   var(--green-300);
  --fresh-ok-border: rgba(5,95,70,0.3);
  --fresh-stale-bg:     rgba(146,64,14,0.2);
  --fresh-stale-text:   var(--amber-200);
  --fresh-stale-border: rgba(146,64,14,0.3);

  /* KPI cards */
  --kpi-bg: var(--bg-surface);
  --kpi-label-color: var(--slate-400);
  --kpi-value-color: var(--slate-100);

  /* Vendor card */
  --vendor-card-bg: var(--bg-surface);

  /* Visit table */
  --vtable-th-bg:   var(--slate-700);
  --vtable-th-text: var(--slate-300);
  --vtable-td-text: var(--slate-300);
  --vtable-hover:   var(--slate-700);

  /* Shadows (softer in dark) */
  --shadow-xs:  0 1px 2px rgba(0,0,0,0.2);
  --shadow-sm:  0 1px 3px rgba(0,0,0,0.3);
  --shadow-md:  0 4px 12px rgba(0,0,0,0.35);
  --shadow-lg:  0 10px 30px rgba(0,0,0,0.4);

  /* Skeleton */
  --skeleton-bg:    var(--slate-700);
  --skeleton-shine: var(--slate-600);
}
