/**
 * PactaHealth Design System
 * Modern, cohesive tokens ensuring WCAG AA minimum contrast
 */

:root {
  color-scheme: light;

  /* Typography */
  --font-primary: "Manrope", "Inter", "Segoe UI", "Helvetica Neue", Arial, sans-serif;
  --font-heading: "Manrope", "Inter", "Segoe UI", "Helvetica Neue", Arial, sans-serif;
  --font-mono: "IBM Plex Mono", "SFMono-Regular", Consolas, monospace;
  --font-scale: 1;
  --font-family-base: var(--font-primary);
  --font-family-arabic: "IBM Plex Sans Arabic", "Noto Sans Arabic", "Segoe UI", system-ui, sans-serif;
  --font-family-mono: var(--font-mono);
  --font-family-clinical-numeric: "Tabular", var(--font-mono);

  --text-xs: 0.75rem;
  --text-sm: 0.875rem;
  --text-base: 1rem;
  --text-lg: 1.125rem;
  --text-xl: 1.25rem;
  --text-2xl: 1.5rem;
  --text-3xl: 2rem;
  --text-4xl: 2.75rem;
  --font-size-xs: var(--text-xs);
  --font-size-sm: var(--text-sm);
  --font-size-base: var(--text-base);
  --font-size-md: var(--text-lg);
  --font-size-lg: var(--text-xl);
  --font-size-xl: var(--text-2xl);
  --font-size-2xl: var(--text-3xl);
  --font-size-3xl: var(--text-4xl);

  --font-light: 300;
  --font-normal: 400;
  --font-medium: 500;
  --font-semibold: 600;
  --font-bold: 700;
  --font-extrabold: 800;
  --font-weight-regular: var(--font-normal);
  --font-weight-medium: var(--font-medium);
  --font-weight-semibold: var(--font-semibold);
  --font-weight-bold: var(--font-bold);

  --line-height-tight: 1.2;
  --line-height-normal: 1.5;
  --line-height-relaxed: 1.7;
  --line-height-base: var(--line-height-normal);

  --letter-spacing-tight: -0.02em;
  --letter-spacing-normal: 0;
  --letter-spacing-wide: 0.05em;

  /* Layout */
  --header-height: 72px;
  --sidebar-width: 308px;
  --sidebar-width-compact: 92px;
  --content-max-width: 1480px;

  /* Spacing */
  --space-0: 0;
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-7: 3rem;
  --space-8: 2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;
  --space-20: 5rem;

  --spacing-0: var(--space-0);
  --spacing-2: var(--space-2);
  --spacing-4: var(--space-4);
  --spacing-6: var(--space-6);
  --spacing-8: var(--space-8);
  --spacing-10: var(--space-10);
  --spacing-12: var(--space-12);
  --spacing-16: var(--space-16);
  --spacing-20: var(--space-20);

  --gap-xs: var(--space-1);
  --gap-sm: var(--space-2);
  --gap-md: var(--space-4);
  --gap-lg: var(--space-6);
  --gap-xl: var(--space-8);
  --gap-2xl: var(--space-12);

  --padding-xs: var(--space-2);
  --padding-sm: var(--space-3);
  --padding-md: var(--space-4);
  --padding-lg: var(--space-5);
  --padding-xl: var(--space-6);

  /* Radius */
  --radius-none: 0;
  --radius-sm: 0.25rem;
  --radius-md: 0.5rem;
  --radius-lg: 0.75rem;
  --radius-xl: 1rem;
  --radius-2xl: 1.75rem;
  --radius-full: 9999px;
  --radius-pill: 9999px;
  --radius-circle: 50%;

  --radius-button: var(--radius-lg);
  --radius-input: var(--radius-md);
  --radius-card: var(--radius-2xl);
  --radius-badge: var(--radius-full);

  /* Sizing */
  --input-height-sm: 36px;
  --input-height-md: 44px;
  --input-height-lg: 52px;
  --button-height-sm: 36px;
  --button-height-md: 44px;
  --button-height-lg: 52px;

  --icon-sm: 16px;
  --icon-md: 20px;
  --icon-lg: 24px;
  --icon-xl: 40px;

  /* Motion */
  --duration-instant: 75ms;
  --duration-fast: 150ms;
  --duration-base: 250ms;
  --duration-slow: 400ms;
  --easing-standard: cubic-bezier(0.4, 0, 0.2, 1);
  --easing-emphasized: cubic-bezier(0.22, 1, 0.36, 1);
  --easing-exit: cubic-bezier(0.4, 0, 1, 1);
  --transition-fast: 150ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-base: 250ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-slow: 350ms cubic-bezier(0.22, 1, 0.36, 1);

  --transition-default: all var(--transition-base);
  --transition-fast-default: all var(--transition-fast);
  --transition-slow-default: all var(--transition-slow);

  /* Color System - Base Scales */
  --primary-50: #eefcf9;
  --primary-100: #d4f5f0;
  --primary-200: #ade8de;
  --primary-300: #74d4c5;
  --primary-400: #36baa8;
  --primary-500: #0f8c7d;
  --primary-600: #0f766e;
  --primary-700: #115e59;
  --primary-800: #114b48;
  --primary-900: #103d3b;

  --secondary-50: #eff6ff;
  --secondary-100: #dbeafe;
  --secondary-200: #bfdbfe;
  --secondary-300: #93c5fd;
  --secondary-400: #60a5fa;
  --secondary-500: #3b82f6;
  --secondary-600: #2563eb;
  --secondary-700: #1d4ed8;
  --secondary-800: #1e40af;
  --secondary-900: #1e3a8a;

  --neutral-0: #ffffff;
  --neutral-50: #f8fafc;
  --neutral-100: #f1f5f9;
  --neutral-200: #e2e8f0;
  --neutral-300: #cbd5e1;
  --neutral-400: #94a3b8;
  --neutral-500: #64748b;
  --neutral-600: #475569;
  --neutral-700: #334155;
  --neutral-800: #1f2937;
  --neutral-900: #0f172a;

  --success-100: #d1fae5;
  --success-200: #a7f3d0;
  --success-500: #10b981;
  --success-700: #047857;

  --warning-100: #fef3c7;
  --warning-200: #fde68a;
  --warning-500: #f59e0b;
  --warning-700: #b45309;

  --error-100: #fee2e2;
  --error-200: #fecaca;
  --error-500: #ef4444;
  --error-700: #b91c1c;

  --info-100: #e0f2fe;
  --info-200: #bae6fd;
  --info-500: #0ea5e9;
  --info-700: #0369a1;

  /* Semantic Theme Mapping (Light) */
  --bg-primary: var(--neutral-0);
  --bg-secondary: #f0f5f4;
  --bg-tertiary: var(--neutral-100);
  --bg-shell: #e8f4f2;
  --bg-overlay: rgba(15, 23, 42, 0.45);

  --surface-raised: var(--neutral-0);
  --surface-subtle: var(--neutral-50);
  --surface-strong: var(--neutral-0);
  --surface-accent: var(--primary-50);

  --text-primary: var(--neutral-900);
  --text-secondary: var(--neutral-600);
  --text-tertiary: #5e6e82;
  --text-inverse: var(--neutral-0);
  --text-link: var(--color-primary);
  --text-disabled: var(--text-tertiary);
  
  --border-light: #cdd5df;
  --border-medium: var(--neutral-300);
  --border-dark: var(--neutral-400);

  --color-primary: var(--primary-500);
  --color-primary-light: var(--primary-400);
  --color-primary-lighter: var(--primary-100);
  --color-primary-dark: var(--primary-600);
  --color-primary-darker: var(--primary-700);

  --color-secondary: var(--secondary-600);
  --color-secondary-light: var(--secondary-100);
  --color-secondary-dark: var(--secondary-700);

  --color-success: var(--success-500);
  --color-success-light: var(--success-100);
  --color-success-dark: var(--success-700);

  --color-warning: var(--warning-500);
  --color-warning-light: var(--warning-100);
  --color-warning-dark: var(--warning-700);

  --color-error: var(--error-500);
  --color-error-light: var(--error-100);
  --color-error-dark: var(--error-700);

  --color-info: var(--info-500);
  --color-info-light: var(--info-100);
  --color-info-dark: var(--info-700);
  --clinical-normal: var(--color-success);
  --clinical-abnormal-low: var(--color-info);
  --clinical-abnormal-high: var(--color-warning);
  --clinical-critical: var(--color-error);
  --clinical-allergy: #9333ea;
  --clinical-pending: var(--text-tertiary);
  --triage-red: #ef4444;
  --triage-yellow: #f59e0b;
  --triage-green: #10b981;
  --triage-blue: #3b82f6;
  --triage-black: #1f2937;

  --focus-ring: 0 0 0 3px rgba(15, 118, 110, 0.2);
  --ring-focus: var(--color-primary);
  --shadow-focus: var(--focus-ring);
  --glass-blur: blur(12px);

  --shadow-none: none;
  --shadow-sm: 0 1px 3px 0 rgba(15, 23, 42, 0.1), 0 1px 2px -1px rgba(15, 23, 42, 0.1);
  --shadow-md: 0 4px 6px -1px rgba(15, 23, 42, 0.1), 0 2px 4px -2px rgba(15, 23, 42, 0.1);
  --shadow-lg: 0 10px 15px -3px rgba(15, 23, 42, 0.1), 0 4px 6px -4px rgba(15, 23, 42, 0.1);
  --shadow-xl: 0 20px 25px -5px rgba(15, 23, 42, 0.1), 0 8px 10px -6px rgba(15, 23, 42, 0.1);
  --shadow-primary: 0 10px 15px -3px rgba(15, 118, 110, 0.25);
  --shadow-2xl: 0 25px 50px -12px rgba(15, 23, 42, 0.25);

  --gradient-primary: linear-gradient(135deg, var(--primary-500), var(--primary-700));
  --gradient-secondary: linear-gradient(135deg, var(--secondary-500), var(--secondary-700));

  --elevation-1: var(--shadow-sm);
  --elevation-2: var(--shadow-md);
  --elevation-3: var(--shadow-lg);
  --elevation-4: var(--shadow-xl);

  --z-hide: -1;
  --z-base: 0;
  --z-normal: 0;
  --z-dropdown: 100;
  --z-sticky: 200;
  --z-fixed: 300;
  --z-overlay: 350;
  --z-modal: 400;
  --z-popover: 500;
  --z-toast: 800;
  --z-alert-critical: 2500;

  --chrome-border: var(--border-light);
  --chrome-border-strong: var(--border-medium);
  --panel-bg: var(--bg-primary);
  --panel-raised: var(--surface-raised);
}

[data-theme="dark"] {
  color-scheme: dark;

  /* Semantic Theme Mapping (Dark) */
  --bg-primary: #0b111a;
  --bg-secondary: #080d14;
  --bg-tertiary: #131b26;
  --bg-shell: #05080c;
  --bg-overlay: rgba(2, 6, 23, 0.75);

  --surface-raised: #151e2b;
  --surface-subtle: #0f1520;
  --surface-strong: #1a2536;
  --surface-accent: rgba(16, 185, 129, 0.16);

  --text-primary: var(--neutral-50);
  --text-secondary: var(--neutral-300);
  --text-tertiary: var(--neutral-400);
  --text-inverse: #000000;

  --border-light: rgba(148, 163, 184, 0.20);
  --border-medium: rgba(148, 163, 184, 0.25);
  --border-dark: rgba(148, 163, 184, 0.35);

  /* Adjust color intent for dark mode readability & contrast */
  --color-primary: #10b981;
  --color-primary-light: #34d399;
  --color-primary-lighter: rgba(16, 185, 129, 0.20);
  --color-primary-dark: #059669;
  --color-primary-darker: #047857;

  --color-secondary: #3b82f6;
  --color-secondary-light: rgba(59, 130, 246, 0.15);
  --color-secondary-dark: #2563eb;

  --color-success: #10b981;
  --color-success-light: rgba(16, 185, 129, 0.15);
  --color-success-dark: #34d399;

  --color-warning: #fbbf24;
  --color-warning-light: rgba(251, 191, 36, 0.15);
  --color-warning-dark: #fcd34d;

  --color-error: #ef4444;
  --color-error-light: rgba(239, 68, 68, 0.15);
  --color-error-dark: #f87171;

  --color-info: #0ea5e9;
  --color-info-light: rgba(14, 165, 233, 0.15);
  --color-info-dark: #38bdf8;

  --focus-ring: 0 0 0 3px rgba(16, 185, 129, 0.25);

  --shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, 0.4), 0 1px 2px -1px rgba(0, 0, 0, 0.4);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.4), 0 2px 4px -2px rgba(0, 0, 0, 0.4);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.5), 0 4px 6px -4px rgba(0, 0, 0, 0.5);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.5), 0 8px 10px -6px rgba(0, 0, 0, 0.5);
  --shadow-primary: 0 10px 15px -3px rgba(16, 185, 129, 0.25);
  --shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.6);

  --gradient-primary: linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));
  --gradient-secondary: linear-gradient(135deg, var(--color-secondary), var(--color-secondary-dark));

  --chrome-border: var(--border-light);
  --panel-bg: var(--bg-primary);
  --panel-raised: var(--surface-raised);

  /* Heading hierarchy (Manrope weight/size refinement) */
  --font-heading-display: var(--font-extrabold);  /* 800 */
  --font-heading-section: var(--font-bold);       /* 700 */
  --font-heading-ui: var(--font-semibold);        /* 600 */
  --letter-spacing-heading-xl: -0.04em;
  --letter-spacing-heading-lg: -0.03em;
  --letter-spacing-heading-md: -0.02em;
  --text-heading-page: clamp(1.75rem, 2.8vw, 2.25rem);
  --text-heading-section: 1.25rem;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  font-size: calc(16px * var(--font-scale));
  min-height: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

body {
  min-height: 100vh;
  margin: 0;
  font-family: var(--font-primary);
  font-size: var(--text-base);
  line-height: var(--line-height-normal);
  color: var(--text-primary);
  background: var(--bg-secondary);
  overflow-x: hidden;
}

:lang(ar),
[dir="rtl"] {
  font-family: var(--font-family-arabic);
}

h1,h2,h3,h4,h5,h6 {
  margin: 0;
  font-family: var(--font-heading);
  font-weight: var(--font-bold);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  color: var(--text-primary);
}

h1:focus,
h2:focus,
h3:focus,
h4:focus,
h5:focus,
h6:focus {
  outline: none;
}

p {
  margin: 0;
  color: var(--text-secondary);
}

a {
  color: inherit;
  text-decoration: none;
  transition: color var(--transition-fast);
}

a:hover {
  color: var(--color-primary);
}

button,
input,
select,
textarea {
  font: inherit;
  color: inherit;
}

code,
pre {
  font-family: var(--font-mono);
}

::selection {
  background: var(--color-primary-lighter);
  color: var(--text-primary);
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.01ms !important;
  }
}
