:root {
    --primary-blue: #0056b3;
    --light-grey: #f4f4f4;
    --text-dark: #333;
    --border-color: #ddd;
}

/* Base & Typographie */
body {
    font-family: 'Georgia', serif;
    line-height: 1.6;
    color: var(--text-dark);
    margin: 0;
    background-color: #fff;
}

h1, h2, h3, nav {
    font-family: 'Helvetica', 'Arial', sans-serif;
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* Mise en page */
.container {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 20px;
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
}

.main-header {
    position: sticky;
    top: 0;
    z-index: 1000;
    background-color: var(--primary-blue);
    padding: 15px 0;
    box-shadow: 0 2px 10px rgba(0,0,0,0.1);
}

.main-header .container {
    display: flex;
    align-items: center; /* Centre verticalement le logo et la navigation */
    justify-content: space-between; /* Espace le logo à gauche et le menu à droite */
}

.main-header .logo { 
    height: 60px; 
    margin-right: 25px; /* Ajoute de l'espace pour que l'image ne touche pas le texte */
    display: block;
}

nav ul { 
    list-style: none; 
    display: flex; 
    gap: 30px; /* Augmente l'espace entre les liens du menu */
    margin: 0; 
    padding: 0;
    align-items: center; /* Assure le centrage vertical des items de liste */
}

nav a { 
    color: white; 
    text-decoration: none; 
    font-weight: bold; 
    font-size: 1.2rem; /* Augmente la taille de la police (ajustez à 1.1rem si trop grand) */
    padding: 5px 0;
    cursor: pointer; 
    transition: 0.3s;
}

nav a.active { border-bottom: 2px solid white; }
nav a:hover { opacity: 0.8; }

.content-article { flex: 3; min-width: 300px; padding: 0 40px 20px 0; }
.article-header { border-bottom: 3px solid var(--primary-blue); margin-bottom: 30px; }

h1 { font-size: 2.2rem; margin: 10px 0; color: #000; white-space: nowrap; }

/* Images & Figures (Redondances éliminées) */
.article-image, figure {
    margin: 30px 0;
    text-align: center;
    max-width: 100%;
}

.article-image img, .main-text img {
    max-width: 100%;
    height: auto;
    border-radius: 4px;
    box-shadow: 0 4px 10px rgba(0,0,0,0.1);
    display: block;
    margin: 20px auto;
}

/* Sidebar & Listes */
.sidebar { flex: 1; min-width: 250px; border-left: 1px solid var(--border-color); padding-left: 20px; }
.sidebar h3 { color: var(--primary-blue); border-bottom: 1px solid var(--border-color); }
.sidebar a.active { font-weight: bold; color: #000; }

.pdf-list { list-style: none; padding: 0; }
.pdf-list li { padding: 12px 0 12px 30px; border-bottom: 1px solid var(--border-color); position: relative; }
.pdf-list li::before { content: "📄"; position: absolute; left: 0; color: var(--primary-blue); }

/* Blocs de code */
pre { background: #f8f8f8; border-left: 4px solid var(--primary-blue); padding: 15px; overflow-x: auto; }
code { color: #d63384; font-family: monospace; }

footer { text-align: center; padding: 20px; background: var(--light-grey); border-top: 1px solid var(--border-color); }




/* Style du bouton Retour en haut */
#backToTop {
    display: none; /* Caché par défaut */
    position: fixed; /* Reste à la même place par rapport à l'écran */
    bottom: 20px;
    right: 20px;
    z-index: 99; /* S'affiche au-dessus de tout le reste */
    border: none;
    outline: none;
    background-color: var(--primary-blue); /* Utilise votre bleu habituel */
    color: white;
    cursor: pointer;
    padding: 15px;
    border-radius: 50%; /* Bouton rond */
    font-size: 20px;
    width: 50px;
    height: 50px;
    box-shadow: 0 4px 8px rgba(0,0,0,0.3);
    transition: opacity 0.3s, transform 0.3s;
}

#backToTop:hover {
    background-color: #003d80; /* Un bleu plus foncé au survol */
    transform: scale(1.1); /* S'agrandit légèrement */
}



/* --- ADAPTATION SMARTPHONE (Écrans < 768px) --- */
@media (max-width: 768px) {
    
    /* 1. On passe la mise en page en une seule colonne */
    .container {
        flex-direction: column;
        padding: 0 15px;
    }

    /* 2. On ajuste le Header (Logo en haut, Menu en dessous) */
    .main-header .container {
        flex-direction: column;
        gap: 15px;
    }

    .main-header .logo {
        margin-right: 0;
        height: 50px; /* Un peu plus petit sur mobile */
    }

    nav ul {
        gap: 15px;
        flex-wrap: wrap; /* Permet aux liens de passer à la ligne si besoin */
        justify-content: center;
    }

    nav a {
        font-size: 1rem; /* On réduit légèrement la taille sur mobile */
    }

    /* 3. On autorise le titre principal à revenir à la ligne */
    h1 {
        white-space: normal; 
        font-size: 1.6rem; /* Taille plus adaptée aux petits écrans */
        text-align: center;
        line-height: 1.2;
    }

    .article-header {
        text-align: center;
    }

    /* 4. On réinitialise les zones Article et Sidebar */
    .content-article {
        padding-right: 0;
        border-right: none;
        width: 100%;
    }


    .sidebar {
        width: 100%;
        min-width: 100%;
        border-left: none;
        border-top: 2px solid var(--border-color);
        padding: 30px 0; /* On centre le contenu de la sidebar */
        margin-top: 30px;
    }

    .sidebar h3 {
        text-align: center;
        margin-bottom: 20px;
    }

    .sidebar ul {
        display: flex;
        flex-direction: column;
        gap: 12px; /* Espace entre les boutons */
        padding: 0;
    }

    .sidebar ul li {
        list-style: none;
    }

    /* Transformation des liens en boutons larges pour le pouce */
    .sidebar ul li a {
        display: block;
        background-color: var(--light-grey);
        color: var(--primary-blue);
        padding: 15px 20px;
        border-radius: 8px;
        text-decoration: none;
        font-weight: bold;
        text-align: center;
        border: 1px solid var(--border-color);
        transition: background 0.2s ease;
        font-size: 1.1rem;
    }

    /* Effet visuel quand on appuie dessus */
    .sidebar ul li a:active {
        background-color: var(--primary-blue);
        color: white;
    }

    /* Style spécifique pour le bouton actif dans la sidebar sur mobile */
    .sidebar ul li a.active {
        background-color: var(--primary-blue);
        color: white;
        border-color: var(--primary-blue);
    }

    /* 5. On réduit les marges des images */
    .article-image img {
        margin: 10px auto;
    }

    
    
    /* bouton Retour en haut */
    #backToTop {
        bottom: 30px;
        right: 15px;
        width: 45px;
        height: 45px;
        padding: 10px;
    }
    
}
