:host {
  position: relative;
  box-sizing: border-box;
  font-feature-settings: "cv03", "cv04", "cv11";
}
:host *, :host *:before, :host *:after {
  box-sizing: inherit;
}

:host {
  display: inline-block;
  --background-color: var(--sl-input-background-color);
  --background-color--hover: var(--sl-input-background-color-hover);
  --background-color--focus: var(--sl-input-background-color-focus);
  --background-color--selected: var(--sl-color-blue-500);
  --background-color--selected-hover: var(--sl-color-blue-400);
  --background-color--selected-focus: var(--sl-color-blue-400);
  --border-color: var(--sl-input-border-color);
  --border-color--hover: var(--sl-input-border-color-hover);
  --border-color--focus: var(--sl-input-border-color-focus);
  --border-color--selected: var(--sl-color-blue-500);
  --border-color--selected-hover: var(--sl-color-blue-400);
  --border-color--selected-focus: var(--sl-color-blue-400);
  --dot: var(--sl-color-white);
}

.radio {
  display: inline-flex;
  font-family: var(--sl-input-font-family);
  font-size: var(--sl-input-font-size-medium);
  font-weight: var(--sl-input-font-weight);
  color: var(--sl-input-color);
  vertical-align: middle;
  cursor: pointer;
}

.radio__icon {
  display: inline-flex;
  width: var(--sl-toggle-size);
  height: var(--sl-toggle-size);
  opacity: 0;
}
.radio__icon svg {
  width: 100%;
  height: 100%;
}

.radio--checked .radio__icon {
  opacity: 1;
}

.radio__control {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--sl-toggle-size);
  height: var(--sl-toggle-size);
  border: solid var(--sl-input-border-width) var(--border-color);
  outline: solid 0 var(--sl-focus-ring-color-blue);
  border-radius: 50%;
  background-color: var(--background-color);
  color: transparent;
  transition: var(--sl-transition-fast) border-color, var(--sl-transition-fast) background-color, var(--sl-transition-fast) color, outline var(--sl-transition-x-fast) ease-in-out;
}
.radio__control input[type=radio] {
  position: absolute;
  opacity: 0;
  padding: 0;
  margin: 0;
  pointer-events: none;
}

.radio:not(.radio--checked):not(.radio--disabled) .radio__control:hover {
  border-color: var(--border-color--hover);
  background-color: var(--background-color--hover);
}

.radio.radio--focused:not(.radio--checked):not(.radio--disabled) .radio__control {
  border-color: var(--border-color--focus);
  background-color: var(--background-color--focus);
  outline-width: var(--sl-focus-ring-width);
}

.radio--checked .radio__control {
  color: var(--dot);
  border-color: var(--border-color--selected);
  background-color: var(--background-color--selected);
}

.radio.radio--checked:not(.radio--disabled) .radio__control:hover {
  border-color: var(--border-color--selected-hover);
  background-color: var(--background-color--selected-hover);
}

.radio.radio--checked:not(.radio--disabled).radio--focused .radio__control {
  border-color: var(--border-color--selected-focus);
  background-color: var(--background-color--selected-focus);
  outline-width: var(--sl-focus-ring-width);
}

.radio--disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.radio--readonly {
  cursor: default;
}

.radio__label {
  line-height: var(--sl-toggle-size);
  margin-left: 0.5em;
  user-select: none;
}

.radio--small {
  font-size: var(--sl-input-font-size-small);
}

.radio--medium {
  font-size: var(--sl-input-font-size-medium);
}

.radio--large {
  font-size: var(--sl-input-font-size-large);
}