/* ===================================
   CONTENT PROSE — Rendu public uniforme
   Services, blog, pages CMS (.prose)
   =================================== */

/* ----- Titres Hn : espacement, couleurs, sections H2 ----- */
.prose h1,
.prose h2,
.prose h3,
.prose h4,
.prose h5,
.prose h6 {
    margin-block: var(--spacing-lg, 32px);
    padding: 0;
    line-height: 1.25;
}

.prose h1:first-child,
.prose h2:first-child,
.prose h3:first-child,
.prose h4:first-child {
    margin-top: 0;
}

.prose h2,
.prose h2.sp-section__title,
.prose h2.sp-intro__title,
.prose h2.sp-cta__title,
.prose h2.sp-case-study__title {
    color: var(--brand-secondary, #30a8db);
    font-weight: var(--font-weight-extrabold, 800);
    font-size: clamp(var(--text-2xl, 1.5rem), 3vw, var(--text-3xl, 1.875rem));
}

.prose h2.sp-intro__title {
    font-size: clamp(var(--text-3xl, 1.875rem), 4vw, 2.5rem);
}

.prose h3,
.prose h3.sp-subsection__title,
.prose h3.sp-short-version__heading,
.prose h3.sp-bonus__block-title {
    color: var(--brand-primary, #ff6900);
    font-weight: var(--font-weight-bold, 700);
    font-size: var(--text-xl, 1.25rem);
}

.prose h4,
.prose h4.prose-card__title,
.prose h4.sp-faq__question,
.prose h4.sp-quoted-heading {
    color: var(--text-primary, #1a1a1a);
    font-weight: var(--font-weight-bold, 700);
    font-size: var(--text-lg, 1.125rem);
}

/* Séparation fine entre sections (contenu plat ou blocs sp-section) */
.prose > h2:not(:first-child) {
    border-top: 1px solid var(--border-color, #e5e7eb);
    padding-top: var(--spacing-xl, 48px);
    margin-top: var(--spacing-xl, 48px);
}

.prose .sp-section + .sp-section {
    border-top: 1px solid var(--border-color, #e5e7eb);
    padding-top: var(--spacing-xl, 48px);
    margin-top: var(--spacing-xl, 48px);
}

/* ----- Icônes Font Awesome (remplace emojis) ----- */
.prose .prose-icon {
    display: inline-block;
    font-style: normal;
    line-height: 1;
    vertical-align: -0.1em;
    margin-right: 0.35em;
}

.prose .prose-icon--check {
    color: var(--brand-primary, #ff6900);
    font-weight: 900;
}

.prose .prose-icon--success {
    color: var(--brand-primary, #ff6900);
}

.prose .prose-icon--danger {
    color: #dc2626;
}

.prose .prose-icon--warning {
    color: #d97706;
}

.prose .prose-icon--gift {
    color: var(--brand-primary, #ff6900);
}

.prose .prose-icon--accent {
    color: var(--brand-secondary, #30a8db);
}

.prose .prose-icon--muted {
    color: var(--text-light, #94a3b8);
}

/* ----- Cartes numérotées (#### 1. Titre + liste) ----- */
.prose .prose-cards {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 320px), 1fr));
    gap: var(--spacing-md, 24px);
    margin: var(--spacing-md, 24px) 0 var(--spacing-lg, 32px);
}

.prose .prose-card {
    background: var(--bg-white, #fff);
    border: 1px solid var(--border-color, #e5e7eb);
    border-radius: var(--border-radius-md, 10px);
    overflow: hidden;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.prose .prose-card:hover {
    border-color: rgba(255, 105, 0, 0.35);
}

.prose .prose-card__header {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-sm, 16px);
    padding: var(--spacing-md, 24px) var(--spacing-md, 24px) var(--spacing-sm, 16px);
    border-bottom: 1px solid var(--border-color, #e5e7eb);
    background: var(--bg-light, #f8f9fa);
}

.prose .prose-card__icon {
    flex-shrink: 0;
    width: 2.5rem;
    height: 2.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--border-radius-md, 10px);
    background: rgba(255, 105, 0, 0.12);
    color: var(--brand-primary, #ff6900);
    font-size: 1.1rem;
}

.prose .prose-card__title {
    margin: 0 !important;
    padding: 0;
    line-height: 1.35;
    flex: 1;
}

.prose .prose-card__body {
    padding: var(--spacing-sm, 16px) var(--spacing-md, 24px) var(--spacing-md, 24px);
}

.prose .prose-card__body ul,
.prose .prose-card__body ol {
    margin: 0;
    padding-left: 1.25rem;
}

.prose .prose-card__body li {
    margin-bottom: 0.5rem;
    line-height: 1.6;
    color: var(--text-secondary, #666666);
}

.prose .prose-card__body li:last-child {
    margin-bottom: 0;
}

.prose .prose-card__body p {
    margin: 0 0 0.75rem;
}

.prose .prose-card__body p:last-child {
    margin-bottom: 0;
}

/* Listes avec checks (✅ → icône fa-check orange) */
.prose ul li:has(.prose-icon--check),
.prose .sp-checklist li {
    list-style: none;
    position: relative;
    padding-left: 1.5rem;
}

.prose ul li:has(.prose-icon--check) .prose-icon--check,
.prose .sp-checklist li .prose-icon--check {
    position: absolute;
    left: 0;
    top: 0.45em;
    margin-right: 0;
    font-size: 0.95em;
}

.prose ul:not(.sp-checklist) li:has(.prose-icon--check) {
    padding-top: 0.2rem;
    padding-bottom: 0.2rem;
}

/* ----- Tableaux ----- */
.prose .prose-table-wrap,
.prose .sp-table-wrap {
    overflow-x: auto;
    margin: var(--spacing-md, 24px) 0;
    border-radius: var(--border-radius-md, 10px);
    border: 1px solid var(--border-color, #e5e7eb);
}

.prose table,
.prose .prose-table,
.prose .sp-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--text-sm, 0.875rem);
    background: var(--bg-white, #fff);
}

.prose table th,
.prose table td,
.prose .prose-table th,
.prose .prose-table td,
.prose .sp-table th,
.prose .sp-table td {
    border: 1px solid var(--border-color, #e5e7eb);
    padding: 0.75rem 1rem;
    text-align: left;
    vertical-align: top;
}

.prose table thead th,
.prose .prose-table thead th,
.prose .sp-table thead th,
.prose table tr:first-child th,
.prose .prose-table tr:first-child th {
    background: var(--bg-light, #f1f5f9);
    font-weight: var(--font-weight-bold, 700);
    color: var(--text-primary, #1a1a1a);
}

.prose table tbody tr:nth-child(even),
.prose .prose-table tbody tr:nth-child(even),
.prose .sp-table tbody tr:nth-child(even) {
    background: rgba(241, 245, 249, 0.55);
}

.prose table tbody tr:hover,
.prose .prose-table tbody tr:hover,
.prose .sp-table tbody tr:hover {
    background: rgba(255, 105, 0, 0.04);
}

/* Titres de section au-dessus des cartes */
.prose h2 + .prose-cards,
.prose h3.sp-subsection__title + .prose-cards,
.prose h3:not(.prose-card__title) + .prose-cards {
    margin-top: var(--spacing-sm, 16px);
}

@media (max-width: 768px) {
    .prose .prose-cards {
        grid-template-columns: 1fr;
    }

    .prose table,
    .prose .prose-table,
    .prose .sp-table {
        font-size: 0.8125rem;
    }

    .prose .prose-card__header {
        padding: var(--spacing-sm, 16px);
    }

    .prose .prose-card__body {
        padding: var(--spacing-sm, 16px);
    }
}
