/* ============================================================
   public-extras.css — supplements theme.css for the Razor pages.
   theme.css is the design vendor file (kept verbatim from the mockup);
   everything that the live pages need beyond it lives here.
   ============================================================ */

/* link/anchor wrappers around cards must not inherit underline/colour */
a.card-link{display:block;color:inherit}

/* ----- article body (Markdig output wrapped in .article-content) ----- */
.article-content a{color:var(--violet-bright);text-decoration:underline;text-underline-offset:3px}
.article-content a:hover{color:var(--violet-soft)}
.article-content pre{background:var(--surface);border:1px solid var(--line);border-radius:14px;
  padding:18px 20px;overflow-x:auto;margin:22px 0;direction:ltr;text-align:left}
.article-content code{background:var(--surface-2);border:1px solid var(--line);border-radius:6px;
  padding:2px 6px;font-size:.92em;direction:ltr;display:inline-block}
.article-content pre code{background:none;border:none;padding:0}
.article-content table{width:100%;border-collapse:collapse;margin:24px 0;font-size:.96rem}
.article-content th,.article-content td{border:1px solid var(--line);padding:10px 14px;text-align:right}
.article-content th{background:var(--surface-2);color:var(--text);font-weight:700}
.article-content hr{border:none;border-top:1px solid var(--line);margin:30px 0}

/* ----- empty / not-found states ----- */
.empty-state{text-align:center;padding:80px 20px;color:var(--text-faint)}
.empty-state h1{font-size:1.8rem;color:var(--text);margin-bottom:12px}
.empty-state p{margin-bottom:18px}
.empty-state a{color:var(--violet-bright)}

/* keyword/tag filter chip shown on the blog list */
.filter-chip{display:inline-flex;align-items:center;gap:10px;background:var(--surface);
  border:1px solid var(--line);border-radius:100px;padding:8px 16px;font-size:.88rem;
  color:var(--text-dim);margin-bottom:24px}
.filter-chip b{color:var(--violet-soft);font-weight:600}
.filter-chip a{color:var(--text-faint);font-size:.8rem}
.filter-chip a:hover{color:var(--violet-soft)}

/* ----- mobile nav dropdown (hamburger) ----- */
@media(max-width:680px){
  .nav-links.open{display:flex;flex-direction:column;position:absolute;top:74px;right:0;left:0;
    background:var(--header-bg);backdrop-filter:blur(16px);border-bottom:1px solid var(--line);
    padding:18px 24px;gap:18px;z-index:999}
  .nav-links.open a{font-size:1.05rem}
  header{position:sticky}
}
