/* Import des polices Google Fonts */
@import url('https://fonts.googleapis.com/css2?family=Roboto',+sans-serif:wght@300;400;500;600;700&display=swap');

/* Variables CSS personnalisées */
:root {
    --primary-color: #7fbf1f;
    --secondary-color: #05aff2;
    --accent-color: #98e525;
    --background-color: #ffffff;
    --text-color: #333333;
    --border-color: #e0e0e0;
    --shadow-color: rgba(0,0,0,0.15);
    --success-color: #28a745;
    --warning-color: #ffc107;
    --error-color: #dc3545;
    --title-font: 'Roboto', sans-serif', sans-serif;
    --text-font: 'Roboto', sans-serif', sans-serif;
}

/* Classes utilitaires pour les couleurs */
.text-primary { color: var(--primary-color) !important; }
.text-secondary { color: var(--secondary-color) !important; }
.text-accent { color: var(--accent-color) !important; }
.text-success { color: var(--success-color) !important; }
.text-warning { color: var(--warning-color) !important; }
.text-error { color: var(--error-color) !important; }

.bg-primary { background-color: var(--primary-color) !important; }
.bg-secondary { background-color: var(--secondary-color) !important; }
.bg-accent { background-color: var(--accent-color) !important; }
.bg-success { background-color: var(--success-color) !important; }
.bg-warning { background-color: var(--warning-color) !important; }
.bg-error { background-color: var(--error-color) !important; }

.border-primary { border-color: var(--primary-color) !important; }
.border-secondary { border-color: var(--secondary-color) !important; }
.border-accent { border-color: var(--accent-color) !important; }

/* Classes pour les polices */
.font-title { font-family: var(--title-font) !important; }
.font-text { font-family: var(--text-font) !important; }

/* Application des polices par défaut */
h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6 {
    font-family: var(--title-font);
}

body, p, .text, .content {
    font-family: var(--text-font);
}

/* Classes pour les sections flexibles */
.flexible-content-section {
    /* Classe parent pour toutes les sections flexibles */
}

.flexible-content-section.py-5 {
    /* Styles spécifiques pour les sections avec py-5 */
}

/* Boutons avec les couleurs du thème */
.btn-primary {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
}

.btn-primary:hover {
    background-color: var(--secondary-color);
    border-color: var(--secondary-color);
}

.btn-secondary {
    background-color: var(--secondary-color);
    border-color: var(--secondary-color);
}

.btn-accent {
    background-color: var(--accent-color);
    border-color: var(--accent-color);
}

/* Liens avec les couleurs du thème */
a {
    color: var(--primary-color);
}

a:hover {
    color: var(--secondary-color);
}

/* Bordures et ombres */
.border-theme {
    border-color: var(--border-color);
}

.shadow-theme {
    box-shadow: 0 2px 4px var(--shadow-color);
}

/* Messages d'état */
.alert-success {
    background-color: var(--success-color);
    border-color: var(--success-color);
    color: white;
}

.alert-warning {
    background-color: var(--warning-color);
    border-color: var(--warning-color);
    color: #333;
}

.alert-error {
    background-color: var(--error-color);
    border-color: var(--error-color);
    color: white;
}
