/* Projects section
–––––––––––––––––––––––––––––––––––––––––––––––––– */

html {
  scroll-behavior: smooth;
}

/* Override absolute centering to allow scrolling */
.hero .landingpage {
  position: static;
  transform: none;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
}

/* Scroll indicator */
.scroll-hint {
  position: absolute;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  color: var(--text-color-softer);
  text-decoration: none;
  animation: bounce 2s ease infinite;
  opacity: 0.6;
  transition: opacity 0.2s;
}

.scroll-hint:hover {
  opacity: 1;
}

@keyframes bounce {
  0%, 20%, 50%, 80%, 100% { transform: translateX(-50%) translateY(0); }
  40% { transform: translateX(-50%) translateY(-8px); }
  60% { transform: translateX(-50%) translateY(-4px); }
}

/* Hero needs relative positioning for the scroll hint */
.hero {
  position: relative;
}

.projects-section {
  max-width: 960px;
  margin: 0 auto;
  padding: 2rem 2rem 4rem;
}

.projects-section h3 {
  text-align: center;
  margin-bottom: 3rem;
}

/* Project cards */
.project-card {
  border: 1px solid var(--border-color-softer);
  border-radius: 4px;
  overflow: hidden;
  text-align: left;
}

.project-image {
  width: 100%;
  height: auto;
  display: block;
}

.project-content {
  padding: 1.5rem;
}

.project-content h4 {
  margin-bottom: 1rem;
}

.project-content p {
  margin-bottom: 1.5rem;
  color: var(--text-color-softer);
}

/* Status badges */
.badge {
  display: inline-block;
  font-size: 1.1rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05rem;
  padding: 0.2rem 0.8rem;
  border-radius: 3px;
  vertical-align: middle;
  margin-left: 0.5rem;
}

.badge-current {
  background-color: hsl(150, 50%, 40%);
  color: white;
}

.badge-past {
  background-color: var(--text-color-softer);
  color: white;
}

/* Project links */
.project-links {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

.project-links a {
  font-size: 1.3rem;
  text-transform: uppercase;
  letter-spacing: 0.05rem;
  font-weight: 600;
}

/* Responsive */
@media (min-width: 600px) {
  .hero .landingpage {
    max-width: 75%;
  }
}

/* Dark mode */
@media screen and (prefers-color-scheme: dark) {
  .badge-current {
    background-color: hsl(150, 50%, 35%);
  }

  .badge-past {
    background-color: hsl(0, 0%, 30%);
  }
}
