/* Programs Intro */
.programs-intro {
  padding: var(--spacing-2xl) 0;
  text-align: justify;
}

.lead-text {
  margin: 0 auto;
}

/* Program Cards */
.program-cards {
  padding: var(--spacing-xl) 0 var(--spacing-3xl);
}

.program-card {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing-xl);
  margin-bottom: var(--spacing-3xl);
  align-items: center;
}

.program-card.reverse {
  grid-template-areas: "image content";
}

.program-card.reverse .program-content {
  grid-area: content;
}

.program-card.reverse .program-image {
  grid-area: image;
}

.program-content {
  padding: var(--spacing-lg);
}

.program-content h2 {
  color: var(--color-primary);
  margin-bottom: var(--spacing-md);
  position: relative;
  padding-bottom: var(--spacing-sm);
}

.program-content h2::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 60px;
  height: 3px;
  background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-secondary) 100%);
}

.program-content p {
  color: var(--color-gray-700);
  margin-bottom: var(--spacing-lg);
  text-align: justify;
}

.program-content h3 {
  color: var(--color-secondary);
  margin-bottom: var(--spacing-sm);
  font-size: 1.25rem;
}

.program-content ul {
  list-style-type: none;
  padding-left: 0;
  margin-bottom: var(--spacing-lg);
}

.program-content ul li {
  padding-left: 1.5rem;
  position: relative;
  margin-bottom: var(--spacing-sm);
  color: var(--color-gray-700);
}

.program-content ul li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.5rem;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: var(--color-secondary);
}

.program-image {
  border-radius: var(--border-radius-lg);
  overflow: hidden;
  box-shadow: var(--box-shadow-large);
  height: 100%;
}

.program-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-long);
}

.program-image:hover img {
  transform: scale(1.05);
}

/* Media Queries */
@media (max-width: 992px) {
  .program-card,
  .program-card.reverse {
    grid-template-columns: 1fr;
    grid-template-areas: "image" "content";
  }
  
  .program-content {
    grid-area: content;
  }
  
  .program-image {
    grid-area: image;
    margin-bottom: var(--spacing-lg);
  }
}

@media (max-width: 768px) {
  .process-steps {
    grid-template-columns: 1fr;
    gap: var(--spacing-lg);
  }
  
  .application-cta {
    padding: var(--spacing-lg);
  }
}

@media (max-width: 576px) {
  .program-content {
    padding: var(--spacing-md);
  }
  
  .application-cta p {
    font-size: 1.1rem;
  }
}