/* ============================================
   Design Tokens — 2026 SaaS Grade
   Single source of truth for all visual values
   ============================================ */

:root {
    /* ── Color: Primary ── */
    --c-primary: #0ea5e9;
    --c-primary-hover: #0284c7;
    --c-primary-active: #0369a1;
    --c-primary-light: rgba(14, 165, 233, 0.08);
    --c-primary-ring: rgba(14, 165, 233, 0.25);

    /* ── Color: Accent (use sparingly — success/positive only) ── */
    --c-accent: #10b981;
    --c-accent-light: rgba(16, 185, 129, 0.08);

    /* ── Color: Status ── */
    --c-success: #10b981;
    --c-warning: #f59e0b;
    --c-danger: #ef4444;
    --c-danger-light: rgba(239, 68, 68, 0.08);

    /* ── Color: Neutral (Gray Scale) ── */
    --c-gray-50: #f8fafc;
    --c-gray-100: #f1f5f9;
    --c-gray-200: #e2e8f0;
    --c-gray-300: #cbd5e1;
    --c-gray-400: #94a3b8;
    --c-gray-500: #64748b;
    --c-gray-600: #475569;
    --c-gray-700: #334155;
    --c-gray-800: #1e293b;
    --c-gray-900: #0f172a;
    --c-gray-950: #020617;

    /* ── Color: Semantic Surface / Text / Border ── */
    --c-bg: var(--c-gray-50);
    --c-surface: #ffffff;
    --c-surface-raised: #ffffff;
    --c-text: var(--c-gray-900);
    --c-text-secondary: var(--c-gray-600);
    --c-text-tertiary: var(--c-gray-400);
    --c-border: rgba(15, 23, 42, 0.08);
    --c-border-strong: rgba(15, 23, 42, 0.15);
    --c-divider: var(--c-gray-100);

    /* ── Typography ── */
    --font-sans: 'Pretendard', -apple-system, BlinkMacSystemFont,
        'Segoe UI', Roboto, 'Noto Sans KR', sans-serif;
    --font-mono: 'JetBrains Mono', 'Fira Code', monospace;

    --text-xs: 0.75rem;
    /* 12 */
    --text-sm: 0.875rem;
    /* 14 */
    --text-base: 1rem;
    /* 16 */
    --text-lg: 1.125rem;
    /* 18 */
    --text-xl: 1.25rem;
    /* 20 */
    --text-2xl: 1.5rem;
    /* 24 */
    --text-3xl: 1.875rem;
    /* 30 */
    --text-4xl: 2.25rem;
    /* 36 */
    --text-5xl: 3rem;
    /* 48 */

    --weight-normal: 400;
    --weight-medium: 500;
    --weight-semibold: 600;
    --weight-bold: 700;
    --weight-extrabold: 800;

    --leading-tight: 1.25;
    --leading-snug: 1.375;
    --leading-normal: 1.5;
    --leading-relaxed: 1.625;

    --tracking-tight: -0.025em;
    --tracking-normal: 0;
    --tracking-wide: 0.025em;

    /* ── Spacing (8px grid) ── */
    --sp-0: 0;
    --sp-0-5: 0.25rem;
    /*  4 */
    --sp-1: 0.5rem;
    /*  8 */
    --sp-1-5: 0.75rem;
    /* 12 */
    --sp-2: 1rem;
    /* 16 */
    --sp-3: 1.5rem;
    /* 24 */
    --sp-4: 2rem;
    /* 32 */
    --sp-5: 2.5rem;
    /* 40 */
    --sp-6: 3rem;
    /* 48 */
    --sp-8: 4rem;
    /* 64 */
    --sp-10: 5rem;
    /* 80 */
    --sp-12: 6rem;
    /* 96 */
    --sp-16: 8rem;
    /* 128 */

    /* ── Radius ── */
    --r-sm: 0.5rem;
    /*  8 */
    --r-md: 0.75rem;
    /* 12 */
    --r-lg: 1rem;
    /* 16 */
    --r-xl: 1.25rem;
    /* 20 */
    --r-2xl: 1.5rem;
    /* 24 */
    --r-full: 9999px;

    /* ── Shadows (subtle!) ── */
    --shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, 0.03);
    --shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, 0.06), 0 1px 2px -1px rgba(0, 0, 0, 0.04);
    --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.06), 0 2px 4px -2px rgba(0, 0, 0, 0.04);
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.06), 0 4px 6px -4px rgba(0, 0, 0, 0.03);
    --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.06), 0 8px 10px -6px rgba(0, 0, 0, 0.03);

    /* ── Transitions ── */
    --ease-default: cubic-bezier(0.4, 0, 0.2, 1);
    --ease-in: cubic-bezier(0.4, 0, 1, 1);
    --ease-out: cubic-bezier(0, 0, 0.2, 1);
    --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);

    --dur-fast: 120ms;
    --dur-base: 200ms;
    --dur-slow: 300ms;
    --dur-slower: 500ms;

    /* ── Layout ── */
    --w-sm: 640px;
    --w-md: 768px;
    --w-lg: 1024px;
    --w-xl: 1200px;
    --w-content: 660px;
    /* Form/card max-width */

    /* ── Z-index ── */
    --z-base: 0;
    --z-raised: 1;
    --z-dropdown: 10;
    --z-sticky: 20;
    --z-overlay: 30;
    --z-modal: 40;
    --z-tooltip: 50;
}

/* ── Dark Mode (manual toggle via data-theme) ── */
[data-theme="dark"] {
    --c-bg: var(--c-gray-950);
    --c-surface: var(--c-gray-900);
    --c-surface-raised: var(--c-gray-800);
    --c-text: var(--c-gray-50);
    --c-text-secondary: var(--c-gray-400);
    --c-text-tertiary: var(--c-gray-500);
    --c-border: rgba(248, 250, 252, 0.08);
    --c-border-strong: rgba(248, 250, 252, 0.15);
    --c-divider: var(--c-gray-800);
    --c-primary-light: rgba(14, 165, 233, 0.15);
    --c-accent-light: rgba(16, 185, 129, 0.15);
    --c-danger-light: rgba(239, 68, 68, 0.15);

    --shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, 0.20);
    --shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, 0.30);
    --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.30);
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.30);
    --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.30);
}

/* OS auto-detect (only when no manual preference saved) */
@media (prefers-color-scheme: dark) {
    [data-theme="auto"] {
        --c-bg: var(--c-gray-950);
        --c-surface: var(--c-gray-900);
        --c-surface-raised: var(--c-gray-800);
        --c-text: var(--c-gray-50);
        --c-text-secondary: var(--c-gray-400);
        --c-text-tertiary: var(--c-gray-500);
        --c-border: rgba(248, 250, 252, 0.08);
        --c-border-strong: rgba(248, 250, 252, 0.15);
        --c-divider: var(--c-gray-800);
        --c-primary-light: rgba(14, 165, 233, 0.15);
        --c-accent-light: rgba(16, 185, 129, 0.15);
        --c-danger-light: rgba(239, 68, 68, 0.15);

        --shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, 0.20);
        --shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, 0.30);
        --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.30);
        --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.30);
        --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.30);
    }
}

/* Smooth theme transition */
html {
    transition: background-color var(--dur-slow) var(--ease-default),
        color var(--dur-slow) var(--ease-default);
}

/* ── Theme Toggle Button ── */
.theme-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    padding: 0;
    background: transparent;
    border: 1px solid var(--c-border-strong);
    border-radius: var(--r-sm);
    cursor: pointer;
    font-size: 1.15rem;
    line-height: 1;
    color: var(--c-text-secondary);
    transition: all var(--dur-base) var(--ease-default);
}

.theme-toggle:hover {
    background: var(--c-gray-100);
    color: var(--c-text);
}

[data-theme="dark"] .theme-toggle:hover {
    background: var(--c-gray-800);
}

.theme-toggle .icon-sun,
.theme-toggle .icon-moon {
    display: none;
}

/* Light: show moon (click to go dark) */
.theme-toggle .icon-moon {
    display: inline;
}

.theme-toggle .icon-sun {
    display: none;
}

[data-theme="dark"] .theme-toggle .icon-moon {
    display: none;
}

[data-theme="dark"] .theme-toggle .icon-sun {
    display: inline;
}

/* Auto mode with OS dark */
@media (prefers-color-scheme: dark) {
    [data-theme="auto"] .theme-toggle .icon-moon {
        display: none;
    }

    [data-theme="auto"] .theme-toggle .icon-sun {
        display: inline;
    }
}