.password-indicator {
    width: 100%;
}

.password-indicator__rules {
    display: flex;
    flex-wrap: wrap;
    column-gap: 1rem;
}

.password-indicator__rules li {
    padding-left: 1.125rem;
    font-size: .75rem;
    font-weight: 500;
    position: relative;
    transition: color .15s ease;
}

.password-indicator__rules li::before, .password-indicator__rules li::after{
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  line-height: 1;
  transition: opacity .1s ease;
}

.password-indicator__rules li::before{
  content: '×';
  font-size: 1.25rem;
  opacity: 1;
}

.password-indicator__rules li::after{
  content: '✓';
  font-size: 1rem;
  opacity: 0;
}

.password-indicator__rules li.is-invalid {
    color: var(--danger, #e50000);
}

.password-indicator__rules li.is-valid {
   color: var(--success, #58a13a);
}

.password-indicator__rules li.is-valid::before {
    opacity: 0;
}

.password-indicator__rules li.is-valid::after  {
    opacity: 1;
}

.form-group:has(.password-indicator) .invalid-feedback {
    margin-top: 0;
}
