/* ---------------------------------------------------------------------------
 * seo.css — shared stylesheet for ChurnMiser's static SEO/GEO marketing pages
 * (comparison pages under /compare/, blog posts under /blog/).
 *
 * These pages are plain HTML served straight from S3/CloudFront — NOT part of
 * the React SPA — so they ship their own self-contained styling. No JS, no
 * framework: fast first paint and clean source for search + AI crawlers.
 *
 * Brand: Manrope, ChurnMiser green (#10B981). Mirrors index.html's first-paint
 * shell so these pages feel on-brand next to the app.
 * ------------------------------------------------------------------------- */

:root {
  --green: #10b981;
  --green-dark: #059669;
  --green-soft: #ecfdf5;
  --ink: #0f172a;
  --slate: #475569;
  --slate-light: #64748b;
  --line: #e2e8f0;
  --line-soft: #f1f5f9;
  --bg: #ffffff;
  --bg-soft: #f8fafc;
  --amber-soft: #fffbeb;
  --amber-line: #fde68a;
  --radius: 14px;
  --maxw: 880px;
}

* { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: 'Manrope', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  color: var(--ink);
  background: var(--bg);
  line-height: 1.65;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
}

img { max-width: 100%; height: auto; }

a { color: var(--green-dark); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ── Site header ──────────────────────────────────────────────────────── */
.site-header {
  border-bottom: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.9);
  backdrop-filter: saturate(180%) blur(8px);
  position: sticky;
  top: 0;
  z-index: 10;
}
.site-header .inner {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 14px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-weight: 800;
  font-size: 18px;
  color: var(--ink);
  letter-spacing: -0.01em;
}
.brand:hover { text-decoration: none; }
.brand img { width: 28px; height: 28px; }

/* ── Buttons ──────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-weight: 700;
  font-size: 15px;
  padding: 11px 20px;
  border-radius: 10px;
  border: 1px solid transparent;
  cursor: pointer;
  transition: opacity 0.15s ease, background 0.15s ease, transform 0.05s ease;
  text-align: center;
}
.btn:hover { text-decoration: none; }
.btn:active { transform: translateY(1px); }
.btn-primary { background: var(--green); color: #fff; }
.btn-primary:hover { background: var(--green-dark); color: #fff; }
.btn-ghost { background: transparent; color: var(--ink); border-color: var(--line); }
.btn-ghost:hover { background: var(--bg-soft); color: var(--ink); }
.btn-sm { padding: 8px 14px; font-size: 14px; }

/* ── Layout ───────────────────────────────────────────────────────────── */
main { max-width: var(--maxw); margin: 0 auto; padding: 0 20px; }

.breadcrumb {
  font-size: 13px;
  color: var(--slate-light);
  padding: 18px 0 0;
}
.breadcrumb a { color: var(--slate-light); }
.breadcrumb a:hover { color: var(--ink); }

.hero { padding: 28px 0 8px; }
.eyebrow {
  display: inline-block;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--green-dark);
  background: var(--green-soft);
  padding: 5px 11px;
  border-radius: 999px;
  margin-bottom: 16px;
}
h1 {
  font-size: clamp(30px, 5vw, 44px);
  line-height: 1.12;
  letter-spacing: -0.02em;
  font-weight: 800;
  margin: 0 0 16px;
}
.lede { font-size: 19px; color: var(--slate); margin: 0 0 8px; }

h2 {
  font-size: clamp(24px, 3.5vw, 30px);
  line-height: 1.2;
  letter-spacing: -0.015em;
  font-weight: 800;
  margin: 48px 0 14px;
  scroll-margin-top: 80px;
}
h3 {
  font-size: 20px;
  font-weight: 700;
  letter-spacing: -0.01em;
  margin: 28px 0 8px;
}
p { margin: 0 0 16px; }
ul, ol { margin: 0 0 16px; padding-left: 22px; }
li { margin: 6px 0; }
strong { font-weight: 700; color: var(--ink); }

/* ── TL;DR / answer box (GEO: direct, citable answer up top) ──────────── */
.tldr {
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-left: 4px solid var(--green);
  border-radius: var(--radius);
  padding: 22px 24px;
  margin: 24px 0 8px;
}
.tldr h2 { margin: 0 0 10px; font-size: 16px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--slate-light); }
.tldr p:last-child { margin-bottom: 0; }

/* ── Comparison / feature tables ──────────────────────────────────────── */
.table-wrap { overflow-x: auto; margin: 20px 0; border: 1px solid var(--line); border-radius: var(--radius); }
table { width: 100%; border-collapse: collapse; font-size: 15px; min-width: 520px; }
thead th {
  background: var(--bg-soft);
  text-align: left;
  font-weight: 800;
  padding: 13px 16px;
  border-bottom: 1px solid var(--line);
  white-space: nowrap;
}
thead th.churnmiser { color: var(--green-dark); }
tbody td { padding: 13px 16px; border-bottom: 1px solid var(--line-soft); vertical-align: top; }
tbody tr:last-child td { border-bottom: none; }
td.feature { font-weight: 600; color: var(--ink); }
.yes { color: var(--green-dark); font-weight: 700; }
.no { color: var(--slate-light); }
.partial { color: #b45309; font-weight: 600; }

/* ── Two-column "where each wins" cards ───────────────────────────────── */
.cols { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin: 20px 0; }
.card {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 22px 24px;
}
.card.win-churnmiser { border-top: 3px solid var(--green); }
.card.win-other { border-top: 3px solid #94a3b8; }
.card h3 { margin-top: 0; }
.card ul { margin-bottom: 0; }

/* ── Callout ──────────────────────────────────────────────────────────── */
.callout {
  background: var(--amber-soft);
  border: 1px solid var(--amber-line);
  border-radius: var(--radius);
  padding: 18px 22px;
  margin: 22px 0;
  font-size: 15px;
}
.callout strong { color: #92400e; }

/* ── FAQ ──────────────────────────────────────────────────────────────── */
.faq { margin: 16px 0; }
.faq-item { border-bottom: 1px solid var(--line); padding: 18px 0; }
.faq-item:first-child { border-top: 1px solid var(--line); }
.faq-item h3 { margin: 0 0 8px; font-size: 18px; }
.faq-item p:last-child { margin-bottom: 0; }

/* ── CTA band ─────────────────────────────────────────────────────────── */
.cta-band {
  background: var(--ink);
  color: #fff;
  border-radius: 18px;
  padding: 40px 32px;
  text-align: center;
  margin: 56px 0 24px;
}
.cta-band h2 { color: #fff; margin: 0 0 10px; }
.cta-band p { color: #cbd5e1; max-width: 540px; margin: 0 auto 22px; }
.cta-band .btn-primary { font-size: 16px; padding: 13px 26px; }
.cta-band .sub { font-size: 13px; color: #94a3b8; margin: 14px 0 0; }

/* ── Footer ───────────────────────────────────────────────────────────── */
.site-footer {
  border-top: 1px solid var(--line);
  margin-top: 48px;
  padding: 28px 0 48px;
}
.site-footer .inner {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 0 20px;
  font-size: 13px;
  color: var(--slate-light);
  display: flex;
  flex-wrap: wrap;
  gap: 8px 18px;
  justify-content: space-between;
}
.site-footer a { color: var(--slate-light); }
.site-footer nav { display: flex; flex-wrap: wrap; gap: 16px; }

.updated { font-size: 13px; color: var(--slate-light); margin-top: 4px; }

/* ── Blog-specific ────────────────────────────────────────────────────── */
.post-meta {
  font-size: 14px;
  color: var(--slate-light);
  margin: 0 0 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px 14px;
}
.toc {
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 18px 22px 18px 40px;
  margin: 24px 0;
}
.toc strong {
  display: block;
  margin: 0 0 8px -18px;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--slate-light);
}
.toc li { margin: 5px 0; }

.formula {
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 18px 22px;
  margin: 20px 0;
  font-size: 16px;
  line-height: 1.5;
}
.formula .eq {
  font-weight: 700;
  color: var(--ink);
  font-size: 18px;
}
.formula .ex { color: var(--slate); font-size: 15px; margin-top: 8px; }

blockquote {
  margin: 22px 0;
  padding: 6px 0 6px 20px;
  border-left: 4px solid var(--green);
  color: var(--slate);
  font-size: 18px;
}

.key-takeaway {
  background: var(--green-soft);
  border: 1px solid #a7f3d0;
  border-radius: var(--radius);
  padding: 18px 22px;
  margin: 22px 0;
  font-size: 15px;
}
.key-takeaway strong { color: var(--green-dark); }

.related {
  border-top: 1px solid var(--line);
  margin-top: 40px;
  padding-top: 20px;
}
.related h2 { margin-top: 0; }
.related ul { list-style: none; padding: 0; }
.related a { font-weight: 600; }

/* ── Mobile ───────────────────────────────────────────────────────────── */
@media (max-width: 640px) {
  body { font-size: 16px; }
  .cols { grid-template-columns: 1fr; }
  .nav-cta-text { display: none; }
  .cta-band { padding: 32px 22px; }
}
