/* Hauteur fixe pour les graphiques */
.chart-container { height: 300px; }

/* Cards indicateurs — compactes */
.card-indicateur .card-body { padding: 0.5rem; }
.card-indicateur .valeur { font-size: 1.4rem; font-weight: 700; line-height: 1.2; }
.card-indicateur .card-title { font-size: 0.8rem; margin-bottom: 0.25rem; }
.card-indicateur .variation { font-size: 0.8rem; }
.card-indicateur .date-maj { font-size: 0.7rem; color: #6c757d; }

/* Bordure colorée selon type */
.card-indicateur-vente { border-left: 3px solid #198754; }
.card-indicateur-achat { border-left: 3px solid #dc3545; }

/* Couleurs métier */
.couleur-favorable { color: #198754; }
.couleur-defavorable { color: #dc3545; }
.couleur-stable { color: #6c757d; }

/* Fonds de cards par catégorie */
.card-cereales { background-color: #f0f7f0; }
.card-maraichage { background-color: #f5f0ff; }
.card-intrants { background-color: #fff5f5; }
.card-hors-saison { background-color: #f8f9fa; opacity: 0.7; }

/* Titres de sections */
.section-cereales { color: #198754; }
.section-maraichage { color: #6f42c1; }
.section-intrants { color: #dc3545; }

/* Marge résultat */
.marge-positive { color: #198754; font-weight: 700; font-size: 1.5rem; }
.marge-negative { color: #dc3545; font-weight: 700; font-size: 1.5rem; }

/* Mobile */
@media (max-width: 768px) {
    .card-indicateur .valeur { font-size: 1.1rem; }
    .chart-container { height: 250px; }
}
