/* ==========================================================================
   Projects Index Page
   ========================================================================== */

.projects-index {
  padding: var(--space-8) var(--gutter) var(--space-16);
  padding-top: calc(134px + var(--space-8));
}

@media (min-width: 768px) {
  .projects-index {
    padding: var(--space-16) var(--gutter) var(--space-24) var(--content-indent);
  }
}

/* Header */
.projects-header {
  margin-bottom: var(--space-16);
  max-width: 50ch;
}

.projects-title {
  font-family: var(--font-display);
  font-size: var(--text-4xl);
  font-weight: var(--font-bold);
  line-height: var(--leading-tight);
  margin: 0 0 var(--space-4);
  color: var(--color-heading);
}

.projects-intro {
  font-family: var(--font-body);
  font-size: var(--text-lg);
  font-weight: var(--font-light);
  line-height: var(--leading-normal);
  color: var(--color-muted);
  margin: 0;
}

/* Projects Grid */
.projects-grid {
  display: grid;
  gap: var(--space-16);
}

/* Project Card */
.project-card {
  position: relative;
}

.project-link {
  display: block;
  text-decoration: none;
  color: inherit;
}

.project-link:hover {
  opacity: 1;
}

/* Image Container */
.project-image-wrap {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16 / 9;
  background: var(--color-border);
}

.project-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Project Info */
.project-info {
  padding: var(--space-6) 0;
}

.project-name {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
  line-height: var(--leading-tight);
  margin: 0 0 var(--space-2);
  color: var(--color-heading);
  transition: color 0.2s ease;
}

.project-link:hover .project-name {
  color: var(--color-muted);
}

.project-description {
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: var(--font-light);
  line-height: var(--leading-normal);
  color: var(--color-muted);
  margin: 0;
  max-width: 55ch;
}

/* ==========================================================================
   Larger Screens - Staggered Layout
   ========================================================================== */

@media (min-width: 768px) {
  .projects-header {
    margin-bottom: var(--space-24);
  }

  .projects-title {
    font-size: var(--text-5xl);
  }

  .projects-grid {
    gap: var(--space-24);
  }

  .project-link {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: var(--space-8);
    align-items: end;
  }

  .project-card:nth-child(even) .project-link {
    grid-template-columns: 1fr 2fr;
  }

  .project-card:nth-child(even) .project-image-wrap {
    order: 2;
  }

  .project-card:nth-child(even) .project-info {
    order: 1;
    text-align: right;
  }

  .project-image-wrap {
    aspect-ratio: 4 / 3;
  }

  .project-info {
    padding: var(--space-4) 0;
  }

  .project-name {
    font-size: var(--text-3xl);
  }
}

/* ==========================================================================
   Extra Large Screens - Asymmetric
   ========================================================================== */

@media (min-width: 1200px) {
  .projects-index {
    padding: var(--space-24) var(--gutter) var(--space-32) var(--content-indent);
  }

  .projects-header {
    max-width: 60ch;
  }

  .project-image-wrap {
    aspect-ratio: 3 / 2;
  }

  .project-name {
    font-size: var(--text-4xl);
  }

  .project-description {
    font-size: var(--text-lg);
  }
}
