
:root{
  --bg:#ffffff;
  --ink:#202020;
  --muted:#666;
  --line:#e6e6e6;
  --soft:#f5f5f3;
  --dark:#06352f;
  --dark-2:#0a4a42;
  --accent:#1c6b5f;
  --max:1120px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Arial, Helvetica, sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
}
a{color:inherit}
.container{width:min(var(--max), calc(100% - 40px)); margin:0 auto}
.narrow{max-width:760px}
.site-header{
  position:sticky;
  top:0;
  z-index:10;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:16px 28px;
  background:rgba(6,53,47,.98);
  color:#fff;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.brand{display:flex; align-items:center; text-decoration:none; min-width:250px; padding:0}
.brand img{display:block; width:250px; max-width:100%; height:auto; background:transparent}
.brand-mark{font-size:34px; font-weight:700; letter-spacing:-2px}
.brand-text{font-size:12px; text-transform:uppercase; letter-spacing:2.4px; line-height:1.15; max-width:180px}
.site-nav{display:flex; align-items:center; gap:22px; flex-wrap:wrap; justify-content:flex-end}
.site-nav a{
  text-decoration:none;
  text-transform:uppercase;
  letter-spacing:1.8px;
  font-size:12px;
  color:#f2f2f2;
  opacity:.9;
}
.site-nav a:hover{opacity:1; text-decoration:underline; text-underline-offset:6px}
.nav-toggle{display:none}
.hero{
  position:relative;
  overflow:hidden;
  min-height:470px;
  display:grid;
  place-items:center;
  text-align:center;
  background:linear-gradient(135deg,#f5f5f3,#ffffff);
}
.hero-bg{
  position:absolute; inset:0;
  background:
    linear-gradient(to bottom, rgba(255,255,255,.22), rgba(255,255,255,.92)),
    linear-gradient(90deg, rgba(6,53,47,.14), rgba(6,53,47,.04)),
    url("community-infrastructure.jpg") center/cover no-repeat;
  filter:saturate(.75);
}
.hero-content{position:relative; padding:80px 0}
.eyebrow{
  margin:0 0 16px;
  text-transform:uppercase;
  letter-spacing:3.4px;
  font-size:12px;
  font-weight:700;
  color:#5c5c5c;
}
.hero .eyebrow{color:#333}
h1,h2,h3{line-height:1.15; margin:0 0 18px}
h1{
  font-size:clamp(32px, 4.7vw, 58px);
  letter-spacing:.04em;
  text-transform:uppercase;
  font-weight:500;
}
h2{font-size:clamp(28px, 3.2vw, 42px); font-weight:500}
h3{font-size:20px}
.hero p{max-width:790px; margin:0 auto 28px; font-size:20px; color:#404040}
.hero-actions{display:flex; gap:14px; justify-content:center; flex-wrap:wrap}
.button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:13px 20px;
  border:1px solid var(--dark);
  background:var(--dark);
  color:#fff;
  text-decoration:none;
  text-transform:uppercase;
  letter-spacing:1.2px;
  font-size:12px;
  font-weight:700;
  cursor:pointer;
}
.button.secondary{background:transparent; color:var(--dark)}
.button:hover{filter:brightness(.92)}
.section{padding:84px 0}
.section.alt{background:var(--soft)}
.section-heading{max-width:760px; margin-bottom:36px}
.lead{font-size:24px; line-height:1.45; color:#333}
.split{
  display:grid;
  grid-template-columns:minmax(0, .85fr) minmax(0, 1.15fr);
  gap:64px;
  align-items:start;
}
.cards{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:22px;
}
.card{
  display:block;
  min-height:205px;
  padding:28px;
  background:#fff;
  border:1px solid var(--line);
  text-decoration:none;
  transition:transform .18s ease, box-shadow .18s ease;
}
.card:hover{transform:translateY(-3px); box-shadow:0 12px 30px rgba(0,0,0,.08)}
.card p{color:var(--muted); margin-bottom:0}
.check-list{padding:0; margin:22px 0 0; list-style:none}
.check-list li{position:relative; padding-left:28px; margin:10px 0}
.check-list li:before{
  content:"";
  position:absolute;
  left:0;
  top:.63em;
  width:12px;
  height:2px;
  background:var(--dark);
}
.cta{background:var(--dark); color:#fff; text-align:center}
.cta p{color:#f0f0f0; max-width:700px; margin:0 auto 24px}
.cta .button{background:#fff; color:var(--dark); border-color:#fff}
.contact-grid{
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);
  gap:70px;
}
.contact-form{
  display:grid;
  gap:16px;
  padding:30px;
  background:var(--soft);
  border:1px solid var(--line);
}
label{display:grid; gap:8px; font-weight:700; font-size:14px}
input,textarea{
  width:100%;
  border:1px solid #cfcfcf;
  background:#fff;
  padding:12px 14px;
  font:inherit;
}
.site-footer{
  background:#222;
  color:#fff;
  padding:42px 0 24px;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.3fr 1fr 1fr;
  gap:28px;
}
.footer-grid p{color:#d6d6d6}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12); margin-top:24px; padding-top:20px; color:#bdbdbd}
@media (max-width:900px){
  .site-header{align-items:flex-start; flex-wrap:wrap}
  .nav-toggle{
    display:inline-flex;
    background:transparent;
    color:#fff;
    border:1px solid rgba(255,255,255,.4);
    padding:8px 12px;
    text-transform:uppercase;
    letter-spacing:1px;
  }
  .site-nav{
    display:none;
    width:100%;
    justify-content:flex-start;
    gap:14px 18px;
    padding-top:12px;
  }
  .site-nav.open{display:flex}
  .split,.contact-grid,.footer-grid{grid-template-columns:1fr; gap:32px}
  .cards{grid-template-columns:1fr 1fr}
}
@media (max-width:620px){
  .container{width:min(var(--max), calc(100% - 28px))}
  .site-header{padding:16px}
  .brand{min-width:0}
  .brand-mark{font-size:28px}
  .brand-text{font-size:10px; letter-spacing:1.8px}
  .hero{min-height:430px}
  .hero p{font-size:17px}
  .section{padding:58px 0}
  .cards{grid-template-columns:1fr}
  .card{min-height:unset}
}

.image-band{
  width:min(var(--max), calc(100% - 40px));
  margin:0 auto 30px;
  display:grid;
  grid-template-columns:1.25fr 1fr 1fr;
  gap:18px;
}
.image-band img{
  width:100%;
  height:230px;
  object-fit:cover;
  border:1px solid var(--line);
  background:#fff;
}
.image-band img:nth-child(2),
.image-band img:nth-child(3){
  filter:saturate(.8);
}
@media (max-width:900px){
  .brand{min-width:0}
  .brand img{width:230px}
  .image-band{grid-template-columns:1fr; margin-bottom:10px}
  .image-band img{height:220px}
}
@media (max-width:620px){
  .brand img{width:205px}
}

.capability-strip{
  background:#06352f;
  color:#fff;
  border-top:1px solid rgba(255,255,255,.12);
  border-bottom:1px solid rgba(255,255,255,.12);
}
.capability-strip .container{
  display:grid;
  grid-template-columns:repeat(5, minmax(0, 1fr));
  gap:1px;
}
.capability-item{
  padding:24px 16px;
  text-align:center;
  border-left:1px solid rgba(255,255,255,.12);
}
.capability-item:last-child{border-right:1px solid rgba(255,255,255,.12)}
.capability-icon{
  display:block;
  font-size:24px;
  line-height:1;
  margin-bottom:10px;
  opacity:.95;
}
.capability-item strong{
  display:block;
  text-transform:uppercase;
  letter-spacing:1.5px;
  font-size:12px;
}
.trusted-band{
  background:#f5f5f3;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:44px 0;
  text-align:center;
}
.trusted-band h2{
  font-size:clamp(24px, 2.8vw, 34px);
  margin-bottom:18px;
}
.trusted-list{
  display:flex;
  justify-content:center;
  gap:16px;
  flex-wrap:wrap;
  margin-top:24px;
}
.trusted-list span{
  border:1px solid #d7d7d7;
  background:#fff;
  padding:10px 14px;
  text-transform:uppercase;
  letter-spacing:1.2px;
  font-size:12px;
  font-weight:700;
}
.site-footer a{text-decoration:none}
.footer-bottom{
  display:flex;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}
@media (max-width:900px){
  .capability-strip .container{grid-template-columns:1fr 1fr}
}
@media (max-width:620px){
  .capability-strip .container{grid-template-columns:1fr}
  .capability-item{border-right:1px solid rgba(255,255,255,.12)}
}
