:root {
            --primary-color: #004494;    /* Bleu CEN Lorraine */
			--success-color: #79B51C;    /* Vert CEN Lorraine */
			--warning-color: #D77A0E;    /* Orange CEN Lorraine */
            --secondary-color: #79B51C;
            --accent-color: #EAB308;
			--info-color: #06B6D4;
            --light-gray: #F8F9FA;
			--bg-gray: #F9FAFB;
        }

body {
	font-family: 'Roboto', sans-serif;
	background-color: var(--bg-gray) !important;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    color: #27314f;
}

/* couleurs de fond */
.bg-primary {
    background-color: var(--primary-color) !important;
}

.bg-success {
    background-color: var(--success-color) !important;
}

.bg-warning {
    background-color: var(--warning-color) !important;
}

/* couleurs des textes pour le contraste */
.text-primary {
    color: var(--primary-color) !important;
}

.text-success {
    color: var(--success-color) !important;
}

.text-warning {
    color: var(--warning-color) !important;
}

/* Variantes d'opacité pour bg-opacity */
.bg-primary.bg-opacity-10 {
    background-color: rgba(0, 68, 148, 0.1) !important;
}

.bg-success.bg-opacity-10 {
    background-color: rgba(121, 181, 28, 0.1) !important;
}

.bg-warning.bg-opacity-10 {
    background-color: rgba(215, 122, 14, 0.1) !important;
}

/* Boutons */
.btn-primary {
    background-color: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
}

.btn-success {
    background-color: var(--success-color) !important;
    border-color: var(--success-color) !important;
}

.btn-warning {
    background-color: var(--warning-color) !important;
    border-color: var(--warning-color) !important;
}

/* Bordures */
.border-primary {
    border-color: var(--primary-color) !important;
}

.border-success {
    border-color: var(--success-color) !important;
}

.border-warning {
    border-color: var(--warning-color) !important;
}

/* Navbar style */
.navbar {
	background-color: white;
	padding-top: 1rem !important;
	padding-bottom: 1rem !important;
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

.navbar-brand {
	color: white !important;
	font-weight: bold;
	}

.nav-link {
	color: #27314f !important;
	font-weight: bold;
}
		
.nav-pills .nav-link.active, .nav-pills .show>.nav-link {
	color: white !important; 
	background-color: var(--primary-color) !important;
	}

@media (min-width: 992px) {
	.navbar-brand {
		margin-right: 3rem; /* Augmenter l'espace après le logo */
	}
            
	#navbarNav {
		margin-left: -10rem; /* Décalage négatif pour ramener le menu vers la gauche */
	}
            
	.navbar-nav {
		margin-left: auto; /* Pour pousser les éléments du menu vers la gauche de l'espace disponible */
	}
}

	
/* card style */
.hover-card {
            transition: transform 0.3s ease, box-shadow 0.3s ease;
        }
        
        .hover-card:hover {
            transform: translateY(-5px);
            box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1) !important;
        }
        
        .card {
            border-radius: 0.5rem;
            overflow: hidden;
        }

/* divers style */
.footer {
            background-color: var(--primary-color);
            color: #fff;
            padding: 3rem 0;
        }
        
        .footer a {
            color: rgba(255, 255, 255, 0.8);
            text-decoration: none;
        }
        
        .footer a:hover {
            color: #fff;
        }
        
        .breadcrumb-item a {
            color: var(--primary-color);
        }
        
        .page-link {
            color: var(--primary-color);
        }
        
        .page-item.active .page-link {
            background-color: var(--primary-color);
            border-color: var(--primary-color);
        }
		
		.form-control img,
		.card-body img,
		.objectifs-content img {
			max-width: 100% !important;
			height: auto !important;
		}

/* Styles pour les cartes de statistiques */
.card {
    transition: all 0.3s ease;
    overflow: hidden;
}

.card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1) !important;
}

/* Animation d'entrée pour les cartes */
.stats-card-animated {
    opacity: 0;
    animation: fadeInUp 0.6s ease-out forwards;
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Décalage des animations pour un effet séquentiel */
.row-cols-lg-4 .card:nth-child(1) {
    animation-delay: 0.1s;
}
.row-cols-lg-4 .card:nth-child(2) {
    animation-delay: 0.2s;
}
.row-cols-lg-4 .card:nth-child(3) {
    animation-delay: 0.3s;
}
.row-cols-lg-4 .card:nth-child(4) {
    animation-delay: 0.4s;
}

/* Effets visuels pour les indicateurs chiffrés */
.rounded-circle {
    transition: all 0.3s ease;
}

.card:hover .rounded-circle {
    transform: scale(1.1);
}

/* Style pour les compteurs animés */
.counter-animate {
    transition: all 0.2s ease;
    position: relative;
}

/* Style spécifique pour la carte de mètres linéaires */
.special-entry {
    position: relative;
    overflow: hidden;
}

.special-entry::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 4px;
    background: linear-gradient(to right, transparent, var(--secondary-color), transparent);
    animation: slideLine 2s ease-in-out infinite;
}

@keyframes slideLine {
    0% {
        left: -100%;
    }
    50% {
        left: 100%;
    }
    100% {
        left: 100%;
    }
}

/* Renforcement visuel des statistiques importantes */
.text-warning, .text-secondary {
    text-shadow: 0 0 1px rgba(0, 0, 0, 0.1);
}

/* Style pour la carte des mètres linéaires */
.special-entry {
    border-top: 3px solid var(--secondary-color);
}

/* Animation des compteurs */
.counter-animate {
    display: inline-block;
    position: relative;
}

.counter-animate::after {
    content: "";
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: currentColor;
    opacity: 0.3;
}

/* Styles pour les filtres avancés */
#advancedFilters {
    transition: all 0.3s ease;
    padding: 15px;
    background-color: #f8f9fa;
    border-radius: 8px;
    margin-top: 15px;
}

#toggleAdvancedFilters {
    font-size: 0.9rem;
    font-weight: 500;
    transition: all 0.2s ease;
    text-decoration: none;
}

#toggleAdvancedFilters:hover {
    color: var(--primary-color) !important;
}

/* Style pour indiquer quand des filtres avancés sont actifs */
.filters-active {
    background-color: #e6f7ff !important;
    border-left: 3px solid var(--primary-color);
}

/* Animation de transition pour l'ouverture/fermeture */
@keyframes slideDown {
    from { opacity: 0; transform: translateY(-10px); }
    to { opacity: 1; transform: translateY(0); }
}

.animate-filters {
    animation: slideDown 0.3s ease-out;
}

/* Responsive styles pour les filtres sur mobile */
@media (max-width: 768px) {
    #advancedFilters .row > div {
        margin-bottom: 10px;
    }
    
    #toggleAdvancedFilters {
        width: 100%;
        text-align: center;
        padding: 10px;
        background-color: #f8f9fa;
        border-radius: 5px;
        margin-top: 10px;
    }
    
    .filters-active {
        border-left: none;
        border-top: 3px solid var(--primary-color);
    }
}