/* Shared styles for SEO landing pages (#70). Matches faq.html tokens. No emojis anywhere. */
:root {
  --bg: #ffffff; --fg: #1a1a1a; --muted: #6b7280; --accent: #4F46E5;
  --border: #e5e7eb; --card: #f9fafb;
}
@media (prefers-color-scheme: dark) {
  :root { --bg: #0f172a; --fg: #f1f5f9; --muted: #94a3b8; --accent: #8B5CF6; --border: #1e293b; --card: #1e293b; }
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; overflow-x: clip; }
body { background: var(--bg); color: var(--fg); font-family: 'Heebo', system-ui, -apple-system, sans-serif; line-height: 1.7; font-size: 16px; }
.container { max-width: 800px; margin: 0 auto; padding: 24px 20px 64px; }
header { border-bottom: 1px solid var(--border); padding-bottom: 16px; margin-bottom: 24px; }
h1 { font-size: 1.85rem; margin: 0 0 8px; }
h2 { font-size: 1.25rem; margin: 28px 0 8px; }
.lead { color: var(--muted); font-size: 1.05rem; margin: 0 0 8px; }
p { margin: 10px 0; }
a { color: var(--accent); }
a:focus, summary:focus { outline: 3px solid var(--accent); outline-offset: 2px; }
.cta { display: inline-block; margin: 18px 0 4px; background: var(--accent); color: #fff; padding: 11px 22px; border-radius: 999px; text-decoration: none; font-weight: 700; }
details { border: 1px solid var(--border); border-radius: 12px; margin: 10px 0; background: var(--card); overflow: hidden; }
details > summary { cursor: pointer; padding: 14px 18px; font-weight: 700; list-style: none; }
details > summary::-webkit-details-marker { display: none; }
details[open] > summary { color: var(--accent); }
details .ans { padding: 0 18px 16px; }
ol.steps { padding-inline-start: 22px; } ol.steps li { margin: 6px 0; }
footer { margin-top: 40px; padding-top: 16px; border-top: 1px solid var(--border); color: var(--muted); font-size: 0.9rem; }
footer a { margin-inline-end: 14px; }
@media (max-width: 600px) { h1 { font-size: 1.45rem; } .container { padding: 16px 14px 48px; } }
