:root{
  --ink:#1C1C1C; --steel:#2F4858; --copper:#B97A56; --linen:#F4F4F4;
  --max:72rem; --pad:1rem; --radius:.75rem;
}
*{box-sizing:border-box} html{scroll-behavior:smooth}
body{margin:0;color:var(--ink);background:#fff;font-family:"Figtree",system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial,sans-serif;line-height:1.6}
h1,h2,h3{font-family:"Merriweather",Georgia,"Times New Roman",serif;line-height:1.2;margin:.5em 0}
a{color:var(--steel);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:var(--max);margin-inline:auto;padding:0 var(--pad)}
.header{padding:1rem 0;border-bottom:1px solid #eee}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.nav ul{display:flex;gap:1rem;list-style:none;margin:0;padding:0}
.hero{padding:4rem 0;background:linear-gradient(180deg,#fff, var(--linen))}
.cta{display:inline-block;padding:.75rem 1rem;border-radius:var(--radius);background:var(--steel);color:#fff;font-weight:600}
.cta.secondary{background:var(--copper)}
.grid{display:grid;gap:1rem}
@media(min-width:768px){.grid.cols-2{grid-template-columns:1fr 1fr}.grid.cols-4{grid-template-columns:repeat(4,1fr)}}
.card{border:1px solid #eee;border-radius:var(--radius);padding:1rem;background:#fff}
.section{padding:3rem 0}
.footer{padding:2rem 0;border-top:1px solid #eee;font-size:.9rem}
label{display:block;font-weight:600;margin:.5rem 0}
input,textarea{width:100%;padding:.6rem;border:1px solid #ddd;border-radius:.5rem;font:inherit}
textarea{min-height:140px;resize:vertical}
button{cursor:pointer}
.hp{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.badge{display:inline-block;background:var(--linen);border:1px solid #e6e6e6;border-radius:999px;padding:.25rem .6rem;font-size:.85rem}
