body, html {
    margin: 0;
    padding: 0;
}

a {
    text-decoration: none;
}

main {
    flex: 1;
    overflow-y: auto;
    padding: 10px;
    margin-top: 5px;  /* Espace pour le header */
    margin-bottom: 60px; /* Espace pour le footer */
    box-sizing: border-box;
}

.cadre {
    padding: 30px 20px;
    max-width: 100%;
    margin: 10px auto;
    box-shadow: 0 0 5px rgba(0, 0, 0, 0.8);
    border-radius: 10px;
    border: 0;
}

.cadre p {
    text-align: justify;
}

.jaune {
    background: #ffff66; /* jaune pâle */
}

.vert {
    background: #ccffcc; /* vert pâle */
}

.bleu {
    background: #cceeff; /* bleu pâle */
}

@media (max-width: 768px) {
    .cadre h1 {
        margin: 2px;
        font-size: 1.3em;
    }

    .cadre {
        padding: 20px 10px;
    }
}
