/* =========================================================================
   PiqBio Blog — article layout atop the main style.css token system.
   Loaded on /blog.html index and all /blog/*.html article pages.
   ========================================================================= */

/* ---------- Article wrapper ------------------------------------------- */
.article-container,
article > .container,
.article-body-wrap > .container {
  max-width: 52rem;
  margin: 0 auto;
  padding: 0 var(--page-pad);
}

/* Breadcrumbs -------------------------------------------------------- */
.breadcrumbs {
  padding: var(--s-6) 0 var(--s-3);
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-45);
  display: flex;
  align-items: center;
  gap: var(--s-2);
  flex-wrap: wrap;
}
.breadcrumbs a {
  color: var(--ink-45);
  transition: color var(--dur-1) var(--ease-out-quart);
}
.breadcrumbs a:hover { color: var(--ink); }
.breadcrumbs span { color: var(--ink-30); }

/* Category badge ---------------------------------------------------- */
.badge {
  display: inline-block;
  padding: 0.25rem 0.5rem;
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink);
  background: var(--paper-mute);
  border: 1px solid var(--rule);
  border-radius: var(--r-1);
}

/* Article header ---------------------------------------------------- */
.article-header {
  padding: clamp(2.5rem, 5vw, 4.5rem) 0 clamp(1.5rem, 3vw, 2.5rem);
  max-width: 52rem;
  margin: 0 auto;
}
.article-header h1 {
  font-size: clamp(2rem, 4vw, 3.25rem);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -0.03em;
  color: var(--ink);
  margin-top: var(--s-4);
  margin-bottom: var(--s-5);
  text-wrap: balance;
}
.article-meta {
  display: flex;
  gap: var(--s-5);
  flex-wrap: wrap;
  font-family: var(--font-mono);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  color: var(--ink-45);
  text-transform: uppercase;
  padding-bottom: var(--s-5);
  border-bottom: 1px solid var(--rule);
}

/* Article body (long-form reading) ---------------------------------- */
.article-content {
  padding: clamp(1.5rem, 3vw, 2.5rem) 0 clamp(2.5rem, 5vw, 4rem);
  max-width: 42rem;
  margin: 0 auto;
  font-size: var(--size-lead);
  line-height: 1.7;
  color: var(--ink-80);
}
.article-content > * + * { margin-top: var(--s-5); }
.article-content h2 {
  font-size: clamp(1.5rem, 2.4vw, 2rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.15;
  color: var(--ink);
  margin-top: var(--s-12);
  margin-bottom: var(--s-4);
  text-wrap: balance;
}
.article-content h3 {
  font-size: 1.25rem;
  font-weight: 700;
  letter-spacing: -0.015em;
  color: var(--ink);
  margin-top: var(--s-8);
  margin-bottom: var(--s-3);
}
.article-content h4 {
  font-size: var(--size-lg);
  font-weight: 700;
  color: var(--ink);
  margin-top: var(--s-6);
  margin-bottom: var(--s-2);
}
.article-content p {
  color: var(--ink-80);
  max-width: 42rem;
}
.article-content ul,
.article-content ol {
  padding-left: var(--s-6);
  color: var(--ink-80);
}
.article-content li {
  list-style: disc;
  margin-bottom: var(--s-2);
  line-height: 1.65;
}
.article-content ol li { list-style: decimal; }
.article-content strong { color: var(--ink); font-weight: 700; }
.article-content em { font-style: italic; color: var(--ink); }
.article-content a {
  color: var(--ink);
  text-decoration: underline;
  text-decoration-color: var(--ink-30);
  text-underline-offset: 3px;
  transition: text-decoration-color var(--dur-1) var(--ease-out-quart);
}
.article-content a:hover { text-decoration-color: var(--ink); }
.article-content blockquote {
  border-left: 0;
  padding: var(--s-4) var(--s-6);
  background: var(--paper-mute);
  border-radius: var(--r-3);
  font-style: italic;
  color: var(--ink);
  font-size: var(--size-lg);
  line-height: 1.55;
}
.article-content code {
  font-family: var(--font-mono);
  font-size: 0.875em;
  background: var(--paper-mute);
  padding: 0.15em 0.4em;
  border-radius: var(--r-1);
  color: var(--ink);
}
.article-content pre {
  background: var(--paper-mute);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  padding: var(--s-5);
  overflow-x: auto;
  font-family: var(--font-mono);
  font-size: 0.8125rem;
  line-height: 1.6;
}
.article-content pre code { background: transparent; padding: 0; }

/* Citation / reference blocks ------------------------------------- */
.citation {
  background: var(--paper-mute);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  padding: var(--s-4) var(--s-5);
  font-size: var(--size-sm);
  line-height: 1.6;
  color: var(--ink-80);
  margin: var(--s-6) 0;
}
.citation strong { color: var(--ink); }
.citation em { font-style: italic; color: var(--ink-60); }
.citation a {
  display: inline-block;
  margin-top: var(--s-2);
  font-family: var(--font-mono);
  font-size: 0.75rem;
  letter-spacing: 0.06em;
  color: var(--ink);
  text-decoration: underline;
  text-decoration-color: var(--ink-30);
  text-underline-offset: 3px;
}

/* Related articles -------------------------------------------------- */
.related-articles {
  padding: clamp(2rem, 4vw, 3.5rem) 0 clamp(3rem, 6vw, 5rem);
  border-top: 1px solid var(--rule);
  margin-top: var(--s-12);
  max-width: 52rem;
  margin-inline: auto;
}
.related-articles h3 {
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-45);
  margin-bottom: var(--s-5);
}
.related-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--s-4);
}
.related-list a {
  display: block;
  padding: var(--s-4) 0;
  font-size: var(--size-base);
  font-weight: 600;
  color: var(--ink);
  border-top: 1px solid var(--rule);
  line-height: 1.35;
  letter-spacing: -0.01em;
  transition: color var(--dur-1) var(--ease-out-quart);
}
.related-list a:hover { color: var(--accent); }

/* Research page — featured creators & library ----------------------- */
.research-featured { padding-block: clamp(3rem, 6vw, 5rem); }
.research-featured__note {
  margin-top: var(--s-10);
  padding-top: var(--s-4);
  border-top: 1px solid var(--rule-hair);
  font-size: var(--size-micro);
  color: var(--ink-45);
  line-height: 1.55;
  max-width: 56rem;
}
.research-featured__note a { color: var(--ink); text-decoration: underline; text-decoration-color: var(--ink-30); text-underline-offset: 3px; }

.creator-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: var(--s-6);
  list-style: none;
  padding: 0;
  margin-top: var(--s-10);
}
.creator-card {
  padding: var(--s-6);
  border: 1px solid var(--rule);
  border-radius: var(--r-3);
  background: var(--paper);
  display: flex;
  flex-direction: column;
  min-height: 260px;
  transition: border-color var(--dur-2) var(--ease-out-quart), transform var(--dur-2) var(--ease-out-quart);
}
.creator-card:hover { border-color: var(--ink); transform: translateY(-2px); }
.creator-card__meta {
  display: flex;
  gap: var(--s-2);
  align-items: center;
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-45);
  margin-bottom: var(--s-4);
}
.creator-card__kind { color: var(--ink); font-weight: 700; }
.creator-card__dot { color: var(--ink-30); }
.creator-card__name {
  font-size: var(--size-lg);
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -0.02em;
  line-height: 1.25;
  margin-bottom: var(--s-2);
  text-wrap: balance;
}
.creator-card__by {
  font-size: var(--size-sm);
  color: var(--ink-60);
  font-weight: 500;
  margin-bottom: var(--s-3);
}
.creator-card__desc {
  font-size: var(--size-sm);
  color: var(--ink-60);
  line-height: 1.55;
  margin-bottom: var(--s-5);
  flex-grow: 1;
}
.creator-card__links {
  display: flex;
  gap: var(--s-4);
  padding-top: var(--s-4);
  border-top: 1px solid var(--rule-hair);
  flex-wrap: wrap;
}
.creator-card__link {
  font-family: var(--font-sans);
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--ink);
  text-decoration: none;
  position: relative;
  transition: color var(--dur-1) var(--ease-out-quart);
}
.creator-card__link:hover { color: var(--accent); }

.research-library { padding-block: clamp(3rem, 6vw, 5rem); }
.research-library .catalog-toolbar { margin-top: var(--s-10); }
.research-library .results-header {
  padding: var(--s-4) 0 var(--s-6);
}
.research-library .results-count {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-45);
}

/* No-results state */
.no-results {
  text-align: center;
  padding: var(--s-12) var(--s-5);
  color: var(--ink-60);
}
.no-results h3 {
  font-size: var(--size-xl);
  font-weight: 700;
  color: var(--ink);
  margin-bottom: var(--s-2);
}

/* Blog index (listing page) ----------------------------------------- */
.blog-hero {
  padding: clamp(3rem, 6vw, 6rem) var(--page-pad) clamp(2rem, 4vw, 3rem);
}
.blog-hero .eyebrow { margin-bottom: var(--s-4); }
.blog-hero h1 {
  font-size: clamp(2.5rem, 5vw, 4.5rem);
  font-weight: 800;
  letter-spacing: -0.035em;
  line-height: 0.95;
  color: var(--ink);
  margin-bottom: var(--s-5);
  max-width: 20ch;
  text-wrap: balance;
}
.blog-hero p {
  font-size: var(--size-xl);
  color: var(--ink-60);
  max-width: 52ch;
  line-height: 1.5;
}

/* Blog category filter tabs ------------------------------------------ */
.blog-filters {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: var(--s-6) var(--page-pad);
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
  justify-content: center;
  border-top: 1px solid var(--rule-hair);
  border-bottom: 1px solid var(--rule-hair);
}
.blog-filters .filter-btn {
  display: inline-block;
  padding: 0.5rem 1rem;
  font-family: inherit;
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: -0.005em;
  color: var(--ink-60);
  border: 1px solid var(--rule);
  border-radius: 999px;
  background: transparent;
  cursor: pointer;
  transition: all var(--dur-1) var(--ease-out-quart);
}
.blog-filters .filter-btn:hover { color: var(--ink); border-color: var(--ink-30); }
.blog-filters .filter-btn.active,
.blog-filters .filter-btn[aria-current="true"] {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}

/* Article list (grid of cards) -------------------------------------- */
.blog-results {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: var(--s-5) var(--page-pad);
}
.blog-result-count {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  color: var(--ink-45);
  text-transform: uppercase;
  margin-bottom: var(--s-6);
}
.blog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--s-6);
  padding-bottom: var(--s-16);
}
.blog-card {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-3);
  padding: var(--s-6);
  display: flex;
  flex-direction: column;
  min-height: 280px;
  transition: border-color var(--dur-2) var(--ease-out-quart), transform var(--dur-2) var(--ease-out-quart);
  position: relative;
}
.blog-card:hover { border-color: var(--ink); transform: translateY(-2px); }
.blog-card .badge { margin-bottom: var(--s-3); align-self: flex-start; }
.blog-card h3 {
  font-size: var(--size-lg);
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -0.015em;
  line-height: 1.25;
  margin-bottom: var(--s-3);
}
.blog-card p {
  font-size: var(--size-sm);
  color: var(--ink-60);
  line-height: 1.55;
  margin-bottom: var(--s-4);
}
.blog-card .article-date {
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  letter-spacing: 0.12em;
  color: var(--ink-45);
  text-transform: uppercase;
  position: absolute;
  top: var(--s-6);
  right: var(--s-6);
}
.blog-card .read-link {
  margin-top: auto;
  font-family: var(--font-sans);
  font-size: var(--size-sm);
  font-weight: 600;
  color: var(--ink);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
}
.blog-card .read-time {
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  letter-spacing: 0.1em;
  color: var(--ink-45);
  text-transform: uppercase;
}

/* Compliance block at footer ----------------------------------------- */
.compliance-notice {
  background: var(--paper-mute);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  padding: var(--s-4) var(--s-5);
  font-size: var(--size-micro);
  color: var(--ink-60);
  line-height: 1.5;
  max-width: 56rem;
  margin: 0 auto;
}
.compliance-notice strong { color: var(--ink); }

/* Hide old legacy chrome if any slips through --------------------- */
.article-container .container,
article .container { padding: 0; max-width: none; }
