:root {
  --accent: #8bc34a;
  --text: #333;
  --muted: #6b7280;
  --light: #f7f7fb;
}

.container {
  padding: 0 10%;
  max-width: 1400px;                
  margin: 0 auto;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

.nav-links a.active { color: var(--accent); }
.nav-links a.active:hover { color: var(--accent); }

.services-hero {
  padding: 56px 0 12px;
  text-align: center;
  margin-bottom: 50px;
  background: var(--light);
}
.services-hero h1 {
  color: var(--accent);
  font-weight: 700;
  line-height: 1.15;
  font-size: clamp(2rem, 2.4vw + 1rem, 2.8rem);
  margin-bottom: 8px;
}
.services-hero p {
  color: var(--muted);
  font-size: clamp(1rem, .4vw + .95rem, 1.15rem);
  max-width: 85ch;
  margin: 0 auto;
}

.services-wrap {
  background: #fff;
  padding: 24px 0 72px;
}

.services-grid {
  display: grid;
  gap: 56px;
  align-items: start;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
}

.services-photo {
  justify-self: start;              
}
.services-photo img {
  width: 100%;
  max-width: 380px;                 
  height: auto;
  border-radius: 16px;
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
  object-fit: cover;
}

.services-columns {
  display: grid;
  grid-template-columns: 1fr;  
  gap: 28px 48px;
}

.service-group h3 {
  color: var(--accent);
  font-size: clamp(1.06rem, .45vw + 1rem, 1.28rem);
  line-height: 1.35;
  margin-bottom: 10px;
  font-weight: 700;
}

.chevron-list {
  list-style: none;
  padding: 0;
  margin: 0;
  color: #4b5563;
}
.chevron-list li {
  position: relative;
  margin: 10px 0;
  line-height: 1.7;
  padding-left: 22px;
}
.chevron-list li::before {
  content: "›";
  position: absolute;
  left: 0;
  top: 0;
  color: #9ca3af;
  font-size: 1.1rem;
  line-height: 1.7;
}

@media (min-width: 1024px) {
  .services-columns {
    grid-template-columns: 1fr 1fr;  
  }
}

.services-grid {
  display: grid;
  grid-template-columns: 1fr; 
  gap: 48px;
  align-items: start;
}

.services-photo {
  justify-self: center;      
  text-align: center;
}

.services-photo img {
  width: 100%;
  max-width: 420px;           
  height: auto;
  border-radius: 16px;
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
  object-fit: cover;
}

.services-columns {
  display: grid;
  grid-template-columns: 1fr; 
  gap: 28px 48px;
}

@media (min-width: 1024px) {
  .services-grid {
    grid-template-columns: 300px 1fr;  
    gap: 56px;
  }

  .services-photo {
    justify-self: start;               
    text-align: left;
  }

  .services-columns {
    grid-template-columns: 1fr 1fr;    
  }
}
