/* article.css — styles unique to a blog POST page.
   Loaded on top of core.css. Extracted verbatim from the live article pages. */

.article-hero { padding: 148px 0 64px; background: linear-gradient(110deg, var(--ink) 0%, var(--night) 100%); position: relative; overflow: hidden; }
.article-hero::before { content: ''; position: absolute; width: 600px; height: 600px; border-radius: 50%; background: radial-gradient(circle, rgba(216,184,102,.14), transparent 68%); top: -200px; right: -100px; }
.article-hero .container { position: relative; z-index: 2; max-width: var(--article-max); }
.back-link { display: inline-flex; align-items: center; gap: 8px; color: var(--champagne); font-size: 13px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 32px; }
.back-link::before { content: '\2190'; }
.back-link:hover { opacity: .8; }
.article-meta { display: flex; align-items: center; gap: 16px; margin-bottom: 24px; flex-wrap: wrap; }
.tag { background: rgba(216,184,102,.18); border: 1px solid rgba(216,184,102,.32); border-radius: 999px; padding: 5px 13px; color: var(--champagne); font-size: 11px; font-weight: 900; letter-spacing: .14em; text-transform: uppercase; }
.article-date { color: rgba(255,255,255,.48); font-size: 13px; font-weight: 600; }
.article-hero h1 { font-family: var(--serif); color: var(--white); font-size: clamp(34px, 5vw, 58px); font-weight: 700; line-height: 1.1; letter-spacing: -.03em; margin-bottom: 22px; }
.article-hero .deck { font-size: 19px; color: rgba(255,255,255,.68); line-height: 1.65; max-width: 640px; }
.author-row { display: flex; align-items: center; gap: 14px; margin-top: 36px; padding-top: 28px; border-top: 1px solid rgba(255,255,255,.1); }
.author-avatar { width: 48px; height: 48px; border-radius: 50%; object-fit: cover; object-position: center top; border: 2px solid rgba(216,184,102,.4); }
.author-info strong { display: block; color: var(--white); font-size: 14px; font-weight: 700; }
.author-info span { color: rgba(255,255,255,.5); font-size: 13px; }

.featured-image { max-width: var(--article-max); margin: 0 auto; padding: 0 24px; transform: translateY(-40px); }
.featured-image img { width: 100%; height: 420px; object-fit: cover; border-radius: var(--radius); box-shadow: var(--shadow); display: block; }

.article-body { padding: 20px 0 100px; }
.prose { max-width: var(--article-max); margin: 0 auto; padding: 0 24px; }
.prose h2 { font-family: var(--serif); color: var(--night); font-size: clamp(26px, 3.5vw, 36px); font-weight: 700; line-height: 1.15; letter-spacing: -.025em; margin: 56px 0 20px; }
.prose p { font-size: 17px; line-height: 1.85; color: #3d3830; margin-bottom: 22px; max-width: none; }
.prose ul { margin: 4px 0 22px 0; padding: 0; list-style: none; display: grid; gap: 10px; }
.prose ul li { padding: 14px 18px 14px 44px; background: rgba(216,184,102,.08); border: 1px solid rgba(216,184,102,.2); border-radius: 14px; font-size: 16px; color: #3d3830; line-height: 1.6; position: relative; }
.prose ul li::before { content: ''; position: absolute; left: 18px; top: 22px; width: 8px; height: 8px; border-radius: 50%; background: var(--gold); }
.prose h3 { font-family: var(--serif); color: var(--night); font-size: 20px; font-weight: 700; margin: 32px 0 10px; letter-spacing: -.015em; }
.prose blockquote { border-left: 3px solid var(--champagne); margin: 36px 0; padding: 20px 26px; background: rgba(216,184,102,.07); border-radius: 0 16px 16px 0; }
.prose blockquote p { font-family: var(--serif); font-size: 20px; color: var(--night); line-height: 1.5; margin: 0; font-weight: 600; }

.article-cta { background: var(--night); border-radius: var(--radius); padding: 48px; text-align: center; margin: 64px auto 0; max-width: var(--article-max); }
.article-cta h3 { font-family: var(--serif); color: var(--white); font-size: 28px; margin-bottom: 14px; }
.article-cta p { color: rgba(255,255,255,.68); font-size: 16px; margin: 0 auto 28px; max-width: 480px; }

@media (max-width: 900px) {
  .article-cta { padding: 36px 24px; }
}

/* Related / internal-linking module */
.related { max-width: var(--article-max); margin: 56px auto 0; padding: 0 24px; }
.related-service { display: flex; flex-direction: column; gap: 5px; padding: 22px 26px; background: rgba(216,184,102,.08); border: 1px solid rgba(216,184,102,.28); border-radius: 16px; margin-bottom: 48px; transition: background .15s ease; }
.related-service:hover { background: rgba(216,184,102,.14); }
.related-kicker { font-size: 11px; font-weight: 900; letter-spacing: .14em; text-transform: uppercase; color: var(--champagne); }
.related-service-title { font-family: var(--serif); font-size: 22px; font-weight: 700; color: var(--night); line-height: 1.25; }
.related-heading { font-family: var(--serif); color: var(--night); font-size: 24px; font-weight: 700; margin: 0 0 22px; }
.related-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-bottom: 36px; }
.related-card { display: flex; flex-direction: column; gap: 12px; align-items: flex-start; padding: 22px 24px; background: #fff; border: 1px solid rgba(0,0,0,.08); border-radius: 16px; box-shadow: var(--shadow); transition: transform .15s ease, box-shadow .15s ease; }
.related-card:hover { transform: translateY(-3px); box-shadow: 0 14px 34px rgba(0,0,0,.12); }
.related-card-title { font-family: var(--serif); font-size: 18px; font-weight: 700; color: var(--night); line-height: 1.3; }
.related-all { display: inline-block; color: var(--champagne); font-weight: 700; font-size: 14px; letter-spacing: .04em; }
.related-all:hover { opacity: .8; }

@media (max-width: 700px) {
  .related-grid { grid-template-columns: 1fr; }
}

/* Visible FAQ (matches FAQPage schema) */
.faq { max-width: var(--article-max); margin: 56px auto 0; padding: 0 24px; }
.faq-heading { font-family: var(--serif); color: var(--night); font-size: clamp(26px, 3.5vw, 34px); font-weight: 700; letter-spacing: -.02em; margin: 0 0 24px; }
.faq-item { border: 1px solid rgba(0,0,0,.1); border-radius: 14px; padding: 4px 22px; margin-bottom: 12px; background: #fff; }
.faq-item summary { font-family: var(--serif); font-size: 18px; font-weight: 700; color: var(--night); cursor: pointer; padding: 16px 0; list-style: none; display: flex; justify-content: space-between; align-items: center; gap: 16px; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: '+'; font-family: var(--sans, sans-serif); font-size: 24px; font-weight: 400; color: var(--champagne); flex-shrink: 0; line-height: 1; }
.faq-item[open] summary::after { content: '\2013'; }
.faq-item p { font-size: 16px; line-height: 1.8; color: #3d3830; margin: 0 0 18px; max-width: none; }
