.gallery {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(8.125rem, 1fr)); 
  gap: .5rem; 
}
.gallery label {
  cursor: pointer;
}
.gallery img {
  width: 100%;
  height: auto;
  display: block;
}
.gallery div {
  font-size: .875rem; 
  line-height: 1rem; 
  color: #5e5e5f; 
}
.gallery > div {
  display: grid;
  grid-template-rows: auto auto 1fr auto;
  height: 100%;
  font-size: .875rem;
  line-height: 1rem;
  color: #5e5e5f;
  padding-top: .25rem; 
  padding: .5rem;
  border: 1px solid #c2c2c2;
}
.gallery > div:nth-child(odd) {
  background-color: #ffffff;
}
.gallery > div:nth-child(even) {
  background-color: #ddebf3;
}
.gallery > div:hover {
  background-color: #e6f3fa;
}
.gallery .author {
  font-weight: 600; 
  padding: .5rem .25rem;
  margin: 0;
}
.gallery .title {
  padding: 0 .5rem; 
}
.gallery .vote {
  padding: .5rem; 
  background: var(--primary-color);
  color: #fff;
  margin-top: .25rem; 
}
