/* PROJECTS TEASER */
.projects-teaser {
  background: var(--color-bg);
  padding-block: clamp(var(--space-20), 12vw, var(--space-40));
}

/* ── HEADER ── */
.projects-teaser__header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: clamp(var(--space-12), 6vw, var(--space-20));
  flex-wrap: wrap;
  gap: var(--space-8);
}

.projects-teaser__header .label {
  display: block;
  margin-bottom: var(--space-4);
}

.projects-teaser__header .display {
  margin: 0;
}

.projects-teaser__header .display em {
  color: var(--color-brand);
  font-style: italic;
}

/* ── ASYMMETRIC GRID ─────────────────────────────────────────────
   Left column is wider — holds the large card.
   Right column holds two stacked cards.
── */
.projects-teaser__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: clamp(var(--space-4), 1.5vw, var(--space-6));
}

/* ── PROJECT CARD ── */
.project-card {
  display: block;
  text-decoration: none;
  color: inherit;
  border-radius: var(--radius-lg);
  overflow: hidden;
  position: relative;
}

/* Large card spans both rows */
.project-card--large {
  grid-row: 1 / 3;
}

.project-card__figure {
  margin: 0;
  width: 100%;
  height: 100%;
  min-height: 280px;
  position: relative;
  overflow: hidden;
  background: var(--color-bg-subtle);
}

.project-card--large .project-card__figure {
  min-height: 520px;
}

.project-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform var(--duration-slower) var(--ease-expo);
}

.project-card:hover .project-card__img {
  transform: scale(1.05);
}

/* ── OVERLAY ── */
.project-card__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(14, 18, 54, 0.92) 0%,
    rgba(14, 18, 54, 0.3) 50%,
    transparent 100%
  );
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: clamp(var(--space-6), 3vw, var(--space-10));
  gap: var(--space-3);
}

/* Tags row */
.project-card__meta {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.project-card__tag {
  font-family: var(--font-label);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--color-gold);
  background: rgba(184, 154, 106, 0.15);
  border: 0.5px solid rgba(184, 154, 106, 0.3);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-pill);
  line-height: 1.6;
}

.project-card__name {
  font-family: var(--font-display);
  font-size: clamp(var(--text-lg), 2vw, var(--text-2xl));
  font-weight: 400;
  color: #fff;
  margin: 0;
  line-height: var(--leading-snug);
}

.project-card__desc {
  font-size: var(--text-sm);
  line-height: var(--leading-normal);
  color: rgba(255, 255, 255, 0.65);
  margin: 0;
  max-width: 380px;
}

/* ── RESPONSIVE ── */
@media (max-width: 768px) {
  .projects-teaser__grid {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
  }

  .project-card--large {
    grid-row: auto;
  }

  .project-card--large .project-card__figure {
    min-height: 360px;
  }

  .project-card__figure {
    min-height: 240px;
  }

  .projects-teaser__header {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-6);
  }
}

@media (max-width: 480px) {
  .project-card--large .project-card__figure {
    min-height: 280px;
  }

  .project-card__figure {
    min-height: 200px;
  }
}
