/* ============================================================
   THÈME « Fineas Christmas » — Couche 2 (identité de marque)
   Thème festif de Noël : rouge rubis, vert sapin, or doré,
   surfaces sombres chaleureuses comme un salon au coin du feu.
   ============================================================ */

[data-theme="christmas"] {

    /* ── 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: 220, 38, 38;
    --base-color-for-secondary-glow: 22, 163, 74;

    /* ── Couleurs principales (brand) ─────────────────────── */
    --color-primary:         #dc2626;          /* rouge Noël */
    --color-primary-dark:    #b91c1c;
    --color-primary-darker:  #991b1b;
    --color-primary-light:   #ef4444;
    --color-primary-lighter: #f87171;
    --color-primary-pale:    #fca5a5;
    --color-primary-glow:    rgba(220, 38, 38, 0.35);

    --color-secondary:       #16a34a;          /* vert sapin */
    --color-secondary-dark:  #15803d;
    --color-secondary-light: #22c55e;
    --color-secondary-pale:  #4ade80;

    --color-accent:          #d97706;           /* or doré */
    --color-accent-light:    #f59e0b;
    --color-accent-pale:     #fbbf24;

    --color-teal:            #22c55e;
    --color-cyan:            #fbbf24;           /* or clair */

    /* ── Couleurs sémantiques ─────────────────────────────── */
    --color-success:         #22c55e;
    --color-success-bright:  #4ade80;
    --color-success-light:   #86efac;
    --color-success-pale:    #bbf7d0;
    --color-success-dark:    #15803d;
    --color-success-bg:      rgba(34, 197, 94, 0.15);
    --color-success-border:  rgba(34, 197, 94, 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(34, 197, 94, 0.08);
    --color-success-border-light: rgba(34, 197, 94, 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:            #3b82f6;
    --color-info-light:      #60a5fa;
    --color-info-pale:       #93c5fd;
    --color-info-bg:         rgba(59, 130, 246, 0.12);
    --color-info-border:     rgba(59, 130, 246, 0.3);

    /* ── Arrière-plans ────────────────────────────────────── */
    --bg-body:               #14120f;           /* bois sombre chaud */
    --bg-body-alt:           #1a1712;
    --bg-body-deep:          #0a0908;
    --bg-card:               #221e18;
    --bg-card-dark:          #18150f;
    --bg-card-darker:        #100e0a;
    --bg-card-gradient-start:#261f16;
    --bg-card-gradient-end:  #14120f;
    --bg-input:              #1e1b14;
    --bg-input-alt:          #15130e;
    --bg-panel:              #1a1712;
    --bg-panel-dark:         #110f0b;
    --bg-nav-hover:          #2c261e;
    --bg-nav-active:         rgba(220, 38, 38, 0.12);
    --bg-table-row:          #221e18;

    /* Surfaces semi-transparentes */
    --bg-glass:              rgba(20, 18, 15, 0.9);
    --bg-glass-heavy:        rgba(10, 9, 8, 0.95);
    --bg-glass-light:        rgba(26, 23, 18, 0.98);
    --bg-overlay:            rgba(0, 0, 0, 0.75);
    --bg-overlay-light:      rgba(0, 0, 0, 0.45);
    --bg-subtle-faint:       rgba(220, 38, 38, 0.02);
    --bg-subtle:             rgba(220, 38, 38, 0.04);
    --bg-subtle-hover:       rgba(220, 38, 38, 0.07);
    --bg-subtle-active:      rgba(220, 38, 38, 0.10);
    --bg-subtle-strong:      rgba(220, 38, 38, 0.14);
    --bg-subtle-extra:       rgba(220, 38, 38, 0.18);

    /* ── Texte ────────────────────────────────────────────── */
    --text-primary:          #fef2f2;           /* blanc neige rosé */
    --text-secondary:        #e8d8c8;           /* parchemin doré */
    --text-muted:            #b8a898;
    --text-dim:              rgba(254, 242, 242, 0.6);
    --text-very-dim:         rgba(254, 242, 242, 0.4);
    --text-hint:             rgba(254, 242, 242, 0.3);
    --text-bright:           rgba(254, 242, 242, 0.9);
    --text-mid:              rgba(254, 242, 242, 0.75);
    --text-faded:            rgba(254, 242, 242, 0.5);
    --text-soft:             #c8b8a0;
    --text-soft-light:       #e0d0b8;
    --text-lavender:         #fbbf24;           /* dorure */
    --text-slate:            #b8a898;
    --text-slate-light:      #d8c8b0;
    --text-cool:             #22c55e;
    --text-cool-light:       #86efac;
    --text-on-primary:       #ffffff;

    /* ── Bordures ─────────────────────────────────────────── */
    --border-subtle:         rgba(217, 119, 6, 0.08);
    --border-light:          rgba(217, 119, 6, 0.12);
    --border-medium:         rgba(217, 119, 6, 0.18);
    --border-strong:         rgba(217, 119, 6, 0.25);
    --border-card:           rgba(217, 119, 6, 0.06);
    --border-card-inner:     #2c261e;
    --border-input:          #3a3020;
    --border-muted:          #2c261e;
    --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.25);
    --shadow-sm:             0 2px 6px rgba(0, 0, 0, 0.30);
    --shadow-md:             0 4px 12px rgba(0, 0, 0, 0.30);
    --shadow-lg:             0 6px 18px rgba(0, 0, 0, 0.40);
    --shadow-xl:             0 8px 24px rgba(0, 0, 0, 0.45);
    --shadow-2xl:            0 10px 26px rgba(0, 0, 0, 0.50);
    --shadow-primary:        0 4px 12px rgba(220, 38, 38, 0.30);
    --shadow-primary-strong: 0 0 15px rgba(220, 38, 38, 0.40);
    --shadow-success:        0 4px 12px rgba(34, 197, 94, 0.25);
    --shadow-danger:         0 0 15px rgba(239, 68, 68, 0.45);

    /* ── Dégradés ─────────────────────────────────────────── */
    --gradient-primary:      linear-gradient(135deg, #dc2626, #16a34a);
    --gradient-accent-blue:  linear-gradient(90deg, #dc2626, #d97706);
    --gradient-accent:       linear-gradient(135deg, #dc2626, #b91c1c);
    --gradient-accent-hover: linear-gradient(135deg, #b91c1c, #991b1b);
    --gradient-accent-dark:  linear-gradient(90deg, #991b1b, #15803d);
    --gradient-accent-teal:  linear-gradient(90deg, #dc2626, #fbbf24);
    --gradient-accent-tri:   linear-gradient(90deg, #dc2626, #d97706, #16a34a);
    --gradient-danger:       linear-gradient(90deg, #ef4444, #dc2626);
    --gradient-success:      linear-gradient(135deg, #15803d, #22c55e);
    --gradient-info:         linear-gradient(135deg, #3b82f6, #2563eb);
    --gradient-teal-accent:  linear-gradient(135deg, #22c55e, #d97706);
    --gradient-card:         linear-gradient(145deg, #261f16, #14120f);
    --gradient-card-hover:   linear-gradient(145deg, #302818, #221e18);
    --gradient-card-subtle:  linear-gradient(180deg, rgba(217, 119, 6, 0.04), rgba(217, 119, 6, 0.02));
    --gradient-disabled:     linear-gradient(135deg, #8a8070, #605848);
    --gradient-calendar-low:    linear-gradient(145deg, #1a1712, #15130e);
    --gradient-calendar-medium: linear-gradient(145deg, #2a1510, #1f100d);
    --gradient-calendar-high:   linear-gradient(145deg, #0f2a15, #0d1f10);

    /* ── Couleurs graphiques (Chart.js) ──────────────────── */
    --chart-line-1:          #dc2626;
    --chart-line-2:          #22c55e;
    --chart-line-3:          #d97706;
    --chart-bar-1:           #22c55e;
    --chart-bar-2:           #dc2626;
    --chart-bar-3:           #d97706;
    --chart-bar-current:     #dc2626;
    --chart-bar-previous:    rgba(220,38,38,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:           #22c55e;
    --chart-alloc-bar:       rgba(34,197,94,0.35);
    --chart-alloc-bar-hover: rgba(34,197,94,0.55);
    --chart-tax-due:         rgba(220, 38, 38, 1);
    --chart-tax-smooth:      rgba(34, 197, 94, 1);
    --chart-tax-provision:   rgba(217, 119, 6, 1);
    --chart-forecast-1:      rgba(220, 38, 38, 1);
    --chart-forecast-2:      rgba(34, 197, 94, 1);
    --chart-forecast-3:      rgba(217, 119, 6, 1);
    --chart-forecast-4:      rgba(251, 191, 36, 1);
    --chart-forecast-5:      rgba(59, 130, 246, 1);
    --chart-forecast-1-bg:   rgba(220, 38, 38, 0.2);
    --chart-forecast-2-bg:   rgba(34, 197, 94, 0.2);
    --chart-forecast-3-bg:   rgba(217, 119, 6, 0.2);
    --chart-forecast-4-bg:   rgba(251, 191, 36, 0.2);
    --chart-forecast-5-bg:   rgba(59, 130, 246, 0.2);
    --chart-text:            #e8d8c8;
    --chart-text-muted:      #b8a898;
    --chart-text-dim:        #8a7868;
    --chart-grid:            rgba(217,119,6,0.06);
    --chart-grid-strong:     rgba(217,119,6,0.12);
    --chart-tooltip-bg:      rgba(10,9,8,0.92);
    --chart-tooltip-text:    #fef2f2;
    --chart-tooltip-border:  #3a3020;
    --chart-center-label:    #b8a898;
    --chart-center-value:    #fef2f2;
    --chart-datalabel:       #ffffff;
    --chart-palette-hue:     0;

    /* ── Objectifs financiers ─────────────────────────────── */
    --goal-monthly-color:       var(--color-secondary-light);
    --goal-monthly-bg:          rgba(22, 163, 74, 0.15);
    --goal-monthly-border:      rgba(22, 163, 74, 0.3);
    --goal-permanent-color:     var(--color-primary-light);
    --goal-permanent-bg:        rgba(220, 38, 38, 0.15);
    --goal-permanent-border:    rgba(220, 38, 38, 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;
}
