:root {
    /* ── Backgrounds ── */
    --bg-body: #FAFAFF;
    --bg-primary: #ffffff;
    --bg-secondary: #FAFAFF;
    --bg-tertiary: #F5F3FF;
    --bg-hover: #EDE9FE;
    --bg-active: #DDD6FE;

    /* ── Text ── */
    --text-primary: #1E1B4B;
    --text-secondary: #5A5C69;
    --text-muted: #94a3b8;
    --text-inverse: #ffffff;

    /* ── Accent (Violet — brand ARTERYX Pulse) ── */
    --accent: #7C3AED;
    --accent-hover: #6D28D9;
    --accent-glow: rgba(124, 58, 237, 0.15);
    --accent-subtle: rgba(124, 58, 237, 0.06);
    --accent-light: #F5F3FF;
    --accent-ai: #06B6D4;

    /* ── Semantic ── */
    --success: #10b981;
    --success-bg: rgba(16, 185, 129, 0.1);
    --success-light: #ecfdf5;
    --warning: #f59e0b;
    --warning-bg: rgba(245, 158, 11, 0.1);
    --warning-light: #fffbeb;
    --danger: #ef4444;
    --danger-bg: rgba(239, 68, 68, 0.1);
    --danger-light: #fef2f2;
    --info: #3b82f6;
    --info-bg: rgba(59, 130, 246, 0.1);
    --info-light: #eff6ff;

    /* ── Borders ── */
    --border: rgba(124, 58, 237, 0.1);
    --border-light: rgba(124, 58, 237, 0.06);
    --border-focus: #7C3AED;

    /* ── Radii ── */
    --radius-sm: 6px;
    --radius: 10px;
    --radius-lg: 14px;
    --radius-xl: 20px;
    --radius-full: 9999px;

    /* ── Shadows (violet-tinted) ── */
    --shadow-sm: 0 1px 2px rgba(124, 58, 237, 0.06);
    --shadow: 0 1px 3px rgba(124, 58, 237, 0.08), 0 1px 2px rgba(124, 58, 237, 0.04);
    --shadow-md: 0 4px 6px -1px rgba(124, 58, 237, 0.08), 0 2px 4px -1px rgba(124, 58, 237, 0.04);
    --shadow-lg: 0 10px 15px -3px rgba(124, 58, 237, 0.1), 0 4px 6px -2px rgba(124, 58, 237, 0.05);
    --shadow-glow: 0 0 20px var(--accent-glow);
    --shadow-hover: 0 16px 32px -8px rgba(124, 58, 237, 0.15);

    /* ── Typography ── */
    --font-sans: 'DM Sans', 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --font-heading: 'Sora', 'DM Sans', sans-serif;
    --font-mono: 'Space Mono', 'JetBrains Mono', 'Fira Code', monospace;

    /* ── Layout ── */
    --sidebar-width: 260px;
    --topbar-height: 64px;

    /* ── Sidebar (dark contrast) ── */
    --sidebar-bg: #0f172a;
    --sidebar-bg-hover: #1e293b;
    --sidebar-border: #1e293b;
    --sidebar-text: #94a3b8;
    --sidebar-text-hover: #e2e8f0;
    --sidebar-text-active: #ffffff;

    /* ── Transitions ── */
    --transition: 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    --transition-slow: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
