:root{
  --navy:#16263b; --navy-2:#22354f; --ink:#23272e; --grey:#5a626c; --line:#e3ddd2;
  --paper:#f7f5f1; --paper-2:#efeae1; --gold:#9a7b4f; --white:#ffffff;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--paper);line-height:1.65;font-size:17px}
h1,h2,h3,.serif{font-family:Georgia,"Times New Roman",serif;font-weight:600;letter-spacing:.2px;color:var(--navy)}
a{color:var(--navy);text-decoration:none}
a:hover{color:var(--gold)}
.wrap{max-width:1080px;margin:0 auto;padding:0 28px}

/* header */
.site-head{border-bottom:1px solid var(--line);background:var(--paper);position:sticky;top:0;z-index:10}
.site-head .wrap{display:flex;align-items:center;justify-content:space-between;height:84px}
.brand{display:flex;align-items:center;gap:13px;text-decoration:none}
.brand-mark{height:46px;width:auto;display:block}
.brand-text{display:flex;flex-direction:column;font-family:Georgia,serif;font-size:22px;color:var(--navy);letter-spacing:1.5px;line-height:1.05}
.brand small{display:block;font-size:10.5px;letter-spacing:3px;color:var(--grey);text-transform:uppercase;margin-top:2px}
nav a{margin-left:28px;font-size:14px;letter-spacing:.6px;color:var(--grey);text-transform:uppercase}
nav a:hover,nav a.active{color:var(--navy)}

/* hero */
.hero{background:var(--navy);color:#eef1f5;padding:96px 0 88px}
.hero h1{color:#fff;font-size:42px;line-height:1.2;max-width:18ch;margin:0 0 18px}
.hero p{max-width:60ch;color:#c8cfd9;font-size:18px}
.kicker{font-size:12px;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:20px}

/* sections */
section{padding:72px 0}
.section-alt{background:var(--paper-2)}
.lead{font-size:20px;color:var(--grey);max-width:64ch}
.rule{width:54px;height:2px;background:var(--gold);margin:0 0 26px}

/* practice cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:36px}
.card{background:var(--white);border:1px solid var(--line);padding:30px}
.card h3{margin:0 0 10px;font-size:20px}
.card p{margin:0;color:var(--grey);font-size:15.5px}

/* people */
.people{display:grid;grid-template-columns:repeat(3,1fr);gap:34px;margin-top:40px}
.person{background:var(--white);border:1px solid var(--line)}
.person .photo{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:center 22%;display:block;filter:grayscale(18%) contrast(1.02)}
.person .meta{padding:18px 20px 22px}
.person .meta h3{margin:0 0 3px;font-size:19px}
.person .role{color:var(--gold);font-size:13px;letter-spacing:.4px;text-transform:uppercase;margin:0 0 10px}
.person .bio{color:var(--grey);font-size:14.5px;margin:0}

/* contact */
.offices{display:grid;grid-template-columns:1fr 1fr;gap:34px;margin-top:30px}
.office h3{margin:0 0 8px}
.office p{margin:0;color:var(--grey)}
form.enq{margin-top:18px;display:grid;gap:14px;max-width:560px}
form.enq input,form.enq textarea{padding:13px 14px;border:1px solid var(--line);background:#fff;font:inherit;font-size:15px}
form.enq button{justify-self:start;background:var(--navy);color:#fff;border:0;padding:13px 30px;font:inherit;letter-spacing:1px;text-transform:uppercase;font-size:13px;cursor:pointer}
form.enq button:hover{background:var(--gold)}
form.enq .hp{position:absolute;left:-9999px}

/* footer */
.site-foot{background:var(--navy);color:#aab4c2;padding:46px 0;font-size:13.5px}
.site-foot .wrap{display:flex;justify-content:space-between;flex-wrap:wrap;gap:18px}
.site-foot a{color:#cdd5df}
.site-foot .small{color:#7d899b;font-size:12px}

@media(max-width:820px){
  .cards,.people,.offices{grid-template-columns:1fr}
  .site-head .wrap{height:auto;padding:14px 28px;flex-wrap:wrap;gap:10px}
  .hero h1{font-size:32px}
}
