/**
 * mm_menu 20MAR2002 Version 6.0
 * Andy Finnell, March 2002
 * Copyright (c) 2000-2002 Macromedia, Inc.
 *
 * based on menu.js
 * by gary smith, July 1997
 * Copyright (c) 1997-1999 Netscape Communications Corp.
 *
 * Netscape grants you a royalty free license to use or modify this
 * software provided that this copyright notice appears on all copies.
 * This software is provided "AS IS," without a warranty of any kind.
 */
function Menu(label, mw, mh, fnt, fs, fclr, fhclr, bg, bgh, halgn, valgn, pad, space, to, sx, sy, srel, opq, vert, idt, aw, ah) 
{
	this.version = "020320 [Menu; mm_menu.js]";
	this.type = "Menu";
	this.menuWidth = mw;
	this.menuItemHeight = mh;
	this.fontSize = fs;
	this.fontWeight = "plain";
	this.fontFamily = fnt;
	this.fontColor = fclr;
	this.fontColorHilite = fhclr;
	this.bgColor = "#555555";
	this.menuBorder = 1;
	this.menuBgOpaque=opq;
	this.menuItemBorder = 1;
	this.menuItemIndent = idt;
	this.menuItemBgColor = bg;
	this.menuItemVAlign = valgn;
	this.menuItemHAlign = halgn;
	this.menuItemPadding = pad;
	this.menuItemSpacing = space;
	this.menuLiteBgColor = "#ffffff";
	this.menuBorderBgColor = "#777777";
	this.menuHiliteBgColor = bgh;
	this.menuContainerBgColor = "#cccccc";
	this.childMenuIcon = "arrows.gif";
	this.submenuXOffset = sx;
	this.submenuYOffset = sy;
	this.submenuRelativeToItem = srel;
	this.vertical = vert;
	this.items = new Array();
	this.actions = new Array();
	this.childMenus = new Array();
	this.hideOnMouseOut = true;
	this.hideTimeout = to;
	this.addMenuItem = addMenuItem;
	this.writeMenus = writeMenus;
	this.MM_showMenu = MM_showMenu;
	this.onMenuItemOver = onMenuItemOver;
	this.onMenuItemAction = onMenuItemAction;
	this.hideMenu = hideMenu;
	this.hideChildMenu = hideChildMenu;
	
	if (!window.menus) 
		window.menus = new Array();
		
	this.label = " " + label;
	window.menus[this.label] = this;
	window.menus[window.menus.length] = this;
	
	if (!window.activeMenus) 
		window.activeMenus = new Array();
}

function addMenuItem(label, action) 
{
	this.items[this.items.length] = label;
	this.actions[this.actions.length] = action;
}

function FIND(item) 
{
	if (window.mmIsOpera) 
		return (document.getElementById(item));
		
	if (document.all) 
		return (document.all[item]);
		
	if (document.getElementById) 
		return (document.getElementById(item));
		
	return (false);
}

function writeMenus(container) 
{
	if (window.triedToWriteMenus) 
		return;
		
	var agt = navigator.userAgent.toLowerCase();
	window.mmIsOpera = agt.indexOf("opera") != -1;
	
	if (!container && document.layers) 
	{
		window.delayWriteMenus = this.writeMenus;
		var timer = setTimeout('delayWriteMenus()', 500);
		container = new Layer(100);
		clearTimeout(timer);
	} 
	else if (document.all || document.hasChildNodes || window.mmIsOpera) 
	{
		document.writeln('<span id="menuContainer"></span>');
		container = FIND("menuContainer");
	}
	
	window.mmHideMenuTimer = null;
	
	if (!container) 
		return;	
		
	window.triedToWriteMenus = true; 
	container.isContainer = true;
	container.menus = new Array();
	
	for (var i = 0; i < window.menus.length; i++) 
		container.menus[i] = window.menus[i];
		
	window.menus.length = 0;
	var countMenus = 0;
	var countItems = 0;
	var top = 0;
	var content = '';
	var lrs = false;
	var theStat = "";
	var tsc = 0;
	
	// For Netscape 4 and earlier...
	if (document.layers) 
		lrs = true;
		
	for (var i = 0; i < container.menus.length; i++, countMenus++) 
	{
		var menu = container.menus[i];
		
		if (menu.bgImageUp || !menu.menuBgOpaque) 
		{
			menu.menuBorder = 0;
			menu.menuItemBorder = 0;
		}
		
		/* 
			Create the menuLayer div 
		*/
		if (lrs) 	// For Netscape 4 and earlier...
		{
			var menuLayer = new Layer(100, container);
			var lite = new Layer(100, menuLayer);
			lite.top = menu.menuBorder;
			lite.left = menu.menuBorder;
			
			var body = new Layer(100, lite);
			body.top = menu.menuBorder;
			body.left = menu.menuBorder;
		} 
		else 
		{
			/*************  fix for z-index problem  *****************************/
			var itemHeight = menu.fontSize + 2 * menu.menuItemPadding; 
			itemHeight = menu.menuItemHeight || itemHeight;
			var frameHeight = (menu.items.length != 0 ? menu.items.length * (itemHeight + menu.menuItemBorder) + 3 : 0);
			/*************************** end fix *********************************/
			
			content += '<div id="menuLayer' + countMenus + '" style="color:' +  menu.menuBorderBgColor + ';left:10px;position:absolute;top:' + (i * 100) + 'px;visibility:hidden;z-index:99;">\n' +

			/************* fix for z-index problem *****************************/
			'<iframe style="left:0px;position:absolute;top:1px;z-index:97;" frameborder="0" src="" scrolling="no" width="' + (menu.menuWidth + 4) + '" height="' + (frameHeight - 1) + '"></iframe>\n' +
			/*************************** end fix *********************************/

			/************* This is the drop shadow for the menu *******************/
			
			'<div style="height:' + (frameHeight + 10) + 'px;width:' + (menu.menuWidth + 22) + 'px;z-index:98;">\n' + 
				'<div style="float:left;height:' + frameHeight + 'px;width:' + menu.menuWidth + 'px;"></div>\n' +
				'<div style="float:right;height:' + frameHeight + 'px;width:20px;">\n' +
					'<div style="background:url(/images/borders/rect_shadow_right_top.png) no-repeat;height:20px;width:100%;"></div>\n' + 
					'<div style="background:url(/images/borders/rect_shadow_right.png) repeat-y;height:' + (frameHeight - 20) + 'px;width:100%;"></div>\n' + 
				'</div>\n' + 
				'<div style="background:url(/images/borders/rect_shadow_left_bottom.png) no-repeat;float:left;height:20px;width:20px;"></div>\n' + 
				'<div style="background:url(/images/borders/rect_shadow_bottom.png) repeat-x;float:left;height:20px;width:' + (menu.menuWidth - 18) + 'px;"></div>\n' + 
				'<div style="background:url(/images/borders/rect_shadow_right_bottom.png) no-repeat;float:left;height:20px;width:20px;"></div>\n' + 
			'</div>\n' + 
			/**********************************************************************/
			
			'<div id="menuLite' + countMenus + '" style="left:' + menu.menuBorder + 'px;position:absolute;top:' + menu.menuBorder + 'px;visibility:hide;z-index:99;" onmouseout="mouseoutMenu();">\n' +
			'<div id="menuFg' + countMenus + '" style="left:' + menu.menuBorder + 'px;position:absolute;top:' + menu.menuBorder + 'px;visibility:hide;">\n' +
			'';
		}
		
		var x=i;
		
		for (var i = 0; i < menu.items.length; i++) 
		{
			var item = menu.items[i];
			var childMenu = false;
			var defaultHeight = menu.fontSize + 2 * menu.menuItemPadding;
			
			if (item.label) 
			{
				item = item.label;
				childMenu = true;
			}
			
			menu.menuItemHeight = menu.menuItemHeight || defaultHeight;
			var itemProps = '';
			
			if (menu.fontFamily != '' ) 
				itemProps += 'font-family:' + menu.fontFamily + ';';
				
			itemProps += 'font-weight:' + menu.fontWeight + 
						';fontSize:' + menu.fontSize + 'px;';
			
			if (menu.fontStyle) 
				itemProps += 'font-style:' + menu.fontStyle + ';';
				
			if (document.all || window.mmIsOpera) 
			{
				itemProps += 'font-size:' + menu.fontSize + 'px;" onmouseover="onMenuItemOver(null,this);" onclick="onMenuItemAction(null,this);';
			}
			else if (!document.layers) 
			{
				itemProps += 'font-size:' + menu.fontSize + 'px;';
			}
			
			var l;
			
			if (lrs) 
			{
				var lw = menu.menuWidth;
				if (menu.menuItemHAlign == 'right') 
					lw -= menu.menuItemPadding;
				l = new Layer(lw,body);
			}
			
			var itemLeft = 0;
			var itemTop = i * menu.menuItemHeight;
			
			if (!menu.vertical) 
			{
				itemLeft = i * menu.menuWidth;
				itemTop = 0;
			}
			
			var dTag = '<div id="menuItem'+ countItems + '" style="left:' + itemLeft + 'px;position:absolute;top:' + itemTop + 'px;' + itemProps + '">';
			var dClose = '</div>'
			
			if (menu.bgImageUp) 
				dTag = '<div id="menuItem'+ countItems +'" style="background:url(' + menu.bgImageUp + ');left:' + itemLeft + 'px;position:absolute;top:' + itemTop +'px;' + itemProps + '">';

			var left = 0, top = 0, right = 0, bottom = 0;
			left = 1 + menu.menuItemPadding + menu.menuItemIndent;
			right = left + menu.menuWidth - 2*menu.menuItemPadding - menu.menuItemIndent;
			
			if (menu.menuItemVAlign == 'top') 
				top = menu.menuItemPadding;
				
			if (menu.menuItemVAlign == 'bottom') 
				top = menu.menuItemHeight - menu.fontSize - 1 - menu.menuItemPadding;
				
			if (menu.menuItemVAlign == 'middle') 
				top = ((menu.menuItemHeight / 2) - (menu.fontSize / 2) - 1);
				
			bottom = menu.menuItemHeight - 2 * menu.menuItemPadding;
			var textProps = 'left:' + left + 'px;position:absolute;top:' + top + 'px;';
			
			if (lrs) 
			{
				textProps += itemProps + 'right:' + right + ';bottom:' + bottom + ';';
				dTag = "";
				dClose = "";
			}
			
			if (document.all && !window.mmIsOpera) 
			{
				// THIS IS USED BY IE
				item = '<div align="' + menu.menuItemHAlign + '">' + item + '</div>';
			} 
			else if (lrs) 
			{
				item = '<div style="text-align:' + menu.menuItemHAlign + ';">' + item + '</div>';
			} 
			else 
			{
				var hitem = null;
				if (menu.menuItemHAlign != 'left') 
				{
					if (window.mmIsOpera) 
					{
						var operaWidth = menu.menuItemHAlign == 'center' ? -(menu.menuWidth-2*menu.menuItemPadding) : (menu.menuWidth-6*menu.menuItemPadding);
						hitem = '<div id="menuItemHilite' + countItems + 'Shim" class="cssItem" style="left:' + menu.menuItemPadding + 'px;position:absolute;text-align:' + menu.menuItemHAlign + ';top:1px;visibility:visible;width:' + operaWidth + 'px;">' + item + '</div>';
						item = '<div id="menuItemText' + countItems + 'Shim" class="cssItem" style="left:' + menu.menuItemPadding + 'px;position:absolute;text-align:' + menu.menuItemHAlign + ';top:1px;width:' + operaWidth + 'px;visibility:visible;">' + item + '</div>';
					} 
					else 
					{
						/****** THIS IS USED BY MOZILLA *******/
						hitem = '<div id="menuItemHilite' + countItems + 'Shim" style="left:1px;position:absolute;right:-' + (left+menu.menuWidth-10*menu.menuItemPadding) + 'px;text-align:' + menu.menuItemHAlign + ';top:1px;visibility:visible;">' + item + '</div>';
						item = '<div id="menuItemText' + countItems + 'Shim" style="left:1px;position:absolute;right:-' + (left+menu.menuWidth-10*menu.menuItemPadding) + 'px;text-align:' + menu.menuItemHAlign + ';top:1px;visibility:visible;">' + item + '</div>';
					}
				} 
				else 
				{
					hitem = null;
				}
			}
			
			if (document.all && !window.mmIsOpera) 
			{
				item = '<div id="menuItemShim' + countItems + '" style="left:0px;position:absolute;top:0px;">' + item + '</div>';
			}
				
			var dText = '<div id="menuItemText' + countItems + '" style="' + textProps + 'color:' + menu.fontColor + ';">' + item + '&nbsp</div>\n'
						+ '<div id="menuItemHilite' + countItems + '" style="' + textProps + 'color:' + menu.fontColorHilite + ';visibility:hidden;">' 
						+ (hitem||item) + '&nbsp</div>';
						
			if (childMenu) 
			{
				content += (dTag + dText + '<div id="childMenu' + countItems +'" style="left:0px;position:absolute;top:3px;"><img src="' + menu.childMenuIcon + '"></div>\n' + dClose);
			}
			else 
			{
				content += (dTag + dText + dClose);
			}
				
			if (lrs) 
			{
				l.document.open("text/html");
				l.document.writeln(content);
				l.document.close();	
				content = '';
				theStat += "-";
				tsc++;
				
				if (tsc > 50) 
				{
					tsc = 0;
					theStat = "";
				}
				status = theStat;
			}
			countItems++;  
		}
		
		if (lrs) 
		{
			var focusItem = new Layer(100, body);
			focusItem.visiblity="hidden";
			focusItem.document.open("text/html");
			focusItem.document.writeln("&nbsp;");
			focusItem.document.close();	
		} 
		else 
		{
		  content += '<div id="focusItem'+ countMenus +'" style="left:0px;position:absolute;top:0px;visibility:hide;" onclick="onMenuItemAction(null,this);">&nbsp;</div>\n';
		  content += '</div>\n  </div>\n</div>\n';
		}
		i=x;
	}
	
	if (document.layers) 
	{		
		container.clip.width = window.innerWidth;
		container.clip.height = window.innerHeight;
		container.onmouseout = mouseoutMenu;
		container.menuContainerBgColor = this.menuContainerBgColor;
		
		for (var i = 0; i < container.document.layers.length; i++) 
		{
			proto = container.menus[i];
			var menu = container.document.layers[i];
			container.menus[i].menuLayer = menu;
			container.menus[i].menuLayer.Menu = container.menus[i];
			container.menus[i].menuLayer.Menu.container = container;
			var body = menu.document.layers[0].document.layers[0];
			body.clip.width = proto.menuWidth || body.clip.width;
			body.clip.height = proto.menuHeight || body.clip.height;
			
			for (var n = 0; n < body.document.layers.length - 1; n++) 
			{
				var l = body.document.layers[n];
				l.Menu = container.menus[i];
				l.menuHiliteBgColor = proto.menuHiliteBgColor;
				l.document.bgColor = proto.menuItemBgColor;
				l.saveColor = proto.menuItemBgColor;
				l.onmouseover = proto.onMenuItemOver;
				l.onclick = proto.onMenuItemAction;
				l.mmaction = container.menus[i].actions[n];
				l.focusItem = body.document.layers[body.document.layers.length-1];
				l.clip.width = proto.menuWidth || body.clip.width;
				l.clip.height = proto.menuItemHeight || l.clip.height;
				
				if (n > 0) 
				{
					if (l.Menu.vertical) 
						l.top = body.document.layers[n-1].top + body.document.layers[n-1].clip.height + proto.menuItemBorder + proto.menuItemSpacing;
					else 
						l.left = body.document.layers[n-1].left + body.document.layers[n-1].clip.width + proto.menuItemBorder + proto.menuItemSpacing;
				}
				
				l.hilite = l.document.layers[1];
				if (proto.bgImageUp) 
					l.background.src = proto.bgImageUp;
				l.document.layers[1].isHilite = true;
				
				if (l.document.layers.length > 2) 
				{
					l.childMenu = container.menus[i].items[n].menuLayer;
					l.document.layers[2].left = l.clip.width -13;
					l.document.layers[2].top = (l.clip.height / 2) -4;
					l.document.layers[2].clip.left += 3;
					l.Menu.childMenus[l.Menu.childMenus.length] = l.childMenu;
				}
			}
			
			if (proto.menuBgOpaque) 
				body.document.bgColor = proto.bgColor;
				
			if (proto.vertical) 
			{
				body.clip.width  = l.clip.width + proto.menuBorder;
				body.clip.height = l.top + l.clip.height + proto.menuBorder;
			} 
			else 
			{
				body.clip.height  = l.clip.height +proto.menuBorder;
				body.clip.width = l.left + l.clip.width + proto.menuBorder;
				if (body.clip.width > window.innerWidth) 
					body.clip.width = window.innerWidth;
			}
			
			var focusItem = body.document.layers[n];
			focusItem.clip.width = body.clip.width;
			focusItem.Menu = l.Menu;
			focusItem.top = -30;
            focusItem.captureEvents(Event.MOUSEDOWN);
            focusItem.onmousedown = onMenuItemDown;
			
			if (proto.menuBgOpaque) 
				menu.document.bgColor = proto.menuBorderBgColor;
				
			var lite = menu.document.layers[0];
			
			if (proto.menuBgOpaque) 
				lite.document.bgColor = proto.menuLiteBgColor;
				
			lite.clip.width = body.clip.width + 1;
			lite.clip.height = body.clip.height + 1;
			menu.clip.width = body.clip.width + (proto.menuBorder * 3);
			menu.clip.height = body.clip.height + (proto.menuBorder * 3);
		}
	} 
	else 
	{
		if ((!document.all) && (container.hasChildNodes) && !window.mmIsOpera) 
		{
			container.innerHTML=content;
		} 
		else 
		{
			container.document.open("text/html");
			container.document.writeln(content);
			container.document.close();	
		}
		
		if (!FIND("menuLayer0")) 
			return;
			
		var menuCount = 0;
		
		for (var x = 0; x < container.menus.length; x++) 
		{
			var menuLayer = FIND("menuLayer" + x);
			container.menus[x].menuLayer = "menuLayer" + x;
			menuLayer.Menu = container.menus[x];
			menuLayer.Menu.container = "menuLayer" + x;
			menuLayer.style.zindex = 1;
		    var s = menuLayer.style;
			s.pixeltop = -300;
			s.pixelleft = -300;
			s.top = '-300px';
			s.left = '-300px';

			var menu = container.menus[x];
			menu.menuItemWidth = menu.menuWidth || menu.menuIEWidth || 140;
			if (menu.menuBgOpaque) 
				menuLayer.style.backgroundColor = menu.menuBorderBgColor;
			var top = 0;
			var left = 0;
			menu.menuItemLayers = new Array();
			
			for (var i = 0; i < container.menus[x].items.length; i++) 
			{
				var l = FIND("menuItem" + menuCount);
				l.Menu = container.menus[x];
				l.Menu.menuItemLayers[l.Menu.menuItemLayers.length] = l;
				
				if (l.addEventListener || window.mmIsOpera) 
				{
					l.style.width = menu.menuItemWidth + 'px';
					l.style.height = menu.menuItemHeight + 'px';
					l.style.pixelWidth = menu.menuItemWidth;
					l.style.pixelHeight = menu.menuItemHeight;
					l.style.top = top + 'px';
					l.style.left = left + 'px';
					
					if (l.addEventListener) 
					{
						l.addEventListener("mouseover", onMenuItemOver, false);
						l.addEventListener("click", onMenuItemAction, false);
						l.addEventListener("mouseout", mouseoutMenu, false);
					}
					
					if (menu.menuItemHAlign != 'left') 
					{
						l.hiliteShim = FIND("menuItemHilite" + menuCount + "Shim");
						l.hiliteShim.style.visibility = "inherit";
						l.textShim = FIND("menuItemText" + menuCount + "Shim");
						l.hiliteShim.style.pixelWidth = menu.menuItemWidth - 2*menu.menuItemPadding - menu.menuItemIndent;
						l.hiliteShim.style.width = l.hiliteShim.style.pixelWidth;
						l.textShim.style.pixelWidth = menu.menuItemWidth - 2*menu.menuItemPadding - menu.menuItemIndent;
						l.textShim.style.width = l.textShim.style.pixelWidth;	
					}
				} 
				else 
				{
					l.style.pixelWidth = menu.menuItemWidth;
					l.style.pixelHeight = menu.menuItemHeight;
					l.style.pixelTop = top;
					l.style.pixelLeft = left;
					if (menu.menuItemHAlign != 'left') 
					{
						var shim = FIND("menuItemShim" + menuCount);
						shim[0].style.pixelWidth = menu.menuItemWidth - 2*menu.menuItemPadding - menu.menuItemIndent;
						shim[1].style.pixelWidth = menu.menuItemWidth - 2*menu.menuItemPadding - menu.menuItemIndent;
						shim[0].style.width = shim[0].style.pixelWidth + 'px';
						shim[1].style.width = shim[1].style.pixelWidth + 'px';
					}
				}
				
				if (menu.vertical) 
					top = top + menu.menuItemHeight + menu.menuItemBorder + menu.menuItemSpacing;
				else 
					left = left + menu.menuItemWidth + menu.menuItemBorder + menu.menuItemSpacing;
					
				l.style.fontSize = menu.fontSize + 'px';
				l.style.backgroundColor = menu.menuItemBgColor;
				l.style.visibility = "inherit";
				l.saveColor = menu.menuItemBgColor;
				l.menuHiliteBgColor = menu.menuHiliteBgColor;
				l.mmaction = container.menus[x].actions[i];
				l.hilite = FIND("menuItemHilite" + menuCount);
				l.focusItem = FIND("focusItem" + x);
				l.focusItem.style.pixelTop = -30;
				l.focusItem.style.top = '-30px';
				var childItem = FIND("childMenu" + menuCount);
				
				if (childItem) 
				{
					l.childMenu = container.menus[x].items[i].menuLayer;
					childItem.style.pixelLeft = menu.menuItemWidth - 11;
					childItem.style.left = childItem.style.pixelLeft + 'px';
					childItem.style.pixelTop = (menu.menuItemHeight /2) -4;
					childItem.style.top = childItem.style.pixelTop + 'px';
					l.Menu.childMenus[l.Menu.childMenus.length] = l.childMenu;
				}
				l.style.cursor = "hand";
				menuCount++;
			}
			
			if (menu.vertical) 
			{
				menu.menuHeight = top - 1 - menu.menuItemSpacing;
				menu.menuWidth = menu.menuItemWidth;
			} 
			else 
			{
				menu.menuHeight = menu.menuItemHeight;
				menu.menuWidth = left - 1 - menu.menuItemSpacing;
			}

			var lite = FIND("menuLite" + x);
			var s = lite.style;
			s.pixelHeight = menu.menuHeight + (menu.menuBorder * 2);
			s.height = s.pixelHeight + 'px';
			s.pixelWidth = menu.menuWidth + (menu.menuBorder * 2);
			s.width = s.pixelWidth + 'px';
			
			if (menu.menuBgOpaque) 
				s.backgroundColor = menu.menuLiteBgColor;

			var body = FIND("menuFg" + x);
			s = body.style;
			s.pixelHeight = menu.menuHeight + menu.menuBorder;
			s.height = s.pixelHeight + 'px';
			s.pixelWidth = menu.menuWidth + menu.menuBorder;
			s.width = s.pixelWidth + 'px';
			if (menu.menuBgOpaque) 
				s.backgroundColor = menu.bgColor;

			s = menuLayer.style;
			s.pixelWidth = menu.menuWidth + (menu.menuBorder * 4);
			s.width = s.pixelWidth + 'px';
			s.pixelHeight  = menu.menuHeight + (menu.menuBorder*4);
			s.height = s.pixelHeight + 'px';
		}
	}
	
	if (document.captureEvents) 
		document.captureEvents(Event.MOUSEUP);
		
	if (document.addEventListener) 
		document.addEventListener("mouseup", onMenuItemOver, false);
		
	if (document.layers && window.innerWidth) 
	{
		window.onresize = NS4resize;
		window.NS4sIW = window.innerWidth;
		window.NS4sIH = window.innerHeight;
		setTimeout("NS4resize()",500);
	}
	
	document.onmouseup = mouseupMenu;
	window.mmWroteMenu = true;
	status = "";
}

function NS4resize() 
{
	if (NS4sIW != window.innerWidth || NS4sIH != window.innerHeight) 
		window.location.reload();
}

function onMenuItemOver(e, l) 
{
	MM_clearTimeout();
	l = l || this;
	var a = window.ActiveMenuItem;
	
	if (document.layers) 
	{
		if (a) 
		{
			a.document.bgColor = a.saveColor;
			if (a.hilite) 
				a.hilite.visibility = "hidden";
				
			if (a.Menu.bgImageOver) 
				a.background.src = a.Menu.bgImageUp;
				
			a.focusItem.top = -100;
			a.clicked = false;
		}
		
		if (l.hilite) 
		{
			l.document.bgColor = l.menuHiliteBgColor;
			l.zIndex = 1;
			l.hilite.visibility = "inherit";
			l.hilite.zIndex = 2;
			l.document.layers[1].zIndex = 1;
			l.focusItem.zIndex = this.zIndex +2;
		}
		
		if (l.Menu.bgImageOver) 
			l.background.src = l.Menu.bgImageOver;
			
		l.focusItem.top = this.top;
		l.focusItem.left = this.left;
		l.focusItem.clip.width = l.clip.width;
		l.focusItem.clip.height = l.clip.height;
		l.Menu.hideChildMenu(l);
	} 
	else if (l.style && l.Menu) 
	{
		if (a) 
		{
			a.style.backgroundColor = a.saveColor;
			if (a.hilite) 
				a.hilite.style.visibility = "hidden";
				
			if (a.hiliteShim) 
				a.hiliteShim.style.visibility = "inherit";
				
			if (a.Menu.bgImageUp) 
				a.style.background = "url(" + a.Menu.bgImageUp +")";;
		} 
		
		l.style.backgroundColor = l.menuHiliteBgColor;
		l.zIndex = 1;
		
		if (l.Menu.bgImageOver) 
			l.style.background = "url(" + l.Menu.bgImageOver +")";
			
		if (l.hilite) 
		{
			l.hilite.style.visibility = "inherit";
			
			if (l.hiliteShim) 
				l.hiliteShim.style.visibility = "visible";
		}
		
		l.focusItem.style.pixelTop = l.style.pixelTop;
		l.focusItem.style.top = l.focusItem.style.pixelTop + 'px';
		l.focusItem.style.pixelLeft = l.style.pixelLeft;
		l.focusItem.style.left = l.focusItem.style.pixelLeft + 'px';
		l.focusItem.style.zIndex = l.zIndex + 1;
		l.Menu.hideChildMenu(l);
	} 
	else 
		return;
		
	window.ActiveMenuItem = l;
}

function onMenuItemAction(e, l) 
{
	l = window.ActiveMenuItem;
	
	if (!l) 
		return;
		
	hideActiveMenus();
	
	if (l.mmaction) 
		eval("" + l.mmaction);
		
	window.ActiveMenuItem = 0;
}

function MM_clearTimeout() 
{
	if (mmHideMenuTimer) 
		clearTimeout(mmHideMenuTimer);
		
	mmHideMenuTimer = null;
	mmDHFlag = false;
}

function MM_startTimeout() 
{
	if (window.ActiveMenu) 
	{
		mmStart = new Date();
		mmDHFlag = true;
		mmHideMenuTimer = setTimeout("mmDoHide()", window.ActiveMenu.Menu.hideTimeout);
	}
}

function mmDoHide() 
{
	if (!mmDHFlag || !window.ActiveMenu) 
		return;
		
	var elapsed = new Date() - mmStart;
	var timeout = window.ActiveMenu.Menu.hideTimeout;
	
	if (elapsed < timeout) 
	{
		mmHideMenuTimer = setTimeout("mmDoHide()", timeout + 100 - elapsed);
		return;
	}
	
	mmDHFlag = false;
	hideActiveMenus();
	window.ActiveMenuItem = 0;
}

function MM_showMenu(menu, x, y, child, imgname) 
{
	if (!window.mmWroteMenu) 
		return;
		
	MM_clearTimeout();
	
	if (menu) 
	{
		var obj = FIND(imgname) || document.images[imgname] || document.links[imgname] || document.anchors[imgname];
		x = moveXbySlicePos(x, obj);
		y = moveYbySlicePos(y, obj);
	}
	
	if (document.layers) 
	{
		if (menu) 
		{
			var l = menu.menuLayer || menu;
			l.top = l.left = 1;
			hideActiveMenus();
			
			if (this.visibility) 
				l = this;
			window.ActiveMenu = l;
		} 
		else 
		{
			var l = child;
		}
		
		if (!l) 
			return;
			
		for (var i = 0; i < l.layers.length; i++) 
		{ 			   
			if (!l.layers[i].isHilite) 
				l.layers[i].visibility = "inherit";
				
			if (l.layers[i].document.layers.length > 0) 
				MM_showMenu(null, "relative", "relative", l.layers[i]);
		}
		
		if (l.parentLayer) 
		{
			if (x != "relative") 
				l.parentLayer.left = x || window.pageX || 0;
				
			if (l.parentLayer.left + l.clip.width > window.innerWidth) 
				l.parentLayer.left -= (l.parentLayer.left + l.clip.width - window.innerWidth);
				
			if (y != "relative") 
				l.parentLayer.top = y || window.pageY || 0;
				
			if (l.parentLayer.isContainer) 
			{
				l.Menu.xOffset = window.pageXOffset;
				l.Menu.yOffset = window.pageYOffset;
				l.parentLayer.clip.width = window.ActiveMenu.clip.width + 2;
				l.parentLayer.clip.height = window.ActiveMenu.clip.height + 2;
				
				if (l.parentLayer.menuContainerBgColor && l.Menu.menuBgOpaque) 
					l.parentLayer.document.bgColor = l.parentLayer.menuContainerBgColor;
			}
		}
		l.visibility = "inherit";
		
		if (l.Menu) 
			l.Menu.container.visibility = "inherit";
	} 
	else if (FIND("menuItem0")) 
	{
		var l = menu.menuLayer || menu;	
		hideActiveMenus();
		
		if (typeof(l) == "string") 
			l = FIND(l);
			
		window.ActiveMenu = l;
		var s = l.style;
		s.visibility = "inherit";
		
		if (x != "relative") 
		{
			s.pixelLeft = x || (window.pageX + document.body.scrollLeft) || 0;
			s.left = s.pixelLeft + 'px';
		}
		
		if (y != "relative") 
		{
			s.pixelTop = y || (window.pageY + document.body.scrollTop) || 0;
			s.top = s.pixelTop + 'px';
		}
		
		l.Menu.xOffset = document.body.scrollLeft;
		l.Menu.yOffset = document.body.scrollTop;
	}
	
	if (menu) 
		window.activeMenus[window.activeMenus.length] = l;
		
	MM_clearTimeout();
}

function onMenuItemDown(e, l) 
{
	var a = window.ActiveMenuItem;
	
	if (document.layers && a) 
	{
		a.eX = e.pageX;
		a.eY = e.pageY;
		a.clicked = true;
    }
}

function mouseupMenu(e) 
{
	hideMenu(true, e);
	hideActiveMenus();
	return true;
}

function getExplorerVersion() 
{
	var ieVers = parseFloat(navigator.appVersion);
	if (navigator.appName != 'Microsoft Internet Explorer') 
		return ieVers;
		
	var tempVers = navigator.appVersion;
	var i = tempVers.indexOf('MSIE ');
	
	if(i >= 0) 
	{
		tempVers = tempVers.substring(i+5);
		ieVers = parseFloat(tempVers); 
	}
	
	return ieVers;
}

function mouseoutMenu() 
{
	if ((navigator.appName == "Microsoft Internet Explorer") && (getExplorerVersion() < 4.5))
		return true;
		
	hideMenu(false, false);
	return true;
}

function hideMenu(mouseup, e) 
{
	var a = window.ActiveMenuItem;
	
	if (a && document.layers) 
	{
		a.document.bgColor = a.saveColor;
		a.focusItem.top = -30;
		
		if (a.hilite) 
			a.hilite.visibility = "hidden";
			
		if (mouseup && a.mmaction && a.clicked && window.ActiveMenu) 
		{
 			if (a.eX <= e.pageX + 15 && a.eX >= e.pageX - 15 && a.eY <= e.pageY + 10 && a.eY >= e.pageY - 10) 
			{
				setTimeout('window.ActiveMenu.Menu.onMenuItemAction();', 500);
			}
		}
		a.clicked = false;
		
		if (a.Menu.bgImageOver) 
			a.background.src = a.Menu.bgImageUp;
	} 
	else if (window.ActiveMenu && FIND("menuItem0")) 
	{
		if (a) 
		{
			a.style.backgroundColor = a.saveColor;
			if (a.hilite) 
				a.hilite.style.visibility = "hidden";
			if (a.hiliteShim) 
				a.hiliteShim.style.visibility = "inherit";
			if (a.Menu.bgImageUp) 
				a.style.background = "url(" + a.Menu.bgImageUp +")";
		}
	}
	
	if (!mouseup && window.ActiveMenu) 
	{
		if (window.ActiveMenu.Menu) 
		{
			if (window.ActiveMenu.Menu.hideOnMouseOut) 
				MM_startTimeout();
				
			return (true);
		}
	}
	
	return (true);
}

function hideChildMenu(hcmLayer) 
{
	MM_clearTimeout();
	var l = hcmLayer;
	
	for (var i = 0; i < l.Menu.childMenus.length; i++) 
	{
		var theLayer = l.Menu.childMenus[i];
		if (document.layers) 
			theLayer.visibility = "hidden";
		else 
		{
			theLayer = FIND(theLayer);
			theLayer.style.visibility = "hidden";
			
			if (theLayer.Menu.menuItemHAlign != 'left') 
			{
				for(var j = 0; j < theLayer.Menu.menuItemLayers.length; j++) 
				{
					var itemLayer = theLayer.Menu.menuItemLayers[j];
					
					if (itemLayer.textShim) 
						itemLayer.textShim.style.visibility = "inherit";
				}
			}
		}
		
		theLayer.Menu.hideChildMenu(theLayer);
	}
	
	if (l.childMenu) 
	{
		var childMenu = l.childMenu;
		
		if (document.layers) 
		{
			l.Menu.MM_showMenu(null, null, null, childMenu.layers[0]);
			childMenu.zIndex = l.parentLayer.zIndex + 1;
			childMenu.top = l.Menu.menuLayer.top + l.Menu.submenuYOffset;
			
			if (l.Menu.vertical) 
			{
				if (l.Menu.submenuRelativeToItem) 
					childMenu.top += l.top + l.parentLayer.top;
					
				childMenu.left = l.parentLayer.left + l.parentLayer.clip.width - (2*l.Menu.menuBorder) + l.Menu.menuLayer.left + l.Menu.submenuXOffset;
			} 
			else 
			{
				childMenu.top += l.top + l.parentLayer.top;	
				
				if(l.Menu.submenuRelativeToItem) 
					childMenu.left = l.Menu.menuLayer.left + l.left + l.clip.width + (2*l.Menu.menuBorder) + l.Menu.submenuXOffset;
				else 
					childMenu.left = l.parentLayer.left + l.parentLayer.clip.width - (2*l.Menu.menuBorder) + l.Menu.menuLayer.left + l.Menu.submenuXOffset;
			}
			
			if (childMenu.left < l.Menu.container.clip.left) 
				l.Menu.container.clip.left = childMenu.left;
				
			var w = childMenu.clip.width + childMenu.left - l.Menu.container.clip.left;
			
			if (w > l.Menu.container.clip.width)  
				l.Menu.container.clip.width = w;
				
			var h = childMenu.clip.height + childMenu.top - l.Menu.container.clip.top;
			
			if (h > l.Menu.container.clip.height) 
				l.Menu.container.clip.height = h;
				
			l.document.layers[1].zIndex = 0;
			childMenu.visibility = "inherit";
		} 
		else if (FIND("menuItem0")) 
		{
			childMenu = FIND(l.childMenu);
			var menuLayer = FIND(l.Menu.menuLayer);
			var s = childMenu.style;
			s.zIndex = menuLayer.style.zIndex + 1;
			
			if (document.all || window.mmIsOpera) 
			{
				s.pixelTop = menuLayer.style.pixelTop + l.Menu.submenuYOffset;
				
				if (l.Menu.vertical) 
				{
					if (l.Menu.submenuRelativeToItem) 
						s.pixelTop += l.style.pixelTop;
						
					s.pixelLeft = l.style.pixelWidth + menuLayer.style.pixelLeft + l.Menu.submenuXOffset;
					s.left = s.pixelLeft + 'px';
				} 
				else 
				{
					s.pixelTop += l.style.pixelTop;
					
					if (l.Menu.submenuRelativeToItem) 
						s.pixelLeft = menuLayer.style.pixelLeft + l.style.pixelLeft + l.style.pixelWidth + (2*l.Menu.menuBorder) + l.Menu.submenuXOffset;
					else 
						s.pixelLeft = (menuLayer.style.pixelWidth - 4*l.Menu.menuBorder) + menuLayer.style.pixelLeft + l.Menu.submenuXOffset;
						
					s.left = s.pixelLeft + 'px';
				}
			} 
			else 
			{
				var top = parseInt(menuLayer.style.top) + l.Menu.submenuYOffset;
				var left = 0;
				
				if (l.Menu.vertical) 
				{
					if (l.Menu.submenuRelativeToItem) 
						top += parseInt(l.style.top);
						
					left = (parseInt(menuLayer.style.width) - 4*l.Menu.menuBorder) + parseInt(menuLayer.style.left) + l.Menu.submenuXOffset;
				} 
				else 
				{
					top += parseInt(l.style.top);
					
					if (l.Menu.submenuRelativeToItem) 
						left = parseInt(menuLayer.style.left) + parseInt(l.style.left) + parseInt(l.style.width) + (2*l.Menu.menuBorder) + l.Menu.submenuXOffset;
					else 
						left = (parseInt(menuLayer.style.width) - 4*l.Menu.menuBorder) + parseInt(menuLayer.style.left) + l.Menu.submenuXOffset;
				}
				
				s.top = top + 'px';
				s.left = left + 'px';
			}
			childMenu.style.visibility = "inherit";
		} 
		else 
			return;
			
		window.activeMenus[window.activeMenus.length] = childMenu;
	}
}

function hideActiveMenus() 
{
	if (!window.activeMenus) 
		return;
		
	for (var i = 0; i < window.activeMenus.length; i++) 
	{
		if (!activeMenus[i]) 
			continue;
			
		if (activeMenus[i].visibility && activeMenus[i].Menu && !window.mmIsOpera) 
		{
			activeMenus[i].visibility = "hidden";
			activeMenus[i].Menu.container.visibility = "hidden";
			activeMenus[i].Menu.container.clip.left = 0;
		} 
		else if (activeMenus[i].style) 
		{
			var s = activeMenus[i].style;
			s.visibility = "hidden";
			s.left = '-200px';
			s.top = '-200px';
		}
	}
	
	if (window.ActiveMenuItem) 
		hideMenu(false, false);
		
	window.activeMenus.length = 0;
}

function moveXbySlicePos(x, img) 
{ 
	if (!document.layers) 
	{
		var onWindows = navigator.platform ? navigator.platform == "Win32" : false;
		var macIE45 = document.all && !onWindows && getExplorerVersion() == 4.5;
		var par = img;
		var lastOffset = 0;
		
		while(par)
		{
			if(par.leftMargin && ! onWindows) 
				x += parseInt(par.leftMargin);
			if((par.offsetLeft != lastOffset) && par.offsetLeft) 
				x += parseInt(par.offsetLeft);
			if(par.offsetLeft != 0) 
				lastOffset = par.offsetLeft;
			par = macIE45 ? par.parentElement : par.offsetParent;
		}
	} 
	else if (img.x) 
		x += img.x;
		
	return x;
}

function moveYbySlicePos(y, img) 
{
	if(!document.layers) 
	{
		var onWindows = navigator.platform ? navigator.platform == "Win32" : false;
		var macIE45 = document.all && !onWindows && getExplorerVersion() == 4.5;
		var par = img;
		var lastOffset = 0;
		
		while(par)
		{
			if (par.topMargin && !onWindows) 
				y += parseInt(par.topMargin);
			if ((par.offsetTop != lastOffset) && par.offsetTop) 
				y += parseInt(par.offsetTop);
			if (par.offsetTop != 0) 
				lastOffset = par.offsetTop;
			par = macIE45 ? par.parentElement : par.offsetParent;
		}		
	} 
	else if (img.y >= 0) 
		y += img.y;
		
	return y;
}
