input[type=radio] {
  box-sizing: border-box;
  padding: 0;
}

.radio {
  background-color: color-mix(in oklab, var(--color-white) 30%, transparent);
  cursor: pointer;
}

.radio input[type=radio] {
  position: absolute;
  opacity: 0;
}

.radio-label {
  display: flex;
  flex-direction: row;
  align-items: center;
  color: var(--color-white);
}

.radio input[type=radio] + .radio-label:before {
  content: '';
  background-color: color-mix(in oklab, var(--color-white) 30%, transparent);
  border-radius: 100%;
  border: 0.1rem solid var(--color-gray-200);
  display: inline-block;
  min-width: 1.0rem;
  min-height: 1.0rem;
  position: relative;
  margin-right: 1rem;
  vertical-align: top;
  cursor: pointer;
  text-align: center;
  transition: all 50ms ease;
}

.radio input[type=radio]:checked + .radio-label:before {
  background-color: var(--color-aqua-500);
  box-shadow: inset 0 0 0 0.15rem var(--color-white);
  border: 0.1rem solid var(--color-aqua-500);
}

.radio input[type=radio]:focus + .radio-label:before {
  outline: none;
  border-color: var(--color-aqua-500);
}

.radio input[type=radio]:disabled + .radio-label:before {
  box-shadow: inset 0 0 0 4px var(--color-gray-200);
  border-color: darken(var(--color-gray-200), 25%);
  background: darken(var(--color-gray-200), 25%);
}

.radio input[type=radio] + .radio-label:empty {
  margin-right: 0;
}

.radio:has(input[type="radio"]:checked) {
  background-color: var(--color-white);
}

.radio:has(input[type="radio"]:checked) .radio-label {
  color: var(--color-black);
}
