/* Lawson Group — brand styles per 04_Marketing/visual-identity.md */
:root{
  --navy:#1B3A5C; --teal:#4A8490; --champagne:#F0EDE6; --ice:#D4E5EB;
  --slate:#8B9EAA; --text:#2B2B2B; --bg:#F8F9FA; --white:#FFFFFF;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;color:var(--text);background:var(--bg);font-size:16px;line-height:1.65}
.container{max-width:1080px;margin:0 auto;padding:0 24px}

/* Nav */
header{background:var(--navy);position:sticky;top:0;z-index:50}
.nav{display:flex;align-items:center;justify-content:space-between;height:64px}
.logo{color:var(--white);font-weight:700;font-size:1.25rem;text-decoration:none;letter-spacing:.3px}
.logo span{color:var(--ice);font-weight:400}
nav ul{display:flex;gap:28px;list-style:none;align-items:center}
nav a{color:var(--ice);text-decoration:none;font-size:.95rem}
nav a:hover{color:var(--white)}
.nav-cta{background:var(--teal);color:var(--white)!important;padding:9px 18px;border-radius:6px;font-weight:600}
.nav-cta:hover{filter:brightness(1.08)}

/* Hero */
.hero{background:var(--navy);color:var(--white);padding:84px 0 92px;text-align:left}
.hero h1{font-size:clamp(2rem,5vw,3rem);font-weight:700;line-height:1.15;max-width:760px}
.hero p{font-size:1.15rem;color:var(--ice);margin:18px 0 30px;max-width:640px}
.btn{display:inline-block;padding:14px 28px;border-radius:6px;font-weight:600;text-decoration:none;font-size:1rem}
.btn-primary{background:var(--teal);color:var(--white)}
.btn-primary:hover{filter:brightness(1.08)}
.btn-navy{background:var(--navy);color:var(--white)}
.btn-outline{border:2px solid var(--navy);color:var(--navy)}

/* Sections */
section{padding:64px 0}
.section-alt{background:var(--champagne)}
.kicker{color:var(--teal);font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:.8rem;margin-bottom:8px}
h2{font-size:1.7rem;font-weight:600;color:var(--navy);margin-bottom:14px}
h3{font-size:1.15rem;font-weight:500;color:var(--navy);margin-bottom:8px}
.lead{font-size:1.08rem;max-width:720px}
.pullquote{font-family:'DM Serif Display',serif;font-style:italic;font-size:1.35rem;color:var(--navy);border-left:4px solid var(--teal);padding-left:20px;margin:28px 0;max-width:680px}

/* Cards */
.grid{display:grid;gap:22px;margin-top:32px}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.grid-2{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}
.card{background:var(--white);border:1px solid var(--ice);border-radius:10px;padding:26px}
.card-ice{background:var(--ice);border:none}
.card .num{font-size:1.6rem;font-weight:700;color:var(--teal)}
.tag{display:inline-block;background:var(--ice);color:var(--navy);font-size:.78rem;font-weight:600;padding:4px 10px;border-radius:99px;margin-right:6px;margin-bottom:10px}

/* Work / portfolio */
.work-card{display:flex;flex-direction:column;gap:10px}
.work-card .meta{color:var(--slate);font-size:.85rem}
.work-card a.visit{color:var(--teal);font-weight:600;text-decoration:none}
.work-card a.visit:hover{text-decoration:underline}
.result{background:var(--champagne);border-radius:8px;padding:12px 16px;font-size:.95rem}

/* Pricing tables */
table{width:100%;border-collapse:collapse;background:var(--white);border-radius:10px;overflow:hidden;margin-top:18px}
th{background:var(--navy);color:var(--white);text-align:left;padding:13px 16px;font-weight:600;font-size:.95rem}
td{padding:13px 16px;border-bottom:1px solid var(--ice);font-size:.95rem}
tr:last-child td{border-bottom:none}

/* Forms */
form{display:grid;gap:14px;max-width:560px}
label{font-weight:600;font-size:.9rem;color:var(--navy)}
input,select,textarea{width:100%;padding:12px;border:1px solid var(--slate);border-radius:6px;font-family:inherit;font-size:.95rem;background:var(--white)}
input:focus,select:focus,textarea:focus{outline:2px solid var(--teal);border-color:var(--teal)}

/* CTA band */
.cta-band{background:var(--navy);color:var(--white);text-align:center;padding:60px 0}
.cta-band h2{color:var(--white)}
.cta-band p{color:var(--ice);margin-bottom:24px}

/* Footer */
footer{background:var(--navy);color:var(--ice);padding:36px 0;font-size:.88rem}
.footer-grid{display:flex;flex-wrap:wrap;gap:32px;justify-content:space-between;align-items:flex-start}
footer a{color:var(--ice);text-decoration:none}
footer a:hover{color:var(--white)}
footer .fine{margin-top:18px;color:var(--slate)}

@media(max-width:720px){
  nav ul{gap:16px}
  nav ul li.hide-m{display:none}
  .hero{padding:56px 0 64px}
}
