/* ============================================================
   THÈME « Midnight » — Couche 2 (thème alternatif)
   Thème très sombre, bleu nuit profond avec accents électriques.
   Inspiration : ciel urbain à minuit, néons bleutés.
   ============================================================ */

[data-theme="midnight"] {

    /* ── Polices ──────────────────────────────────────────── */
    --font-body:             'Barlow', 'Arial', sans-serif;
    --font-display:          'Poppins', sans-serif;
    --font-heading:          'Inter', sans-serif;
    --font-mono:             'Courier New', monospace;
    --font-brand:            'Aboreto', cursive;

    /* ── Tailles de base ──────────────────────────────────── */
    --text-base-size:        16px;

    --base-color-for-glow: 59, 130, 246;
    --base-color-for-secondary-glow: 34, 211, 238;

    /* ── Couleurs principales (brand) ─────────────────────── */
    --color-primary:         #3b82f6;
    --color-primary-dark:    #2563eb;
    --color-primary-darker:  #1d4ed8;
    --color-primary-light:   #60a5fa;
    --color-primary-lighter: #93c5fd;
    --color-primary-pale:    #bfdbfe;
    --color-primary-glow:    rgba(59, 130, 246, 0.3);

    --color-secondary:       #22d3ee;
    --color-secondary-dark:  #06b6d4;
    --color-secondary-light: #67e8f9;
    --color-secondary-pale:  #a5f3fc;

    --color-accent:          #818cf8;
    --color-accent-light:    #a5b4fc;
    --color-accent-pale:     #c7d2fe;

    --color-teal:            #2dd4bf;
    --color-cyan:            #22d3ee;

    /* ── Couleurs sémantiques ─────────────────────────────── */
    --color-success:         rgb(34, 197, 94);
    --color-success-bright:  #4ade80;
    --color-success-light:   #86efac;
    --color-success-pale:    #bbf7d0;
    --color-success-dark:    #16a34a;
    --color-success-bg:      rgba(34, 197, 94, 0.12);
    --color-success-border:  rgba(34, 197, 94, 0.3);

    --color-danger:          #ef4444;
    --color-danger-bright:   #f87171;
    --color-danger-light:    #fca5a5;
    --color-danger-pale:     #fecaca;
    --color-danger-deep:     #dc2626;
    --color-danger-dark:     #b91c1c;
    --color-danger-bg:       rgba(239, 68, 68, 0.12);
    --color-danger-border:   rgba(239, 68, 68, 0.35);

    --color-warning:         #f59e0b;
    --color-warning-light:   #fbbf24;
    --color-warning-icon:    #fcd34d;
    --color-warning-pale:    #fde68a;
    --color-warning-yellow:  #eab308;
    --color-warning-gold:    #f59e0b;
    --color-warning-bg:      rgba(245, 158, 11, 0.12);
    --color-warning-border:  rgba(245, 158, 11, 0.35);

    --color-success-bg-light:     rgba(34, 197, 94, 0.06);
    --color-success-border-light: rgba(34, 197, 94, 0.15);
    --color-danger-bg-light:      rgba(239, 68, 68, 0.06);
    --color-danger-border-light:  rgba(239, 68, 68, 0.15);
    --color-warning-bg-light:     rgba(245, 158, 11, 0.06);
    --color-warning-border-light: rgba(245, 158, 11, 0.15);

    --color-info:            #38bdf8;
    --color-info-light:      #7dd3fc;
    --color-info-pale:       #bae6fd;
    --color-info-bg:         rgba(56, 189, 248, 0.1);
    --color-info-border:     rgba(56, 189, 248, 0.25);

    /* ── Arrière-plans ────────────────────────────────────── */
    --bg-body:               #0a0e1a;
    --bg-body-alt:           #0c1020;
    --bg-body-deep:          #050810;
    --bg-card:               #111827;
    --bg-card-dark:          #0a0e1a;
    --bg-card-darker:        #0d1220;
    --bg-card-gradient-start:#141c2e;
    --bg-card-gradient-end:  #0a0e1a;
    --bg-input:              #141c2e;
    --bg-input-alt:          #0f1525;
    --bg-panel:              #0a0e1a;
    --bg-panel-dark:         #070b14;
    --bg-nav-hover:          #1e293b;
    --bg-nav-active:         rgba(59, 130, 246, 0.12);
    --bg-table-row:          #1a2236;

    /* Surfaces semi-transparentes */
    --bg-glass:              rgba(10, 14, 26, 0.9);
    --bg-glass-heavy:        rgba(7, 11, 20, 0.96);
    --bg-glass-light:        rgba(10, 14, 26, 0.98);
    --bg-overlay:            rgba(0, 0, 0, 0.75);
    --bg-overlay-light:      rgba(0, 0, 0, 0.45);
    --bg-subtle-faint:       rgba(255, 255, 255, 0.015);
    --bg-subtle:             rgba(255, 255, 255, 0.03);
    --bg-subtle-hover:       rgba(255, 255, 255, 0.05);
    --bg-subtle-active:      rgba(255, 255, 255, 0.07);
    --bg-subtle-strong:      rgba(255, 255, 255, 0.1);
    --bg-subtle-extra:       rgba(255, 255, 255, 0.13);

    /* ── Texte ────────────────────────────────────────────── */
    --text-primary:          #e2e8f0;
    --text-secondary:        #94a3b8;
    --text-muted:            #64748b;
    --text-dim:              rgba(226, 232, 240, 0.6);
    --text-very-dim:         rgba(226, 232, 240, 0.4);
    --text-hint:             rgba(226, 232, 240, 0.3);
    --text-bright:           rgba(226, 232, 240, 0.9);
    --text-mid:              rgba(226, 232, 240, 0.75);
    --text-faded:            rgba(226, 232, 240, 0.5);
    --text-soft:             #64748b;
    --text-soft-light:       #94a3b8;
    --text-lavender:         #cbd5e1;
    --text-slate:            #64748b;
    --text-slate-light:      #94a3b8;
    --text-cool:             #7b8daf;
    --text-cool-light:       #b0c0d8;
    --text-on-primary:       #ffffff;

    /* ── Bordures ─────────────────────────────────────────── */
    --border-subtle:         rgba(148, 163, 184, 0.06);
    --border-light:          rgba(148, 163, 184, 0.1);
    --border-medium:         rgba(148, 163, 184, 0.15);
    --border-strong:         rgba(148, 163, 184, 0.22);
    --border-card:           rgba(148, 163, 184, 0.08);
    --border-card-inner:     #1e293b;
    --border-input:          #334155;
    --border-muted:          #1e293b;
    --border-danger:         rgba(239, 68, 68, 0.3);

    /* ── Rayons de bordure ────────────────────────────────── */
    --radius-xs:             4px;
    --radius-sm:             6px;
    --radius-md:             8px;
    --radius-lg:             12px;
    --radius-xl:             16px;
    --radius-2xl:            20px;
    --radius-pill:           999px;

    /* ── Ombres ───────────────────────────────────────────── */
    --shadow-xs:             0 1px 3px rgba(0, 0, 0, 0.25);
    --shadow-sm:             0 2px 6px rgba(0, 0, 0, 0.3);
    --shadow-md:             0 4px 12px rgba(0, 0, 0, 0.3);
    --shadow-lg:             0 6px 18px rgba(0, 0, 0, 0.4);
    --shadow-xl:             0 8px 24px rgba(0, 0, 0, 0.45);
    --shadow-2xl:            0 10px 26px rgba(0, 0, 0, 0.55);
    --shadow-primary:        0 4px 12px rgba(59, 130, 246, 0.3);
    --shadow-primary-strong: 0 0 15px rgba(59, 130, 246, 0.35);
    --shadow-success:        0 4px 12px rgba(34, 197, 94, 0.2);
    --shadow-danger:         0 0 15px rgba(239, 68, 68, 0.35);

    /* ── Dégradés ─────────────────────────────────────────── */
    --gradient-primary:      linear-gradient(135deg, #3b82f6, #22d3ee);
    --gradient-accent-blue:  linear-gradient(90deg, #3b82f6, #818cf8);
    --gradient-accent:       linear-gradient(135deg, #3b82f6, #2563eb);
    --gradient-accent-hover: linear-gradient(135deg, #2563eb, #1d4ed8);
    --gradient-accent-dark:  linear-gradient(90deg, #2563eb, #6366f1);
    --gradient-accent-teal:  linear-gradient(90deg, #3b82f6, #2dd4bf);
    --gradient-accent-tri:   linear-gradient(90deg, #2563eb, #3b82f6, #22d3ee);
    --gradient-danger:       linear-gradient(90deg, #ef4444, #dc2626);
    --gradient-success:      linear-gradient(135deg, #22c55e, #10b981);
    --gradient-info:         linear-gradient(135deg, #38bdf8, #0ea5e9);
    --gradient-teal-accent:  linear-gradient(135deg, #2dd4bf, #818cf8);
    --gradient-card:         linear-gradient(145deg, #141c2e, #0a0e1a);
    --gradient-card-hover:   linear-gradient(145deg, #1e293b, #111827);
    --gradient-card-subtle:  linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01));
    --gradient-disabled:     linear-gradient(135deg, #94a3b8, #64748b);
    --gradient-calendar-low:    linear-gradient(145deg, #111d33, #0e1828);
    --gradient-calendar-medium: linear-gradient(145deg, #1e3a6e, #19305e);
    --gradient-calendar-high:   linear-gradient(145deg, #155e75, #164e63);

    /* ── Couleurs graphiques (Chart.js) ──────────────────── */
    --chart-line-1:          #3b82f6;
    --chart-line-2:          #22d3ee;
    --chart-line-3:          #f43f5e;
    --chart-bar-1:           #22d3ee;
    --chart-bar-2:           #3b82f6;
    --chart-bar-3:           #fbbf24;
    --chart-bar-current:     #3b82f6;
    --chart-bar-previous:    rgba(59,130,246,0.35);
    --chart-spent:           #f43f5e;
    --chart-spent-fill:      rgba(244,63,94,0.10);
    --chart-spent-bar:       rgba(244,63,94,0.6);
    --chart-spent-bar-hover: rgba(244,63,94,0.8);
    --chart-alloc:           #818cf8;
    --chart-alloc-bar:       rgba(129,140,248,0.35);
    --chart-alloc-bar-hover: rgba(129,140,248,0.55);
    --chart-tax-due:         rgba(244, 63, 94, 1);
    --chart-tax-smooth:      rgba(34, 211, 238, 1);
    --chart-tax-provision:   rgba(129, 140, 248, 1);
    --chart-forecast-1:      rgba(59, 130, 246, 1);
    --chart-forecast-2:      rgba(244, 63, 94, 1);
    --chart-forecast-3:      rgba(34, 211, 238, 1);
    --chart-forecast-4:      rgba(251, 191, 36, 1);
    --chart-forecast-5:      rgba(129, 140, 248, 1);
    --chart-forecast-1-bg:   rgba(59, 130, 246, 0.2);
    --chart-forecast-2-bg:   rgba(244, 63, 94, 0.2);
    --chart-forecast-3-bg:   rgba(34, 211, 238, 0.2);
    --chart-forecast-4-bg:   rgba(251, 191, 36, 0.2);
    --chart-forecast-5-bg:   rgba(129, 140, 248, 0.2);
    --chart-text:            #cbd5e1;
    --chart-text-muted:      #94a3b8;
    --chart-text-dim:        #64748b;
    --chart-grid:            rgba(255,255,255,0.04);
    --chart-grid-strong:     rgba(255,255,255,0.10);
    --chart-tooltip-bg:      rgba(10,14,26,0.92);
    --chart-tooltip-text:    #f1f5f9;
    --chart-tooltip-border:  #1e3a5f;
    --chart-center-label:    #94a3b8;
    --chart-center-value:    #f1f5f9;
    --chart-datalabel:       #ffffff;
    --chart-palette-hue:     210;

    /* ── Objectifs financiers ─────────────────────────────── */
    --goal-monthly-color:       var(--color-secondary-light);
    --goal-monthly-bg:          rgba(34, 211, 238, 0.1);
    --goal-monthly-border:      rgba(34, 211, 238, 0.25);
    --goal-permanent-color:     var(--color-accent-light);
    --goal-permanent-bg:        rgba(129, 140, 248, 0.1);
    --goal-permanent-border:    rgba(129, 140, 248, 0.25);
    --goal-info-color:          var(--color-info-light);
    --goal-info-bg:             var(--color-info-bg);
    --goal-info-border:         var(--color-info-border);
    --goal-warning-color:       var(--color-warning);
    --goal-warning-bg:          var(--color-warning-bg);
    --goal-warning-border:      var(--color-warning-border);
    --goal-danger-color:        var(--color-danger);
    --goal-danger-bg:           var(--color-danger-bg);
    --goal-danger-border:       var(--color-danger-border);
    --goal-success-color:       var(--color-success-bright);
    --goal-success-bg:          var(--color-success-bg);
    --goal-success-border:      var(--color-success-border);

    /* ── Transitions ──────────────────────────────────────── */
    --transition-fast:       all 0.2s ease;
    --transition-normal:     all 0.3s ease;
    --transition-smooth:     all 0.35s cubic-bezier(0.22, 1, 0.36, 1);

    --duration-fast:         0.2s;
    --duration-normal:       0.3s;
    --duration-smooth:       0.35s;
    --easing-default:        ease;
    --easing-smooth:         cubic-bezier(0.22, 1, 0.36, 1);

    /* ── Sidebar ──────────────────────────────────────────── */
    --sidebar-width:         250px;
    --sidebar-collapsed:     60px;
}
