/* ============================================================
   BLOG POST styles · cargado condicionalmente cuando $currentPage = 'blog'
   Define todo el sistema de tipografía, layout y componentes del blog:
   .blog-post-hero / .blog-card / .blog-toc / .blog-callout / .blog-list / etc.
   ============================================================ */

.blog-post-hero { background: var(--color-dark); padding: 100px 0 48px; }
.blog-post-hero-inner { max-width: 780px; }
.blog-post-meta-top { margin-bottom: 16px; }
.blog-post-meta-top .blog-card-cat { display: inline-flex; align-items: center; gap: 6px; }
.blog-card-cat { display: inline-block; font-size: 11px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--color-gold-light); }
.blog-post-hero h1 { font-family: var(--font-serif); font-size: clamp(1.8rem, 3.5vw, 2.8rem); font-weight: 700; color: #fff; line-height: 1.2; margin: 0 0 16px; }
.blog-post-hero h1 em { font-style: italic; color: var(--color-gold-light); }
.blog-post-lead { font-size: 17px; color: rgba(255,255,255,.75); line-height: 1.65; margin: 0 0 28px; max-width: 660px; }

.blog-reviewed-by { display: flex; align-items: center; gap: 14px; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.15); border-radius: 10px; padding: 14px 18px; max-width: 460px; }
.blog-reviewed-avatar { width: 48px; height: 48px; border-radius: 50%; object-fit: cover; flex-shrink: 0; border: 2px solid var(--color-gold); }
.blog-reviewed-label { display: block; font-size: 10px; text-transform: uppercase; letter-spacing: .1em; color: rgba(255,255,255,.5); margin-bottom: 2px; }
.blog-reviewed-name { display: block; font-size: 14px; font-weight: 700; color: #fff; line-height: 1.2; }
.blog-reviewed-role { display: block; font-size: 12px; color: var(--color-gold-light); margin-top: 2px; }

.blog-post-dates { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; margin-top: 18px; font-size: 12px; color: rgba(255,255,255,.55); }
.blog-post-dates i { color: var(--color-gold); margin-right: 4px; }
.blog-post-dates-sep { color: rgba(255,255,255,.3); }

.blog-post-featured-img { max-width: 900px; margin: 0 auto; border-radius: 16px; overflow: hidden; transform: translateY(-32px); box-shadow: 0 20px 60px rgba(0,0,0,.15); }
.blog-post-featured-img img { width: 100%; display: block; aspect-ratio: 16/7; object-fit: cover; }

.blog-post-content { padding: 0 0 80px; }
.blog-post-layout { display: grid; grid-template-columns: 1fr; gap: 56px; align-items: start; max-width: 880px; margin: 0 auto; }
.blog-post-body { font-size: 16px; line-height: 1.75; color: var(--color-dark); }
.blog-intro { font-size: 17px; line-height: 1.7; color: var(--color-dark); margin-bottom: 28px; }
.blog-post-body h2 { font-family: var(--font-serif); font-size: 1.7rem; font-weight: 700; color: var(--color-dark); margin: 48px 0 16px; padding-top: 8px; border-top: 2px solid var(--color-gray-warm); }
.blog-post-body h3 { font-family: var(--font-serif); font-size: 1.2rem; font-weight: 700; color: var(--color-dark); margin: 28px 0 10px; }
.blog-post-body p { margin: 0 0 20px; }

.blog-link { color: var(--color-gold-dark); text-decoration: underline; text-decoration-color: rgba(168,134,74,.4); text-underline-offset: 3px; font-weight: 600; transition: color .2s; }
.blog-link:hover { color: var(--color-gold); }

.blog-list { padding-left: 0; list-style: none; margin: 0 0 24px; display: flex; flex-direction: column; gap: 10px; }
.blog-list li { padding-left: 24px; position: relative; font-size: 15px; line-height: 1.65; }
.blog-list li::before { content: ''; position: absolute; left: 0; top: 9px; width: 8px; height: 8px; border-radius: 50%; background: var(--color-gold); }
ol.blog-list { counter-reset: blog-li; }
ol.blog-list li { counter-increment: blog-li; padding-left: 32px; }
ol.blog-list li::before { content: counter(blog-li); display: inline-flex; align-items: center; justify-content: center; width: 22px; height: 22px; border-radius: 50%; background: var(--color-gold); color: #fff; font-size: 11px; font-weight: 700; top: 0; }

.blog-table-wrap { overflow-x: auto; margin: 0 0 28px; border-radius: 10px; border: 1px solid var(--color-gray-warm); }
.blog-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.blog-table thead { background: var(--color-dark); color: #fff; }
.blog-table th { padding: 12px 16px; text-align: left; font-weight: 600; font-size: 12px; text-transform: uppercase; letter-spacing: .06em; }
.blog-table td { padding: 12px 16px; border-bottom: 1px solid var(--color-gray-warm); }
.blog-table tbody tr:last-child td { border-bottom: none; }
.blog-table tbody tr:nth-child(even) { background: var(--color-cream); }
.blog-table-caption { font-size: 13px; color: var(--color-dark-light); margin-top: 8px; }

.blog-callout { display: flex; gap: 16px; background: rgba(184,150,90,.08); border-left: 4px solid var(--color-gold); border-radius: 0 10px 10px 0; padding: 20px 24px; margin: 32px 0; }
.blog-callout i { font-size: 1.3rem; color: var(--color-gold); flex-shrink: 0; margin-top: 2px; }
.blog-callout strong { display: block; font-size: 14px; font-weight: 700; color: var(--color-dark); margin-bottom: 6px; }
.blog-callout p { font-size: 14px; margin: 0; color: var(--color-dark-light); }

.blog-toc { background: var(--color-cream); border: 1px solid var(--color-gray-warm); border-left: 3px solid var(--color-gold); border-radius: 8px; padding: 22px 26px; margin: 0 0 36px; }
.blog-toc-title { display: block; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--color-dark); margin-bottom: 12px; }
.blog-toc ol { margin: 0; padding-left: 20px; display: flex; flex-direction: column; gap: 6px; list-style: decimal; }
.blog-toc ol li { font-size: 14px; color: var(--color-dark-light); }
.blog-toc ol li a { color: var(--color-gold-dark); text-decoration: none; transition: color .2s; }
.blog-toc ol li a:hover { color: var(--color-gold); text-decoration: underline; }

.blog-cite-line { font-size: 13.5px; color: var(--color-dark-light); background: rgba(154,125,74,.06); border-radius: 8px; padding: 14px 18px; display: flex; align-items: center; gap: 10px; margin: 24px 0; }
.blog-cite-line i { color: var(--color-gold); flex-shrink: 0; }
.blog-cite-line a { color: var(--color-gold-dark); text-decoration: underline; text-underline-offset: 2px; font-weight: 600; }

.blog-related-posts { font-size: 15px; }
.blog-related-posts ul li { margin-bottom: 6px; }

.blog-final-cta { max-width: 880px; margin-left: auto; margin-right: auto; }

/* ============================================================
   BLOG INDEX grid (la página /blog/)
   ============================================================ */
.blog-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 32px; }
.blog-card { background: #fff; border-radius: 14px; overflow: hidden; box-shadow: 0 6px 20px rgba(45,41,38,.06); border: 1px solid var(--color-gray-warm); display: flex; flex-direction: column; transition: transform .2s ease, box-shadow .2s ease; }
.blog-card:hover { transform: translateY(-3px); box-shadow: 0 14px 32px rgba(45,41,38,.10); }
.blog-card-img-link { display: block; overflow: hidden; aspect-ratio: 16/9; }
.blog-card-img-link img { width: 100%; height: 100%; object-fit: cover; display: block; }
.blog-card-body { padding: 22px 24px 26px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.blog-card-body .blog-card-cat { color: var(--color-gold-dark); }
.blog-card-title { font-family: var(--font-serif); font-size: 1.25rem; font-weight: 700; line-height: 1.3; margin: 0; color: var(--color-dark); }
.blog-card-title a { color: inherit; text-decoration: none; }
.blog-card-title a:hover { color: var(--color-gold-dark); }
.blog-card-excerpt { font-size: 14px; line-height: 1.6; color: var(--color-dark-light); margin: 0; flex: 1; }
.blog-card-link { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; font-weight: 600; color: var(--color-gold-dark); text-decoration: none; margin-top: auto; }
.blog-card-link:hover { color: var(--color-gold); }

@media (max-width: 640px) {
    .blog-post-hero { padding: 90px 0 36px; }
    .blog-post-featured-img { transform: translateY(-20px); border-radius: 10px; }
    .blog-post-dates { font-size: 11px; }
    .blog-grid { grid-template-columns: 1fr; gap: 20px; }
}
