:root {
    --couleur-fond: #f5f6f8;
    --couleur-texte: #1f2430;
    --couleur-accent: #1a6b3c;
    --couleur-accent-fonce: #11502c;
    --couleur-bordure: #d8dce2;
    --couleur-carte: #ffffff;
    --couleur-erreur: #b3261e;
    --couleur-succes: #1a6b3c;
    --couleur-info: #2563a8;
    /* Jaune du logo M-Volt (dégradé du "M") */
    --couleur-bouton: #F8CE46;
    --couleur-bouton-fonce: #E8B411;
}

* { box-sizing: border-box; }

body {
    margin: 0;
    font-family: -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    background: var(--couleur-fond);
    color: var(--couleur-texte);
}

a { color: var(--couleur-accent); text-decoration: none; }
a:hover { text-decoration: underline; }

.entete {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: var(--couleur-carte);
    border-bottom: 1px solid var(--couleur-bordure);
    padding: 0.3rem 1.5rem;
    flex-wrap: wrap;
    gap: 0.75rem;
}
.entete-marque a { font-weight: 700; font-size: 1.1rem; color: var(--couleur-texte); display: flex; align-items: center; }
.logo-entete { height: 128px; width: auto; display: block; }
.entete-nav a { margin-right: 1rem; color: var(--couleur-texte); }
.entete-nav a:hover { color: var(--couleur-accent); }
.entete-utilisateur { display: flex; align-items: center; gap: 1rem; font-size: 0.9rem; }

.conteneur {
    max-width: 1100px;
    margin: 0 auto;
    padding: 1.5rem;
}

.messages-flash { list-style: none; padding: 0; margin: 0 0 1rem; }
.flash { padding: 0.6rem 1rem; border-radius: 6px; margin-bottom: 0.5rem; font-size: 0.92rem; }
.flash-erreur { background: #fbe9e7; color: var(--couleur-erreur); border: 1px solid #f1b3ad; }
.flash-succes { background: #e7f3ea; color: var(--couleur-succes); border: 1px solid #b6dcc1; }
.flash-info { background: #e8f0fa; color: var(--couleur-info); border: 1px solid #b8d2ec; }

.carte {
    background: var(--couleur-carte);
    border: 1px solid var(--couleur-bordure);
    border-radius: 8px;
    padding: 1.5rem;
    margin-bottom: 1.5rem;
}

h1 { font-size: 1.5rem; margin-top: 0; }
h2 { font-size: 1.2rem; }

table { width: 100%; border-collapse: collapse; }
th, td { text-align: left; padding: 0.5rem 0.6rem; border-bottom: 1px solid var(--couleur-bordure); font-size: 0.92rem; }
th { color: #555; font-weight: 600; }
tr:hover td { background: #fafbfc; }

.formulaire label { display: block; margin: 0.8rem 0 0.3rem; font-weight: 600; font-size: 0.88rem; }
.formulaire input, .formulaire select, .formulaire textarea {
    width: 100%;
    padding: 0.55rem 0.7rem;
    border: 1px solid var(--couleur-bordure);
    border-radius: 6px;
    font-size: 0.95rem;
    font-family: inherit;
}
.formulaire .aide { font-size: 0.8rem; color: #666; margin-top: 0.2rem; }
.ligne-form { display: flex; gap: 1rem; flex-wrap: wrap; }
.ligne-form > div { flex: 1; min-width: 200px; }

.bouton {
    display: inline-block;
    background: var(--couleur-bouton);
    color: var(--couleur-texte);
    border: none;
    padding: 0.6rem 1.2rem;
    border-radius: 6px;
    font-size: 0.95rem;
    font-weight: 600;
    cursor: pointer;
    margin-top: 1.2rem;
}
.bouton:hover { background: var(--couleur-bouton-fonce); text-decoration: none; }
.bouton-secondaire { background: #fff; color: var(--couleur-texte); border: 1px solid var(--couleur-bordure); }
.bouton-secondaire:hover { background: #f0f1f3; }
.bouton-danger { background: var(--couleur-erreur); color: #fff; }
.bouton-petit { padding: 0.3rem 0.7rem; font-size: 0.82rem; margin-top: 0; }

.badge { display: inline-block; padding: 0.15rem 0.55rem; border-radius: 12px; font-size: 0.78rem; font-weight: 600; }
.badge-actif { background: #e7f3ea; color: var(--couleur-succes); }
.badge-inactif { background: #f1f2f4; color: #777; }

.page-connexion { max-width: 380px; margin: 6rem auto; }
.lien-retour { display: inline-block; margin-bottom: 1rem; font-size: 0.9rem; }

.recap-chiffre { font-size: 1.4rem; font-weight: 700; }
.recap-ligne { display: flex; justify-content: space-between; padding: 0.35rem 0; border-bottom: 1px dashed var(--couleur-bordure); }
.recap-ligne.total { font-weight: 700; border-bottom: none; border-top: 2px solid var(--couleur-texte); padding-top: 0.6rem; margin-top: 0.4rem; }
