/**
 * Dashboard Themes - CSS Variables and Common Styles
 * Version 1.0 - Unified theme system for all dashboards
 */

/* ========================================================================
   THEME VARIABLES - Dashboard-specific color schemes
   ======================================================================== */

/* Default dashboard theme (fallback for pages that explicitly set default/light) */
.dashboard-theme-default,
body[data-dashboard-theme="default"],
body[data-dashboard-theme="light"] {
    --dashboard-primary: var(--primary);
    --dashboard-primary-hover: var(--primary-dark);
    --dashboard-primary-light: var(--primary-light);
    --dashboard-primary-dark: var(--primary-dark);
}

/* Citizen Dashboard Theme */
.dashboard-theme-citizen,
body[data-dashboard-theme="citizen"] {
    --dashboard-primary: #6366f1;
    --dashboard-primary-hover: #4f46e5;
    --dashboard-primary-light: #e0e7ff;
    --dashboard-primary-dark: #4338ca;
    --primary: var(--dashboard-primary);
    --primary-hover: var(--dashboard-primary-hover);
    --primary-light: var(--dashboard-primary-light);
}

/* Analyst Dashboard Theme */
.dashboard-theme-analyst,
body[data-dashboard-theme="analyst"] {
    --dashboard-primary: #2563eb;
    --dashboard-primary-hover: #1d4ed8;
    --dashboard-primary-light: #dbeafe;
    --dashboard-primary-dark: #1e40af;
    --primary: var(--dashboard-primary);
    --primary-hover: var(--dashboard-primary-hover);
    --primary-light: var(--dashboard-primary-light);
}

/* Researcher Dashboard Theme */
.dashboard-theme-researcher,
body[data-dashboard-theme="researcher"] {
    --dashboard-primary: #0ea5e9;
    --dashboard-primary-hover: #0284c7;
    --dashboard-primary-light: #e0f2fe;
    --dashboard-primary-dark: #0369a1;
    --primary: var(--dashboard-primary);
    --primary-hover: var(--dashboard-primary-hover);
    --primary-light: var(--dashboard-primary-light);
}

/* Methodologist Dashboard Theme */
.dashboard-theme-methodologist,
body[data-dashboard-theme="methodologist"] {
    --dashboard-primary: #8b5cf6;
    --dashboard-primary-hover: #7c3aed;
    --dashboard-primary-light: #ede9fe;
    --dashboard-primary-dark: #6d28d9;
    --primary: var(--dashboard-primary);
    --primary-hover: var(--dashboard-primary-hover);
    --primary-light: var(--dashboard-primary-light);
}

/* Academy Theme */
.dashboard-theme-academy,
body[data-dashboard-theme="academy"] {
    --dashboard-primary: #6366f1;
    --dashboard-primary-hover: #4f46e5;
    --dashboard-primary-light: #e0e7ff;
    --dashboard-primary-dark: #4338ca;
    --primary: var(--dashboard-primary);
    --primary-hover: var(--dashboard-primary-hover);
    --primary-light: var(--dashboard-primary-light);
}

/* Patron Dashboard Theme */
.dashboard-theme-patron,
body[data-dashboard-theme="patron"] {
    --dashboard-primary: #f59e0b;
    --dashboard-primary-hover: #d97706;
    --dashboard-primary-light: #fef3c7;
    --dashboard-primary-dark: #b45309;
    --primary: var(--dashboard-primary);
    --primary-hover: var(--dashboard-primary-hover);
    --primary-light: var(--dashboard-primary-light);
}

/* Moderator Dashboard Theme */
.dashboard-theme-moderator,
body[data-dashboard-theme="moderator"] {
    --dashboard-primary: #e11d48;
    --dashboard-primary-hover: #be123c;
    --dashboard-primary-light: #ffe4e6;
    --dashboard-primary-dark: #9f1239;
    --primary: var(--dashboard-primary);
    --primary-hover: var(--dashboard-primary-hover);
    --primary-light: var(--dashboard-primary-light);
}

/* Urbanist Dashboard Theme */
.dashboard-theme-urbanist,
body[data-dashboard-theme="urbanist"] {
    --dashboard-primary: #6366f1;
    --dashboard-primary-hover: #4f46e5;
    --dashboard-primary-light: #e0e7ff;
    --dashboard-primary-dark: #4338ca;
    --primary: var(--dashboard-primary);
    --primary-hover: var(--dashboard-primary-hover);
    --primary-light: var(--dashboard-primary-light);
}

/* Data Engineer Dashboard Theme */
.dashboard-theme-data_engineer,
body[data-dashboard-theme="data_engineer"] {
    --dashboard-primary: #10b981;
    --dashboard-primary-hover: #059669;
    --dashboard-primary-light: #d1fae5;
    --dashboard-primary-dark: #047857;
    --primary: var(--dashboard-primary);
    --primary-hover: var(--dashboard-primary-hover);
    --primary-light: var(--dashboard-primary-light);
}

/* Historian Dashboard Theme */
.dashboard-theme-historian,
body[data-dashboard-theme="historian"] {
    --dashboard-primary: #0f766e;
    --dashboard-primary-hover: #115e59;
    --dashboard-primary-light: #ccfbf1;
    --dashboard-primary-dark: #134e4a;
    --primary: var(--dashboard-primary);
    --primary-hover: var(--dashboard-primary-hover);
    --primary-light: var(--dashboard-primary-light);
}

/* Task Setter Dashboard Theme */
.dashboard-theme-task_setter,
body[data-dashboard-theme="task_setter"] {
    --dashboard-primary: #dc2626;
    --dashboard-primary-hover: #b91c1c;
    --dashboard-primary-light: #fee2e2;
    --dashboard-primary-dark: #991b1b;
    --primary: var(--dashboard-primary);
    --primary-hover: var(--dashboard-primary-hover);
    --primary-light: var(--dashboard-primary-light);
}

/* Producer Dashboard Theme */
.dashboard-theme-producer,
body[data-dashboard-theme="producer"] {
    --dashboard-primary: #8b5cf6;
    --dashboard-primary-hover: #7c3aed;
    --dashboard-primary-light: #ede9fe;
    --dashboard-primary-dark: #6d28d9;
    --primary: var(--dashboard-primary);
    --primary-hover: var(--dashboard-primary-hover);
    --primary-light: var(--dashboard-primary-light);
}

/* Cultural Map Theme */
.dashboard-theme-cultural_map,
body[data-dashboard-theme="cultural_map"] {
    --dashboard-primary: #ea580c;
    --dashboard-primary-hover: #c2410c;
    --dashboard-primary-light: #ffedd5;
    --dashboard-primary-dark: #9a3412;
    --primary: var(--dashboard-primary);
    --primary-hover: var(--dashboard-primary-hover);
    --primary-light: var(--dashboard-primary-light);
}

/* Parser Sandbox Theme */
.dashboard-theme-parser_sandbox,
body[data-dashboard-theme="parser_sandbox"] {
    --dashboard-primary: #475569;
    --dashboard-primary-hover: #334155;
    --dashboard-primary-light: #e2e8f0;
    --dashboard-primary-dark: #1f2937;
    --primary: var(--dashboard-primary);
    --primary-hover: var(--dashboard-primary-hover);
    --primary-light: var(--dashboard-primary-light);
}

/* Strategist Dashboard Theme */
.dashboard-theme-strategist,
body[data-dashboard-theme="strategist"] {
    --dashboard-primary: #dc2626;
    --dashboard-primary-hover: #b91c1c;
    --dashboard-primary-light: #fee2e2;
    --dashboard-primary-dark: #991b1b;
    /* Совместимость со старыми переменными */
    --primary: var(--dashboard-primary);
    --primary-hover: var(--dashboard-primary-hover);
    --primary-light: var(--dashboard-primary-light);
}

/* Visionary Dashboard Theme */
.dashboard-theme-visionary,
body[data-dashboard-theme="visionary"] {
    --dashboard-primary: #9b59b6;
    --dashboard-primary-hover: #8e44ad;
    --dashboard-primary-light: #f3e5f5;
    --dashboard-primary-dark: #7d3c98;
    /* Совместимость со старыми переменными */
    --primary: var(--dashboard-primary);
    --primary-hover: var(--dashboard-primary-hover);
    --primary-light: var(--dashboard-primary-light);
}

/* Developer Dashboard Theme */
.dashboard-theme-developer,
body[data-dashboard-theme="developer"] {
    --dashboard-primary: #10b981;
    --dashboard-primary-hover: #059669;
    --dashboard-primary-light: #d1fae5;
    --dashboard-primary-dark: #047857;
    /* Совместимость со старыми переменными */
    --primary: var(--dashboard-primary);
    --primary-hover: var(--dashboard-primary-hover);
    --primary-light: var(--dashboard-primary-light);
}

/* ========================================================================
   COMMON DASHBOARD COMPONENTS
   ======================================================================== */

/* Dashboard Header */
.dashboard-header {
    height: var(--header-height, 60px);
    background: var(--bg-primary);
    border-bottom: 1px solid var(--border);
    padding: 0 var(--spacing-lg);
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-shrink: 0;
    box-shadow: var(--shadow-xs);
    z-index: 100;
}

.dashboard-header .header-left {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.dashboard-header h1 {
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
}

.dashboard-header .city-name {
    font-size: 0.875rem;
    color: var(--text-secondary);
    padding: 0.25rem 0.75rem;
    background: var(--bg-secondary);
    border-radius: var(--radius);
}

.dashboard-header .header-right {
    display: flex;
    gap: var(--spacing-sm);
    align-items: center;
}

/* Dashboard layout primitives are defined in dashboard-base.css */

/* ========================================================================
   THEME-SPECIFIC OVERRIDES
   ======================================================================== */

/* Strategist specific overrides */
.dashboard-theme-strategist .btn-primary,
body[data-dashboard-theme="strategist"] .btn-primary {
    background-color: var(--dashboard-primary);
    border-color: var(--dashboard-primary);
}

.dashboard-theme-strategist .btn-primary:hover,
body[data-dashboard-theme="strategist"] .btn-primary:hover {
    background-color: var(--dashboard-primary-hover);
    border-color: var(--dashboard-primary-hover);
}

/* Visionary specific overrides */
.dashboard-theme-visionary .btn-primary,
body[data-dashboard-theme="visionary"] .btn-primary {
    background-color: var(--dashboard-primary);
    border-color: var(--dashboard-primary);
}

.dashboard-theme-visionary .btn-primary:hover,
body[data-dashboard-theme="visionary"] .btn-primary:hover {
    background-color: var(--dashboard-primary-hover);
    border-color: var(--dashboard-primary-hover);
}

/* Developer specific overrides */
.dashboard-theme-developer .btn-primary,
body[data-dashboard-theme="developer"] .btn-primary {
    background-color: var(--dashboard-primary);
    border-color: var(--dashboard-primary);
}

.dashboard-theme-developer .btn-primary:hover,
body[data-dashboard-theme="developer"] .btn-primary:hover {
    background-color: var(--dashboard-primary-hover);
    border-color: var(--dashboard-primary-hover);
}

