/* ==========================================================================
   pages.css — shared styles for marketing sub-pages (pricing, alternatives,
   blog, use-cases). Builds on landing.css tokens (--ink, --line, --rad, etc.).
   ========================================================================== */

.pagewrap { max-width: 980px; margin: 0 auto; padding: 96px 32px 90px; }
.pagewrap.narrow { max-width: 760px; }

/* ---- breadcrumb ---- */
.crumbs { font-family: var(--mono); font-size: 11px; letter-spacing: .04em; color: var(--ink-3); margin-bottom: 26px; }
.crumbs a { color: var(--ink-3); text-decoration: none; }
.crumbs a:hover { color: var(--ink); }
.crumbs span { margin: 0 7px; }

/* ---- page hero ---- */
.page-hero { max-width: 720px; margin-bottom: 48px; }
.page-hero .kicker { margin-bottom: 18px; }
.page-hero h1 { font-size: clamp(32px, 4.6vw, 50px); font-weight: 700; letter-spacing: -0.04em; line-height: 1.03; }
.page-hero h1 em { font-style: normal; color: var(--brand); }
.page-hero .lede { margin-top: 22px; font-size: 18.5px; line-height: 1.55; color: var(--ink-2); }
.page-hero .hero-cta { margin-top: 30px; display: flex; gap: 12px; flex-wrap: wrap; align-items: center; }
.page-hero .hero-note { font-size: 13px; color: var(--ink-3); }

/* ---- verdict / callout ---- */
.callout { border: 1px solid var(--line); background: var(--bg-2); border-radius: var(--rad); padding: 24px 26px; margin: 0 0 40px; }
.callout.accent { border-color: var(--ink); box-shadow: var(--shadow-soft); background: #fff; }
.callout h2 { font-size: 16px; font-weight: 650; margin-bottom: 8px; letter-spacing: -0.01em; }
.callout p { font-size: 15px; line-height: 1.65; color: var(--ink-2); margin: 0; }
.callout p + p { margin-top: 10px; }

/* ---- comparison table ---- */
.cmp { margin: 36px 0 44px; overflow-x: auto; }
.cmp table { width: 100%; border-collapse: collapse; font-size: 14.5px; min-width: 560px; }
.cmp th, .cmp td { text-align: left; padding: 13px 16px; border-bottom: 1px solid var(--line); vertical-align: top; }
.cmp thead th { font-family: var(--mono); font-size: 11px; letter-spacing: .04em; text-transform: uppercase; color: var(--ink-3); font-weight: 500; border-bottom: 1px solid var(--line-2); }
.cmp thead th.us { color: var(--ink); }
.cmp tbody th { font-weight: 600; color: var(--ink); width: 31%; }
.cmp td { color: var(--ink-2); }
.cmp td.us { color: var(--ink); font-weight: 550; background: var(--bg-2); }
.cmp tr:last-child td, .cmp tbody tr:last-child td, .cmp tbody tr:last-child th { border-bottom: none; }
.cmp .yes { color: #0e8a68; font-weight: 600; }
.cmp .no { color: var(--ink-3); }

/* ---- when-to-choose two-column ---- */
.choose { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin: 8px 0 44px; }
.choose .card { border: 1px solid var(--line); border-radius: var(--rad); padding: 24px; }
.choose .card.us { border-color: var(--ink); box-shadow: var(--shadow-soft); }
.choose .card h3 { font-size: 16px; font-weight: 650; margin-bottom: 12px; }
.choose .card ul { list-style: none; display: flex; flex-direction: column; gap: 9px; }
.choose .card li { font-size: 14px; line-height: 1.5; color: var(--ink-2); padding-left: 20px; position: relative; }
.choose .card li::before { content: ""; position: absolute; left: 1px; top: 7px; width: 6px; height: 6px; border-radius: 50%; background: var(--ink-3); }
.choose .card.us li::before { background: var(--brand); }

/* ---- prose body (blog + use-case + pricing copy) ---- */
.prose { max-width: 720px; }
.prose h2 { font-size: 25px; font-weight: 650; letter-spacing: -0.025em; margin: 46px 0 14px; scroll-margin-top: 88px; }
.prose h3 { font-size: 18px; font-weight: 600; margin: 30px 0 10px; }
.prose p, .prose li { font-size: 16px; line-height: 1.72; color: var(--ink-2); }
.prose p { margin: 0 0 16px; }
.prose ul, .prose ol { margin: 0 0 18px; padding-left: 22px; display: flex; flex-direction: column; gap: 8px; }
.prose a { color: var(--ink); text-decoration: underline; text-underline-offset: 2px; }
.prose strong { color: var(--ink); font-weight: 600; }
.prose .lede { font-size: 19px; line-height: 1.6; color: var(--ink); margin-bottom: 26px; }
.prose figure { margin: 26px 0; }
.prose figure img { width: 100%; border: 1px solid var(--line); border-radius: var(--rad); }
.prose figcaption { font-size: 12.5px; color: var(--ink-3); margin-top: 8px; text-align: center; }

/* article meta */
.post-meta { font-family: var(--mono); font-size: 12px; letter-spacing: .02em; color: var(--ink-3); margin-bottom: 18px; }
.post-meta b { color: var(--ink-2); font-weight: 500; }
.updated { display: inline-block; margin-top: 4px; }

/* ---- blog index grid ---- */
.bloglist { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-top: 40px; }
.post-card { display: flex; flex-direction: column; border: 1px solid var(--line); border-radius: var(--rad); padding: 26px; text-decoration: none; transition: border-color .2s, box-shadow .2s; }
.post-card:hover { border-color: var(--line-2); box-shadow: var(--shadow-soft); }
.post-card .tag { font-family: var(--mono); font-size: 10.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 12px; }
.post-card h2 { font-size: 19px; font-weight: 650; letter-spacing: -0.02em; line-height: 1.25; color: var(--ink); }
.post-card p { font-size: 14px; line-height: 1.55; color: var(--ink-2); margin-top: 10px; }
.post-card .more { margin-top: auto; padding-top: 16px; font-size: 13px; font-weight: 600; color: var(--brand); }
.post-card.feat { grid-column: 1 / -1; background: var(--bg-2); }

/* ---- inline CTA band inside content ---- */
.inline-cta { border: 1px solid var(--ink); border-radius: var(--rad); padding: 28px 30px; margin: 44px 0; text-align: center; box-shadow: var(--shadow-soft); }
.inline-cta h2 { font-size: 22px; font-weight: 650; letter-spacing: -0.02em; margin: 0 0 8px; }
.inline-cta p { font-size: 14.5px; color: var(--ink-2); margin: 0 0 18px; }

/* ---- pricing page extras ---- */
.pp-faq { max-width: 760px; margin: 60px auto 0; }
.pp-faq h2 { text-align: center; font-size: 26px; font-weight: 650; letter-spacing: -0.02em; margin-bottom: 26px; }

@media (max-width: 760px) {
  .pagewrap { padding: 80px 22px 70px; }
  .choose, .bloglist { grid-template-columns: 1fr; }
}
