.radio {
  appearance: none;
  position: relative;
  margin: 0;
  width: 20px;
  height: 20px;
  cursor: pointer;
  border-radius: 50%;
}
.radio::before {
  content: '';
  display: inline-block;
  width: 20px;
  height: 20px;
  border: 2px solid #2B403B;
  border-radius: 50%;
  background: #F2ECE6;
  position: absolute;
  top: 0;
  left: 0;
  animation-duration: 0.4s;
  animation-delay: 0.05s;
  animation-timing-function: ease-in-out;
  animation-fill-mode: backwards;
  box-sizing: border-box;
}
@media (hover: hover) {
  .radio:hover::before {
    border-color: #F18F01;
    background: #F2ECE6;
  }
}
@media (hover: none) {
  .radio:active::before {
    border-color: #F18F01;
    background: #F2ECE6;
  }
}

.radio:checked::before {
  border-color: #F18F01;
  background-color: #F18F01;
}

.radio::after {
  position: absolute;
  content: '';
  top: 7px;
  left: 7px;
  width: 6px;
  height: 6px;
  border: none;
  background: #F2ECE6;
  border-radius: 50%;
  transition: transform 0.1s ease-in-out, background-color 0.1s ease-in-out;
  transform: scale(0);
  box-sizing: border-box;
}

.radio:checked::after {
  border: none;
  background: #F2ECE6;
  transform: scale(1);
}
@media (hover: hover) {
  .radio:hover:checked::after {
    background: #F2ECE6;
  }
}
@media (hover: none) {
  .radio:active:checked::after {
    background: #F2ECE6;
  }
}
