/*
 * article-content.css
 * --------------------------------------------------------------------------
 * Rendu du contenu d'article stocké en HTML (éditeur WYSIWYG) dans le bloc
 * <article class="article-content ...">.
 *
 * Reproduit fidèlement le rendu historique sections/blocs :
 *   - titres  -> .article-content h2  (font-semibold text-primary + écart de section)
 *   - listes  -> ul.list-disc ps-10 font-medium space-y-3
 *   - citation-> blockquote bordé/italique/fond léger
 *   - images  -> rounded-xl my-8 shadow-sm border
 *
 * Utilise les variables de marque déjà exposées dans :root par
 * tailwind-compiled.css (--primary-color, --accent-color), ce qui évite la
 * dépendance au build Tailwind (cf. CLAUDE.md §10).
 */

/* Rythme vertical de base (équivaut à space-y-6 entre enfants directs). */
.article-content > * + * {
    margin-top: 1.5rem;
}

.article-content > :first-child {
    margin-top: 0;
}

/* Titres de section : DM Sans, rouge marque, gras. Écart marqué avant chaque
   titre pour reproduire l'espace inter-sections (mt-20). */
.article-content h2 {
    font-family: "DM Sans", sans-serif;
    font-weight: 600;
    color: var(--primary-color, #e1000f);
    line-height: 1.25;
}

.article-content > h2 {
    margin-top: 4rem;
}

.article-content > h2:first-child {
    margin-top: 0;
}

/* Sous-titre (nouveau, via l'éditeur). */
.article-content h3 {
    font-family: "DM Sans", sans-serif;
    font-weight: 600;
    color: var(--primary-color, #e1000f);
    font-size: 1.125rem;
    line-height: 1.3;
}

.article-content p {
    line-height: 1.7;
}

/* Listes à puces / numérotées. */
.article-content ul,
.article-content ol {
    padding-inline-start: 2.5rem;
    font-weight: 500;
}

.article-content ul {
    list-style: disc;
}

.article-content ol {
    list-style: decimal;
}

.article-content li + li {
    margin-top: 0.75rem;
}

.article-content ul ul,
.article-content ol ol,
.article-content ul ol,
.article-content ol ul {
    margin-top: 0.75rem;
}

/* Citation. */
.article-content blockquote {
    border-left: 4px solid var(--primary-color, #e1000f);
    padding: 0.5rem 0 0.5rem 1.5rem;
    margin: 2rem 0;
    font-style: italic;
    font-size: 1.125rem;
    color: rgba(0, 0, 0, 0.7);
    background: rgba(0, 0, 0, 0.05);
    border-radius: 0 0.5rem 0.5rem 0;
}

@media (min-width: 640px) {
    .article-content blockquote {
        font-size: 1.25rem;
    }
}

/* Images dans le corps. */
.article-content img {
    width: 100%;
    height: auto;
    border-radius: 0.75rem;
    margin: 2rem 0;
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    border: 1px solid rgba(0, 0, 0, 0.05);
}

/* Liens. */
.article-content a {
    color: var(--accent-color, #000091);
    text-decoration: underline;
    text-underline-offset: 2px;
}

.article-content a:hover {
    opacity: 0.85;
}

/* Mise en forme inline issue de l'éditeur. */
.article-content strong,
.article-content b {
    font-weight: 700;
}

.article-content em,
.article-content i {
    font-style: italic;
}

.article-content u {
    text-decoration: underline;
}
