:host {
  display: inline-flex;
}

  :host * {
    box-sizing: border-box;
  }

.spinner {
  position: relative;
  display: inline-flex;
  overflow: hidden;
  width: 2.25rem;
  height: 2.25rem;
}

.spinner--size-xs,
.spinner--size-20 {
  width: 1.25rem;
  height: 1.25rem;
}

.spinner--size-xs .spinner__circle, .spinner--size-20 .spinner__circle {
    stroke-width: 0.1875rem;
  }

.spinner--size-s,
.spinner--size-24 {
  width: 1.5rem;
  height: 1.5rem;
}

.spinner--size-s .spinner__circle, .spinner--size-24 .spinner__circle {
    stroke-width: 0.1875rem;
  }

.spinner__indicator {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  transform-origin: center center;
  animation: spinner-rotate 2s linear infinite;
}

.spinner__background {
  stroke: var(--s-border-default);
  stroke-linecap: round;
}

.spinner__circle {
  animation: spinner-dash 1.5s ease-in-out infinite;
  stroke: var(--s-interactive-primary-default);
  stroke-dasharray: 1, 200;
  stroke-dashoffset: 0;
  stroke-linecap: round;
}

@keyframes spinner-rotate {
  100% {
    transform: rotate(360deg);
  }
}

@keyframes spinner-dash {
  0% {
    stroke-dasharray: 1, 200;
    stroke-dashoffset: 0;
  }
  50% {
    stroke-dasharray: 89, 200;
    stroke-dashoffset: -35;
  }
  100% {
    stroke-dasharray: 89, 200;
    stroke-dashoffset: -124;
  }
}
