:root{
  --ink:#16202c; --muted:#5b6b7b; --line:#e3e8ef; --bg:#ffffff; --soft:#f5f7fa;
  --brand:#0b4f8a; --brand-dark:#08365f; --accent:#1f9d8c; --max:1080px; --radius:10px;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;font:16px/1.6 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg)}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto}
.container{max-width:var(--max);margin:0 auto;padding:0 20px}
.muted{color:var(--muted)}
.center{text-align:center}

/* Header / nav */
.site-header{border-bottom:1px solid var(--line);background:#fff;position:sticky;top:0;z-index:50}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 20px}
.brand{display:flex;align-items:center;gap:12px;color:var(--ink)}
.brand:hover{text-decoration:none}
.brand-mark{font-weight:800;letter-spacing:.5px;color:#fff;background:var(--brand);padding:8px 10px;border-radius:8px;font-size:15px}
.brand-text{display:flex;flex-direction:column;font-weight:700;line-height:1.15}
.brand-text small{font-weight:400;color:var(--muted);font-size:12px}
.site-nav ul{list-style:none;display:flex;gap:4px;margin:0;padding:0}
.site-nav li{position:relative}
.site-nav a{display:block;padding:10px 12px;color:var(--ink);border-radius:6px;font-weight:500}
.site-nav a:hover{background:var(--soft);text-decoration:none}
.submenu{display:none;position:absolute;left:0;top:100%;background:#fff;border:1px solid var(--line);border-radius:8px;min-width:200px;box-shadow:0 8px 24px rgba(0,0,0,.08);padding:6px}
.site-nav li.has-children:hover .submenu{display:block}
.nav-toggle{display:none;font-size:22px;background:none;border:0;cursor:pointer}

/* Hero */
.hero{background:linear-gradient(135deg,var(--brand),var(--brand-dark));color:#fff}
.hero-inner{max-width:var(--max);margin:0 auto;padding:64px 20px}
.hero h1{font-size:2.4rem;margin:0 0 12px}
.hero p{font-size:1.15rem;max-width:640px;opacity:.95}
.btn{display:inline-block;background:#fff;color:var(--brand-dark);font-weight:600;padding:11px 20px;border-radius:8px;border:0;cursor:pointer;margin-top:18px}
.btn:hover{text-decoration:none;background:var(--soft)}

/* Blocks */
main.container{padding-top:36px;padding-bottom:56px}
.block{margin:0 0 48px}
.block h2{font-size:1.5rem;margin:0 0 18px}
.prose h1{font-size:2rem;margin:.2em 0 .5em}
/* Cap + center content images so migrated headshots/photos render consistently */
.prose img{border-radius:var(--radius);max-width:min(100%,520px);height:auto;display:block;margin:1.2em auto}
.prose p{margin:0 0 1em}

/* Cards */
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:18px}
.card{display:block;border:1px solid var(--line);border-radius:var(--radius);padding:18px;background:#fff;color:var(--ink);transition:box-shadow .15s,transform .15s}
.card:hover{text-decoration:none;box-shadow:0 8px 24px rgba(0,0,0,.08);transform:translateY(-2px)}
.card img{border-radius:8px;margin-bottom:10px;aspect-ratio:16/10;object-fit:cover;width:100%}
.card h3{margin:.2em 0;font-size:1.1rem}
.card-date{font-size:.8rem;color:var(--accent);font-weight:700;text-transform:uppercase;letter-spacing:.04em}

/* Lists */
.post-list{list-style:none;padding:0;margin:0}
.post-list li{padding:12px 0;border-bottom:1px solid var(--line)}
.post-list-date{display:inline-block;width:64px;color:var(--accent);font-weight:700}
.year-grid{list-style:none;display:flex;flex-wrap:wrap;gap:10px;padding:0}
.year-grid a{display:block;border:1px solid var(--line);padding:12px 18px;border-radius:8px;font-weight:600}

/* Post / spotlight */
.post-meta{color:var(--muted);margin:-.3em 0 1.2em}
.post-hero{border-radius:var(--radius);margin:0 0 1.2em}
.spotlight-head{display:flex;gap:24px;align-items:center;flex-wrap:wrap}
.spotlight-photo{width:180px;height:180px;object-fit:cover;border-radius:12px}

/* Forms */
.form{display:flex;flex-direction:column;gap:14px;max-width:560px}
.form label{display:flex;flex-direction:column;gap:6px;font-weight:600}
.form input,.form textarea{font:inherit;padding:11px 12px;border:1px solid var(--line);border-radius:8px;width:100%}
.form .btn{align-self:flex-start;background:var(--brand);color:#fff}
.form .btn:hover{background:var(--brand-dark)}
.hp{position:absolute;left:-9999px;height:0;overflow:hidden}

/* Flash */
.flash{padding:12px 16px;border-radius:8px;margin:0 0 18px}
.flash-success{background:#e7f7ef;color:#0a6b43}
.flash-error{background:#fdeaea;color:#a32020}
.flash-info{background:#eaf2fb;color:#0b4f8a}

/* Footer */
.site-footer{border-top:1px solid var(--line);background:var(--soft);margin-top:40px}
.footer-inner{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;padding:28px 20px}
.footer-nav{display:flex;gap:18px}

/* Popup */
.popup-overlay{position:fixed;inset:0;background:rgba(10,20,30,.55);display:flex;align-items:center;justify-content:center;z-index:100;padding:20px}
.popup-box{background:#fff;border-radius:12px;max-width:520px;width:100%;padding:28px;position:relative;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.popup-close{position:absolute;top:10px;right:14px;font-size:26px;background:none;border:0;cursor:pointer;color:var(--muted)}

/* Mobile */
@media (max-width:760px){
  .nav-toggle{display:block}
  .site-nav{display:none;width:100%}
  .site-nav.open{display:block}
  .header-inner{flex-wrap:wrap}
  .site-nav ul{flex-direction:column;width:100%}
  .submenu{position:static;display:block;border:0;box-shadow:none;padding-left:16px}
  .hero h1{font-size:1.8rem}
}
