jQuery.fn.doFade = function(settings) {

    // if no paramaters supplied...
	settings = jQuery.extend({
		fadeColor: "black",
		duration: 200,
		fadeOn: 0.95,
		fadeOff: 0.7
	}, settings);

    var duration = settings.duration;
    var fadeOff = settings.fadeOff;
    var fadeOn = settings.fadeOn;
    var fadeColor = settings.fadeColor;
        
    $(this).hover(function(){
	  $(this)
	      .stop()
	      .data("origColor", $(this).css("background-color"))
	      .animate({
	          opacity: fadeOn,
	          backgroundColor: fadeColor
	      }, duration)
	}, function() {
	  $(this)
	      .stop()
	      .animate({
	          opacity: fadeOff,
	          backgroundColor: $(this).data("origColor")
	      }, duration)
	});

};

$(function(){

   $("#mapa ul").css("opacity", "0.7");
   
   $("#mapa ul").doFade({ fadeColor: "#333" });
   $("#mapa ul ul").doFade({ fadeColor: "#040649" });
   $("#mapa ul ul ul").doFade({ fadeColor: "#9b272a" });
   $("#mapa ul ul ul ul").doFade({ fadeColor: "#72352d" });

});
