/* ============================================================
   ASTERWISE — Blog article (post detail) pages
   Styles the real post markup (post-header / post-body /
   read-next) ported from the codebase. Loads after
   tokens.css + home.css + blog.css.
   ============================================================ */
.blog-page { padding: calc(var(--nav-h) + var(--sp-12)) 0 var(--sp-24); }
.blog-container { max-width: 720px; margin-inline: auto; padding-inline: var(--pad); min-width: 0; }

/* header */
.post-header { padding-bottom: var(--sp-8); margin-bottom: var(--sp-8); border-bottom: 1px solid var(--line); }
.post-meta { display: flex; flex-wrap: wrap; gap: 9px; align-items: center; margin-bottom: var(--sp-5); font-family: var(--mono); font-size: var(--t-sm); color: var(--text-3); }
.tag { display: inline-flex; align-items: center; white-space: nowrap; padding: 3px 10px; border-radius: var(--r-full); background: var(--bg-3); color: var(--text-2); font-family: var(--mono); font-size: var(--t-micro); letter-spacing: .02em; }
.tag-concept   { background: var(--brand-soft); color: var(--brand); }
.tag-deepdive  { background: #ece8fb; color: #5b3fc4; }
.tag-methodology, .tag-method { background: #e6f3ec; color: var(--ok); }
.meta-sep { width: 3px; height: 3px; border-radius: 50%; background: var(--text-3); }
.post-date, .post-read { font-family: var(--mono); }
.post-title { font-size: var(--h1-hero); line-height: 1.1; letter-spacing: var(--track-tighter); font-weight: var(--w-semi); text-wrap: balance; }
.post-subtitle { margin-top: var(--sp-5); font-size: var(--t-lg); line-height: 1.5; color: var(--text-2); }
.post-author { margin-top: var(--sp-6); font-family: var(--mono); font-size: var(--t-sm); color: var(--text-3); }

/* body */
.post-body { font-size: var(--prose-body); line-height: 1.75; color: var(--text-2); min-width: 0; overflow-x: clip; }
.post-body > p { margin-bottom: var(--sp-6); }
.post-body > p:first-child { font-size: var(--prose-lead); color: var(--text); }
.post-body h2 { font-size: var(--h2-prose); letter-spacing: var(--track-tight); color: var(--text); margin: var(--sp-12) 0 var(--sp-4); line-height: 1.2; }
.post-body h3 { font-size: var(--h3-card); color: var(--text); margin: var(--sp-8) 0 var(--sp-3); }
.post-body strong { color: var(--text); font-weight: var(--w-semi); }
.post-body a { color: var(--brand); }
.post-body code { font-family: var(--mono); font-size: .86em; background: var(--bg-2); border: 1px solid var(--line); border-radius: var(--r-sm); padding: 1px 6px; color: var(--text); word-break: break-word; overflow-wrap: anywhere; }
.post-body ul, .post-body ol { margin: 0 0 var(--sp-6); padding-left: 24px; display: flex; flex-direction: column; gap: 8px; }
.post-body li { line-height: 1.65; }
.post-body li::marker { color: var(--text-3); }
.post-body hr { border: none; border-top: 1px solid var(--line); margin: var(--sp-12) 0; }
.post-body .callout { background: var(--brand-soft); border: 1px solid var(--brand-line); border-left: 3px solid var(--brand); border-radius: var(--r-lg); padding: var(--sp-6) var(--sp-8); margin: var(--sp-8) 0; }
.post-body .callout p { margin: 0; color: var(--text); font-size: var(--prose-aside); line-height: 1.6; }
.post-body table { width: 100%; border-collapse: collapse; margin: var(--sp-6) 0; font-size: var(--t-sm); max-width: 100%; }
.post-body img { max-width: 100%; height: auto; display: block; }
.post-body pre { background: var(--ink-bg); color: var(--text-on-ink-2); border: 1px solid var(--line-ink); border-radius: var(--r-lg); padding: var(--sp-5) var(--sp-6); overflow-x: auto; margin: var(--sp-6) 0; font-family: var(--mono); font-size: var(--t-code); line-height: 1.7; max-width: 100%; min-width: 0; white-space: pre; }

.post-body th, .post-body td { text-align: left; padding: 9px 12px; border-bottom: 1px solid var(--line); }
.post-body th { font-family: var(--mono); font-size: var(--t-micro); text-transform: uppercase; letter-spacing: .06em; color: var(--text-3); }

/* read next */
.read-next { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-4); margin-top: var(--sp-8); min-width: 0; }
.read-next-card { display: block; padding: var(--sp-5) var(--sp-6); border: 1px solid var(--line); border-radius: var(--r-lg); background: var(--surface); text-decoration: none; transition: border-color .15s, box-shadow .15s, transform .15s; min-width: 0; }
.read-next-card:hover { border-color: var(--line-2); box-shadow: var(--sh-sm); transform: translateY(-2px); }
.read-next-direction { font-family: var(--mono); font-size: var(--t-micro); text-transform: uppercase; letter-spacing: .08em; color: var(--text-3); display: flex; align-items: center; gap: 6px; }
.read-next-card-title { display: block; margin-top: 8px; font-weight: var(--w-semi); color: var(--text); font-size: var(--t-sm); line-height: 1.35; }
@media (max-width: 540px) {
  .read-next { grid-template-columns: 1fr; }
  .post-body table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .post-body .callout { padding: var(--sp-5) var(--sp-6); }
  .post-meta { gap: 6px; }
}
