body.landing {
  margin: 0;
  font-family: 'MainSerif', Serif;
  color: #222;
  background: #fff;
  line-height: 1.5;
}

.landing-wrap {
  max-width: 760px;
  margin: 0 auto;
  padding: 60px 24px;
}

.landing a:link,
.landing a:visited { color: #3B93FC; }
.landing a:hover { color: #D54D00; }

.landing .hero {
  text-align: center;
  padding: 20px 0 50px;
  border-bottom: 1px solid #eee;
  margin-bottom: 50px;
}
.landing .hero h1 {
  font-size: 2.6rem;
  margin: 0 0 14px;
}
.landing .hero .tagline {
  font-size: 1.3rem;
  line-height: 1.45;
  color: #333;
  margin: 0 0 12px;
  max-width: 620px;
  margin-left: auto;
  margin-right: auto;
}
.landing .hero-meta {
  color: #888;
  font-size: 0.95rem;
  margin: 0;
}

.landing section {
  margin-bottom: 60px;
}
.landing h2 {
  font-size: 1.7rem;
  margin: 0 0 24px;
}

.landing .service-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}
@media (min-width: 720px) {
  .landing .service-grid {
    grid-template-columns: 1fr 1fr 1fr;
  }
}
.landing .service {
  padding: 22px;
  box-shadow: 0 0 3px rgba(20,0,0,1.0);
  border-radius: 25px;
  background: #fff;
  display: flex;
  flex-direction: column;
}
.landing .service h3 {
  margin: 0 0 12px;
  font-size: 1.1rem;
  line-height: 1.3;
}
.landing .service h3 a {
  color: inherit;
  text-decoration: none;
}
.landing .service h3 a:hover {
  color: #D54D00;
}
.landing .service p {
  font-size: 1rem;
  line-height: 1.5;
  color: #444;
  margin: 0 0 12px;
}
.landing .service-list {
  list-style: disc;
  padding-left: 20px;
  margin: 0 0 18px;
  font-size: 0.95rem;
  color: #444;
  line-height: 1.5;
  flex-grow: 1;
}
.landing .service-list li {
  margin: 2px 0;
}
.landing .service-cta {
  font-weight: 700;
  text-decoration: none;
}

.landing .post-list {
  list-style: none;
  padding: 0;
  margin: 0 0 18px;
}
.landing .post-list li {
  padding: 12px 0;
  border-bottom: 1px solid #f0f0f0;
}
.landing .post-list a {
  font-size: 1.1rem;
  text-decoration: none;
  font-weight: 600;
}
.landing .post-tags {
  display: block;
  font-size: 0.85rem;
  color: #999;
  margin-top: 4px;
}
.landing .all-posts-link {
  font-weight: 600;
  text-decoration: none;
}

.landing .about-short p {
  font-size: 1.05rem;
  line-height: 1.6;
  color: #333;
  margin: 0 0 16px;
}

.landing .contact-list {
  list-style: none;
  padding: 0;
  margin: 0 0 18px;
  font-size: 1.15rem;
}
.landing .contact-list li {
  margin: 8px 0;
}
.landing .contact-list a {
  font-weight: 700;
  text-decoration: none;
}
.landing .contact-note {
  font-size: 0.95rem;
  color: #666;
}
.landing .contact-note a {
  text-decoration: none;
}

.landing footer.footer {
  text-align: center;
  margin-top: 40px;
  color: #999;
  font-size: 0.9rem;
}
