.vui-radio > input[type='radio'],
.vui-radio-button > input[type='radio'] {
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 0;
  opacity: 0;
}
.vui-radio > input[type='radio']:focus + .vui-radio-icon-hover::before,
.vui-radio-button > input[type='radio']:focus + .vui-radio-icon-hover::before {
  background-color: var(--color-fill-2);
}
.vui-icon-hover.vui-radio-icon-hover::before {
  width: 24px;
  height: 24px;
}
.vui-radio {
  position: relative;
  display: inline-flex;
  align-items: center;
  padding-left: 5px;
  font-size: 14px;
  line-height: unset;
  cursor: pointer;
}
.vui-radio-label {
  margin-left: 8px;
  color: var(--color-text-1);
}
.vui-radio-icon {
  position: relative;
  display: block;
  box-sizing: border-box;
  width: 14px;
  height: 14px;
  line-height: 14px;
  border: 2px solid var(--color-neutral-3);
  border-radius: var(--border-radius-circle);
}
.vui-radio-icon::after {
  position: absolute;
  top: 0;
  left: 0;
  display: inline-block;
  box-sizing: border-box;
  width: 10px;
  height: 10px;
  background-color: var(--color-bg-2);
  border-radius: var(--border-radius-circle);
  transform: scale(1);
  transition: transform 0.3s cubic-bezier(0.3, 1.3, 0.3, 1);
  content: '';
}
.vui-radio:hover .vui-radio-icon {
  border-color: var(--color-neutral-3);
}
.vui-radio-checked .vui-radio-icon {
  background-color: rgb(var(--primary-6));
  border-color: rgb(var(--primary-6));
}
.vui-radio-checked .vui-radio-icon::after {
  background-color: var(--color-white);
  transform: scale(0.4);
}
.vui-radio-checked:hover .vui-radio-icon {
  border-color: rgb(var(--primary-6));
}
.vui-radio-disabled {
  cursor: not-allowed;
}
.vui-radio-disabled .vui-radio-icon-hover {
  cursor: not-allowed;
}
.vui-radio-disabled .vui-radio-label {
  color: var(--color-text-4);
}
.vui-radio-disabled .vui-radio-icon {
  border-color: var(--color-neutral-3);
}
.vui-radio-disabled .vui-radio-icon::after {
  background-color: var(--color-fill-2);
}
.vui-radio-disabled:hover .vui-radio-icon {
  border-color: var(--color-neutral-3);
}
.vui-radio-checked.vui-radio-disabled .vui-radio-icon,
.vui-radio-checked.vui-radio-disabled:hover .vui-radio-icon {
  background-color: var(--color-primary-light-3);
  border-color: transparent;
}
.vui-radio-checked.vui-radio-disabled .vui-radio-icon::after {
  background-color: var(--color-fill-2);
}
.vui-radio-checked.vui-radio-disabled .vui-radio-label {
  color: var(--color-text-4);
}
.vui-radio:hover .vui-radio-icon-hover::before {
  background-color: var(--color-fill-2);
}

.vui-radio-button {
  position: relative;
  display: inline-block;
  margin: 1.5px;
  color: var(--color-text-2);
  font-size: 14px;
  line-height: 26px;
  background-color: transparent;
  border-radius: var(--border-radius-small);
  cursor: pointer;
  transition: all 0.1s cubic-bezier(0, 0, 1, 1);
}
.vui-radio-button-content {
  position: relative;
  display: block;
  padding: 0 12px;
}
.vui-radio-button:not(:first-of-type)::before {
  position: absolute;
  top: 50%;
  left: -2px;
  display: block;
  width: 1px;
  height: 14px;
  background-color: var(--color-neutral-3);
  transform: translateY(-50%);
  transition: all 0.1s cubic-bezier(0, 0, 1, 1);
  content: '';
}
.vui-radio-button:hover::before,
.vui-radio-button:hover + .vui-radio-button::before,
.vui-radio-button.vui-radio-checked::before,
.vui-radio-button.vui-radio-checked + .vui-radio-button::before {
  opacity: 0;
}
.vui-radio-button:hover {
  color: var(--color-text-1);
  background-color: var(--color-bg-5);
}
.vui-radio-button.vui-radio-checked {
  color: rgb(var(--primary-6));
  background-color: var(--color-bg-5);
}
.vui-radio-button.vui-radio-disabled {
  color: var(--color-text-4);
  background-color: transparent;
  cursor: not-allowed;
}
.vui-radio-button.vui-radio-disabled.vui-radio-checked {
  color: var(--color-primary-light-3);
  background-color: var(--color-bg-5);
}

body[vui-theme='dark'] .vui-radio-button.vui-radio-checked,
body[vui-theme='dark'] .vui-radio-button:not(.vui-radio-disabled):hover {
  background-color: var(--color-fill-3);
}
body[vui-theme='dark'] .vui-radio-button::after {
  background-color: var(--color-bg-3);
}
