/* Blog post styles — extends the canonical margin design system tokens. */
@import url("/styles/tokens.css");

/* Base reset — body color/font already set by tokens.css */
html { scroll-behavior: smooth; }

a {
  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px solid var(--ink);
  transition: color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
}
a:hover { color: var(--accent); border-bottom-color: var(--accent); }

button { font-family: inherit; cursor: pointer; }

.wrap {
  max-width: var(--maxw-page);
  margin: 0 auto;
  padding: 0 var(--space-7);
}

/* ============================================================
   TOP BAR — full-width border, content centered to --maxw-page
   ============================================================ */
.topbar {
  display: flex; align-items: center; justify-content: space-between;
  min-height: var(--header-h);
  padding-inline: max(var(--space-7), calc((100vw - var(--maxw-page)) / 2));
  border-bottom: 1px solid var(--soft);
  background: var(--bg);
  position: sticky; top: 0; z-index: 10;
}
.topbar .brand {
  font-size: var(--fs-h4);
  font-weight: var(--fw-bold);
  letter-spacing: -0.01em;
  color: var(--ink); text-transform: lowercase; border: none;
}
.topbar .brand .dot { color: var(--accent); }
.topbar nav { display: flex; align-items: center; gap: var(--space-4); }
.topbar nav a {
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.06em;
  text-transform: lowercase;
  color: var(--muted); border: none;
}
.topbar nav a:hover { color: var(--accent); }
.topbar nav a.active { color: var(--ink); }
.topbar .cta {
  font-size: var(--fs-eyebrow);
  letter-spacing: var(--tk-eyebrow);
  text-transform: lowercase;
  background: var(--ink); color: var(--bg);
  border: 1px solid var(--ink);
  padding: 8px 14px;
  border-bottom: 1px solid var(--ink);
}
.topbar .cta:hover { background: var(--accent); border-color: var(--accent); color: #fff; }
.topbar .theme-toggle {
  background: transparent; border: 1px solid var(--soft);
  width: 32px; height: 32px; padding: 0;
  color: var(--muted);
  display: inline-flex; align-items: center; justify-content: center;
  transition: color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
}
.topbar .theme-toggle:hover { color: var(--ink); border-color: var(--ink); }
.topbar .theme-toggle svg {
  width: 14px; height: 14px;
  stroke: currentColor; fill: none; stroke-width: 1.5;
}
.topbar .theme-toggle .icon-sun { display: none; }
[data-theme="dark"] .topbar .theme-toggle .icon-sun { display: inline-block; }
[data-theme="dark"] .topbar .theme-toggle .icon-moon { display: none; }

/* ============================================================
   ARTICLE HEADER
   ============================================================ */
.article-header { padding: var(--space-9) 0 var(--space-7); }
.breadcrumbs {
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.06em;
  text-transform: lowercase;
  color: var(--muted);
  margin-bottom: var(--space-5);
}
.breadcrumbs a { color: var(--muted); border: none; }
.breadcrumbs a:hover { color: var(--accent); }
.breadcrumbs .sep { margin: 0 var(--space-2); color: var(--soft); }

.article-label {
  font-size: var(--fs-eyebrow);
  letter-spacing: var(--tk-micro);
  text-transform: lowercase;
  color: var(--accent);
  font-weight: var(--fw-bold);
  margin-bottom: var(--space-3);
}

.article-header h1 {
  font-size: var(--fs-h1);
  line-height: var(--lh-h1);
  letter-spacing: var(--tk-h1);
  font-weight: var(--fw-medium);
  margin: 0 0 var(--space-3);
  text-transform: lowercase;
}

.article-subtitle {
  font-size: var(--fs-lede);
  line-height: var(--lh-body);
  color: var(--muted);
  max-width: var(--maxw-prose);
  margin: 0 0 var(--space-6);
}

.article-meta {
  display: flex; align-items: center; flex-wrap: wrap; gap: var(--space-2);
  font-size: var(--fs-micro);
  letter-spacing: 0.04em;
  color: var(--muted);
  text-transform: lowercase;
}
.article-meta .author-avatar {
  width: 22px; height: 22px;
  border-radius: var(--radius-pill);
  overflow: hidden;
  border: 1px solid var(--soft);
  flex: none;
}
.article-meta .author-avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.article-meta .name { color: var(--ink); font-weight: var(--fw-medium); }
.article-meta .dot {
  width: 3px; height: 3px;
  border-radius: var(--radius-pill);
  background: var(--soft); display: inline-block;
}

/* ============================================================
   FEATURED IMAGE
   ============================================================ */
.article-feat {
  border: 1px solid var(--soft);
  background: var(--bg-alt);
  margin: 0 0 var(--space-9);
  overflow: hidden;
}
.article-feat img { width: 100%; height: auto; display: block; }

/* ============================================================
   ARTICLE LAYOUT — prose centered at 720px, TOC floats in the right gutter
   ============================================================ */
.article-layout {
  position: relative;
  margin-bottom: var(--space-10);
}

/* ============================================================
   ARTICLE CONTENT — prose width = --maxw-prose (720px)
   ============================================================ */
.article-content {
  max-width: var(--maxw-prose);
  margin: 0 auto;
  font-size: var(--fs-body);
  line-height: 1.75;
  color: var(--ink);
}
.article-content > p { margin: 0 0 var(--space-5); }
.article-content h2 {
  font-size: var(--fs-h3);
  line-height: var(--lh-h3);
  letter-spacing: -0.01em;
  font-weight: var(--fw-medium);
  margin: var(--space-8) 0 var(--space-4);
  text-transform: lowercase;
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--soft);
}
.article-content h3 {
  font-size: var(--fs-h4);
  line-height: var(--lh-h4);
  letter-spacing: -0.005em;
  font-weight: var(--fw-medium);
  margin: var(--space-7) 0 var(--space-3);
  text-transform: lowercase;
}
.article-content ul, .article-content ol {
  margin: 0 0 var(--space-5);
  padding-left: var(--space-6);
}
.article-content li { margin-bottom: var(--space-2); }
.article-content li::marker { color: var(--accent); }
.article-content strong { color: var(--ink); font-weight: var(--fw-bold); }
.article-content em { color: var(--accent); font-style: normal; }
.article-content blockquote {
  border-left: 2px solid var(--accent);
  padding: var(--space-1) 0 var(--space-1) var(--space-5);
  margin: var(--space-6) 0;
  color: var(--muted);
  font-style: normal;
}
.article-content blockquote p { margin: 0; font-size: var(--fs-lede); }
.article-content code {
  font-family: var(--font-mono);
  font-size: var(--fs-meta);
  background: var(--bg-alt); padding: 2px 6px;
  border: 1px solid var(--soft);
}
.article-content pre {
  background: var(--bg-alt); border: 1px solid var(--soft);
  padding: var(--space-4); overflow-x: auto;
  margin: 0 0 var(--space-6);
  font-size: var(--fs-meta);
  line-height: 1.6;
}
.article-content pre code { background: transparent; border: none; padding: 0; }
.article-content a {
  color: var(--ink);
  border-bottom: 1px solid var(--accent);
}
.article-content a:hover { color: var(--accent); }

/* ============================================================
   STAT GRID
   ============================================================ */
.stat-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-3);
  margin: var(--space-6) 0 var(--space-7);
}
.stat-card {
  border: 1px solid var(--soft);
  background: var(--card);
  padding: var(--space-5) var(--space-5);
}
.stat-card .stat-number {
  font-size: var(--fs-h3);
  font-weight: var(--fw-medium);
  color: var(--accent);
  letter-spacing: -0.02em;
  line-height: 1.1;
  margin-bottom: var(--space-2);
}
.stat-card .stat-label {
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.04em;
  text-transform: lowercase;
  color: var(--muted);
  line-height: 1.5;
}

/* ============================================================
   COMPARISON TABLE
   ============================================================ */
.comparison-table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--space-6) 0 var(--space-7);
  font-size: var(--fs-meta);
  border: 1px solid var(--soft);
}
.comparison-table th, .comparison-table td {
  padding: var(--space-3) var(--space-4);
  text-align: left;
  border-bottom: 1px solid var(--soft);
  text-transform: lowercase;
}
.comparison-table th {
  font-size: var(--fs-micro);
  letter-spacing: 0.1em;
  font-weight: var(--fw-bold);
  background: var(--bg-alt);
  color: var(--muted);
}
.comparison-table th.human-col { color: var(--muted); }
.comparison-table th.ai-col { color: var(--accent); }
.comparison-table td:first-child { font-weight: var(--fw-medium); color: var(--ink); }
.comparison-table td.ai-col.win { color: var(--green); font-weight: var(--fw-medium); }
.comparison-table tr:last-child td { border-bottom: none; }

/* ============================================================
   HIGHLIGHT / WARNING BOXES
   ============================================================ */
.highlight-box {
  border: 1px solid var(--green);
  background: var(--card);
  padding: var(--space-4) var(--space-5);
  margin: var(--space-6) 0;
  border-left: 3px solid var(--green);
}
.highlight-box p {
  font-size: var(--fs-lede);
  color: var(--ink);
  margin: 0;
  line-height: 1.65;
}
.warning-box {
  border: 1px solid var(--accent);
  background: var(--card);
  padding: var(--space-4) var(--space-5);
  margin: var(--space-6) 0;
  border-left: 3px solid var(--accent);
}
.warning-box p {
  font-size: var(--fs-lede);
  color: var(--ink);
  margin: 0;
  line-height: 1.65;
}

/* ============================================================
   INLINE CTA
   ============================================================ */
.inline-cta {
  border: 1px solid var(--ink);
  background: var(--card);
  padding: var(--space-7) var(--space-7);
  margin: var(--space-8) 0;
  text-align: center;
}
.inline-cta .eyebrow {
  font-size: var(--fs-eyebrow);
  letter-spacing: var(--tk-micro);
  text-transform: lowercase;
  color: var(--accent);
  font-weight: var(--fw-bold);
  margin-bottom: var(--space-2);
}
.inline-cta h3 {
  font-size: var(--fs-h4);
  line-height: var(--lh-h4);
  letter-spacing: -0.01em;
  font-weight: var(--fw-medium);
  margin: 0 0 var(--space-2);
  text-transform: lowercase;
}
.inline-cta p {
  font-size: var(--fs-body);
  color: var(--muted);
  line-height: 1.6;
  margin: 0 auto var(--space-5);
  max-width: 460px;
}
.inline-cta .btn-primary {
  display: inline-flex; align-items: center; gap: var(--space-2);
  font-size: var(--fs-eyebrow);
  letter-spacing: var(--tk-eyebrow);
  text-transform: lowercase;
  background: var(--ink); color: var(--bg);
  border: 1px solid var(--ink);
  padding: 11px 18px;
  font-weight: var(--fw-medium);
  border-bottom: 1px solid var(--ink);
}
.inline-cta .btn-primary:hover { background: var(--accent); border-color: var(--accent); color: #fff; }

/* Visually hide the form's <label> while keeping it for screen readers.
   Defined here because blog/blog-post.css is shared by every live post,
   and the inline-cta form labels rely on this class. */
.visually-hidden {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;
}

/* Email-capture form variant — mirrors the homepage capture so signing up
   from a blog post feels identical to signing up from the homepage. */
.inline-cta .cta-form {
  display: flex; gap: 0;
  max-width: 440px; margin: 0 auto;
  border: 1px solid var(--ink); background: var(--bg);
}
.inline-cta .cta-form input[type="email"] {
  flex: 1; min-width: 0;
  font-family: inherit; font-size: var(--fs-body);
  padding: var(--space-3) var(--space-4);
  background: transparent; color: var(--ink);
  border: none; border-right: 1px solid var(--ink); outline: none;
  border-radius: 0;
  -webkit-appearance: none; appearance: none;
}
.inline-cta .cta-form input[type="email"]::placeholder { color: var(--muted); text-transform: lowercase; }
.inline-cta .cta-form button {
  font-family: inherit; font-size: var(--fs-eyebrow);
  letter-spacing: var(--tk-eyebrow); text-transform: lowercase;
  background: var(--ink); color: var(--bg);
  border: none; padding: var(--space-3) var(--space-5);
  font-weight: var(--fw-medium); cursor: pointer;
  border-radius: 0;
  -webkit-appearance: none; appearance: none;
  transition: background var(--dur-fast) var(--ease-out);
}
.inline-cta .cta-form button:hover { background: var(--accent); }
.inline-cta .cta-form button:disabled { opacity: 0.5; cursor: not-allowed; }
.inline-cta .cap-footnote {
  margin: var(--space-3) auto 0; max-width: 440px; text-align: left;
  font-size: var(--fs-eyebrow); letter-spacing: 0.04em; line-height: 1.7;
}
.inline-cta .cap-footnote .promise { color: var(--ink); }
.inline-cta .cap-footnote .cadence { color: var(--muted); }
.inline-cta .cta-status {
  font-size: var(--fs-eyebrow); letter-spacing: 0.04em;
  min-height: 1em; margin-top: var(--space-3); color: var(--muted);
  text-align: center;
}
.inline-cta .cta-status.ok { color: var(--accent); }
.inline-cta .cta-status.err { color: var(--accent); }
@media (max-width: 520px) {
  .inline-cta .cta-form { flex-direction: column; max-width: none; }
  .inline-cta .cta-form input[type="email"] { border-right: none; border-bottom: 1px solid var(--ink); }
  .inline-cta .cta-form button { width: 100%; }
}

/* ============================================================
   FLOATING TOC — sticky in the right gutter, beyond the prose
   ============================================================ */
.toc-wrapper {
  position: fixed;
  top: calc(var(--header-h) + var(--space-7));
  right: var(--space-7);
  width: 200px;
  max-height: calc(100vh - var(--header-h) - var(--space-9));
  overflow-y: auto;
  opacity: 0;
  transition: opacity var(--dur-base) var(--ease-out);
  pointer-events: none;
}
.toc-wrapper.visible { opacity: 1; pointer-events: auto; }
.toc {
  border-left: 1px solid var(--soft);
  padding: var(--space-1) 0 var(--space-1) var(--space-5);
}
.toc-label {
  font-size: var(--fs-micro);
  letter-spacing: var(--tk-micro);
  text-transform: lowercase;
  color: var(--muted);
  font-weight: var(--fw-bold);
  margin-bottom: var(--space-4);
}
.toc ul { list-style: none; padding: 0; margin: 0; }
.toc li { margin-bottom: var(--space-3); }
.toc a {
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.02em;
  text-transform: lowercase;
  color: var(--muted);
  border: none;
  line-height: 1.5;
  display: block;
  transition: color var(--dur-fast) var(--ease-out);
}
.toc a:hover { color: var(--ink); }
.toc a.active { color: var(--accent); font-weight: var(--fw-medium); }

/* ============================================================
   FOOTER
   ============================================================ */
footer {
  border-top: 1px solid var(--soft);
  padding: var(--space-6) 0;
}
footer .wrap {
  display: flex; align-items: center; justify-content: space-between;
}
footer .foot-mark {
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.06em;
  text-transform: lowercase;
  color: var(--muted);
}
footer .foot-mark b { color: var(--ink); font-weight: var(--fw-bold); }
footer .foot-mark a { border: none; color: var(--muted); }
footer .foot-mark a:hover { color: var(--accent); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1300px) {
  .toc-wrapper { display: none; }
}
@media (max-width: 880px) {
  .stat-grid { grid-template-columns: repeat(2, 1fr); }
  .article-header h1 { font-size: 28px; }
}
@media (max-width: 560px) {
  .topbar { min-height: 56px; }
  .topbar nav { gap: var(--space-3); }
  .topbar nav a { font-size: 10.5px; }
  .topbar .cta { padding: 7px 11px; font-size: 10.5px; }
  .wrap { padding: 0 var(--space-5); }
  .article-header { padding: var(--space-8) 0 var(--space-6); }
  .article-header h1 { font-size: 24px; }
  .article-content h2 { font-size: 19px; margin-top: var(--space-7); }
  .stat-grid { grid-template-columns: 1fr; }
  .inline-cta { padding: var(--space-6) var(--space-5); }
  .comparison-table { font-size: 11.5px; }
  .comparison-table th, .comparison-table td { padding: var(--space-3) var(--space-3); }
}

/* CTA button — replaces the legacy email-capture form in inline CTAs.
   Links straight to the cal.com assessment booking. */
.inline-cta .cta-button {
  display: inline-block;
  background: var(--accent);
  color: #fff;
  border: 1px solid var(--accent-hi);
  border-radius: 8px;
  padding: 12px 20px;
  font-weight: var(--fw-bold, 600);
  text-decoration: none;
  letter-spacing: 0.01em;
  transition: background var(--dur-fast, .15s) var(--ease-out, ease);
}
.inline-cta .cta-button:hover { background: var(--accent-hi); border-color: var(--accent-hi); color: #fff; }

/* Download-as-Markdown button — sits in the article meta row. */
.article-meta .download-md {
  display: inline-flex; align-items: center; gap: 6px;
  background: none; border: none; padding: 0; margin: 0;
  font: inherit; font-size: var(--fs-micro); letter-spacing: 0.04em;
  text-transform: lowercase; color: var(--accent); cursor: pointer;
}
.article-meta .download-md svg { width: 14px; height: 14px; stroke: currentColor; fill: none; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
.article-meta .download-md:hover { color: var(--accent-hi); }
