:root {
    --bocal-primary: #1a3a5c;
    --bocal-accent:  #e8772e;
}

.bg-bocal {
    background-color: var(--bocal-primary) !important;
}

.navbar-brand {
    letter-spacing: 0.03em;
}

/* Badges débit/crédit */
.badge-debit  { background-color: #dc3545; color: #fff; }
.badge-credit { background-color: #198754; color: #fff; }

/* Cartes dashboard */
.card-stat {
    border: 1px solid #ebebeb;
    border-radius: 6px;
    box-shadow: 0 1px 4px rgba(0,0,0,.05);
    transition: box-shadow .15s;
}
.card-stat:hover {
    box-shadow: 0 3px 10px rgba(0,0,0,.09);
}
.card-stat .stat-label {
    font-size: .68rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .12em;
    color: #adb5bd;
    margin-bottom: .4rem;
}
.card-stat .stat-value {
    font-size: 1.45rem;
    font-weight: 700;
    letter-spacing: -.01em;
    line-height: 1.2;
}
.card-stat .stat-sub {
    font-size: .75rem;
    color: #9ca3af;
    margin-top: .3rem;
}

/* Tableau */
.table th {
    font-size: .8rem;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: #6c757d;
    border-top: none;
}

/* Barres mini-graphe */
.bar-wrap { height: 6px; background: #e9ecef; border-radius: 3px; }
.bar-fill  { height: 6px; border-radius: 3px; transition: width .4s; }
.bar-reversee  { background-color: var(--bocal-accent); }
.bar-deductible { background-color: var(--bocal-primary); }

/* Toggle dépense/recette */
.btn-check:checked + .btn-type-depense  { background-color: #dc3545; color: #fff; border-color: #dc3545; }
.btn-check:checked + .btn-type-recette  { background-color: #198754; color: #fff; border-color: #198754; }

/* Champ montant en lecture seule calculé */
input.calc-field {
    background-color: #f8f9fa;
    font-weight: 600;
}

.footer { position: sticky; top: 100vh; }
