
.table-grid {
    display: flex;         /* Active le mode Flexbox */
    flex-wrap: wrap;       /* Permet de passer à la ligne sur petit écran (mobile) */            /* Crée un espace entre les tableaux */
    justify-content: space-evenly ; /* Aligne les tableaux aux extrémités */
    padding: 20px;
}

/* Chaque bloc contenant un tableau */
.table-item {
    flex: 1;               /* Force les tableaux à prendre la même largeur */
    min-width: 400px;      /* Largeur minimum avant de passer à la ligne */
    background: white;
    padding: 15px;
    border-radius: 8px;
}
/* Conteneur pour permettre le scroll horizontal sur mobile */
.table-container {
    overflow-x: auto;
    margin: 20px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
    border-radius: 10px;
    max-height: max-content;
}

.table-title {
    text-align: center;
}

.service-table {
    display: flex;
}

.modern-table {
    width: 100%;
    border-collapse: collapse; /* Supprime les doubles bordures */
    background-color: white;
    font-family: 'Segoe UI', sans-serif;
    min-width: 600px;
}

/* Style de l'en-tête */
.modern-table thead tr {
    background-color: #2c3e50;
    color: #ffffff;
    text-align: center;
    font-weight: bold;
}

.modern-table th, 
.modern-table td {
    padding: 15px 20px;
    text-align: center;
}

/* Style des lignes du corps */
.modern-table tbody tr {
    border-bottom: 1px solid #dddddd;
    transition: background-color 0.2s ease;
}

/* Effet "Zèbre" (une ligne sur deux) */
.modern-table tbody tr:nth-of-type(even) {
    background-color: #f8f9fa;
}

/* Effet de survol (Hover) */
.modern-table tbody tr:hover {
    background-color: #f1f4f9;
    cursor: pointer;
}

/* Style de la dernière ligne (pour finir proprement) */
.modern-table tbody tr:last-of-type {
    border-bottom: 2px solid #3498db;
}

/* Bonus : Petits badges de statut */
.badge {
    padding: 5px 10px;
    border-radius: 20px;
    font-size: 0.85rem;
    font-weight: 500;
}
.success { background-color: #d4edda; color: #155724; }
.warning { background-color: #fff3cd; color: #856404; }

.chart-container {
    padding: 20px;
    background: #fff;
    border-radius: 10px;
    box-shadow: 0 4px 15px rgba(0,0,0,0.1);
    max-width: 500px;
    margin: 20px auto;
    padding-bottom: 50px;
}

.chart-title {
    text-align: center;
    font-family: sans-serif;
    color: #2c3e50;
}

.bar-chart {
    display: flex;
    align-items: flex-end; /* Aligne les bâtons en bas */
    justify-content: space-around;
    text-align: center;
    height: 200px; /* Hauteur fixe du graphique */
    padding-top: 20px;
    border-bottom: 2px solid #333;
}

.bar {
    width: 40px;
    background: #3498db;
    height: var(--size); /* Utilise la variable définie en HTML */
    position: relative;
    border-radius: 5px 5px 0 0;
    transition: background 0.3s, height 1s ease-out;
}

.bar:hover {
    background: #2980b9;
}

/* Texte à l'intérieur du bâton */
.bar span {
    position: absolute;
    top: -25px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 12px;
    font-weight: bold;
    font-family: sans-serif;
}

/* Label sous le bâton (Mois) */
.bar::after {
    content: attr(data-label);
    position: absolute;
    bottom: -50px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 14px;
    color: #7f8c8d;
}

.dashboard-row {
    display: flex;
    flex-wrap: wrap; /* Important pour le mobile */
    gap: 30px;       /* Espace entre le tableau et le graphique */
    padding: 20px;
    align-items: flex-start; /* Aligne les hauts des blocs */
}

.dashboard-item {
    flex: 1;           /* Les deux blocs prennent la même largeur */
    min-width: 450px;  /* En dessous de 450px, ils s'empilent l'un sur l'autre */
    background: #ffffff;
    padding: 20px;
    border-radius: 12px;
    box-shadow: 0 5px 15px rgba(0,0,0,0.05);
}

.dashboard-item h3,
.form-lien h2 {

    font-family: 'Segoe UI', sans-serif;
    color: #2c3e50;
    padding-left: 10px;
}

.form-container {
    padding: 20px;
    display: flex; /* Pour qu'il ne prenne pas toute la largeur */
    justify-content: center;;
    position: sticky;
    top: 100px; /* La hauteur de la navbar */
    z-index: 999;
    background: #fff;
    align-items: center;
}

.modern-form label {
    display: block;
    font-weight: 600;
    color: #2c3e50;
    font-family: sans-serif;
}

.modern-form {
    margin-right: 10px;
}
.form-item{
    padding: 10px;
}

.form-lien {
    display: flex;
    align-items: center;
}

.form-item-container {
    display: inherit;
    overflow-y: scroll;
    max-width: 700px;
}

.input-wrapper {
    display: flex;
    gap: 10px;
    align-items: center;
}

/* Style de l'input mois */
input[type="month"], #id_site {
    padding: 10px 15px;
    border: 2px solid #e0e6ed;
    border-radius: 8px;
    font-size: 1rem;
    color: #333;
    outline: none;
    transition: border-color 0.3s, box-shadow 0.3s;
    font-family: inherit;
}



input[type="month"]:focus {
    border-color: var(--hover-color);
    box-shadow: 0 0 0 3px rgba(52, 152, 219, 0.2);
}


.login-submit,
.user-create
 {
    background-color: var(--accent-color);
    color: #fff;
}

/* Bouton stylisé */
input[type="submit"] ,
.user-create,
.form-item a {
    
    border: none;
    padding: 10px 20px;
    border-radius: 8px;
    font-weight: bold;
    cursor: pointer;
    transition: background 0.3s, transform 0.2s;
}


.input-wrapper input[type="submit"]{
    background-color: #2a81bb;
    color: #fff;
}

input[type="submit"]:hover ,
.user-create:hover {
    background-color: var(--hover-color);
    transform: translateY(-2px);
}

.input[type="submit"]:active {
    transform: translateY(0);
}

.service-section {
    scroll-margin-top: 190px;
}

.service-section h2 {
    padding: 10px;
    background: var(--accent-color);
    border-radius: 10px;
    color: #fff;
    text-align: center;
    width: 700px;
    justify-self: center;
}

.login-form {
    display: flex;
  margin: 70px; /* Centre horizontalement */
  align-items: center;     /* Centre verticalement */
    
  min-height: 100vh;       /* Prend toute la hauteur de l'écran */
  font-family: sans-serif;
  flex-direction: column;
    width: 600px;
    justify-self: center;
}
.errorlist {
    color: red;
}

.helptext {
    font-size: 13px;
}

#id_password2_helptext {
    display: none;
}

.login-form form {
background: #80808012;
  padding: 2.5rem;
  border-radius: 10px;
  width: 100%;
  max-width: 400px; /* Évite que le formulaire soit trop large sur PC */
  display: flex;
  flex-direction: column;
  gap: 1.5rem; /* Espace automatique entre les éléments */
min-width: 600px;
border-radius: 0 0 10px 10px;
}
.login-form h2 {
    text-align: center;
    background-color: var(--accent-color);
    width: 600px;
    border-radius: 10px 10px 0 0;
    color: #fff;
}

.login-form input, 
.login-form label,
.login-form select {
    justify-self: center;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.login-form input[type='text'],
.login-form input[type='password'],
.login-form input[type='email']
 {
    border: 1px solid #0082b0;
    border-radius: 5px;
    height: 25px;
}


.login-form label {
    margin-bottom: 10px;
   /* color: var(--accent-color); */
    font-size: 20px;
}

.login-form ul {
    list-style-type: None;
}
.btn-top {
    color: var(--accent-color);
}

.dashboard-link {
    color: var(--accent-color)
    
}

.form-item:hover {
    font-style: oblique;
}
.donne-vide {
    justify-self: center;
    margin-top: 20px;
}

.donuts-chart-container {
            background-color: white;
            padding: 30px;
            border-radius: 15px;
            box-shadow: 0 10px 25px rgba(0,0,0,0.1);
            text-align: center;
            width: 350px;
        }

        .donuts-chart-title {
            margin-top: 0;
            margin-bottom: 25px;
            color: #333;
            font-size: 1.5rem;
        }

        /* --- LE GRAPHIQUE (La Magie CSS) --- */
        .donuts-chart {
            /* 1. Taille et Forme */
            width: 200px;
            height: 200px;
            margin: 0 auto 25px auto; /* Centré horizontalement */
            border-radius: 50%;
            
            /* 2. Le fond gris par défaut (100%) */
            background-color: #eee;

            /* 3. Le dégradé conique (Calcul des segments) */
            /* Syntaxe : couleur position_début, couleur position_fin */
            background-image: conic-gradient(
    /* Segment 1 */
                var(--color-1) 0 calc(var(--percent-1) * 1%),
    /* Segment 2 */
            var(--color-2) calc(var(--percent-1) * 1%) calc((var(--percent-1) + var(--percent-2)) * 1%),
    /* Segment 3 */
    var(--color-3) calc((var(--percent-1) + var(--percent-2)) * 1%) calc((var(--percent-1) + var(--percent-2) + var(--percent-3)) * 1%),
    /* Segment 4 */
    var(--color-4) calc((var(--percent-1) + var(--percent-2) + var(--percent-3)) * 1%) calc((var(--percent-1) + var(--percent-2) + var(--percent-3) + var(--percent-4)) * 1%),
    /* Segment 5 */
    var(--color-5) calc((var(--percent-1) + var(--percent-2) + var(--percent-3) + var(--percent-4)) * 1%) calc((var(--percent-1) + var(--percent-2) + var(--percent-3) + var(--percent-4) + var(--percent-5)) * 1%),
    /* Segment 6 */
    var(--color-6) calc((var(--percent-1) + var(--percent-2) + var(--percent-3) + var(--percent-4) + var(--percent-5)) * 1%) 100%
);  

            /* 4. Centrage du trou (Donut) */
            display: grid;
            place-items: center;
            
            /* Petit effet d'ombre interne pour la profondeur */
            box-shadow: inset 0 0 10px rgba(0,0,0,0.1);
        }

        /* 5. Le trou du milieu */
        .donut-chart::before {
            content: "";
            width: 70%; /* Taille du trou */
            height: 70%;
            background-color: white; /* Couleur du fond du conteneur */
            border-radius: 50%;
            box-shadow: 0 2px 5px rgba(0,0,0,0.1);
        }

        /* --- La Légende --- */
        .legend {
            list-style: none;
            padding: 0;
            margin: 0;
            display: grid;
            grid-template-columns: 1fr 1fr; /* 2 colonnes */
            gap: 15px;
            text-align: left;
        }

        .legend-item {
            display: flex;
            align-items: center;
            font-size: 0.9rem;
            color: #555;
        }

        /* Le petit carré de couleur */
        .color-box {
            width: 15px;
            height: 15px;
            border-radius: 4px;
            margin-right: 10px;
        }

        .data-value {
            font-weight: bold;
            margin-left: auto; /* Pousse la valeur à droite */
            color: #333;
        }