/* Service Card CTA Button Alignment */

/* Ensure service cards use flexbox for proper alignment */
.service-card {
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
}

/* Service content should fill available space */
.service-content {
  display: flex !important;
  flex-direction: column !important;
  flex-grow: 1 !important;
  padding: var(--spacing-lg) !important;
}

/* Service title and description maintain their natural spacing */
.service-title {
  margin-bottom: var(--spacing-sm) !important;
}

.service-description {
  margin-bottom: var(--spacing-md) !important;
}

/* Service features list should grow to fill available space */
.service-features {
  flex-grow: 1 !important;
  margin-bottom: var(--spacing-md) !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-start !important;
}

/* Individual service features */
.service-feature {
  margin-bottom: var(--spacing-xs) !important;
  padding-left: var(--spacing-sm) !important;
  position: relative !important;
}

/* CTA button should be at the bottom of each card */
.service-content .btn {
  margin-top: auto !important;
  align-self: flex-start !important;
  width: auto !important;
  min-width: 140px !important;
  text-align: center !important;
}

/* Ensure consistent grid layout */
.services-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)) !important;
  gap: var(--spacing-lg) !important;
  align-items: stretch !important;
}

/* Responsive adjustments */
@media (min-width: 768px) and (max-width: 1023px) {
  .services-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (min-width: 1024px) {
  .services-grid {
    grid-template-columns: repeat(4, 1fr) !important;
  }
}

@media (max-width: 767px) {
  .services-grid {
    grid-template-columns: 1fr !important;
  }
  
  .service-content .btn {
    width: 100% !important;
  }
}

/* Additional styling for better visual alignment */
.service-features {
  list-style: none !important;
  padding: 0 !important;
  margin-bottom: var(--spacing-lg) !important;
}

.service-features li {
  padding: var(--spacing-xs) 0 !important;
  border-left: 2px solid transparent !important;
  padding-left: var(--spacing-sm) !important;
  transition: border-color 0.3s ease !important;
}

.service-features li:hover {
  border-left-color: var(--color-accent) !important;
}

/* Ensure all cards have the same height in the grid */
.services-grid .service-card {
  min-height: 100% !important;
}

/* Make service images consistent height */
.service-image {
  height: 200px !important;
  flex-shrink: 0 !important;
}

/* Fix button styling for consistency */
.service-content .btn-primary {
  padding: var(--spacing-sm) var(--spacing-lg) !important;
  font-size: 0.9rem !important;
  font-weight: 600 !important;
  border-radius: var(--border-radius-md) !important;
  transition: all 0.3s ease !important;
}

.service-items-container {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: center;
    gap: 40px;
    max-width: 1200px;
    margin: 0 auto;
    position: relative;
    z-index: 2;
}