/* Star rating (radio group, cumulative fill) — GitHub issue #93. Partial: app/views/shared/components/_star_rating.html.erb */
@layer components {

.star-rating__fieldset {
  border: none;
  margin: 0;
  padding: 0;
}

.star-rating__legend {
  font-weight: 600;
  margin-bottom: var(--space-1);
}

.star-rating__options {
  display: flex;
  flex-direction: row-reverse;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-1);
  justify-content: flex-end;
}

.star-rating__label {
  display: inline-flex;
  align-items: center;
  cursor: pointer;
  margin: 0;
}

.star-rating__input {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
}

.star-rating__star {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  font-size: 1.5rem;
  color: var(--color-border);
  transition: color var(--duration-fast) var(--ease-default);
  border-radius: var(--radius-sm);
}

.star-rating__label:has(.star-rating__input:focus-visible) .star-rating__star {
  outline: 2px solid var(--color-border-focus);
  outline-offset: 2px;
}

/* Fill selected star and stars to its left (DOM order max..1; row-reverse shows 1..max). */
.star-rating__label:has(.star-rating__input:checked) .star-rating__star,
.star-rating__label:has(.star-rating__input:checked) ~ .star-rating__label .star-rating__star {
  color: var(--color-warning-border);
}

.star-rating__label:hover .star-rating__star {
  color: var(--color-warning-border);
}

}
