/* ── Blog Article Styles ─────────────────────────────────────────────────── */
/* Loaded on all blog posts. Requires .noa-page on <body> for variable scope. */

/* ── BREADCRUMB ── */
.article-breadcrumb { border-bottom: 1px solid var(--border); }
.article-breadcrumb-inner { max-width: 1200px; margin: 0 auto; padding: 12px 64px; display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.article-breadcrumb-inner a { font-size: 0.72rem; color: var(--teal); text-decoration: none; }
.article-breadcrumb-inner a:hover { text-decoration: underline; }
.article-breadcrumb-inner span:not(.bc-sep) { font-size: 0.72rem; color: var(--text-dim); }
.bc-sep { font-size: 0.72rem; color: var(--text-dim); }

/* ── ARTICLE LAYOUT ── */
.article-wrap { max-width: 1200px; margin: 0 auto; padding: 64px; display: grid; grid-template-columns: 1fr 300px; gap: 80px; align-items: start; }

/* ── ARTICLE HEADER ── */
.article-header { grid-column: 1 / -1; max-width: 720px; padding-bottom: 40px; border-bottom: 1px solid var(--border); margin-bottom: 8px; }
.article-tag-pills { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 18px; }
.article-tag-pill { font-size: 0.6rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; padding: 3px 10px; background: var(--teal-dim); color: var(--teal); border: 1px solid var(--teal-border); text-decoration: none; }
/* Legacy .article-tag support */
.article-tag { font-size: 0.6rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--teal); display: block; margin-bottom: 16px; }
.article-title { font-family: 'Bricolage Grotesque', sans-serif; font-size: clamp(2rem, 4vw, 3rem); font-weight: 800; letter-spacing: -0.03em; line-height: 1.05; margin-bottom: 18px; color: var(--text); }
.article-title em { font-style: italic; color: var(--teal); }
.article-intro { font-size: 1rem; color: var(--text-mid); line-height: 1.75; max-width: 620px; margin-bottom: 22px; }
.article-meta { font-size: 0.78rem; color: var(--text-mid); display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.article-meta-avatar { width: 28px; height: 28px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.article-meta-author { font-weight: 500; color: var(--text); }
.article-meta-sep { color: var(--text-dim); }

/* ── ARTICLE BODY ── */
.article-body { min-width: 0; }
.article-body h2 { font-family: 'Bricolage Grotesque', sans-serif; font-size: 1.6rem; font-weight: 800; letter-spacing: -0.02em; margin: 48px 0 14px; line-height: 1.2; color: var(--text); }
.article-body h2 em { font-style: italic; color: var(--teal); }
.article-body h3 { font-family: 'Bricolage Grotesque', sans-serif; font-size: 1.05rem; font-weight: 700; letter-spacing: -0.01em; margin: 28px 0 10px; color: var(--text); }
.article-body p { font-family: 'Outfit', sans-serif; font-size: 15px; line-height: 1.85; color: var(--text-mid); margin-bottom: 20px; }
.article-body ul:not(.toc-list):not(.sidebar-list) { padding-left: 20px; margin-bottom: 20px; display: flex; flex-direction: column; gap: 8px; }
.article-body ul:not(.toc-list):not(.sidebar-list) li { font-family: 'Outfit', sans-serif; font-size: 15px; line-height: 1.75; color: var(--text-mid); }
.article-body ol { padding-left: 20px; margin-bottom: 20px; display: flex; flex-direction: column; gap: 8px; }
.article-body ol li { font-family: 'Outfit', sans-serif; font-size: 15px; line-height: 1.75; color: var(--text-mid); }
.article-body code { font-family: 'Courier New', monospace; font-size: 0.85em; background: var(--teal-dim); color: var(--teal); padding: 2px 6px; border: 1px solid var(--teal-border); }
.article-body a { color: var(--teal); text-decoration: none; }
.article-body a:hover { text-decoration: underline; }
.article-body strong { color: var(--text); font-weight: 600; }

/* ── CALLOUT BOXES ── */
.callout { background: var(--teal-dim); border-left: 3px solid var(--teal); padding: 20px 24px; margin: 28px 0; font-family: 'Outfit', sans-serif; font-size: 0.9rem; line-height: 1.75; color: var(--text-mid); }
.callout strong { color: var(--text); font-weight: 600; }
.callout-green { background: var(--pass-dim); border-left: 3px solid var(--pass); padding: 20px 24px; margin: 28px 0; font-family: 'Outfit', sans-serif; font-size: 0.9rem; line-height: 1.75; color: var(--text-mid); }
.callout-green strong { color: var(--pass); font-weight: 500; }
.callout-dark { background: var(--teal-dark); color: rgba(245,248,247,0.8); padding: 24px 28px; margin: 28px 0; font-family: 'Outfit', sans-serif; font-size: 0.9rem; line-height: 1.75; }
.callout-dark strong { color: #4ade80; font-weight: 500; }
.callout-dark a { color: #4ade80; }

/* ── TABLES ── */
.data-table { width: 100%; border-collapse: collapse; margin: 24px 0; font-size: 0.85rem; }
.data-table th { background: var(--surface); padding: 10px 14px; text-align: left; font-size: 0.7rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-mid); border-bottom: 2px solid var(--border); }
.data-table td { padding: 10px 14px; border-bottom: 1px solid var(--border); color: var(--text-mid); line-height: 1.5; font-size: 0.88rem; }
.data-table tr:last-child td { border-bottom: none; }

/* ── CHECK LISTS ── */
.check-list { display: flex; flex-direction: column; gap: 1px; background: var(--border); margin: 24px 0; }
.check-item { background: var(--bg); padding: 14px 20px; display: flex; gap: 14px; align-items: flex-start; font-size: 0.88rem; line-height: 1.6; color: var(--text-mid); }
.check-icon-pass { color: var(--pass); flex-shrink: 0; margin-top: 1px; font-weight: 700; }
.check-icon-fail { color: var(--coral); flex-shrink: 0; margin-top: 1px; font-weight: 700; }
.check-icon-warn { color: var(--warn, #b07a10); flex-shrink: 0; margin-top: 1px; font-weight: 700; }

/* ── MID-ARTICLE CTA ── */
.mid-article-cta { background: var(--teal-dark); padding: 32px 36px; margin: 48px 0; }
.mid-article-cta-eyebrow { font-size: 0.6rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.14em; color: rgba(245,248,247,0.45); margin-bottom: 10px; }
.mid-article-cta-label { font-family: 'Bricolage Grotesque', sans-serif; font-size: 1.1rem; font-weight: 700; letter-spacing: -0.01em; color: white; margin-bottom: 10px; line-height: 1.3; }
.mid-article-cta-body { font-size: 0.88rem; color: rgba(245,248,247,0.6); line-height: 1.7; margin-bottom: 20px; }
.mid-article-cta-actions { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.btn-coral-sm { background: #e05c3a; color: white; padding: 10px 20px; font-family: 'Outfit', sans-serif; font-size: 0.85rem; font-weight: 600; text-decoration: none; display: inline-block; transition: opacity 0.15s; white-space: nowrap; }
.btn-coral-sm:hover { opacity: 0.88; }
.mid-article-cta-free { font-size: 0.82rem; color: rgba(245,248,247,0.5); text-decoration: none; transition: color 0.15s; }
.mid-article-cta-free:hover { color: rgba(245,248,247,0.85); }

/* ── ARTICLE TAGS ── */
.article-tags { display: flex; gap: 6px; flex-wrap: wrap; margin: 40px 0 28px; }

/* ── AUTHOR BIO ── */
.author-bio { margin-top: 8px; padding: 24px 28px; border: 1px solid var(--border); display: flex; align-items: center; gap: 20px; background: var(--surface); }
.author-bio-photo { width: 52px; height: 52px; flex-shrink: 0; border-radius: 50%; overflow: hidden; }
.author-bio-photo img { width: 100%; height: 100%; object-fit: cover; }
.author-bio-name { font-size: 0.88rem; font-weight: 600; color: var(--text); margin-bottom: 4px; }
.author-bio-name a { color: var(--text); text-decoration: none; }
.author-bio-name a:hover { color: var(--teal); }
.author-bio-desc { font-size: 0.8rem; color: var(--text-mid); line-height: 1.6; }

/* ── RELATED POSTS ── */
.related-posts { margin-top: 48px; grid-column: 1 / -1; }
.related-posts-title { font-family: 'Bricolage Grotesque', sans-serif; font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--text-mid); margin-bottom: 12px; }
.related-rows { display: flex; flex-direction: column; gap: 1px; background: var(--border); }
.related-row { background: var(--bg); padding: 16px 22px; display: flex; align-items: center; gap: 16px; text-decoration: none; transition: background 0.15s; }
.related-row:hover { background: var(--surface); }
.related-tag { font-size: 0.58rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; padding: 2px 8px; background: var(--teal-dim); color: var(--teal); border: 1px solid var(--teal-border); flex-shrink: 0; }
.related-title { font-size: 0.88rem; font-weight: 500; color: var(--text); flex: 1; line-height: 1.4; }
.related-meta { font-size: 0.72rem; color: var(--text-dim); flex-shrink: 0; }
.related-arrow { font-size: 0.85rem; color: var(--text-dim); flex-shrink: 0; }
.related-row:hover .related-arrow { color: var(--teal); }

/* ── SIDEBAR ── */
.article-sidebar { position: sticky; top: 80px; }
.toc-card { border: 1px solid var(--border); padding: 24px 28px; margin-bottom: 20px; }
.toc-title { font-size: 0.65rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-dim); margin-bottom: 14px; }
.toc-list { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.toc-list a { color: var(--text-mid); text-decoration: none; font-size: 0.82rem; line-height: 1.4; transition: color 0.15s; }
.toc-list a:hover { color: var(--teal); }
.sidebar-cta { background: var(--teal-dark); color: white; padding: 28px 24px; margin-bottom: 20px; }
.sidebar-cta h3 { font-family: 'Bricolage Grotesque', sans-serif; font-size: 1.1rem; font-weight: 700; letter-spacing: -0.01em; line-height: 1.25; margin-bottom: 10px; color: white; }
.sidebar-cta h3 em { font-style: italic; color: #4ade80; }
.sidebar-cta p { font-size: 0.82rem; color: rgba(245,248,247,0.6); line-height: 1.65; margin-bottom: 18px; }
.sidebar-list { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.sidebar-list a { color: var(--text-mid); text-decoration: none; font-size: 0.82rem; line-height: 1.4; }
.sidebar-list a:hover { color: var(--teal); }

/* ── RESPONSIVE ── */
@media (max-width: 900px) {
  .article-breadcrumb-inner { padding: 10px 24px; }
  .article-wrap { grid-template-columns: 1fr; padding: 32px 24px; gap: 40px; }
  .article-header { grid-column: 1; }
  .article-sidebar { position: static; }
  .related-posts { grid-column: 1; }
  .mid-article-cta { padding: 24px; }
}
@media (max-width: 600px) {
  .author-bio { flex-direction: column; align-items: flex-start; }
}
