Cómo leer datos de json en C #

Tengo el siguiente objeto json que paso a mi servidor c #

[
    {
        "ID": 1,
        "FirstName": "Jay",
        "LastName": "Smith"
    },
    {
        "ID": 2,
        "FirstName": "Rich",
        "LastName": "Son"
    },
    {
        "ID": 3,
        "FirstName": "Emmy",
        "LastName": "Wat"
    }
]

Yo creo una clase como esta

public class Person
{
    public int ID { get; set; }
    public string FirstName { get; set; }
    public string LastName { get; set; }

}

Cuando hago esto

public static string addRecord(string details)
{
    Person tempRecord = JsonConvert.DeserializeObject<Person>(details);
    string tempFN = tempRecord.FirstName;
    return tempFN;
}

No puedo obtener el resultado real.

¿Qué estoy haciendo mal? ¿Tengo que hacer otra lista en mi clase de persona? ¿Alguna ayuda?

ACTUALIZACIÓN - mi registro es de Grid y así es como lo envío a mi servidor

    var jsonD = Ext.encode(Ext.pluck(this.myGridStore.data.items, 'data'));
    Ext.Ajax.request({
        scope: this,
        method: 'POST',
        url: 'myApp/AddRecord',
        headers: { 'Content-Type': 'application/json' },
        dataType: 'json',
        jsonData: jsonD,
        success: function (response) {
        },
        failure: function (response) {
        }
    });

Respuestas a la pregunta(1)

Su respuesta a la pregunta