body{
  font-family: Arial, sans-serif;
  margin:0;
  color:#13304a;
  background:#f4f8fb;
  line-height:1.7;
}

*{ box-sizing:border-box; }

a{ color:#0f5f94; }
a:hover{ color:#0b4e79; }

header{
  background:linear-gradient(180deg,#0d4d77 0%,#146695 62%,#1c7db0 100%);
  color:#fff;
  padding:28px 20px 20px;
  text-align:center;
}
header h1{
  margin:0;
  font-size:48px;
  line-height:1.05;
  letter-spacing:-1px;
}
header p{
  margin:10px auto 0;
  font-size:18px;
  line-height:1.4;
  max-width:760px;
  color:rgba(255,255,255,0.88);
}

nav{
  background:#ffffff;
  border-bottom:1px solid #d8e3ec;
  display:flex;
  justify-content:center;
  gap:10px;
  flex-wrap:wrap;
  padding:14px 18px;
  position:sticky;
  top:0;
  z-index:20;
}
nav a{
  text-decoration:none;
  color:#114c76;
  font-weight:700;
  padding:10px 16px;
  border-radius:999px;
}
nav a:hover{ background:#eaf4fb; }

.container{
  max-width:1200px;
  margin:0 auto;
  padding:36px 20px 64px;
}

.hero, .page-hero{
  background:linear-gradient(135deg,#0f5d8f 0%,#187bb0 55%,#5db8d8 100%);
  color:#fff;
  border-radius:28px;
  padding:56px 44px;
  box-shadow:0 18px 42px rgba(14,72,108,0.18);
  margin-bottom:28px;
}
.page-hero.compact{
  padding:40px 36px;
}

.hero h1, .page-hero h1{
  margin:0 0 16px;
  font-size:54px;
  line-height:1.04;
  max-width:760px;
  letter-spacing:-1.2px;
}
.page-hero.compact h1{ font-size:44px; }
.hero p, .page-hero p{
  margin:0;
  max-width:820px;
  font-size:19px;
  color:rgba(255,255,255,0.92);
}

.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:26px;
}

.button,
.button-secondary{
  display:inline-block;
  padding:14px 22px;
  border-radius:999px;
  text-decoration:none;
  font-weight:700;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.button{
  background:#ffffff;
  color:#0d567f;
  box-shadow:0 8px 22px rgba(0,0,0,0.12);
}
.button-secondary{
  background:rgba(255,255,255,0.18);
  color:#ffffff;
  border:1px solid rgba(255,255,255,0.32);
}
.button:hover,
.button-secondary:hover{ transform:translateY(-1px); }

.metrics{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
  margin:22px 0 30px;
}
.metric{
  background:#ffffff;
  border:1px solid #dbe8f0;
  border-radius:20px;
  padding:22px;
  box-shadow:0 8px 20px rgba(12,63,99,0.06);
}
.metric strong{
  display:block;
  font-size:28px;
  color:#0d567f;
  margin-bottom:6px;
}

.section-heading{
  margin:0 0 18px;
  font-size:32px;
  line-height:1.15;
  color:#123d5b;
  letter-spacing:-0.6px;
}
.section-intro{
  max-width:760px;
  margin:0 0 24px;
  color:#45637a;
}

.grid-2, .grid-3, .grid-4{
  display:grid;
  gap:20px;
  margin-bottom:28px;
}
.grid-2{ grid-template-columns:repeat(2,minmax(0,1fr)); }
.grid-3{ grid-template-columns:repeat(3,minmax(0,1fr)); }
.grid-4{ grid-template-columns:repeat(4,minmax(0,1fr)); }

.card, .feature-card, .article, .soft-card, .sidebar-card{
  background:#ffffff;
  border:1px solid #dbe8f0;
  border-radius:22px;
  padding:26px;
  box-shadow:0 10px 24px rgba(12,63,99,0.07);
  margin-bottom:22px;
}
.feature-card h2, .card h2, .card h3, .article h1, .article h2, .soft-card h2, .soft-card h3, .sidebar-card h3{ margin-top:0; }
.feature-card p, .card p, .soft-card p, .sidebar-card p{ color:#4a667c; }

.kicker{
  display:inline-block;
  margin-bottom:12px;
  font-size:12px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:1.4px;
  color:#0b5a87;
  background:#e6f3fb;
  padding:7px 12px;
  border-radius:999px;
}
.hero .kicker, .page-hero .kicker{
  background:rgba(255,255,255,0.16);
  color:#fff;
}

.band{
  background:#eaf5fb;
  border:1px solid #d8e7f2;
  border-radius:26px;
  padding:28px;
  margin:26px 0;
}

.cta{
  background:linear-gradient(135deg,#0f5d8f 0%,#187bb0 55%,#5db8d8 100%);
  color:#fff;
  border-radius:26px;
  padding:34px 30px;
  margin:28px 0;
  box-shadow:0 18px 42px rgba(14,72,108,0.16);
}
.cta h2{ margin-top:0; color:#fff; }
.cta p{ color:rgba(255,255,255,.92); }
.cta .button-secondary{ background:rgba(255,255,255,.16); }

.link-list, .link-grid, .article-list{
  margin:0;
  padding-left:20px;
}
.link-grid{
  columns:2;
}
.link-list li, .link-grid li, .article-list li{
  margin-bottom:10px;
}
.article-list small{
  display:block;
  color:#69839a;
  margin-top:3px;
}

footer{
  text-align:center;
  padding:26px 20px 40px;
  color:#5d778f;
  font-size:14px;
}

.content-grid{
  display:grid;
  grid-template-columns:minmax(0,2.1fr) minmax(290px,0.9fr);
  gap:24px;
  align-items:start;
}
.article-shell{
  margin-top:4px;
}
.article{
  padding:34px;
}
.article h2{
  font-size:30px;
  color:#123d5b;
  letter-spacing:-0.5px;
  margin-top:32px;
}
.article h3{
  font-size:22px;
  color:#174d73;
  margin-top:26px;
}
.article p, .article li{
  color:#3f5b70;
  font-size:18px;
}
.article ul{
  padding-left:22px;
}
.back-link{
  display:inline-block;
  margin-bottom:16px;
  font-weight:700;
  text-decoration:none;
}
.lead{
  font-size:20px !important;
  color:#eaf7ff !important;
}
.local-note{
  background:#eff8fd;
  border:1px solid #d9ebf4;
  border-radius:18px;
  padding:18px 20px;
  color:#35607d;
  margin:22px 0;
}
.meta-chip-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:18px;
}
.meta-chip{
  background:#eaf4fb;
  color:#114c76;
  font-size:13px;
  font-weight:700;
  border-radius:999px;
  padding:8px 12px;
}
.sidebar-card .button, .sidebar-card .button-secondary{
  margin-top:10px;
}
.sidebar-card .button-secondary{
  color:#114c76;
  background:#eaf4fb;
  border:none;
}
.note-list{
  padding-left:20px;
  margin:10px 0 0;
}
.inline-cta{
  background:#f4fbff;
  border:1px solid #dcecf5;
  border-radius:18px;
  padding:22px;
  margin:26px 0;
}
.inline-cta h2, .inline-cta h3{
  margin-top:0 !important;
}
.school-strip{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
  margin:26px 0 0;
}
.school-card{
  background:#fff;
  border:1px solid #dbe8f0;
  border-radius:22px;
  padding:24px;
  box-shadow:0 10px 24px rgba(12,63,99,0.07);
}
.muted{
  color:#5f7b90;
}

@media (max-width: 960px){
  .grid-4{ grid-template-columns:repeat(2,minmax(0,1fr)); }
  .grid-3{ grid-template-columns:repeat(2,minmax(0,1fr)); }
  .content-grid{ grid-template-columns:1fr; }
}
@media (max-width: 720px){
  header h1{ font-size:38px; }
  .hero, .page-hero{ padding:34px 24px; border-radius:22px; }
  .hero h1, .page-hero h1{ font-size:36px; }
  .grid-2, .grid-3, .grid-4, .metrics, .school-strip{ grid-template-columns:1fr; }
  .link-grid{ columns:1; }
  .article{ padding:24px; }
  .article h2{ font-size:26px; }
  .container{ padding:24px 16px 52px; }
}