@import url('../vars.css');

/* Base section styles */
#services {
  background-color: var(--color-white);
  padding: var(--padding-large) var(--padding-small);
  font-family: var(--font-body);
  color: var(--color-text-dark);
}

/* Main section heading */
#services h2 {
  font-family: var(--font-heading);
  font-size: var(--font-size-xlarge);
  font-weight: 800;
  color: var(--color-white);
  background-color: var(--color-primary);
  text-align: center;
  margin: 0 auto var(--spacing-xlarge);
  max-width: 600px;
  padding: var(--padding-medium);
  border-radius: var(--border-radius-medium);
  line-height: 1.2;
}

/* Service category */
#services .service-category {
  margin-bottom: var(--spacing-xlarge);
}

/* Category heading */
#services .service-category h3 {
  font-family: var(--font-heading);
  font-size: calc(var(--font-size-large) * 1.1);
  font-weight: 700;
  color: var(--color-primary);
  text-align: center;
  margin: 0 0 var(--spacing-large);
  padding: var(--padding-small);
  background-color: var(--color-light-gray);
  border-radius: var(--border-radius-small);
}

/* Services container - Grid layout */
#services .services-container {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: var(--spacing-large);
  justify-content: center; /* Center the entire grid content */
}

/* Service item */
#services .service-item {
  padding: var(--padding-medium);
  border-radius: var(--border-radius-medium);
  border-left: 4px solid var(--color-accent);
  transition: transform var(--animation-duration) ease, background-color var(--animation-duration) ease;
  width: 100%;
  max-width: 350px; /* Fixed width for consistent centering */
}

/* Odd-numbered cards */
#services .service-item:nth-child(odd) {
  background-color: var(--color-light-gray); /* #F0F4F8 */
}

/* Even-numbered cards */
#services .service-item:nth-child(even) {
  background-color: var(--color-primary); /* Lightened navy */
  color: var(--color-white);
}

/* Adjust text colors for even cards */
#services .service-item:nth-child(even) h4,
#services .service-item:nth-child(even) p,
#services .service-item:nth-child(even) ul li {
  color: var(--color-white);
}

#services .service-item:nth-child(even) ul li strong {
  color: var(--color-accent);
}

/* Hover effects */
#services .service-item:hover {
  transform: translateY(-4px);
}

#services .service-item:nth-child(odd):hover {
  background-color: #E0E8F0;
}

#services .service-item:nth-child(even):hover {
  background-color: #4A6B92;
}

/* Service item heading */
#services .service-item h4 {
  font-family: var(--font-heading);
  font-size: calc(var(--font-size-large) * 0.9);
  font-weight: 700;
  color: var(--color-primary);
  margin: 0 0 var(--margin-small);
}

/* Service item paragraph */
#services .service-item p {
  font-size: calc(var(--font-size-medium) * 0.85);
  line-height: 1.6;
  margin: 0 0 var(--spacing-medium);
}

/* Service list */
#services .service-item ul {
  list-style-type: disc;
  padding-left: var(--spacing-medium);
  margin: 0;
}

#services .service-item ul li {
  font-size: calc(var(--font-size-medium) * 0.85);
  line-height: 1.6;
  margin-bottom: var(--margin-small);
  color: var(--color-text-dark);
}

#services .service-item ul li strong {
  font-weight: 600;
  color: var(--color-primary);
}

/* Accessibility */
#services .service-item:focus-within {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
}

/* Responsive design */
@media (max-width: 1024px) {
  #services .services-container {
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: var(--spacing-medium);
  }

  #services .service-item {
    padding: var(--padding-small);
    max-width: 300px;
  }
}

@media (max-width: 768px) {
  #services {
    padding: var(--padding-medium) var(--padding-small);
  }

  #services h2 {
    font-size: calc(var(--font-size-xlarge) * 0.8);
    padding: var(--padding-small);
    max-width: 90%;
  }

  #services .service-category h3 {
    font-size: calc(var(--font-size-large) * 1);
  }

  #services .services-container {
    grid-template-columns: 1fr;
    gap: var(--spacing-large);
  }

  #services .service-item {
    max-width: 100%;
  }
}

@media (max-width: 480px) {
  #services h2 {
    font-size: calc(var(--font-size-xlarge) * 0.7);
  }

  #services .service-category h3 {
    font-size: calc(var(--font-size-large) * 0.9);
  }

  #services .service-item h4 {
    font-size: calc(var(--font-size-large) * 0.8);
  }
}