/* Zabulan Notes — Theme Variables */
/* Brand palette: #02020A navy dominant + white trim/lettering.
   All theme blocks (light, dark, prefers-color-scheme) share the
   same values so users see the brand palette regardless of their
   saved theme preference. */

:root {
    /* Primary accent — white-faced buttons with navy text (inverted) */
    --color-primary: #ffffff;
    --color-primary-hover: rgba(255, 255, 255, 0.9);
    --color-primary-light: rgba(255, 255, 255, 0.1);
    --color-primary-text: #02020A;

    --color-danger: #ef4444;
    --color-danger-hover: #dc2626;
    --color-warning: #f59e0b;
    --color-success: #22c55e;
    --color-info: #ffffff;

    /* Backgrounds — pure brand navy throughout */
    --bg-body: #02020A;
    --bg-sidebar: #02020A;
    --bg-main: #02020A;
    --bg-card: #02020A;
    --bg-input: #02020A;
    --bg-hover: rgba(255, 255, 255, 0.06);
    --bg-active: rgba(255, 255, 255, 0.12);
    --bg-editor: #02020A;
    --bg-modal-overlay: rgba(0, 0, 0, 0.6);
    --bg-tooltip: #ffffff;

    /* Borders — white at low opacity for layering */
    --border-color: rgba(255, 255, 255, 0.15);
    --border-color-light: rgba(255, 255, 255, 0.08);

    /* Text — white with hierarchy via opacity */
    --text-primary: #ffffff;
    --text-secondary: rgba(255, 255, 255, 0.85);
    --text-muted: rgba(255, 255, 255, 0.55);
    --text-active: #ffffff;
    --text-editor: #ffffff;
    --text-inverse: #02020A;

    --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.3);
    --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.4);
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.5);

    --radius-sm: 4px;
    --radius-md: 8px;
    --radius-lg: 12px;
    --radius-full: 9999px;

    --activity-bar-width: 56px;
    --nav-width: 240px;
    --notelist-width: 320px;
    --header-height: 56px;
    --avatar-size: 36px;

    --bg-activity-bar: #02020A;
    --bg-activity-bar-hover: rgba(255, 255, 255, 0.08);
    --bg-activity-bar-active: rgba(255, 255, 255, 0.14);
    --bg-activity-bar-indicator: #ffffff;
    --text-activity-bar: rgba(255, 255, 255, 0.6);
    --text-activity-bar-hover: rgba(255, 255, 255, 0.9);
    --text-activity-bar-active: #ffffff;

    --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --font-mono: 'JetBrains Mono', 'Fira Code', monospace;

    --font-size-xs: 0.6875rem;    /* 11px */
    --font-size-sm: 0.75rem;       /* 12px */
    --font-size-base: 0.8125rem;   /* 13px */
    --font-size-md: 0.875rem;      /* 14px */
    --font-size-lg: 1rem;          /* 16px */

    --transition-fast: 150ms ease;
    --transition-normal: 250ms ease;

    /* Z-index scale */
    --z-base: 1;
    --z-overlay: 10;
    --z-overlay-controls: 25;
    --z-overlay-connectors: 40;
    --z-overlay-cp: 46;
    --z-sticky: 50;
    --z-activity-bar: 100;
    --z-tooltip: 125;
    --z-dropdown: 500;
    --z-mobile-editor: 600;
    --z-mobile-nav: 800;
    --z-mobile-bar: 801;
    --z-avatar: 900;
    --z-modal: 1000;
    --z-theme-editor: 1100;
    --z-popover: 1500;
    --z-drawing-toolbar: 1600;
    --z-edit-toolbar: 1650;
    --z-recording: 1700;
    --z-menubar: 1800;
    --z-toast: 2000;
    --z-resizer-overlay: 9999;

    /* Density — default comfortable */
    --density-padding-sm: 4px;
    --density-padding-md: 8px;
    --density-padding-lg: 12px;
    --density-padding-xl: 16px;
    --density-gap-sm: 4px;
    --density-gap-md: 8px;
    --density-font-sm: 0.8125rem;
    --density-font-md: 0.875rem;

    /* Graph View — keep functional colors for node-type distinction */
    --graph-bg: #02020A;
    --graph-node-note: #60a5fa;
    --graph-node-kanban: #4ade80;
    --graph-node-mindmap: #fbbf24;
    --graph-node-drawing: #a78bfa;
    --graph-node-chart: #22d3ee;
    --graph-node-calendar: #f87171;
    --graph-node-capture: #f472b6;
    --graph-edge: rgba(255, 255, 255, 0.4);
    --graph-label: #ffffff;
}

/* Dark Theme — same as :root so user theme toggles are no-ops color-wise */
[data-theme="dark"] {
    --color-primary: #ffffff;
    --color-primary-hover: rgba(255, 255, 255, 0.9);
    --color-primary-light: rgba(255, 255, 255, 0.1);
    --color-primary-text: #02020A;
    --color-info: #ffffff;

    --bg-body: #02020A;
    --bg-sidebar: #02020A;
    --bg-main: #02020A;
    --bg-card: #02020A;
    --bg-input: #02020A;
    --bg-hover: rgba(255, 255, 255, 0.06);
    --bg-active: rgba(255, 255, 255, 0.12);
    --bg-editor: #02020A;
    --bg-modal-overlay: rgba(0, 0, 0, 0.6);
    --bg-tooltip: #ffffff;

    --border-color: rgba(255, 255, 255, 0.15);
    --border-color-light: rgba(255, 255, 255, 0.08);

    --text-primary: #ffffff;
    --text-secondary: rgba(255, 255, 255, 0.85);
    --text-muted: rgba(255, 255, 255, 0.55);
    --text-active: #ffffff;
    --text-editor: #ffffff;
    --text-inverse: #02020A;

    --bg-activity-bar: #02020A;
    --bg-activity-bar-hover: rgba(255, 255, 255, 0.08);
    --bg-activity-bar-active: rgba(255, 255, 255, 0.14);
    --bg-activity-bar-indicator: #ffffff;
    --text-activity-bar: rgba(255, 255, 255, 0.6);
    --text-activity-bar-hover: rgba(255, 255, 255, 0.9);
    --text-activity-bar-active: #ffffff;

    --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.3);
    --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.4);
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.5);

    --graph-bg: #02020A;
    --graph-node-note: #60a5fa;
    --graph-node-kanban: #4ade80;
    --graph-node-mindmap: #fbbf24;
    --graph-node-drawing: #a78bfa;
    --graph-node-chart: #22d3ee;
    --graph-node-calendar: #f87171;
    --graph-node-capture: #f472b6;
    --graph-edge: rgba(255, 255, 255, 0.4);
    --graph-label: #ffffff;
}

/* Compact Density */
body.density-compact {
    --density-padding-sm: 2px;
    --density-padding-md: 4px;
    --density-padding-lg: 8px;
    --density-padding-xl: 12px;
    --density-gap-sm: 2px;
    --density-gap-md: 4px;
    --density-font-sm: 0.75rem;
    --density-font-md: 0.8125rem;
    --header-height: 44px;
    --activity-bar-width: 48px;
}

/* Focus indicators */
:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

/* Remove outline for mouse/touch users */
:focus:not(:focus-visible) {
    outline: none;
}

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

/* System color scheme detection — same brand palette either way */
@media (prefers-color-scheme: dark) {
    :root:not([data-theme]) {
        --color-primary: #ffffff;
        --color-primary-hover: rgba(255, 255, 255, 0.9);
        --color-primary-light: rgba(255, 255, 255, 0.1);
        --bg-body: #02020A;
        --bg-sidebar: #02020A;
        --bg-main: #02020A;
        --bg-card: #02020A;
        --bg-input: #02020A;
        --bg-hover: rgba(255, 255, 255, 0.06);
        --bg-active: rgba(255, 255, 255, 0.12);
        --bg-editor: #02020A;
        --bg-modal-overlay: rgba(0, 0, 0, 0.6);
        --bg-tooltip: #ffffff;
        --border-color: rgba(255, 255, 255, 0.15);
        --border-color-light: rgba(255, 255, 255, 0.08);
        --text-primary: #ffffff;
        --text-secondary: rgba(255, 255, 255, 0.85);
        --text-muted: rgba(255, 255, 255, 0.55);
        --text-active: #ffffff;
        --text-editor: #ffffff;
        --text-inverse: #02020A;
        --bg-activity-bar: #02020A;
        --bg-activity-bar-indicator: #ffffff;
        --text-activity-bar: rgba(255, 255, 255, 0.6);
        --text-activity-bar-hover: rgba(255, 255, 255, 0.9);
        --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.3);
        --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.4);
        --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.5);
    }
}
