:root { --max: 980px; --pad: 18px; }
body { font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; margin: 0; line-height: 1.55; color: #111; }
a { color: inherit; }
.site-header, .site-footer { border-bottom: 1px solid #eee; }
.site-header { display:flex; align-items:center; justify-content:space-between; padding: 14px var(--pad); }
.site-header nav a { margin-left: 14px; text-decoration:none; opacity:.85; }
.site-header nav a:hover { opacity:1; text-decoration:underline; }
.logo { font-weight: 750; text-decoration:none; letter-spacing:.2px; }
main { max-width: var(--max); margin: 0 auto; padding: 28px var(--pad) 60px; }
h1 { font-size: 2.1rem; margin: 0 0 8px; }
h2 { margin-top: 26px; }
.lead { font-size: 1.1rem; opacity:.9; }
.cta { display:inline-block; padding: 10px 14px; border:1px solid #111; border-radius: 10px; text-decoration:none; margin-right:10px; }
.cta.secondary { border-color:#bbb; opacity:.9; }
ul { padding-left: 18px; }
.cards { display:grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 14px; }
.card { border:1px solid #eee; border-radius: 14px; padding: 14px; }
.kicker { text-transform: uppercase; letter-spacing: .12em; font-size: .78rem; opacity:.7; }
.site-footer { border-top: 1px solid #eee; border-bottom: none; padding: 18px var(--pad); }
.site-footer nav a { margin-right: 14px; text-decoration:none; opacity:.8; }
.site-footer nav a:hover { opacity:1; text-decoration:underline; }
