Looking back at an entry from November about Lisp pairs ('conses', i think), it is now obvious that they should be something like
public abstract class MalValue {} // the base type for values
public class MalPair(MalValue first, MalValue rest) : MalValue {} 
(C#'s new "Primary Constructor" syntax is nifty)
Because MalPair extends MalValue, either side of the pair can be another pair. I wonder how much work it would be to drop lists and construct these instead. Probably not worth it (I can only see it costing performance), but it might be fun.