Для показанного HTML вы можете попытаться сузить комбинацию селектора родительского идентификатора и атрибута локального класса
ThisWorkbook.Worksheets("Sheet1").Cells(1,1) = ie.document.querySelector("#ID-layout-1536671725872 [class='_GAeS _GAHeb _GAA6']").innerText
Не все селекторы отображаются в поле запроса ниже, но это результат:

Селектор идентификатора добавлен, чтобы попытаться локализовать селектор класса, учитывая небольшой пример HTML."#"
- это селектор идентификатора CSS, а "[]"
- селектор атрибута.
Комбинация селектора применяется с помощью метода .querySelector
документа.При условии, что вы используете выше IE8, это должно работать нормально.
Если страница не JS интенсивно / медленно загружается, вы можете отменить открытие IE для выдачи запроса XMLHTTP:
Dim html As New HTMLDocument '<==Tools > references > add reference to microsoft html object library
With CreateObject("MSXML2.XMLHTTP")
.Open "GET", URL, False
.send
sResponse = StrConv(.responseBody, vbUnicode)
sResponse = Mid$(sResponse, InStr(1, sResponse, "<!DOCTYPE "))
With html
.body.innerHTML = sResponse
ThisWorkbook.Worksheets("Sheet1").Cells(1,1) = .querySelector("#ID-layout-1536671725872 [class='_GAeS _GAHeb _GAA6']").innerText
End With
End With