/************* 
**** <config> 
**/ 

var startColor = "#3399FF"; // MouseOut link color 
var endColor = "#FF0000"; // MouseOver link color
var hoverColor = "#FF0000"; // MouseOver link color 
//var hoverColor = "#99CCFF"; // MouseOver link color

// Original
//startColor = "#E8A80E"; // MouseOut link color 
//endColor = "#666699"; // MouseOver link color 

stepIn = 20; 	// delay when fading in (orig. 20).
stepOut = 20;	// delay when fading out (orig. 20).

/* 
** set to true or false; true will 
** cause all links to fade automatically 
***/ 
autoFade = true; 
/* 
** set to true or false; true will cause all CSS 
** classes with "fade" in them to fade onmouseover 
***/ 
sloppyClass = true; 
/** 
**** </config> 
**************/ 
/************* 
**** <install> 
** 
** 
**** </install> 
**************/ 

var gsaHexa = new makearray(16); 
var i;

for(var i = 0; i < 10; i++){
	gsaHexa[i] = i;
}
gsaHexa[10]="a";
gsaHexa[11]="b";
gsaHexa[12]="c"; 
gsaHexa[13]="d";
gsaHexa[14]="e";
gsaHexa[15]="f"; 

document.onmouseover = domouseover; 
document.onmouseout = domouseout; 

startColor = dehexize(startColor.toLowerCase()); 
endColor = dehexize(endColor.toLowerCase());
hoverColor = dehexize(hoverColor.toLowerCase());

var fadeId = new Array(); 

function dehexize(sColor){ 
	var i;
	var j;
	var colorArr = new makearray(3);
	
	for (i=1; i<7; i++){
		for (j=0; j<16; j++){
			if (sColor.charAt(i) == gsaHexa[j]){
				if (i%2 !=0){
					colorArr[Math.floor((i-1)/2)]=eval(j)*16;
				}
				else{
					colorArr[Math.floor((i-1)/2)]+=eval(j);
				}
			}
		} 
	} 
	return colorArr;
} //dehexize

function domouseover(){ 
	if(document.all){
		var srcElement = event.srcElement;
		if ((srcElement.tagName == "A" && autoFade) || srcElement.className == "fade" || (sloppyClass && srcElement.className.indexOf("fade") != -1)){
			fade(startColor,endColor,srcElement.uniqueID,stepIn);
			fade(endColor,hoverColor,srcElement.uniqueID,stepIn);
		} 
	}
} //domouseover

function domouseout(){ 
	if (document.all){ 
		var srcElement = event.srcElement;
		if ((srcElement.tagName == "A" && autoFade) || srcElement.className == "fade" || (sloppyClass && srcElement.className.indexOf("fade") != -1)){
			
			fade(hoverColor,endColor,srcElement.uniqueID,stepOut);
			fade(endColor,startColor,srcElement.uniqueID,stepOut);		
		} 
	}
} //domouseout

function makearray(n){ 
	var i
	this.length = n; 
	for(i = 1; i <= n; i++){
		this[i] = 0;
	}
	return this; 
} //makearray

function hex(i){ 
	if (i < 0){
		return "00";
	}
	else if (i > 255){
		return "ff";
	}
	else{
		return "" + gsaHexa[Math.floor(i/16)] + gsaHexa[i%16];
	} 
} //hex

function setColor(r, g, b, element){ 
	var hr = hex(r);
	var hg = hex(g);
	var hb = hex(b);
	element.style.color = "#"+hr+hg+hb;
} //setColor

function fade(s,e, element,step){ 
	var sr = s[0];
	var sg = s[1];
	var sb = s[2];
	var er = e[0];
	var eg = e[1];
	var eb = e[2];
	var i;
	
	if (fadeId[0] != null && fade[0] != element){ 
		setColor(sr,sg,sb,eval(fadeId[0])); 
		i = 1;
		
		while(i < fadeId.length){ 
			clearTimeout(fadeId[i]);
			i++;
		} 
	}
	
	for(var i = 0; i <= step; i++){
		fadeId[i+1] = setTimeout("setColor(Math.floor(" +sr+ " *(( " +step+ " - " +i+ " )/ " +step+ " ) + " +er+ " * (" +i+ "/" + step+ ")),Math.floor(" +sg+ " * (( " +step+ " - " +i+ " )/ " +step+ " ) + " +eg+ " * (" +i+ "/" +step+ ")),Math.floor(" +sb+ " * ((" +step+ "-" +i+ ")/" +step+ ") + " +eb+ " * (" +i+ "/" +step+ ")),"+element+");",i*step); 
	} 
	fadeId[0] = element; 
} //function