/* ==========================================================================
   1. VARIABLES & CONFIGURATION UNIFIÉES
   ========================================================================== */
:root {
    --couleur-primaire: #7b1c8d; /* Violet signature */
    --couleur-primaire-hover: #6e4874;
    --couleur-grise: #efefef;
    --couleur-grise-pale: #f5f5f5; /* Pour le style dark */
    --couleur-bordure: #ccc;
    --couleur-erreur: #ff0000;
    --couleur-succes: #008000;
    --radius: 6px;
    --transition-rapide: 0.2s ease-in-out;
    --transition-messages: 0.8s ease; /* Synchronisé avec le JS */
}

/* ==========================================================================
   2. RESET & BASE
   ========================================================================== */
* { box-sizing: border-box; }

html, body { 
    margin: 0; 
    padding: 0; 
    background-color: #fff; 
    font-family: 'Segoe UI', Arial, sans-serif;
    color: #333;
}

body { 
    width: 100%;
    max-width: 1400px;
    margin: 0 auto; 
    overflow-x: hidden; 
    line-height: 1.5;
}

/* ==========================================================================
   3. SYSTÈME DE MESSAGES TEMPORAIRES (NOTIFICATIONS)
   ========================================================================== */

/* Conteneur fixe pour centrer les messages en haut de l'écran */
#container-messages {
    position: fixed;
    top: 20px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 9999;
    width: 90%;
    max-width: 500px;
    pointer-events: none; /* Permet de cliquer à travers les messages */
    display: flex;
    flex-direction: column;
    gap: 10px;
}

/* Style de base pour TOUS les messages */
.boite-temporaire, .hide, .success-box, .alert-box {
    pointer-events: auto; /* Réactive le clic sur le message lui-même */
    padding: 15px 25px;
    border-radius: var(--radius);
    text-align: center;
    font-weight: bold;
    border: 2px dashed; /* Votre style signature */
    opacity: 1;
    background-color: #fff;
    transition: opacity var(--transition-messages), transform var(--transition-messages);
    box-shadow: 0 4px 10px rgba(0,0,0,0.1);
}

/* --- Variantes de couleurs --- */

.boite-temporaire.succes, .success-box {
    background-color: #ccffcc;
    color: var(--couleur-succes);
    border-color: var(--couleur-succes);
}

.boite-temporaire.erreur, .alert-box, .incorrect {
    background-color: #ffcccc;
    color: var(--couleur-erreur);
    border-color: var(--couleur-erreur);
}

.boite-temporaire.info, .hide {
    background-color: #333;
    color: #fff;
    border-color: #555;
}

.boite-temporaire.dark {
    background-color: var(--couleur-grise-pale);
    color: #000;
    border-color: #000;
}

/* ==========================================================================
   4. BOUTONS & FORMULAIRES STANDARDS
   ========================================================================== */

input:not([type="checkbox"]):not([type="submit"]), 
select, 
textarea {
    border-radius: var(--radius);
    border: 1px solid var(--couleur-bordure);
    padding: 8px;
    font-size: 14px;
}

input[type="submit"], 
button, 
.btn-nav {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 8px 20px;
    border-radius: var(--radius);
    background: var(--couleur-grise);
    color: #000;
    font-weight: 500;
    cursor: pointer;
    transition: var(--transition-rapide);
    border: none;
    text-decoration: none;
}

input[type="submit"]:hover, button:hover, .btn-nav:hover {
    background: var(--couleur-primaire-hover);
    color: #fff;
}

/* Supprime le padding hérité pour le bouton X de recherche */
.btn-cancel-search {
    padding: 0 !important;
    background: none !important; /* Optionnel : assure qu'il n'y a pas de fond gris */
    border: none !important;
}

/* ==========================================================================
   BANNIÈRE UNIVERSELLE (NAVIGATION)
   ========================================================================== */
#banniere {
    display: flex;          /* Utilise Flexbox pour aligner les boutons sur une ligne */
    flex-wrap: wrap;       /* Permet de passer à la ligne sur petit écran au lieu de chevaucher */
    justify-content: space-between; /* Espace égal entre les boutons */
    align-items: center;
    gap: 10px;              /* Espace constant entre chaque bouton */
    padding: 10px 0;       /* Pas de marge à gauche/droite selon votre demande */
    width: 100%;
}

.inside_banniere {
    display: flex;
    flex: 0 1 auto;        /* Chaque conteneur prend juste la place nécessaire */
}

#banniere .btn-nav {
    display: inline-block;
    width: auto;           /* Annule la largeur fixe de 180px qui causait le chevauchement */
    min-width: fit-content;/* S'adapte au texte */
    padding: 8px 15px;     /* Largeur du texte + padding de 15px de chaque côté */
    font-size: 14px;
    text-align: center;
    white-space: nowrap;   /* Empêche le texte du bouton de se couper sur deux lignes */
    background-color: var(--couleur-grise);
    border-radius: var(--radius);
    text-decoration: none;
    color: #333;
    transition: var(--transition-rapide);
}

#banniere .btn-nav:hover {
    background-color: var(--couleur-primaire-hover);
    color: #fff;
}

/* Suppression des marges sur le premier et dernier élément pour coller aux bords */
.inside_banniere:first-child { margin-left: 0; }
.inside_banniere:last-child { margin-right: 0; }

/* Ajustement spécifique pour Tablettes */
@media (max-width: 1024px) {
    #banniere {
        justify-content: center; /* Centre les boutons si l'espace manque sur tablette */
    }
}



/* ==========================================================================
   5. TITRES & STRUCTURE
   ========================================================================== */
h1, h2, h3 { color: var(--couleur-primaire); text-align: center; }

#container-top { 
    position: sticky; 
    top: 0; 
    z-index: 2000; 
    background: #fff;
    box-shadow: 0 2px 10px rgba(0,0,0,0.1);
}

#banniere {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
    gap: 10px;
    padding: 10px;
}

/* ==========================================================================
   6. PRINT & ACCESSIBILITÉ
   ========================================================================== */
@media print {
    .no_print { display: none !important; }
    body { width: 100%; margin: 0; padding: 0; }
}

:disabled {
    background: #e0e0e0 !important;
    color: #999 !important;
    cursor: not-allowed !important;
    opacity: 0.7;
}
