.form-signin {
  max-width: 380px;
  padding: 1rem;
}

.password-rules {
  display: grid;
  gap: 0.4rem;
}

.password-rule,
.password-match-status {
  align-items: center;
  color: var(--app-text-muted);
  display: flex;
  font-size: 0.84rem;
  gap: 0.55rem;
  line-height: 1.35;
  min-height: 1.25rem;
}

.password-rule-indicator,
.password-match-indicator {
  align-items: center;
  border: 1px solid rgba(107, 114, 128, 0.28);
  border-radius: 999px;
  display: inline-flex;
  flex: 0 0 1rem;
  height: 1rem;
  justify-content: center;
  margin-top: 1px;
  width: 1rem;
}

.password-rule-indicator::before,
.password-match-indicator::before {
  content: '';
  font-size: 0.72rem;
  font-weight: 700;
  line-height: 1;
}

.password-rule.is-neutral .password-rule-indicator::before,
.password-match-status.is-neutral .password-match-indicator::before {
  background: currentColor;
  border-radius: 999px;
  content: '';
  height: 0.3rem;
  opacity: 0.7;
  width: 0.3rem;
}

.password-rule.is-valid,
.password-match-status.is-valid {
  color: #335c43;
}

.password-rule.is-valid .password-rule-indicator,
.password-match-status.is-valid .password-match-indicator {
  background: rgba(51, 92, 67, 0.12);
  border-color: rgba(51, 92, 67, 0.3);
}

.password-rule.is-valid .password-rule-indicator::before,
.password-match-status.is-valid .password-match-indicator::before {
  content: '\2713';
}

.password-rule.is-invalid,
.password-match-status.is-invalid {
  color: #7a3944;
}

.password-rule.is-invalid .password-rule-indicator,
.password-match-status.is-invalid .password-match-indicator {
  background: rgba(122, 57, 68, 0.1);
  border-color: rgba(122, 57, 68, 0.28);
}

.password-rule.is-invalid .password-rule-indicator::before,
.password-match-status.is-invalid .password-match-indicator::before {
  content: '\00d7';
}

@media (max-width: 575.98px) {
  .form-signin {
    max-width: 100%;
    padding: 0.75rem;
  }

  .password-rule,
  .password-match-status {
    align-items: flex-start;
    font-size: 0.8rem;
  }
}
