:root{
  --maroon:#660000; --ink:#0b1220; --muted:#5b6776; --bg:#ffffff; --surface:#f7f7f9;
  --fs-hero: clamp(1.9rem, 5.5vw, 3.2rem);
  --fs-h2:   clamp(1.25rem, 2.2vw, 1.6rem);
  --fs-body: clamp(0.98rem, 1.2vw, 1.05rem);
  --radius: 12px;
  --s-1:8px; --s-2:12px; --s-3:16px; --s-4:20px; --s-5:24px; --s-6:28px; --s-7:32px; --s-8:40px;
}

html{font:16px/1.5 -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Helvetica, Arial, sans-serif}
body{margin:0;background:var(--bg);color:var(--ink);font-size:var(--fs-body)}
a{color:var(--maroon);text-decoration:none}
a:focus-visible,.btn:focus-visible,input:focus-visible,textarea:focus-visible{outline:3px solid #1e90ff;outline-offset:2px}
.sr-only{position:absolute;left:-10000px;top:auto;width:1px;height:1px;overflow:hidden}

.wrap{max-width:1100px;margin:0 auto;padding-inline:18px}
.narrow{max-width:760px}
.small{color:var(--muted);font-size:.9rem}
.link-more{font-weight:600}

.page-hero{
  background:var(--maroon);color:#fff;border-bottom:8px solid #5a0000;
  padding-block: clamp(28px, 6.5vw, 56px); margin:0 0 var(--s-5);
}
.page-hero h1{margin:0;font-size:var(--fs-hero);font-weight:800;color:#D3AF37;}

.section{padding-block: clamp(36px, 7vw, 56px)}
.section.alt{background:var(--surface)}
.section-title{margin:0 0 var(--s-3);font-size:var(--fs-h2);font-weight:700;color:#660000;}

.cards{display:grid;gap:var(--s-3);grid-template-columns:1fr}
@media (min-width: 720px){ .cards{grid-template-columns:repeat(2,1fr)} }
@media (min-width: 1024px){ .cards{grid-template-columns:repeat(3,1fr)} }
.card{background:#fff;border:1px solid #e6e6ef;border-radius:var(--radius);padding:var(--s-3)}
.card h3{margin:0 0 6px;font-size:1.1rem}
.card p{margin:0;color:#3c4658}

.footer{background:#D3AF37;color:#0b1220;padding-block:28px}
@media (max-width: 480px){
  .section{padding-block:40px}
}

/* Header nav */
.site-header{background:var(--maroon);color:#fff}
.header-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-block:20px}
.brand{display:flex;align-items:center;gap:10px;color:#fff;text-decoration:none;font-weight:800}
.brand .logo{height:150px;width:auto;display:block}
.menu{display:flex;gap:16px;align-items:center}
.menu a{color:#fff}
.nav-toggle{display:none;background:transparent;border:1px solid #fff;color:#fff;border-radius:8px;padding:8px 10px;font-weight:600}
@media (max-width: 720px){
  .menu{display:none;flex-direction:column;align-items:flex-start;padding-block:8px}
  .menu.open{display:flex}
  .nav-toggle{display:inline-block}
}

/* About headshot & grid */
.headshot{
  width: clamp(180px, 40vw, 320px);
  max-width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  height: auto;
  border-radius: var(--radius);
  display:block;
}
@media (min-width: 720px){
  .about-grid{grid-template-columns: minmax(220px, 320px) 1fr}
}

.btn {
  display:inline-block;
  border:2px solid var(--maroon);
  border-radius:10px;
  padding:12px 20px;
  font-weight:700;
  text-decoration:none;
  background:transparent;
  color:var(--maroon);
  transition:all 0.2s ease;
}
.btn:hover,
.btn:focus {
  background:var(--maroon);
  color:#fff;
}
.btn.primary {
  background:var(--maroon);
  color:#fff;
  border-color:var(--maroon);
}
.btn.primary:hover,
.btn.primary:focus {
  background:#fff;
  color:var(--maroon);
}
/* Form styling */
.form{
  display:flex;
  flex-direction:column;
  gap:16px;
}
.form input,
.form textarea{
  font:inherit;
  border:1px solid #cfd7e6;
  border-radius:10px;
  padding:12px;
  width:100%;
  box-sizing:border-box;
}
.form button{
  align-self:flex-start;
}