/* ============================================================
   Anonimator Design System — Tokens
   Polish legal document anonymization tool
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap');

:root {
  /* -- Core color scales ------------------------------------ */
  --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;

  --indigo-50:  #eef2ff; --indigo-100: #e0e7ff; --indigo-200: #c7d2fe;
  --indigo-300: #a5b4fc; --indigo-400: #818cf8; --indigo-500: #6366f1;
  --indigo-600: #4f46e5; --indigo-700: #4338ca; --indigo-800: #3730a3;
  --indigo-900: #312e81; --indigo-950: #1e1b4b;

  --emerald-50:  #ecfdf5; --emerald-100: #d1fae5; --emerald-200: #a7f3d0;
  --emerald-300: #6ee7b7; --emerald-400: #34d399; --emerald-500: #10b981;
  --emerald-600: #059669; --emerald-700: #047857; --emerald-800: #065f46;
  --emerald-900: #064e3b; --emerald-950: #022c22;

  --amber-50:  #fffbeb; --amber-100: #fef3c7; --amber-200: #fde68a;
  --amber-300: #fcd34d; --amber-400: #fbbf24; --amber-500: #f59e0b;
  --amber-600: #d97706; --amber-700: #b45309; --amber-800: #92400e;
  --amber-900: #78350f; --amber-950: #451a03;

  --rose-50:  #fff1f2; --rose-100: #ffe4e6; --rose-200: #fecdd3;
  --rose-300: #fda4af; --rose-400: #fb7185; --rose-500: #f43f5e;
  --rose-600: #e11d48; --rose-700: #be123c; --rose-800: #9f1239;
  --rose-900: #881337; --rose-950: #4c0519;

  --teal-50:  #f0fdfa; --teal-100: #ccfbf1; --teal-200: #99f6e4;
  --teal-300: #5eead4; --teal-400: #2dd4bf; --teal-500: #14b8a6;
  --teal-600: #0d9488; --teal-700: #0f766e; --teal-800: #115e59;
  --teal-900: #134e4a; --teal-950: #042f2e;

  /* -- Semantic colors ------------------------------------- */
  --color-primary: var(--indigo-600);
  --color-primary-hover: var(--indigo-700);
  --color-primary-active: var(--indigo-800);

  --color-text-primary: var(--slate-800);
  --color-text-secondary: var(--slate-500);
  --color-text-tertiary: var(--slate-400);
  --color-text-inverse: var(--slate-50);
  --color-text-brand: var(--indigo-600);

  --color-bg-page: var(--slate-50);
  --color-bg-surface: #ffffff;
  --color-bg-surface-elevated: #ffffff;
  --color-bg-code: var(--slate-100);

  --color-border-default: var(--slate-200);
  --color-border-hover: var(--slate-300);
  --color-border-active: var(--indigo-500);
  --color-border-focus: var(--indigo-500);

  --color-success: var(--emerald-600);
  --color-warning: var(--amber-600);
  --color-error: var(--rose-600);
  --color-info: var(--teal-600);

  /* -- Type ------------------------------------------------- */
  --font-sans: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  --font-mono: 'JetBrains Mono', 'Fira Code', 'SF Mono', monospace;

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

  --fs-3xs: 9px;  --fs-2xs: 10px; --fs-micro: 11px; --fs-xs: 12px;
  --fs-sm: 13px;  --fs-base: 14px; --fs-md: 16px;   --fs-lg: 18px;
  --fs-xl: 20px;  --fs-2xl: 24px;  --fs-3xl: 30px;  --fs-4xl: 36px;

  --lh-tight: 1.2; --lh-snug: 1.35; --lh-normal: 1.5;
  --lh-relaxed: 1.625; --lh-loose: 1.8;

  --tracking-tight: -0.025em; --tracking-normal: 0;
  --tracking-wide: 0.025em;   --tracking-wider: 0.05em; --tracking-widest: 0.1em;

  /* -- Spacing --------------------------------------------- */
  --space-base: 4px;
  --space-0: 0;     --space-px: 1px;  --space-0_5: 2px;
  --space-1: 4px;   --space-1_5: 6px; --space-2: 8px;   --space-2_5: 10px;
  --space-3: 12px;  --space-3_5: 14px;--space-4: 16px;  --space-5: 20px;
  --space-6: 24px;  --space-7: 28px;  --space-8: 32px;  --space-9: 36px;
  --space-10: 40px; --space-11: 44px; --space-12: 48px; --space-14: 56px;
  --space-16: 64px; --space-20: 80px; --space-24: 96px;

  /* -- Radius ---------------------------------------------- */
  --radius-none: 0;   --radius-xs: 2px;  --radius-sm: 4px;
  --radius-md: 6px;   --radius-lg: 8px;  --radius-xl: 12px;
  --radius-2xl: 16px; --radius-full: 9999px;
  --radius-component: var(--radius-md);
  --radius-surface: var(--radius-lg);
  --radius-pill: var(--radius-full);

  /* -- Shadow ---------------------------------------------- */
  --shadow-xs: 0 1px 2px rgba(15,23,42,0.05);
  --shadow-sm: 0 1px 3px rgba(15,23,42,0.10);
  --shadow-md: 0 4px 12px -2px rgba(15,23,42,0.08);
  --shadow-lg: 0 8px 24px -4px rgba(15,23,42,0.10);
  --shadow-xl: 0 16px 48px -8px rgba(15,23,42,0.12);
  --shadow-focus: 0 0 0 3px rgba(99,102,241,0.30);
  --shadow-focus-error: 0 0 0 3px rgba(244,63,94,0.30);

  --shadow-card: var(--shadow-sm);
  --shadow-card-hover: var(--shadow-md);
  --shadow-dropdown: var(--shadow-lg);
  --shadow-modal: var(--shadow-xl);
  --shadow-toast: var(--shadow-lg);

  /* -- Motion ---------------------------------------------- */
  --dur-instant: 0ms; --dur-fast: 100ms; --dur-normal: 200ms;
  --dur-slow: 300ms;  --dur-slower: 500ms; --dur-slowest: 700ms;
  --ease-in: cubic-bezier(0.4, 0, 1, 1);
  --ease-out: cubic-bezier(0, 0, 0.2, 1);
  --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* ============================================================
   Semantic type styles (drop-in classes for previews)
   ============================================================ */
.text-h1 { font: var(--fw-semibold) var(--fs-4xl)/var(--lh-tight) var(--font-sans); color: var(--color-text-primary); letter-spacing: var(--tracking-tight); }
.text-h2 { font: var(--fw-semibold) var(--fs-3xl)/var(--lh-tight) var(--font-sans); color: var(--color-text-primary); letter-spacing: var(--tracking-tight); }
.text-h3 { font: var(--fw-semibold) var(--fs-2xl)/var(--lh-tight) var(--font-sans); color: var(--color-text-primary); }
.text-h4 { font: var(--fw-semibold) var(--fs-xl)/var(--lh-snug)  var(--font-sans); color: var(--color-text-primary); }
.text-h5 { font: var(--fw-medium)   var(--fs-lg)/var(--lh-snug)  var(--font-sans); color: var(--color-text-primary); }
.text-h6 { font: var(--fw-medium)   var(--fs-md)/var(--lh-snug)  var(--font-sans); color: var(--color-text-primary); }
.text-body-large { font: var(--fw-regular) var(--fs-md)/var(--lh-normal) var(--font-sans); color: var(--color-text-primary); }
.text-body       { font: var(--fw-regular) var(--fs-base)/var(--lh-normal) var(--font-sans); color: var(--color-text-primary); }
.text-body-small { font: var(--fw-regular) var(--fs-sm)/var(--lh-normal) var(--font-sans); color: var(--color-text-primary); }
.text-body-caption { font: var(--fw-medium) var(--fs-xs)/var(--lh-normal) var(--font-sans); color: var(--color-text-secondary); }
.text-helper { font: var(--fw-regular) var(--fs-xs)/var(--lh-normal) var(--font-sans); color: var(--color-text-secondary); }
.text-code-inline, .text-code-block { font: var(--fw-regular) var(--fs-sm)/var(--lh-loose) var(--font-mono); color: var(--color-text-primary); }
.text-entity-token { font: var(--fw-medium) var(--fs-xs)/1.4 var(--font-mono); }
