.image-choicegroup {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 1em;
  margin-bottom: 2em;
}

.image-choicegroup .image-choice {
  cursor: pointer;
  display: block;
  text-align: left;
}

.image-choicegroup .image-choice input[type="checkbox"],
.image-choicegroup .image-choice input[type="radio"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.image-choicegroup .image-choice img,
.image-choicegroup .image-choice .image-choice-placeholder {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  border: 2px solid transparent;
  border-radius: 4px;
  transition: border-color 0.2s;
  background: #f2f2f2;
  box-sizing: border-box;
}

.image-choicegroup .image-choice .image-choice-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  color: #b5b5b5;
}

.image-choicegroup .image-choice .image-choice-placeholder svg {
  width: 40%;
  max-width: 56px;
  height: auto;
}

.image-choicegroup .image-choice:hover img {
  border-color: rgba(0, 0, 0, 0.2);
}

.image-choicegroup .image-choice:has(input:checked) img,
.image-choicegroup .image-choice:has(input:checked) .image-choice-placeholder {
  border-color: currentColor;
}

.image-choicegroup .image-choice-label {
  display: block;
  padding-top: 0.4em;
  font-size: 0.9em;
}

@media screen and (max-width: 560px) {
  .image-choicegroup {
    grid-template-columns: repeat(2, 1fr);
  }
}

.form-options-stacked {
  display: block;
}

.form-options-stacked > label {
  display: flex;
  align-items: baseline;
  gap: 0.5em;
  margin-bottom: 0.35em;
}

.form-options-stacked.formgrid > label {
  grid-column: span 3;
}
