:root,
:root[data-theme="light"],
[data-bs-theme="light"] {
    --surface-0: #f5f6f8;
    --surface-1: #ffffff;
    --surface-2: #f8fafc;
    --border-1: #dbe3ee;
    --text-1: #111827;
    --text-2: #4b5563;
    --text-3: #6b7280;
    --muted: #64748b;
    --shadow-1: 0 1px 2px rgba(15, 23, 42, 0.06);
    --shadow-2: 0 10px 24px rgba(15, 23, 42, 0.08);
    --radius-1: 0.5rem;
    --radius-2: 0.75rem;
    --radius-3: 1rem;
    --accent-1: #4f46e5;
    --accent-2: #0ea5e9;
    --accent-soft: color-mix(in srgb, var(--accent-1) 10%, var(--surface-1));
    --success: #15803d;
    --warn: #b45309;
    --danger: #b91c1c;
    --focus-ring: 0 0 0 0.22rem color-mix(in srgb, var(--accent-1) 26%, transparent);
}

:root[data-theme="dark"],
[data-bs-theme="dark"] {
    --surface-0: #0b1220;
    --surface-1: #111827;
    --surface-2: #0f172a;
    --border-1: #263244;
    --text-1: #e5e7eb;
    --text-2: #cbd5e1;
    --text-3: #94a3b8;
    --muted: #94a3b8;
    --shadow-1: 0 1px 2px rgba(2, 6, 23, 0.48);
    --shadow-2: 0 14px 30px rgba(2, 6, 23, 0.54);
    --accent-1: #818cf8;
    --accent-2: #38bdf8;
    --accent-soft: color-mix(in srgb, var(--accent-1) 22%, var(--surface-1));
    --success: #4ade80;
    --warn: #fbbf24;
    --danger: #f87171;
}
