/**
 * Gate Away — Single Blog Post Styles
 */

/* ═══ VARIABLES ═══ */
.ga-single-post {
    --ga-blue: #24378C !important;
    --ga-blue-dark: #1a2a6c !important;
    --ga-gold: #C8A44E !important;
    --ga-gold-light: #f5edda !important;
    --ga-gold-dark: #a8873a !important;
    --ga-text: #1a1a2e !important;
    --ga-text-2: #444 !important;
    --ga-text-3: #888 !important;
    --ga-bg: #F8F9FA !important;
    --ga-white: #ffffff !important;
    --ga-radius: 14px !important;
    --ga-shadow: 0 4px 24px rgba(0,0,0,0.06) !important;
    --ga-transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

/* ═══ PAGE RESET ═══ */
.ga-single-post {
    background: var(--ga-bg) !important;
    padding: 0 !important;
    margin: 0 !important;
    font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif !important;
    color: var(--ga-text) !important;
}
.ga-single-post *,
.ga-single-post *::before,
.ga-single-post *::after {
    box-sizing: border-box !important;
}
.ga-single-post a {
    text-decoration: none !important;
    color: inherit !important;
}

/* ═══ CONTAINER ═══ */
.ga-single-container {
    max-width: 1100px !important;
    margin: 0 auto !important;
    padding: 0 24px !important;
}

/* ═══ READING PROGRESS BAR ═══ */
.ga-reading-progress {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    height: 3px !important;
    background: linear-gradient(90deg, var(--ga-gold), var(--ga-blue)) !important;
    z-index: 99999 !important;
    width: 0% !important;
    transition: width 0.1s linear !important;
}

/* ═══ BREADCRUMB ═══ */
.ga-single-breadcrumb {
    background: var(--ga-white) !important;
    border-bottom: 1px solid #eee !important;
    padding: 14px 0 !important;
}
.ga-single-breadcrumb .ga-single-container {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    flex-wrap: wrap !important;
    font-size: 13px !important;
    color: var(--ga-text-3) !important;
}
.ga-single-breadcrumb a {
    color: var(--ga-text-3) !important;
    transition: var(--ga-transition) !important;
}
.ga-single-breadcrumb a:hover {
    color: var(--ga-gold-dark) !important;
}
.ga-single-breadcrumb span:last-child {
    color: var(--ga-text-2) !important;
    font-weight: 600 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    max-width: 300px !important;
}
.ga-single-breadcrumb svg {
    flex-shrink: 0 !important;
    opacity: 0.4 !important;
}

/* ═══ TAG ═══ */
.ga-single-tag,
.ga-guide-tag {
    display: inline-block !important;
    background: var(--ga-gold-light) !important;
    color: var(--ga-gold-dark) !important;
    padding: 4px 14px !important;
    border-radius: 20px !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
}

/* ═══ HERO ═══ */
.ga-single-hero {
    padding: 48px 0 32px !important;
    text-align: center !important;
}
.ga-single-hero__title {
    font-size: 38px !important;
    font-weight: 800 !important;
    color: var(--ga-text) !important;
    line-height: 1.2 !important;
    margin: 16px 0 18px !important;
    letter-spacing: -0.02em !important;
    max-width: 800px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}
.ga-single-hero__excerpt {
    font-size: 18px !important;
    color: var(--ga-text-2) !important;
    line-height: 1.65 !important;
    max-width: 680px !important;
    margin: 0 auto 20px !important;
}
.ga-single-hero__meta {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    flex-wrap: wrap !important;
    font-size: 14px !important;
    color: var(--ga-text-3) !important;
}
.ga-single-hero__meta-item {
    display: inline-flex !important;
    align-items: center !important;
    gap: 5px !important;
}
.ga-single-hero__meta-item svg {
    opacity: 0.5 !important;
}
.ga-single-hero__meta-sep {
    opacity: 0.3 !important;
}

/* ═══ IMAGE PRINCIPALE ═══ */
.ga-single-featured-img {
    padding-bottom: 32px !important;
}
.ga-single-featured-img img {
    width: 100% !important;
    max-height: 500px !important;
    object-fit: cover !important;
    border-radius: var(--ga-radius) !important;
    box-shadow: 0 8px 40px rgba(0,0,0,0.1) !important;
}

/* ═══ LAYOUT 2 COLONNES ═══ */
.ga-single-grid {
    display: grid !important;
    grid-template-columns: 260px 1fr !important;
    gap: 40px !important;
    align-items: start !important;
}

/* ═══ SIDEBAR / SOMMAIRE ═══ */
.ga-single-sidebar {
    position: sticky !important;
    top: 100px !important;
}
.ga-single-toc {
    background: var(--ga-white) !important;
    border-radius: var(--ga-radius) !important;
    box-shadow: var(--ga-shadow) !important;
    padding: 20px !important;
    margin-bottom: 20px !important;
}
.ga-single-toc__title {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    color: var(--ga-text) !important;
    margin: 0 0 14px !important;
    padding-bottom: 12px !important;
    border-bottom: 2px solid var(--ga-gold-light) !important;
}
.ga-single-toc__title svg {
    color: var(--ga-gold) !important;
    flex-shrink: 0 !important;
}

/* TOC List */
.ga-toc-list {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}
.ga-toc-item {
    margin: 0 !important;
    padding: 0 !important;
}
.ga-toc-item--sub {
    padding-left: 14px !important;
}
.ga-toc-link {
    display: block !important;
    padding: 6px 10px !important;
    font-size: 13px !important;
    color: var(--ga-text-3) !important;
    border-left: 2px solid transparent !important;
    border-radius: 0 6px 6px 0 !important;
    transition: var(--ga-transition) !important;
    line-height: 1.4 !important;
}
.ga-toc-link:hover {
    color: var(--ga-text) !important;
    background: var(--ga-bg) !important;
}
.ga-toc-link--active {
    color: var(--ga-gold-dark) !important;
    border-left-color: var(--ga-gold) !important;
    background: var(--ga-gold-light) !important;
    font-weight: 600 !important;
}

/* Sidebar CTA */
.ga-single-sidebar-cta {
    background: linear-gradient(135deg, var(--ga-blue-dark), var(--ga-blue)) !important;
    border-radius: var(--ga-radius) !important;
    padding: 22px 20px !important;
    text-align: center !important;
}
.ga-single-sidebar-cta__title {
    color: var(--ga-white) !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    margin: 0 0 6px !important;
}
.ga-single-sidebar-cta__sub {
    color: rgba(255,255,255,0.7) !important;
    font-size: 13px !important;
    margin: 0 0 14px !important;
    line-height: 1.5 !important;
}
.ga-single-sidebar-cta__btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    background: var(--ga-gold) !important;
    color: var(--ga-white) !important;
    padding: 10px 20px !important;
    border-radius: 8px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    transition: var(--ga-transition) !important;
}
.ga-single-sidebar-cta__btn:hover {
    background: var(--ga-gold-dark) !important;
    transform: translateY(-2px) !important;
}

/* ═══ CONTENU ARTICLE ═══ */
.ga-single-content {
    background: var(--ga-white) !important;
    border-radius: var(--ga-radius) !important;
    box-shadow: var(--ga-shadow) !important;
    padding: 40px 44px !important;
    min-height: 400px !important;
}

/* Typographie du contenu */
.ga-single-content h2 {
    font-size: 26px !important;
    font-weight: 800 !important;
    color: var(--ga-text) !important;
    margin: 40px 0 16px !important;
    padding-top: 24px !important;
    border-top: 2px solid #f0f0f0 !important;
    letter-spacing: -0.01em !important;
    line-height: 1.25 !important;
}
.ga-single-content h2:first-child {
    margin-top: 0 !important;
    padding-top: 0 !important;
    border-top: none !important;
}
.ga-single-content h3 {
    font-size: 20px !important;
    font-weight: 700 !important;
    color: var(--ga-text) !important;
    margin: 28px 0 12px !important;
    line-height: 1.3 !important;
}
.ga-single-content p {
    font-size: 16px !important;
    line-height: 1.8 !important;
    color: var(--ga-text-2) !important;
    margin: 0 0 18px !important;
}
.ga-single-content ul,
.ga-single-content ol {
    margin: 0 0 18px 20px !important;
    padding: 0 !important;
}
.ga-single-content li {
    font-size: 16px !important;
    line-height: 1.8 !important;
    color: var(--ga-text-2) !important;
    margin-bottom: 6px !important;
}
.ga-single-content strong {
    color: var(--ga-text) !important;
    font-weight: 700 !important;
}
.ga-single-content a {
    color: var(--ga-blue) !important;
    font-weight: 600 !important;
    border-bottom: 1px solid rgba(36,55,140,0.2) !important;
    transition: var(--ga-transition) !important;
}
.ga-single-content a:hover {
    color: var(--ga-gold-dark) !important;
    border-bottom-color: var(--ga-gold) !important;
}
.ga-single-content blockquote {
    margin: 24px 0 !important;
    padding: 20px 24px !important;
    border-left: 4px solid var(--ga-gold) !important;
    background: var(--ga-gold-light) !important;
    border-radius: 0 var(--ga-radius) var(--ga-radius) 0 !important;
    font-style: italic !important;
}
.ga-single-content blockquote p {
    margin: 0 !important;
    color: var(--ga-text) !important;
}

/* Images dans le contenu */
.ga-single-content img {
    max-width: 100% !important;
    height: auto !important;
    border-radius: 10px !important;
    margin: 24px 0 !important;
    box-shadow: 0 4px 20px rgba(0,0,0,0.08) !important;
}
.ga-single-content figure {
    margin: 24px 0 !important;
    padding: 0 !important;
}
.ga-single-content figcaption {
    text-align: center !important;
    font-size: 13px !important;
    color: var(--ga-text-3) !important;
    margin-top: 8px !important;
    font-style: italic !important;
}

/* CTA inline dans le contenu */
.ga-single-content .ga-inline-cta {
    background: linear-gradient(135deg, var(--ga-blue-dark), var(--ga-blue)) !important;
    border-radius: var(--ga-radius) !important;
    padding: 28px 32px !important;
    margin: 32px 0 !important;
    text-align: center !important;
    position: relative !important;
    overflow: hidden !important;
}
.ga-single-content .ga-inline-cta::before {
    content: '' !important;
    position: absolute !important;
    top: -30% !important;
    right: -10% !important;
    width: 200px !important;
    height: 200px !important;
    background: radial-gradient(circle, rgba(200,164,78,0.2) 0%, transparent 70%) !important;
    border-radius: 50% !important;
}
.ga-single-content .ga-inline-cta p {
    color: var(--ga-white) !important;
    font-size: 17px !important;
    font-weight: 600 !important;
    margin: 0 0 14px !important;
    position: relative !important;
}
.ga-single-content .ga-inline-cta a {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    background: var(--ga-gold) !important;
    color: var(--ga-white) !important;
    padding: 12px 28px !important;
    border-radius: 8px !important;
    font-weight: 700 !important;
    font-size: 15px !important;
    border: none !important;
    transition: var(--ga-transition) !important;
    position: relative !important;
}
.ga-single-content .ga-inline-cta a:hover {
    background: var(--ga-gold-dark) !important;
    transform: translateY(-2px) !important;
    color: var(--ga-white) !important;
    border: none !important;
}

/* ═══ CTA FULL-WIDTH BANNER ═══ */
.ga-single-cta-banner {
    padding: 48px 0 !important;
}
.ga-single-cta-banner__inner {
    background: linear-gradient(135deg, var(--ga-blue-dark) 0%, var(--ga-blue) 100%) !important;
    border-radius: var(--ga-radius) !important;
    padding: 40px 48px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 32px !important;
    position: relative !important;
    overflow: hidden !important;
}
.ga-single-cta-banner__inner::before {
    content: '' !important;
    position: absolute !important;
    top: -50% !important;
    right: -10% !important;
    width: 350px !important;
    height: 350px !important;
    background: radial-gradient(circle, rgba(200,164,78,0.15) 0%, transparent 70%) !important;
    border-radius: 50% !important;
}
.ga-single-cta-banner__text {
    position: relative !important;
}
.ga-single-cta-banner__text h3 {
    color: var(--ga-white) !important;
    font-size: 24px !important;
    font-weight: 800 !important;
    margin: 0 0 6px !important;
}
.ga-single-cta-banner__text p {
    color: rgba(255,255,255,0.75) !important;
    font-size: 15px !important;
    margin: 0 !important;
}
.ga-single-cta-banner__btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 10px !important;
    background: var(--ga-gold) !important;
    color: var(--ga-white) !important;
    padding: 16px 32px !important;
    border-radius: 10px !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    white-space: nowrap !important;
    transition: var(--ga-transition) !important;
    box-shadow: 0 4px 16px rgba(200,164,78,0.3) !important;
    flex-shrink: 0 !important;
    position: relative !important;
}
.ga-single-cta-banner__btn:hover {
    background: var(--ga-gold-dark) !important;
    transform: translateY(-3px) !important;
    box-shadow: 0 8px 24px rgba(200,164,78,0.4) !important;
}

/* ═══ PARTAGE ═══ */
.ga-single-share {
    padding: 0 0 48px !important;
}
.ga-single-share .ga-single-container {
    display: flex !important;
    align-items: center !important;
    gap: 16px !important;
    justify-content: center !important;
}
.ga-single-share__label {
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--ga-text-3) !important;
    margin: 0 !important;
}
.ga-single-share__btns {
    display: flex !important;
    gap: 10px !important;
}
.ga-single-share__btn {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 44px !important;
    height: 44px !important;
    border-radius: 10px !important;
    transition: var(--ga-transition) !important;
    color: var(--ga-white) !important;
}
.ga-single-share__btn:hover {
    transform: translateY(-3px) !important;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15) !important;
}
.ga-single-share__btn--wa {
    background: #25D366 !important;
}
.ga-single-share__btn--fb {
    background: #1877F2 !important;
}
.ga-single-share__btn--tw {
    background: #1a1a2e !important;
}
.ga-single-share__btn--email {
    background: var(--ga-gold) !important;
}

/* ═══ ARTICLES SIMILAIRES ═══ */
.ga-single-related {
    padding: 0 0 64px !important;
}
.ga-single-related__title {
    font-size: 26px !important;
    font-weight: 800 !important;
    color: var(--ga-text) !important;
    text-align: center !important;
    margin: 0 0 32px !important;
}
.ga-single-related__grid {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 24px !important;
}
.ga-single-related__card {
    background: var(--ga-white) !important;
    border-radius: var(--ga-radius) !important;
    overflow: hidden !important;
    box-shadow: var(--ga-shadow) !important;
    transition: var(--ga-transition) !important;
}
.ga-single-related__card:hover {
    transform: translateY(-6px) !important;
    box-shadow: 0 12px 40px rgba(0,0,0,0.1) !important;
}
.ga-single-related__img {
    height: 180px !important;
    background-size: cover !important;
    background-position: center !important;
}
.ga-single-related__img--placeholder {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: #f0f0f0 !important;
}
.ga-single-related__body {
    padding: 18px 20px 22px !important;
}
.ga-single-related__body h3 {
    font-size: 16px !important;
    font-weight: 700 !important;
    margin: 8px 0 10px !important;
    line-height: 1.35 !important;
    color: var(--ga-text) !important;
}
.ga-single-related__card:hover h3 {
    color: var(--ga-blue) !important;
}
.ga-single-related__meta {
    font-size: 12px !important;
    color: var(--ga-text-3) !important;
}

/* ═══════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════ */
@media (max-width: 1024px) {
    .ga-single-grid {
        grid-template-columns: 1fr !important;
    }

    /* Sommaire mobile : barre collante en haut */
    .ga-single-sidebar {
        position: relative !important;
        top: 0 !important;
        order: -1 !important;
    }
    .ga-single-toc {
        border-radius: 10px !important;
    }
    .ga-single-toc__title {
        cursor: pointer !important;
        margin-bottom: 0 !important;
        padding-bottom: 0 !important;
        border-bottom: none !important;
    }
    .ga-single-toc__nav {
        max-height: 0 !important;
        overflow: hidden !important;
        transition: max-height 0.3s ease !important;
    }
    .ga-single-toc--open .ga-single-toc__nav {
        max-height: 600px !important;
        margin-top: 12px !important;
        padding-top: 12px !important;
        border-top: 2px solid var(--ga-gold-light) !important;
    }
    .ga-single-toc__title::after {
        content: '+' !important;
        margin-left: auto !important;
        font-size: 20px !important;
        font-weight: 300 !important;
        color: var(--ga-text-3) !important;
        transition: var(--ga-transition) !important;
    }
    .ga-single-toc--open .ga-single-toc__title::after {
        content: '−' !important;
    }

    .ga-single-sidebar-cta {
        display: none !important;
    }

    .ga-single-related__grid {
        grid-template-columns: 1fr !important;
    }
}

@media (max-width: 768px) {
    .ga-single-hero {
        padding: 32px 0 24px !important;
    }
    .ga-single-hero__title {
        font-size: 26px !important;
    }
    .ga-single-hero__excerpt {
        font-size: 16px !important;
    }
    .ga-single-content {
        padding: 24px 20px !important;
    }
    .ga-single-content h2 {
        font-size: 22px !important;
    }
    .ga-single-content h3 {
        font-size: 18px !important;
    }
    .ga-single-content p,
    .ga-single-content li {
        font-size: 15px !important;
    }
    .ga-single-featured-img img {
        max-height: 280px !important;
        border-radius: 10px !important;
    }
    .ga-single-cta-banner__inner {
        flex-direction: column !important;
        text-align: center !important;
        padding: 32px 24px !important;
    }
    .ga-single-cta-banner__btn {
        width: 100% !important;
        justify-content: center !important;
    }
    .ga-single-share .ga-single-container {
        flex-direction: column !important;
        gap: 12px !important;
    }
    .ga-single-breadcrumb span:last-child {
        max-width: 180px !important;
    }
}
