/* Shared styles for SEO landing pages — matches biteful design tokens */
:root {
  --paper:      #F1E7D3;
  --paper-soft: #ECE2CB;
  --paper-deep: #E0D2B0;
  --rule:       #C5B9A0;
  --ink:        #2A2621;
  --ink-soft:   #5C544A;
  --ink-muted:  #8A7F70;
  --ink-faint:  #B8AC98;
  --good:       #7B9460;
  --good-bg:    #E5ECCF;
  --good-ink:   #4A5A36;
  --good-soft:  #BCC9A0;
  --bad:        #BE644A;
  --bad-bg:     #F2DDC8;
  --bad-ink:    #7A3825;
  --display: "Fraunces", "Iowan Old Style", Georgia, serif;
  --sans:    "Inter Tight", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  --mono:    "JetBrains Mono", "SF Mono", ui-monospace, monospace;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  background-image:
    radial-gradient(circle at 20% 10%, #F4ECDB, transparent 40%),
    radial-gradient(circle at 80% 90%, #DDD0B5, transparent 50%);
}
a { color: inherit; }
em { font-family: var(--display); font-style: italic; }

.wrap { max-width: 760px; margin: 0 auto; padding: 0 24px; }
.wrap-wide { max-width: 980px; margin: 0 auto; padding: 0 24px; }

.topbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 22px 0; max-width: 980px; margin: 0 auto; padding-left: 24px; padding-right: 24px;
}
.wordmark {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--display); font-size: 22px; font-weight: 500;
  letter-spacing: -0.4px; color: var(--ink); text-decoration: none;
}
.wordmark .dot { color: var(--bad); }
.wordmark img { width: 28px; height: 28px; border-radius: 6px; }
.back { color: var(--ink-soft); text-decoration: none; font-size: 14px; font-weight: 500; }
.back:hover { color: var(--ink); }

.eyebrow {
  font-family: var(--mono); font-size: 11px; letter-spacing: 1.4px;
  text-transform: uppercase; color: var(--ink-muted); font-weight: 700;
}

.seo-hero { padding: 24px 0 48px; }
.seo-hero h1 {
  font-family: var(--display); font-weight: 400;
  font-size: clamp(34px, 5vw, 48px);
  line-height: 1.05; letter-spacing: -1.2px;
  margin: 14px 0 16px; text-wrap: balance;
}
.seo-hero h1 em.good { color: var(--good); }
.seo-hero h1 em.bad { color: var(--bad); }
.seo-hero .lede {
  font-size: 17px; line-height: 1.55; color: var(--ink-soft);
  max-width: 620px; margin: 0 0 28px;
}

.appstore-badge {
  display: inline-flex; align-items: center; gap: 12px;
  background: var(--ink); color: #fff;
  padding: 12px 22px; border-radius: 14px;
  text-decoration: none; font-weight: 600;
  box-shadow: 0 18px 40px -18px rgba(42,38,33,0.45);
  transition: transform 160ms ease;
}
.appstore-badge:hover { transform: translateY(-1px); }
.appstore-badge .apple-icon { width: 22px; height: 22px; }
.appstore-badge .label-stack { display: flex; flex-direction: column; line-height: 1; }
.appstore-badge .label-stack small { font-size: 10px; opacity: 0.8; font-weight: 500; letter-spacing: 0.3px; }
.appstore-badge .label-stack span { font-size: 16px; font-weight: 600; margin-top: 3px; }

.seo-body { padding-bottom: 60px; }
.seo-body h2 {
  font-family: var(--display); font-weight: 500;
  font-size: 26px; letter-spacing: -0.5px; line-height: 1.15;
  margin: 44px 0 14px;
}
.seo-body h3 {
  font-family: var(--sans); font-weight: 600; font-size: 16px;
  margin: 28px 0 8px; color: var(--ink);
}
.seo-body p { color: var(--ink-soft); margin: 0 0 16px; }
.seo-body ul, .seo-body ol {
  color: var(--ink-soft); margin: 0 0 20px; padding-left: 22px;
}
.seo-body li { margin-bottom: 8px; }
.seo-body a { color: var(--ink); font-weight: 500; text-underline-offset: 3px; }

.feature-list {
  list-style: none; padding: 0; margin: 24px 0 32px;
  display: grid; gap: 12px;
}
.feature-list li {
  background: var(--paper-soft); border: 1px solid var(--rule);
  border-radius: 14px; padding: 16px 18px; margin: 0;
  color: var(--ink-soft); font-size: 15px;
}
.feature-list li strong { color: var(--ink); font-weight: 600; }

.compare-table {
  width: 100%; border-collapse: collapse; margin: 24px 0 32px;
  font-size: 14.5px;
}
.compare-table th, .compare-table td {
  border: 1px solid var(--rule); padding: 12px 14px; text-align: left;
}
.compare-table th {
  background: var(--paper-soft); font-weight: 600; color: var(--ink);
}
.compare-table td { color: var(--ink-soft); }
.compare-table td:first-child { font-weight: 500; color: var(--ink); }

.callout {
  background: var(--good-bg); border: 1px solid var(--good-soft, #BCC9A0);
  border-radius: 16px; padding: 22px 24px; margin: 32px 0;
}
.callout p { margin: 0; color: var(--good-ink); font-size: 15px; }

.steps { counter-reset: step; list-style: none; padding: 0; margin: 24px 0; }
.steps li {
  counter-increment: step; position: relative;
  padding-left: 44px; margin-bottom: 20px; color: var(--ink-soft);
}
.steps li::before {
  content: counter(step);
  position: absolute; left: 0; top: 0;
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--ink); color: #fff;
  font-family: var(--mono); font-size: 12px; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
}
.steps li strong { color: var(--ink); }

.related {
  padding: 40px 0 20px; border-top: 1px solid var(--rule); margin-top: 20px;
}
.related h2 {
  font-family: var(--display); font-size: 22px; font-weight: 500;
  margin: 0 0 16px; letter-spacing: -0.3px;
}
.related-links {
  display: flex; flex-wrap: wrap; gap: 10px;
}
.related-links a {
  display: inline-block; padding: 10px 14px;
  background: var(--paper-soft); border: 1px solid var(--rule);
  border-radius: 999px; text-decoration: none;
  font-size: 13.5px; font-weight: 500; color: var(--ink-soft);
  transition: background 160ms ease, color 160ms ease;
}
.related-links a:hover { background: var(--paper-deep); color: var(--ink); }

.seo-shot {
  margin: 32px 0; text-align: center;
}
.seo-shot img {
  max-width: 280px; width: 100%;
  border-radius: 24px;
}

footer {
  padding: 40px 0; border-top: 1px solid var(--rule);
  color: var(--ink-faint); font-size: 12px; text-align: center;
}
footer a { color: var(--ink-soft); text-decoration: none; }
footer a:hover { color: var(--ink); }

@media (max-width: 640px) {
  .compare-table { font-size: 13px; }
  .compare-table th, .compare-table td { padding: 10px; }
}
