/* ============================================================
   THÈME « Fineas Lunar » — Couche 2 (identité de marque)
   Thème du Nouvel An chinois, année du Cheval 🐴
   Rouge impérial, or dynastique, jade, surfaces laque noire.
   ============================================================ */

[data-theme="lunar"] {

    /* ── 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: 190, 18, 60;
    --base-color-for-secondary-glow: 217, 119, 6;

    /* ── Couleurs principales (brand) ─────────────────────── */
    --color-primary:         #be123c;          /* rouge impérial */
    --color-primary-dark:    #9f1239;
    --color-primary-darker:  #881337;
    --color-primary-light:   #e11d48;
    --color-primary-lighter: #fb7185;
    --color-primary-pale:    #fda4af;
    --color-primary-glow:    rgba(190, 18, 60, 0.35);

    --color-secondary:       #d97706;          /* or dynastique */
    --color-secondary-dark:  #b45309;
    --color-secondary-light: #f59e0b;
    --color-secondary-pale:  #fbbf24;

    --color-accent:          #059669;           /* jade impérial */
    --color-accent-light:    #10b981;
    --color-accent-pale:     #34d399;

    --color-teal:            #10b981;
    --color-cyan:            #fbbf24;           /* or clair */

    /* ── Couleurs sémantiques ─────────────────────────────── */
    --color-success:         #10b981;
    --color-success-bright:  #34d399;
    --color-success-light:   #6ee7b7;
    --color-success-pale:    #a7f3d0;
    --color-success-dark:    #047857;
    --color-success-bg:      rgba(16, 185, 129, 0.15);
    --color-success-border:  rgba(16, 185, 129, 0.4);

    --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.15);
    --color-danger-border:   rgba(239, 68, 68, 0.4);

    --color-warning:         #f59e0b;
    --color-warning-light:   #fbbf24;
    --color-warning-icon:    #fde047;
    --color-warning-pale:    #fef08a;
    --color-warning-yellow:  #fbbf24;
    --color-warning-gold:    #d97706;
    --color-warning-bg:      rgba(245, 158, 11, 0.15);
    --color-warning-border:  rgba(245, 158, 11, 0.4);

    --color-success-bg-light:     rgba(16, 185, 129, 0.08);
    --color-success-border-light: rgba(16, 185, 129, 0.2);
    --color-danger-bg-light:      rgba(239, 68, 68, 0.08);
    --color-danger-border-light:  rgba(239, 68, 68, 0.2);
    --color-warning-bg-light:     rgba(245, 158, 11, 0.08);
    --color-warning-border-light: rgba(245, 158, 11, 0.2);

    --color-info:            #0ea5e9;
    --color-info-light:      #38bdf8;
    --color-info-pale:       #7dd3fc;
    --color-info-bg:         rgba(14, 165, 233, 0.12);
    --color-info-border:     rgba(14, 165, 233, 0.3);

    /* ── Arrière-plans ────────────────────────────────────── */
    --bg-body:               #0c0a08;           /* laque noire */
    --bg-body-alt:           #120e0a;
    --bg-body-deep:          #060504;
    --bg-card:               #1c1510;
    --bg-card-dark:          #120e0a;
    --bg-card-darker:        #0a0806;
    --bg-card-gradient-start:#201810;
    --bg-card-gradient-end:  #0c0a08;
    --bg-input:              #1a1410;
    --bg-input-alt:          #110d0a;
    --bg-panel:              #120e0a;
    --bg-panel-dark:         #0a0806;
    --bg-nav-hover:          #2a2018;
    --bg-nav-active:         rgba(190, 18, 60, 0.14);
    --bg-table-row:          #1c1510;

    /* Surfaces semi-transparentes */
    --bg-glass:              rgba(12, 10, 8, 0.92);
    --bg-glass-heavy:        rgba(6, 5, 4, 0.95);
    --bg-glass-light:        rgba(18, 14, 10, 0.98);
    --bg-overlay:            rgba(0, 0, 0, 0.78);
    --bg-overlay-light:      rgba(0, 0, 0, 0.48);
    --bg-subtle-faint:       rgba(190, 18, 60, 0.025);
    --bg-subtle:             rgba(190, 18, 60, 0.05);
    --bg-subtle-hover:       rgba(190, 18, 60, 0.08);
    --bg-subtle-active:      rgba(190, 18, 60, 0.12);
    --bg-subtle-strong:      rgba(217, 119, 6, 0.12);
    --bg-subtle-extra:       rgba(217, 119, 6, 0.16);

    /* ── Texte ────────────────────────────────────────────── */
    --text-primary:          #fef3e2;           /* soie crème dorée */
    --text-secondary:        #e8d5b8;
    --text-muted:            #b8a088;
    --text-dim:              rgba(254, 243, 226, 0.6);
    --text-very-dim:         rgba(254, 243, 226, 0.4);
    --text-hint:             rgba(254, 243, 226, 0.3);
    --text-bright:           rgba(254, 243, 226, 0.9);
    --text-mid:              rgba(254, 243, 226, 0.75);
    --text-faded:            rgba(254, 243, 226, 0.5);
    --text-soft:             #c8a880;
    --text-soft-light:       #dcc0a0;
    --text-lavender:         #fbbf24;           /* or lumineux */
    --text-slate:            #b8a088;
    --text-slate-light:      #d8c0a0;
    --text-cool:             #10b981;           /* jade */
    --text-cool-light:       #6ee7b7;
    --text-on-primary:       #fef3e2;

    /* ── Bordures ─────────────────────────────────────────── */
    --border-subtle:         rgba(217, 119, 6, 0.08);
    --border-light:          rgba(217, 119, 6, 0.14);
    --border-medium:         rgba(217, 119, 6, 0.20);
    --border-strong:         rgba(217, 119, 6, 0.28);
    --border-card:           rgba(190, 18, 60, 0.08);
    --border-card-inner:     #2a2018;
    --border-input:          #3a2a18;
    --border-muted:          #2a2018;
    --border-danger:         rgba(239, 68, 68, 0.35);

    /* ── 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.30);
    --shadow-sm:             0 2px 6px rgba(0, 0, 0, 0.35);
    --shadow-md:             0 4px 12px rgba(0, 0, 0, 0.35);
    --shadow-lg:             0 6px 18px rgba(0, 0, 0, 0.45);
    --shadow-xl:             0 8px 24px rgba(0, 0, 0, 0.50);
    --shadow-2xl:            0 10px 26px rgba(0, 0, 0, 0.55);
    --shadow-primary:        0 4px 12px rgba(190, 18, 60, 0.30);
    --shadow-primary-strong: 0 0 15px rgba(190, 18, 60, 0.40);
    --shadow-success:        0 4px 12px rgba(16, 185, 129, 0.25);
    --shadow-danger:         0 0 15px rgba(239, 68, 68, 0.45);

    /* ── Dégradés ─────────────────────────────────────────── */
    --gradient-primary:      linear-gradient(135deg, #be123c, #d97706);
    --gradient-accent-blue:  linear-gradient(90deg, #be123c, #059669);
    --gradient-accent:       linear-gradient(135deg, #be123c, #9f1239);
    --gradient-accent-hover: linear-gradient(135deg, #9f1239, #881337);
    --gradient-accent-dark:  linear-gradient(90deg, #881337, #b45309);
    --gradient-accent-teal:  linear-gradient(90deg, #d97706, #059669);
    --gradient-accent-tri:   linear-gradient(90deg, #be123c, #d97706, #059669);
    --gradient-danger:       linear-gradient(90deg, #ef4444, #dc2626);
    --gradient-success:      linear-gradient(135deg, #047857, #10b981);
    --gradient-info:         linear-gradient(135deg, #0ea5e9, #0284c7);
    --gradient-teal-accent:  linear-gradient(135deg, #10b981, #d97706);
    --gradient-card:         linear-gradient(145deg, #201810, #0c0a08);
    --gradient-card-hover:   linear-gradient(145deg, #2a2018, #1c1510);
    --gradient-card-subtle:  linear-gradient(180deg, rgba(217, 119, 6, 0.04), rgba(190, 18, 60, 0.02));
    --gradient-disabled:     linear-gradient(135deg, #8a7868, #605040);
    --gradient-calendar-low:    linear-gradient(145deg, #120e0a, #0e0c08);
    --gradient-calendar-medium: linear-gradient(145deg, #2a1810, #1f120d);
    --gradient-calendar-high:   linear-gradient(145deg, #0f2a18, #0d1f12);

    /* ── Couleurs graphiques (Chart.js) ──────────────────── */
    --chart-line-1:          #be123c;
    --chart-line-2:          #d97706;
    --chart-line-3:          #059669;
    --chart-bar-1:           #d97706;
    --chart-bar-2:           #be123c;
    --chart-bar-3:           #059669;
    --chart-bar-current:     #be123c;
    --chart-bar-previous:    rgba(190,18,60,0.35);
    --chart-spent:           #d97706;
    --chart-spent-fill:      rgba(217,119,6,0.10);
    --chart-spent-bar:       rgba(217,119,6,0.6);
    --chart-spent-bar-hover: rgba(217,119,6,0.8);
    --chart-alloc:           #059669;
    --chart-alloc-bar:       rgba(5,150,105,0.35);
    --chart-alloc-bar-hover: rgba(5,150,105,0.55);
    --chart-tax-due:         rgba(190, 18, 60, 1);
    --chart-tax-smooth:      rgba(217, 119, 6, 1);
    --chart-tax-provision:   rgba(5, 150, 105, 1);
    --chart-forecast-1:      rgba(190, 18, 60, 1);
    --chart-forecast-2:      rgba(217, 119, 6, 1);
    --chart-forecast-3:      rgba(5, 150, 105, 1);
    --chart-forecast-4:      rgba(251, 191, 36, 1);
    --chart-forecast-5:      rgba(14, 165, 233, 1);
    --chart-forecast-1-bg:   rgba(190, 18, 60, 0.2);
    --chart-forecast-2-bg:   rgba(217, 119, 6, 0.2);
    --chart-forecast-3-bg:   rgba(5, 150, 105, 0.2);
    --chart-forecast-4-bg:   rgba(251, 191, 36, 0.2);
    --chart-forecast-5-bg:   rgba(14, 165, 233, 0.2);
    --chart-text:            #e8d5b8;
    --chart-text-muted:      #b8a088;
    --chart-text-dim:        #8a7060;
    --chart-grid:            rgba(217,119,6,0.06);
    --chart-grid-strong:     rgba(217,119,6,0.12);
    --chart-tooltip-bg:      rgba(6,5,4,0.92);
    --chart-tooltip-text:    #fef3e2;
    --chart-tooltip-border:  #3a2a18;
    --chart-center-label:    #b8a088;
    --chart-center-value:    #fef3e2;
    --chart-datalabel:       #ffffff;
    --chart-palette-hue:     15;

    /* ── Objectifs financiers ─────────────────────────────── */
    --goal-monthly-color:       var(--color-secondary-light);
    --goal-monthly-bg:          rgba(217, 119, 6, 0.15);
    --goal-monthly-border:      rgba(217, 119, 6, 0.3);
    --goal-permanent-color:     var(--color-primary-light);
    --goal-permanent-bg:        rgba(190, 18, 60, 0.15);
    --goal-permanent-border:    rgba(190, 18, 60, 0.3);
    --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;
}
