.projects {
  --gap: clamp(var(--inline-space), 2cqi, calc(var(--inline-space) * 3));
  --hover-size: 0;

  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(max(250px, 30cqi), 0.5fr));
  gap: var(--block-space) var(--gap);
  justify-content: center;
  padding: var(--gap);
}

.projects__project {
  --row-gap: calc(var(--block-space) * 0.2);

  container-type: inline-size;
  display: flex;
  flex-direction: column;
  aspect-ratio: 16/9;
  margin: 0;
  padding-inline: 1ch;
  text-align: left;
  text-decoration: none;
  color: var(--color-ink);
  background-color: var(--color-bg);
  border-radius: 0.3em;
  box-shadow: 0 0 0 1px var(--color-subtle-dark);
  background-clip: border-box;
  transition: background-color 300ms ease;

  &:hover {
    background-color: var(--color-subtle);
  }
}

.projects__project--empty {
  display: inline-grid;
  place-items: center;
  aspect-ratio: 16/9;
  background-color: var(--color-bg);
  border-radius: 0.3em;
  box-shadow: 0 0 0 1px var(--color-subtle-dark);
  transition: background 300ms ease;

  * {
    grid-area: 1 / 1;
  }

  &:hover {
    background-color: var(--color-subtle);
  }
}
