.avatar {
  color: var(--color-text-reversed);
  background-color: var(--color-primary);
}

.avatar-outline {
  color: var(--color-gray-500);
  border: solid 1px var(--color-gray-300);
}

.avatar, .avatar-outline {
  flex-shrink: 0;
  inline-size: 2.5rem;
  block-size: 2.5rem;

  aspect-ratio: 1;
  border-radius: 9999px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.875rem;
  font-weight: 500;

  img {
    inline-size: 100%;
    block-size: 100%;
    object-fit: cover;
    border-radius: inherit;
  }

  &-size-3 {
    inline-size: 3rem;
    block-size: 3rem;
    font-size: 1.25rem;
    font-weight: 600;
  }

  &-size-2-5 {
    inline-size: 2.5rem;
    block-size: 2.5rem;
  }

  &-blue {
    background: linear-gradient(to bottom right, #3b82f6, #6366f1);
    svg {
      color: var(--color-text-reversed);
    }
  }

  &-purple {
    background-color: #6366f1;
    svg {
      color: var(--color-text-reversed);
    }
  }
}
