.loading-overlay {
  position: absolute;
  z-index: 10;
  width: 3rem;
}

.loading-overlay {
  top: 0;
  right: 0;
}

@media screen and (min-width: 750px) {
  .loading-overlay {
    left: 0;
    right: auto;
  }
}

.loading-overlay__spinner {
  display: inline-block;
  width: 3rem;
}

.loading-overlay__spinner svg {
  width: var(--spacing-sm);
}

@keyframes spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

.spinner {
  animation: spin 1.4s ease-in-out infinite;  
}

.path {
  stroke-dasharray: 280;
  stroke-dashoffset: 0;
  animation: dash 1.4s ease-in-out infinite;
  color: black;
  transform-origin:center;
  stroke: currentColor;
}

@keyframes dash {
  0% {
    stroke-dashoffset: 280;
  }
  50% {
    stroke-dashoffset: 75;
    transform: rotate(135deg);
  }
  100% {
    stroke-dashoffset: 280;
    transform: rotate(450deg);
  }
}

.loading-overlay:not(.hidden) + .cart-item__price-wrapper, {
  opacity: 0.5;
}

.loading-overlay:not(.hidden) ~ cart-remove-button {
  opacity: 0;
}

.loading-overlay:not(.hidden) ~ cart-remove-button {
  pointer-events: auto;
  cursor: default;
}
