.activitydetail-layout {
    display: flex;
    align-items: flex-start;
    /*min-height: 80vh;*/
    width: min(90%, 1600px);
    padding: 0px;
    box-sizing: border-box;
    gap: 40px;
    margin: 40px auto 100px auto;
    background-color: #fff;
}

.blue-banner h2 {
    margin: 0 0 5px 0 !important;
}

/* Conteneur principal */
.page-title-container {
    display: inline-flex !important;
    align-items: baseline;
    flex-wrap: nowrap;
}

/* Groupe Date + Séparateur */
.title-meta {
    font-size: 1em;
    font-weight: 500;
    opacity: 0.85;
    letter-spacing: 0.02em;
}

.title-separator {
    margin: 0 0.5em 0 0.5em;
    color: #288FE2; /* Ton bleu fétiche pour le slash */
    font-weight: bold;
    font-size: 1.5rem;
}

.title-date {
    margin-right: 1em;
    color: #288FE2; /* Ton bleu fétiche pour le slash */
    font-weight: bold;
    font-size: 1.5rem;
}

.title-lieu {
    margin-right: 1em;
    color: #288FE2; /* Ton bleu fétiche pour le slash */
    font-weight: bold;
    font-size: 1.5rem;
}

/* Gauche */
.activity-left {
    flex: 0 0 100%;
    max-width: 100%;
}

/* Le conteneur devient un parent Flex */
.activity-main {
    display: flex;
    align-items: flex-start; /* Aligne l'image et le texte en haut */
    gap: 30px;               /* Espace entre l'image et le texte */
    margin-top: 20px;
}

/* La colonne de l'image */
.activity-media {
    flex: 0 0 40%;
    max-width: 450px;
}

.activity-image {
    width: 100%;
    height: auto;
}

/* La colonne du texte */
.activity-body {
    flex: 1;                 /* Prend tout l'espace restant */
}

.activity-subtitle {
    margin-top: 0;           /* Aligne le titre avec le haut de l'image */
    color: #092851;
    font-size: 1.4rem;
}

/* Droite */
.activity-right {
    /*flex: 0 0 20%;*/
    flex: 1;
    padding-left: 20px;
    transform: translateY(-20px);
}

/* Image / contenu */
.activity-media img,
.activity-image {
    max-width: 100%;
    height: auto;
    display: block;
    margin: 0 auto 15px 0;
}

.activity-text,
.activity-description {
    text-align: justify;
    line-height: 1.6;
    margin-top: 15px;
    font-size: 18px;
    line-height: 1.6rem;
    color: gray;
}

.activity-text,
.activity-description p {
    text-align: justify;
    line-height: 1.6;
    margin-top: 15px;
    font-size: 18px;
    line-height: 1.6rem;
    color: gray;
    font-weight: bold;
}

.activity-description a {
    font-size: 16px !important;
    line-height: 1.5 !important; /* Un peu plus d'espace pour la lisibilité */
    text-align: left !important;
}
/* Mots-clés */
.motcle {
    display: inline-block;
    margin: 5px 5px 0 0;
    padding: 4px 10px;
    background: #1d305d;
    color: #fff;
    border-radius: 12px;
    font-size: 13px;
}

.activity-description iframe {
    max-width: 100%;
    width: 100% !important;
    aspect-ratio: 16 / 9;
    height: auto;
    border: 0;
    display: block;
}

/* --- BLUE BANNERS --- */
.blue-banner-keywords {
    background-color: var(--tertiary-blue);
    color: white;
    padding: 10px;
    text-align: left;
    border-radius: 1px;
    margin-bottom: 30px;
}

.blue-banner-keywords h2 {
    margin: 0;
    font-size: 18px;
}

.motcle-list {
    list-style: disc;
    padding-left: 20px;
    margin: 10px 0 0 0;
}

.motcle-item {
    margin: 6px 0;
    padding: 6px 10px;
    color: var(--tertiary-blue);
    font-size: 18px;
}

.motcle-empty {
    color: #999;
    font-style: italic;
}

/* --- AJOUT DE LA SECTION RESPONSIVE --- */

@media (max-width: 1024px) {
    .activitydetail-layout {
        gap: 20px;
        margin: 20px auto;
    }
}

@media (max-width: 768px) {
    /* 1. Layout Global : On empile les colonnes (Gauche / Droite) */
    .activitydetail-layout {
        flex-direction: column;
        max-width: 100%;
        padding: 15px;
    }

    .activity-left, .activity-right {
        flex: none;
        width: 100%;
    }

    /* 2. Titre : On permet le retour à la ligne */
    .page-title-container {
        display: flex !important; /* On casse le inline-flex */
        flex-direction: column;
        align-items: flex-start;
    }

    .page-title {
        font-size: 1.5rem;
        line-height: 1.2;
    }

    .title-separator {
        display: none; /* On cache le slash sur mobile pour gagner de la place */
    }

    /* Le parent devient une colonne */
    .title-meta {
        display: flex;
        flex-direction: column; /* Empile la date et le lieu */
        gap: 5px;               /* Petit espace entre les deux lignes */
        margin-left: 15px;      /* Pour l'aligner après le titre si besoin */
    }

    .title-date {
        display: block;         /* Force le bloc */
        color: #288FE2;
        font-weight: bold;
        font-size: 1.5rem;
        margin: 0;              /* On nettoie les marges inutiles */
    }

    .title-lieu {
        display: block;         /* Force le bloc */
        color: #288FE2;
        font-weight: bold;
        font-size: 1.2rem;      /* Un peu plus petit que la date pour la hiérarchie ? */
        margin: 0;
    }

    /* 3. Section Image + Texte (Main) */
    .activity-main {
        flex-direction: column; /* Image au dessus du texte */
        align-items: center;
        gap: 20px;
    }

    .activity-media {
        flex: none;
        width: 100%;
        max-width: 100%; /* L'image prend toute la largeur possible */
    }

    .activity-image {
        max-width: 350px; /* On limite quand même pour pas que ce soit énorme */
        margin: 0 auto;
    }

    /* 4. Colonne de Droite (Mots-clés) */
    .activity-left, .activity-right {
        flex: 0 0 100%;        /* Chaque colonne prend toute la largeur */
        max-width: 100%;
        border-left: none;      /* On retire la bordure latérale */
        padding-left: 0;
    }

    .activity-right {
        transform: none;        /* On annule le décalage vers le haut */
        margin-top: 40px;       /* On ajoute de l'espace entre les deux */
    }

    /* 5. Texte et description */
    .activity-text, .activity-description p {
        font-size: 16px; /* On réduit un peu la taille pour mobile */
        text-align: left; /* Le justifié est souvent moche sur petits écrans */
    }

}

@media (max-width: 480px) {
    .page-title {
        font-size: 1.3rem;
    }

    .motcle-item {
        font-size: 16px;
    }
}