/* ============================================================
   QAF Blog — Redesigned Stylesheet
   Aesthetic: Editorial luxury — dark navy hero, cream content,
   typographic rhythm, intentional whitespace, gold accents
   ============================================================ */

/* ──────────────────────────────────────────────────────────
   BLOG HERO
────────────────────────────────────────────────────────── */
.blog-hero {
    position: relative;
    background: var(--navy);
    padding: calc(var(--nav-height) + 80px) 0 100px;
    overflow: hidden;
}

/* Diagonal geometric pattern */
.blog-hero-bg-pattern {
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(45deg, rgba(255,255,255,0.015) 25%, transparent 25%),
        linear-gradient(-45deg, rgba(255,255,255,0.015) 25%, transparent 25%),
        linear-gradient(45deg, transparent 75%, rgba(255,255,255,0.015) 75%),
        linear-gradient(-45deg, transparent 75%, rgba(255,255,255,0.015) 75%);
    background-size: 40px 40px;
    background-position: 0 0, 0 20px, 20px -20px, -20px 0px;
    pointer-events: none;
}

/* Gold ambient orbs */
.blog-hero-orb {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    filter: blur(80px);
}
.blog-hero-orb--1 {
    width: 500px; height: 500px;
    background: radial-gradient(circle, rgba(197,150,58,0.18) 0%, transparent 70%);
    top: -100px; right: -80px;
}
.blog-hero-orb--2 {
    width: 360px; height: 360px;
    background: radial-gradient(circle, rgba(200,16,46,0.12) 0%, transparent 70%);
    bottom: -80px; left: 10%;
}

.blog-hero-container {
    position: relative;
    z-index: 2;
}

/* Eyebrow row */
.blog-hero-eyebrow {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 28px;
}
.blog-hero-tag {
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--gold);
    background: rgba(197,150,58,0.12);
    border: 1px solid rgba(197,150,58,0.3);
    padding: 6px 14px;
}
.blog-hero-divider {
    display: block;
    width: 32px;
    height: 1px;
    background: rgba(255,255,255,0.25);
}
.blog-hero-freq {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.45);
}

/* Main heading */
.blog-hero-heading {
    font-family: 'Cinzel', serif;
    font-size: clamp(32px, 4.5vw, 62px);
    font-weight: 900;
    color: #fff;
    line-height: 1.06;
    letter-spacing: -0.02em;
    margin-bottom: 24px;
}
.blog-hero-heading em {
    color: var(--gold-light);
    font-style: normal;
    position: relative;
}
.blog-hero-heading em::after {
    content: '';
    position: absolute;
    bottom: -4px;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg, var(--gold), transparent);
}

/* Sub */
.blog-hero-sub {
    font-size: 16px;
    color: rgba(255,255,255,0.55);
    line-height: 1.85;
    max-width: 560px;
    margin-bottom: 44px;
}

/* Stats row */
.blog-hero-stats {
    display: flex;
    align-items: center;
    gap: 0;
}
.blog-hero-stat {
    display: flex;
    flex-direction: column;
    gap: 3px;
    padding-right: 32px;
    margin-right: 32px;
    border-right: 1px solid rgba(255,255,255,0.12);
}
.blog-hero-stat:last-of-type {
    border-right: none;
    margin-right: 0;
    padding-right: 0;
}
.bhs-sep { display: none; }
.bhs-num {
    font-family: 'Cinzel', serif;
    font-size: 26px;
    font-weight: 900;
    color: #fff;
    line-height: 1;
}
.bhs-label {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.4);
}

/* Scroll hint */
.blog-hero-scroll-hint {
    position: absolute;
    bottom: 28px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    font-size: 9px;
    font-weight: 800;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.3);
    z-index: 2;
}
.scroll-arrow {
    display: block;
    width: 1px;
    height: 32px;
    background: linear-gradient(180deg, rgba(255,255,255,0.3), transparent);
    animation: scrollPulse 1.6s ease-in-out infinite;
}
@keyframes scrollPulse {
    0%, 100% { transform: scaleY(1); opacity: 0.3; }
    50% { transform: scaleY(1.2); opacity: 0.7; }
}


/* ──────────────────────────────────────────────────────────
   BLOG MAIN
────────────────────────────────────────────────────────── */
.blog-main {
    background: var(--cream-mid);
    padding: 72px 0 96px;
}


/* ──────────────────────────────────────────────────────────
   TOOLBAR
────────────────────────────────────────────────────────── */
.blog-toolbar {
    background: #fff;
    border: 1px solid var(--border-cream);
    box-shadow: var(--shadow-sm);
    padding: 18px 24px;
    margin-bottom: 36px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    flex-wrap: wrap;
}

.blog-toolbar-left {
    display: flex;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
}

.blog-toolbar-label {
    font-size: 9px;
    font-weight: 800;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--text-muted);
    white-space: nowrap;
}

/* Filter tabs */
.filter-tabs {
    display: flex;
    gap: 2px;
    flex-wrap: wrap;
}
.filter-tab {
    background: transparent;
    border: 1.5px solid var(--border-cream);
    color: var(--navy);
    font-family: 'Nunito Sans', sans-serif;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.09em;
    text-transform: uppercase;
    padding: 7px 16px;
    cursor: pointer;
    transition: background 0.2s, border-color 0.2s, color 0.2s;
}
.filter-tab:hover {
    border-color: var(--navy);
    background: var(--cream);
}
.filter-tab.active {
    background: var(--navy);
    border-color: var(--navy);
    color: #fff;
}

/* Search */
.blog-search-wrap {
    min-width: 260px;
    flex: 1;
    max-width: 340px;
    position: relative;
}
.blog-search-icon {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    width: 15px;
    height: 15px;
    color: var(--text-muted);
    pointer-events: none;
}
.blog-search-input {
    width: 100%;
    border: 1.5px solid var(--border-cream);
    background: var(--cream);
    color: var(--navy);
    font-family: 'Nunito Sans', sans-serif;
    font-size: 13px;
    padding: 9px 14px 9px 38px;
    outline: none;
    transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
}
.blog-search-input:focus {
    border-color: var(--navy);
    background: #fff;
    box-shadow: 0 0 0 3px rgba(27,42,74,0.07);
}
.blog-search-input::placeholder { color: var(--text-muted); }


/* ──────────────────────────────────────────────────────────
   BLOG LAYOUT
────────────────────────────────────────────────────────── */
.blog-layout {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 48px;
    align-items: start;
}

.blog-grid {
    display: flex;
    flex-direction: column;
    gap: 0;
}


/* ──────────────────────────────────────────────────────────
   FEATURED POST
────────────────────────────────────────────────────────── */
.blog-featured {
    display: grid;
    grid-template-columns: 1fr 1fr;
    background: #fff;
    border: 1px solid var(--border-cream);
    overflow: hidden;
    margin-bottom: 32px;
    transition: box-shadow 0.35s, transform 0.35s;
}
.blog-featured:hover {
    box-shadow: var(--shadow-hover);
    transform: translateY(-3px);
}

.blog-featured-img {
    position: relative;
    min-height: 340px;
    background: var(--navy);
    overflow: hidden;
}
.blog-featured-img img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}
.blog-featured:hover .blog-featured-img img {
    transform: scale(1.04);
}
.blog-featured-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(27,42,74,0.35) 0%, transparent 60%);
    z-index: 1;
}
.blog-featured-badge {
    position: absolute;
    top: 20px;
    left: 20px;
    z-index: 2;
    background: var(--gold);
    color: var(--navy);
    font-size: 9px;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    padding: 5px 12px;
    display: flex;
    align-items: center;
    gap: 5px;
}
.blog-featured-badge svg {
    width: 10px;
    height: 10px;
}

/* Placeholder */
.blog-img-placeholder {
    position: absolute;
    inset: 0;
    background: linear-gradient(150deg, #1B2A4A, #283c63);
    display: flex;
    align-items: center;
    justify-content: center;
}
.bip-letter {
    font-family: 'Cinzel', serif;
    font-size: 80px;
    font-weight: 900;
    color: rgba(255,255,255,0.06);
    letter-spacing: -0.05em;
    user-select: none;
}
.blog-img-placeholder--sm .bip-letter { font-size: 48px; }

/* Featured body */
.blog-featured-body {
    padding: 40px 44px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    position: relative;
}
.blog-featured-body::before {
    content: '';
    position: absolute;
    left: 0;
    top: 40px;
    bottom: 40px;
    width: 3px;
    background: linear-gradient(180deg, var(--gold), var(--crimson));
    opacity: 0;
    transition: opacity 0.3s;
}
.blog-featured:hover .blog-featured-body::before { opacity: 1; }

.blog-cat {
    display: inline-block;
    background: var(--crimson);
    color: #fff;
    font-size: 9px;
    font-weight: 800;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    padding: 5px 12px;
    margin-bottom: 16px;
    align-self: flex-start;
}
.blog-cat.gold { background: var(--gold); color: var(--navy); }

.blog-title {
    font-family: 'Cinzel', serif;
    font-size: 22px;
    font-weight: 700;
    color: var(--navy);
    line-height: 1.25;
    text-decoration: none;
    display: block;
    margin-bottom: 14px;
    transition: color 0.2s;
}
.blog-title:hover { color: var(--crimson); }

.blog-excerpt {
    font-size: 14px;
    color: var(--text-body);
    line-height: 1.8;
    margin-bottom: 24px;
}

.blog-meta {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 11px;
    color: var(--text-muted);
    flex-wrap: wrap;
    margin-bottom: 24px;
}
.blog-meta-dot {
    display: inline-block;
    width: 3px;
    height: 3px;
    border-radius: 50%;
    background: var(--border-cream);
    flex-shrink: 0;
}

.blog-author-chip {
    display: flex;
    align-items: center;
    gap: 7px;
}
.blog-author-dot {
    width: 26px;
    height: 26px;
    border-radius: 50%;
    background: var(--crimson);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    font-weight: 800;
    flex-shrink: 0;
}
.blog-author-name-text {
    font-weight: 700;
    color: var(--navy);
    font-size: 11px;
}

.blog-read-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--crimson);
    text-decoration: none;
    transition: gap 0.2s;
    align-self: flex-start;
}
.blog-read-link svg {
    width: 15px;
    height: 15px;
    transition: transform 0.2s;
}
.blog-read-link:hover { gap: 12px; color: var(--crimson-dark); }
.blog-read-link:hover svg { transform: translateX(3px); }


/* ──────────────────────────────────────────────────────────
   BLOG CARDS ROW
────────────────────────────────────────────────────────── */
.blog-cards-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1px;
    background: var(--border-cream);
    border: 1px solid var(--border-cream);
    overflow: hidden;
}

.blog-card {
    display: grid;
    grid-template-columns: 200px 1fr;
    background: #fff;
    transition: box-shadow 0.25s;
    position: relative;
}
.blog-card:hover {
    box-shadow: 4px 0 0 inset var(--crimson), var(--shadow-card);
    z-index: 1;
}

.blog-card-img {
    position: relative;
    background: var(--cream-dark);
    min-height: 160px;
    overflow: hidden;
}
.blog-card-img img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s;
}
.blog-card:hover .blog-card-img img { transform: scale(1.06); }
.blog-card-cat-badge {
    position: absolute;
    bottom: 10px;
    left: 10px;
    background: var(--crimson);
    color: #fff;
    font-size: 8px;
    font-weight: 800;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    padding: 4px 9px;
    z-index: 2;
}
.blog-card-cat-badge.gold { background: var(--gold); color: var(--navy); }

.blog-card-body {
    padding: 24px 28px;
    display: flex;
    flex-direction: column;
}
.blog-card-title {
    font-family: 'Cinzel', serif;
    font-size: 15px;
    font-weight: 700;
    color: var(--navy);
    line-height: 1.3;
    text-decoration: none;
    display: block;
    margin-bottom: 10px;
    transition: color 0.2s;
}
.blog-card-title:hover { color: var(--crimson); }
.blog-card-excerpt {
    font-size: 13px;
    color: var(--text-body);
    line-height: 1.75;
    flex: 1;
    margin-bottom: 16px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.blog-card-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: auto;
}
.blog-card-arrow {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border: 1.5px solid var(--border-cream);
    color: var(--navy);
    transition: background 0.2s, border-color 0.2s, color 0.2s;
    flex-shrink: 0;
}
.blog-card-arrow svg { width: 14px; height: 14px; }
.blog-card:hover .blog-card-arrow {
    background: var(--crimson);
    border-color: var(--crimson);
    color: #fff;
}


/* ──────────────────────────────────────────────────────────
   EMPTY STATE
────────────────────────────────────────────────────────── */
.blog-empty-state {
    background: #fff;
    border: 1px dashed var(--border-cream);
    padding: 60px 32px;
    text-align: center;
    margin-top: 24px;
}
.blog-empty-icon {
    width: 64px;
    height: 64px;
    margin: 0 auto 20px;
    color: var(--text-muted);
    opacity: 0.5;
}
.blog-empty-icon svg { width: 100%; height: 100%; }
.blog-empty-state h4 {
    font-family: 'Cinzel', serif;
    font-size: 18px;
    color: var(--navy);
    margin-bottom: 8px;
}
.blog-empty-state p {
    font-size: 13px;
    color: var(--text-muted);
    margin-bottom: 20px;
}
.blog-empty-reset {
    background: transparent;
    border: 1.5px solid var(--navy);
    color: var(--navy);
    font-family: 'Nunito Sans', sans-serif;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    padding: 9px 22px;
    cursor: pointer;
    transition: background 0.2s, color 0.2s;
}
.blog-empty-reset:hover { background: var(--navy); color: #fff; }

.blog-hidden { display: none !important; }


/* ──────────────────────────────────────────────────────────
   SIDEBAR
────────────────────────────────────────────────────────── */
.blog-sidebar {
    position: sticky;
    top: calc(var(--nav-height) + 24px);
    align-self: start;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.sidebar-widget {
    background: #fff;
    border: 1px solid var(--border-cream);
    padding: 28px;
}

.sidebar-widget-title {
    font-family: 'Cinzel', serif;
    font-size: 13px;
    font-weight: 700;
    color: var(--navy);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: 20px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--border-cream);
    position: relative;
}
.sidebar-widget-title::after {
    content: '';
    position: absolute;
    bottom: -1px;
    left: 0;
    width: 40px;
    height: 2px;
    background: var(--crimson);
}

/* Sidebar category links */
.sidebar-cats {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.sidebar-cat {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    text-decoration: none;
    color: var(--text-body);
    font-size: 13px;
    font-weight: 600;
    transition: background 0.18s, color 0.18s, transform 0.18s;
    border-left: 2px solid transparent;
}
.sidebar-cat:hover {
    background: var(--cream);
    color: var(--navy);
    border-left-color: var(--crimson);
    transform: translateX(3px);
}

/* Category icons */
.sc-icon {
    width: 30px;
    height: 30px;
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.sc-icon svg { width: 14px; height: 14px; }
.sc-icon--market  { background: rgba(27,42,74,0.07);   color: var(--navy); }
.sc-icon--quality { background: rgba(197,150,58,0.1);  color: var(--gold); }
.sc-icon--dist    { background: rgba(200,16,46,0.07);  color: var(--crimson); }
.sc-icon--brand   { background: rgba(27,42,74,0.07);   color: var(--navy); }
.sc-label { flex: 1; }
.sc-count {
    font-size: 11px;
    font-weight: 800;
    color: var(--text-muted);
    background: var(--cream);
    border: 1px solid var(--border-cream);
    padding: 2px 8px;
    min-width: 28px;
    text-align: center;
}

/* Recent posts */
.sidebar-recents { display: flex; flex-direction: column; }
.recent-post {
    display: flex;
    gap: 12px;
    padding: 12px 0;
    border-bottom: 1px solid var(--border-cream);
}
.recent-post:last-child { border-bottom: none; padding-bottom: 0; }

.recent-post-img {
    width: 64px;
    height: 56px;
    background: var(--cream-dark);
    flex-shrink: 0;
    display: block;
    overflow: hidden;
    position: relative;
    text-decoration: none;
}
.recent-post-img img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s;
}
.recent-post-img:hover img { transform: scale(1.08); }
.rp-placeholder {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Cinzel', serif;
    font-size: 22px;
    font-weight: 900;
    color: rgba(27,42,74,0.12);
    background: var(--cream-dark);
}

.recent-post-info { display: flex; flex-direction: column; justify-content: center; gap: 4px; }
.recent-post-title {
    font-size: 12.5px;
    font-weight: 700;
    color: var(--navy);
    line-height: 1.35;
    text-decoration: none;
    display: block;
    transition: color 0.2s;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.recent-post-title:hover { color: var(--crimson); }
.recent-post-date {
    font-size: 10px;
    color: var(--text-muted);
    font-weight: 600;
}

/* Newsletter widget */
.blog-newsletter {
    background: linear-gradient(150deg, var(--navy), #283c63);
    border-color: transparent;
}
.newsletter-icon {
    width: 44px;
    height: 44px;
    background: rgba(255,255,255,0.08);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 16px;
    color: var(--gold);
}
.newsletter-icon svg { width: 22px; height: 22px; }
.blog-newsletter .sidebar-widget-title { color: #fff; border-bottom-color: rgba(255,255,255,0.1); }
.blog-newsletter .sidebar-widget-title::after { background: var(--gold); }
.blog-newsletter p {
    font-size: 13px;
    color: rgba(255,255,255,0.6);
    line-height: 1.7;
    margin-bottom: 18px;
}
.blog-newsletter .btn-primary {
    width: 100%;
    text-align: center;
    background: var(--gold);
    color: var(--navy);
}
.blog-newsletter .btn-primary:hover {
    background: var(--gold-light);
    box-shadow: 0 8px 24px rgba(197,150,58,0.35);
    color: var(--navy);
}


/* ──────────────────────────────────────────────────────────
   FADE-IN CARDS (intersection observer)
────────────────────────────────────────────────────────── */
.fade-card {
    opacity: 0;
    transform: translateY(18px);
    transition: opacity 0.5s ease, transform 0.5s ease;
}
.fade-card.visible {
    opacity: 1;
    transform: translateY(0);
}


/* ══════════════════════════════════════════════
   BLOG DETAILS / SHOW PAGE
══════════════════════════════════════════════ */

/* Reading progress */
.blog-reading-progress {
    position: fixed;
    top: 0;
    left: 0;
    height: 3px;
    width: 0;
    background: linear-gradient(90deg, var(--gold), var(--crimson));
    z-index: 1100;
    transition: width 0.12s linear;
}

/* Details hero — inherits base hero styles */
.blog-details-hero {
    position: relative;
    background: var(--navy);
    padding: calc(var(--nav-height) + 64px) 0 80px;
    overflow: hidden;
}
.blog-details-hero .blog-hero-bg-pattern,
.blog-details-hero .blog-hero-orb { /* reuse from blog-hero */ }

/* Breadcrumb */
.bdh-breadcrumb {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 20px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.4);
}
.bdh-breadcrumb a {
    color: rgba(255,255,255,0.5);
    text-decoration: none;
    transition: color 0.2s;
}
.bdh-breadcrumb a:hover { color: var(--gold); }
.bdh-breadcrumb svg { width: 10px; height: 10px; color: rgba(255,255,255,0.25); }

.blog-details-hero .blog-cat { margin-bottom: 18px; }

.blog-details-hero h1 {
    font-family: 'Cinzel', serif;
    font-size: clamp(26px, 3.5vw, 50px);
    font-weight: 900;
    color: #fff;
    line-height: 1.1;
    max-width: 760px;
    margin-bottom: 28px;
    letter-spacing: -0.02em;
}

/* Meta row */
.blog-details-meta {
    display: flex;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
}
.blog-author-card {
    display: flex;
    align-items: center;
    gap: 12px;
}
.blog-author-avatar {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: rgba(197,150,58,0.25);
    border: 2px solid rgba(197,150,58,0.4);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Cinzel', serif;
    font-size: 17px;
    font-weight: 900;
    color: var(--gold-light);
    flex-shrink: 0;
}
.blog-author-name {
    font-size: 13px;
    font-weight: 700;
    color: #fff;
    line-height: 1.2;
}
.blog-author-role {
    font-size: 10px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.4);
    margin-top: 2px;
}

.blog-meta-sep {
    display: block;
    width: 1px;
    height: 32px;
    background: rgba(255,255,255,0.15);
    flex-shrink: 0;
}

.bdh-meta-items {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
}
.blog-meta-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: rgba(255,255,255,0.5);
    font-weight: 600;
}
.blog-meta-item svg { width: 13px; height: 13px; flex-shrink: 0; }


/* ──────────────────────────────────────────────────────────
   DETAILS BODY
────────────────────────────────────────────────────────── */
.blog-details-body {
    background: var(--cream-mid);
    padding: 72px 0 96px;
}

.blog-details-layout {
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: 56px;
    align-items: start;
}

/* Cover image */
.blog-cover-img {
    width: 100%;
    height: 400px;
    background: var(--cream-dark);
    border: 1px solid var(--border-cream);
    overflow: hidden;
    margin-bottom: 48px;
    position: relative;
}
.blog-cover-placeholder {
    position: absolute;
    inset: 0;
    background: linear-gradient(150deg, var(--navy), #283c63);
    display: flex;
    align-items: center;
    justify-content: center;
}
.blog-cover-placeholder span {
    font-family: 'Cinzel', serif;
    font-size: 120px;
    font-weight: 900;
    color: rgba(255,255,255,0.05);
    user-select: none;
}

/* Article content */
.blog-content {
    font-size: 16.5px;
    color: var(--text-body);
    line-height: 1.95;
}
.blog-content-lead {
    font-size: 18px;
    color: var(--navy);
    font-weight: 600;
    line-height: 1.75;
    margin-bottom: 28px;
    padding-left: 20px;
    border-left: 3px solid var(--gold);
}
.blog-content h2 {
    font-family: 'Cinzel', serif;
    font-size: 24px;
    font-weight: 700;
    color: var(--navy);
    margin: 44px 0 18px;
    scroll-margin-top: 100px;
}
.blog-content h2::before {
    content: '';
    display: block;
    width: 32px;
    height: 2px;
    background: var(--crimson);
    margin-bottom: 10px;
}
.blog-content h3 {
    font-family: 'Cinzel', serif;
    font-size: 18px;
    font-weight: 700;
    color: var(--navy);
    margin: 32px 0 12px;
    scroll-margin-top: 100px;
}
.blog-content p { margin-bottom: 22px; }
.blog-content blockquote {
    border-left: 3px solid var(--gold);
    padding: 16px 24px;
    background: var(--cream);
    margin: 28px 0;
    font-style: italic;
    color: var(--navy);
    font-size: 17px;
    line-height: 1.75;
}
.blog-content ul {
    margin: 0 0 22px 24px;
    list-style: disc;
}
.blog-content ul li { margin-bottom: 10px; line-height: 1.75; }
.blog-content strong { color: var(--navy); font-weight: 700; }

/* Content tags */
.blog-content-tags {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-top: 40px;
    padding-top: 28px;
    border-top: 1px solid var(--border-cream);
}
.blog-tag {
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--navy);
    border: 1.5px solid var(--border-cream);
    background: var(--cream);
    padding: 5px 13px;
    transition: border-color 0.2s, background 0.2s;
    cursor: default;
}
.blog-tag:hover {
    border-color: var(--navy);
    background: #fff;
}

/* Share strip */
.blog-share-strip {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 20px 24px;
    background: var(--cream);
    border: 1px solid var(--border-cream);
    margin-top: 28px;
    flex-wrap: wrap;
}
.bss-label {
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--text-muted);
}
.bss-actions {
    display: flex;
    align-items: center;
    gap: 8px;
}
.bss-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border: 1.5px solid var(--border-cream);
    background: #fff;
    color: var(--navy);
    text-decoration: none;
    cursor: pointer;
    transition: background 0.2s, border-color 0.2s, color 0.2s;
    font-family: inherit;
}
.bss-btn svg { width: 15px; height: 15px; }
.bss-btn:hover { background: var(--navy); border-color: var(--navy); color: #fff; }
.bss-copy { position: relative; }
.bss-copy .check-icon { display: none; }
.bss-copy.copied .check-icon { display: block; }
.bss-copy.copied svg:not(.check-icon) { display: none; }
.bss-copy.copied { background: #22c55e; border-color: #22c55e; color: #fff; }

/* Author bio */
.blog-author-bio {
    background: #fff;
    border: 1px solid var(--border-cream);
    padding: 32px;
    margin-top: 40px;
    display: flex;
    gap: 24px;
    position: relative;
    overflow: hidden;
}
.blog-author-bio::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--gold), var(--crimson));
}
.blog-author-bio-avatar {
    width: 68px;
    height: 68px;
    border-radius: 50%;
    background: var(--navy);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Cinzel', serif;
    font-size: 26px;
    font-weight: 900;
    color: var(--gold-light);
    flex-shrink: 0;
}
.babi-label {
    font-size: 9px;
    font-weight: 800;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--crimson);
    margin-bottom: 5px;
}
.blog-author-bio-info h4 {
    font-family: 'Cinzel', serif;
    font-size: 16px;
    font-weight: 700;
    color: var(--navy);
    margin-bottom: 2px;
}
.blog-author-bio .role {
    font-size: 10px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--text-muted);
    margin-bottom: 10px;
}
.blog-author-bio p {
    font-size: 13.5px;
    color: var(--text-body);
    line-height: 1.7;
    margin: 0;
}

/* Related (mobile) */
.blog-related-mobile { margin-top: 48px; }
.brm-title {
    font-family: 'Cinzel', serif;
    font-size: 16px;
    font-weight: 700;
    color: var(--navy);
    margin-bottom: 20px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border-cream);
}
.brm-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.brm-card {
    text-decoration: none;
    display: block;
    border: 1px solid var(--border-cream);
    background: #fff;
    overflow: hidden;
    transition: box-shadow 0.2s;
}
.brm-card:hover { box-shadow: var(--shadow-card); }
.brm-img {
    height: 100px;
    background: var(--cream-dark);
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}
.brm-img img { width: 100%; height: 100%; object-fit: cover; position: absolute; inset: 0; }
.brm-img span {
    font-family: 'Cinzel', serif;
    font-size: 32px;
    font-weight: 900;
    color: rgba(27,42,74,0.1);
}
.brm-body { padding: 14px; }
.brm-card-title {
    font-size: 12px;
    font-weight: 700;
    color: var(--navy);
    line-height: 1.4;
    margin-bottom: 6px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.brm-date { font-size: 10px; color: var(--text-muted); }


/* ──────────────────────────────────────────────────────────
   DETAILS SIDEBAR — TOC + Back
────────────────────────────────────────────────────────── */
.sidebar-toc-widget .sidebar-cat {
    gap: 12px;
    font-size: 12.5px;
}
.toc-num {
    font-family: 'Cinzel', serif;
    font-size: 10px;
    font-weight: 900;
    color: var(--text-muted);
    min-width: 24px;
}
.sidebar-cat:hover .toc-num { color: var(--crimson); }

/* Back to blog */
.sidebar-back-widget {
    padding: 20px 24px;
    background: var(--cream);
    border-color: var(--border-cream);
}
.back-to-blog {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--navy);
    text-decoration: none;
    transition: gap 0.2s, color 0.2s;
}
.back-to-blog svg { width: 15px; height: 15px; transition: transform 0.2s; }
.back-to-blog:hover { color: var(--crimson); gap: 12px; }
.back-to-blog:hover svg { transform: translateX(-3px); }


/* ──────────────────────────────────────────────────────────
   RESPONSIVE
────────────────────────────────────────────────────────── */
@media (max-width: 1024px) {
    .blog-layout {
        grid-template-columns: 1fr;
    }
    .blog-sidebar {
        display: none;
        position: static;
    }
    .blog-details-layout {
        grid-template-columns: 1fr;
    }
    .blog-details-layout .blog-sidebar {
        display: flex;
    }
}

@media (max-width: 900px) {
    .blog-featured {
        grid-template-columns: 1fr;
    }
    .blog-featured-img {
        min-height: 220px;
    }
}

@media (max-width: 768px) {
    .blog-hero {
        padding: calc(var(--nav-height) + 48px) 0 72px;
    }
    .blog-toolbar {
        padding: 14px 16px;
    }
    .blog-toolbar-left { width: 100%; }
    .blog-search-wrap { min-width: 100%; max-width: 100%; }
    .blog-hero-stats { flex-wrap: wrap; gap: 16px; }
    .blog-hero-stat { border-right: none; padding-right: 0; margin-right: 0; }
    .blog-details-hero h1 { font-size: clamp(22px, 6vw, 36px); }
    .blog-cover-img { height: 240px; }
    .brm-grid { grid-template-columns: 1fr; }
    .blog-share-strip { gap: 12px; }
}

/* Pagination (Bootstrap 5) */
.blog-pagination {
    margin-top: 40px;
    display: flex;
    justify-content: center;
}
.blog-pagination .pagination {
    gap: 6px;
    flex-wrap: wrap;
    margin: 0;
    padding: 0;
    list-style: none;
}
.blog-pagination .page-item {
    list-style: none;
}
.blog-pagination .page-link {
    border: 1.5px solid var(--border-cream);
    color: var(--navy);
    font-size: 13px;
    font-weight: 700;
    padding: 9px 16px;
    background: #fff;
    border-radius: 0;
    text-decoration: none;
    min-width: 42px;
    text-align: center;
    transition: background 0.2s, border-color 0.2s, color 0.2s;
}
.blog-pagination .page-item.active .page-link {
    background: var(--navy);
    border-color: var(--navy);
    color: #fff;
    z-index: 1;
}
.blog-pagination .page-link:hover {
    background: var(--cream);
    color: var(--crimson);
    border-color: var(--navy);
}
.blog-pagination .page-item.disabled .page-link {
    opacity: 0.4;
    pointer-events: none;
}

.blog-toc {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

@media (max-width: 640px) {
    .blog-card {
        grid-template-columns: 1fr;
    }
    .blog-card-img {
        height: 150px;
        min-height: 150px;
    }
    .blog-featured-body { padding: 28px 24px; }
    .blog-author-bio { flex-direction: column; gap: 16px; }
    .blog-author-bio-avatar { width: 56px; height: 56px; font-size: 20px; }
    .blog-hero-heading { font-size: clamp(28px, 8vw, 42px); }
    .blog-content { font-size: 15px; }
    .blog-content-lead { font-size: 16px; }
}
