/* ═══ Blog — Mon Partenaires Patrimoine ═══ */
* { box-sizing: border-box; margin: 0; padding: 0; }
:root {
    --noir:#0a0e1a; --noir-clair:#131826;
    --or:#d4af37; --or-clair:#f4d77f; --or-fonce:#a88828; --or-glow:rgba(212,175,55,0.55);
    --texte:#e8eaf0; --gris:#8590a8; --cream:#f9f5ed;
}
html { scroll-behavior: smooth; }
body {
    font-family: 'Inter', sans-serif;
    background: var(--noir); color: var(--texte); line-height: 1.7;
}
.gold { color: var(--or); }

/* Header */
.site-header {
    position: sticky; top: 0; z-index: 100;
    background: rgba(10,14,26,0.92); backdrop-filter: blur(16px);
    border-bottom: 1px solid rgba(212,175,55,0.12);
    padding: 16px 32px; display: flex; align-items: center; justify-content: space-between;
}
.site-header .logo {
    font-family: 'Cormorant Garamond', serif; font-size: 22px; font-weight: 600;
    color: white; text-decoration: none; display: flex; align-items: center; gap: 12px;
}
.logo-mark {
    width: 32px; height: 32px; border-radius: 50%;
    background: linear-gradient(135deg, var(--or-clair), var(--or-fonce));
    color: var(--noir); font-weight: 700; display: flex; align-items: center; justify-content: center;
    box-shadow: 0 0 16px var(--or-glow);
}
.site-header nav { display: flex; gap: 6px; align-items: center; }
.site-header nav a {
    color: var(--cream); font-size: 14px; padding: 8px 14px; border-radius: 6px;
    text-decoration: none; transition: all 0.2s;
}
.site-header nav a:hover { background: rgba(212,175,55,0.08); color: var(--or-clair); }
.site-header nav a.active { color: var(--or); }
.site-header nav a.cta {
    background: linear-gradient(135deg, var(--or), var(--or-fonce));
    color: var(--noir); font-weight: 600;
    box-shadow: 0 4px 14px var(--or-glow);
}

/* Article */
.article-main {
    max-width: 1200px; margin: 0 auto; padding: 60px 32px;
    display: grid; grid-template-columns: 1fr 280px; gap: 50px;
}
@media(max-width: 900px) { .article-main { grid-template-columns: 1fr; } }
.article { max-width: 760px; }
.hero-img-wrap {
    border-radius: 14px; overflow: hidden;
    box-shadow: 0 30px 80px rgba(0,0,0,0.4); margin-bottom: 36px;
}
.hero-img { width: 100%; display: block; }
.article-meta {
    color: var(--gris); font-size: 13px; margin-bottom: 18px;
    display: flex; flex-wrap: wrap; gap: 8px; align-items: center;
}
.article-meta .sep { opacity: 0.4; }

.article-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(32px, 4vw, 48px); font-weight: 600;
    color: white; line-height: 1.15; letter-spacing: -1px; margin-bottom: 18px;
}
.article-lede {
    font-size: 19px; color: var(--cream); line-height: 1.6;
    padding-left: 20px; border-left: 3px solid var(--or); margin-bottom: 40px;
    font-style: italic;
}

.article-body { font-size: 17px; color: var(--cream); }
.article-body h2 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 30px; font-weight: 600; color: white;
    margin: 50px 0 18px; padding-bottom: 8px;
    border-bottom: 1px solid rgba(212,175,55,0.15);
    letter-spacing: -0.5px;
}
.article-body h3 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 23px; font-weight: 600; color: var(--or-clair);
    margin: 32px 0 12px;
}
.article-body p { margin: 0 0 18px; }
.article-body ul, .article-body ol { margin: 0 0 24px 24px; }
.article-body li { margin-bottom: 8px; }
.article-body a { color: var(--or-clair); text-decoration: underline; text-decoration-color: rgba(212,175,55,0.4); transition: all 0.2s; }
.article-body a:hover { color: var(--or); text-decoration-color: var(--or); }
.article-body strong { color: white; font-weight: 600; }
.article-body blockquote {
    margin: 30px 0; padding: 24px 28px;
    background: rgba(212,175,55,0.06); border-left: 3px solid var(--or);
    border-radius: 4px; font-style: italic;
}
.article-body table {
    width: 100%; border-collapse: collapse; margin: 30px 0;
    background: rgba(20,28,45,0.4); border: 1px solid rgba(212,175,55,0.12);
    border-radius: 10px; overflow: hidden;
}
.article-body table th {
    background: rgba(212,175,55,0.1); color: var(--or-clair);
    padding: 12px 16px; text-align: left; font-size: 14px; font-weight: 600;
    border-bottom: 1px solid rgba(212,175,55,0.2);
}
.article-body table td {
    padding: 12px 16px; font-size: 15px;
    border-top: 1px solid rgba(255,255,255,0.05);
}

.article-cta {
    margin-top: 60px; padding: 36px 32px;
    background: linear-gradient(145deg, rgba(20,28,45,0.85), rgba(15,22,38,0.95));
    border: 1px solid rgba(212,175,55,0.3); border-radius: 16px;
    text-align: center;
    box-shadow: 0 30px 80px rgba(0,0,0,0.4);
}
.article-cta h3 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 26px; font-weight: 600; color: white; margin-bottom: 12px;
}
.article-cta p { color: var(--gris); margin-bottom: 24px; font-size: 15px; }
.cta-btn {
    display: inline-block; padding: 14px 32px;
    background: linear-gradient(135deg, var(--or), var(--or-fonce));
    color: var(--noir); font-weight: 700; border-radius: 100px;
    text-decoration: none; box-shadow: 0 8px 24px var(--or-glow);
    transition: all 0.2s;
}
.cta-btn:hover { transform: translateY(-2px); box-shadow: 0 12px 32px var(--or-glow); }

/* Aside */
.aside-card {
    position: sticky; top: 100px;
    background: rgba(20,28,45,0.5); border: 1px solid rgba(212,175,55,0.12);
    border-radius: 14px; padding: 24px;
}
.aside-card h4 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 20px; font-weight: 600; color: var(--or-clair);
    margin-bottom: 16px;
}
.aside-card a {
    display: block; padding: 10px 0;
    color: var(--cream); font-size: 14px; line-height: 1.4;
    text-decoration: none; border-top: 1px solid rgba(255,255,255,0.06);
    transition: color 0.2s;
}
.aside-card a:first-of-type { border-top: none; }
.aside-card a:hover { color: var(--or); }

/* Footer */
.site-footer {
    background: var(--noir-clair); border-top: 1px solid rgba(212,175,55,0.12);
    padding: 40px 32px 24px; color: var(--gris); font-size: 13px;
    text-align: center;
}
.footer-inner { max-width: 900px; margin: 0 auto; }
.footer-inner p { margin: 8px 0; }
.footer-inner .legal { font-size: 11px; opacity: 0.7; margin-top: 16px; }
.footer-inner nav { display: flex; gap: 24px; justify-content: center; flex-wrap: wrap; margin-top: 16px; }
.footer-inner nav a { color: var(--gris); text-decoration: none; }
.footer-inner nav a:hover { color: var(--or); }
