/** 
 * Name:    Highslide JS 
 * Version: 4.1.9 (2010-07-05) 
 * Author:  Torstein Hønsi 
 * Support: www.highslide.com/support 
 * License: www.highslide.com/#license 
 */ 
if (!hs) {var hs = { 
// Language strings 
lang : { 
	cssDirection: 'ltr', 
	loadingText : 'Loading...', 
	loadingTitle : 'Click to cancel', 
	focusTitle : 'Click to bring to front', 
	fullExpandTitle : 'Expand to actual size (f)', 
	creditsText : 'Powered by <i>Highslide JS</i>', 
	creditsTitle : 'Go to the Highslide JS homepage', 
	restoreTitle : 'Click to close image, click and drag to move. Use arrow keys for next and previous.' 
}, 
// See http://highslide.com/ref for examples of settings 
graphicsDir : '../highslide/graphics/', 
expandCursor : 'zoomin.cur', // null disables 
restoreCursor : 'zoomout.cur', // null disables 
expandDuration : 250, // milliseconds 
restoreDuration : 250, 
marginLeft : 15, 
marginRight : 15, 
marginTop : 15, 
marginBottom : 15, 
zIndexCounter : 1001, // adjust to other absolutely positioned elements 
loadingOpacity : 0.75, 
allowMultipleInstances: true, 
numberOfImagesToPreload : 5, 
outlineWhileAnimating : 2, // 0 = never, 1 = always, 2 = HTML only 
outlineStartOffset : 3, // ends at 10 
padToMinWidth : false, // pad the popup width to make room for wide caption 
fullExpandPosition : 'bottom right', 
fullExpandOpacity : 1, 
showCredits : true, // you can set this to false if you want 
creditsHref : 'http://highslide.com/', 
creditsTarget : '_self', 
enableKeyListener : true, 
openerTagNames : ['a'], // Add more to allow slideshow indexing 
 
dragByHeading: true, 
minWidth: 200, 
minHeight: 200, 
allowSizeReduction: true, // allow the image to reduce to fit client size. If false, this overrides minWidth and minHeight 
outlineType : 'drop-shadow', // set null to disable outlines 
// END OF YOUR SETTINGS 
 
 
// declare internal properties 
preloadTheseImages : [], 
continuePreloading: true, 
expanders : [], 
overrides : [ 
	'allowSizeReduction', 
	'useBox', 
	'outlineType', 
	'outlineWhileAnimating', 
	'captionId', 
	'captionText', 
	'captionEval', 
	'captionOverlay', 
	'headingId', 
	'headingText', 
	'headingEval', 
	'headingOverlay', 
	'creditsPosition', 
	'dragByHeading', 
 
	'width', 
	'height', 
 
	'wrapperClassName', 
	'minWidth', 
	'minHeight', 
	'maxWidth', 
	'maxHeight', 
	'pageOrigin', 
	'slideshowGroup', 
	'easing', 
	'easingClose', 
	'fadeInOut', 
	'src' 
], 
overlays : [], 
idCounter : 0, 
oPos : { 
	x: ['leftpanel', 'left', 'center', 'right', 'rightpanel'], 
	y: ['above', 'top', 'middle', 'bottom', 'below'] 
}, 
mouse: {}, 
headingOverlay: {}, 
captionOverlay: {}, 
timers : [], 
 
pendingOutlines : {}, 
clones : {}, 
onReady: [], 
uaVersion: /Trident\/4\.0/.test(navigator.userAgent) ? 8 : 
	parseFloat((navigator.userAgent.toLowerCase().match( /.+(?:rv|it|ra|ie)[\/: ]([\d.]+)/ ) || [0,'0'])[1]), 
ie : (document.all && !window.opera), 
safari : /Safari/.test(navigator.userAgent), 
geckoMac : /Macintosh.+rv:1\.[0-8].+Gecko/.test(navigator.userAgent), 
 
$ : function (id) { 
	if (id) return document.getElementById(id); 
}, 
 
push : function (arr, val) { 
	arr[arr.length] = val; 
}, 
 
createElement : function (tag, attribs, styles, parent, nopad) { 
	var el = document.createElement(tag); 
	if (attribs) hs.extend(el, attribs); 
	if (nopad) hs.setStyles(el, {padding: 0, border: 'none', margin: 0}); 
	if (styles) hs.setStyles(el, styles); 
	if (parent) parent.appendChild(el); 
	return el; 
}, 
 
extend : function (el, attribs) { 
	for (var x in attribs) el[x] = attribs[x]; 
	return el; 
}, 
 
setStyles : function (el, styles) { 
	for (var x in styles) { 
		if (hs.ie && x == 'opacity') { 
			if (styles[x] > 0.99) el.style.removeAttribute('filter'); 
			else el.style.filter = 'alpha(opacity='+ (styles[x] * 100) +')'; 
		} 
		else el.style[x] = styles[x]; 
	} 
}, 
animate: function(el, prop, opt) { 
	var start, 
		end, 
		unit; 
	if (typeof opt != 'object' || opt === null) { 
		var args = arguments; 
		opt = { 
			duration: args[2], 
			easing: args[3], 
			complete: args[4] 
		}; 
	} 
	if (typeof opt.duration != 'number') opt.duration = 250; 
	opt.easing = Math[opt.easing] || Math.easeInQuad; 
	opt.curAnim = hs.extend({}, prop); 
	for (var name in prop) { 
		var e = new hs.fx(el, opt , name ); 
 
		start = parseFloat(hs.css(el, name)) || 0; 
		end = parseFloat(prop[name]); 
		unit = name != 'opacity' ? 'px' : ''; 
 
		e.custom( start, end, unit ); 
	} 
}, 
css: function(el, prop) { 
	if (el.style[prop]) { 
		return el.style[prop]; 
	} else if (document.defaultView) { 
		return document.defaultView.getComputedStyle(el, null).getPropertyValue(prop); 
 
	} else { 
		if (prop == 'opacity') prop = 'filter'; 
		var val = el.currentStyle[prop.replace(/\-(\w)/g, function (a, b){return b.toUpperCase();})]; 
		if (prop == 'filter') 
			val = val.replace(/alpha\(opacity=([0-9]+)\)/, 
				function (a, b) {return b / 100}); 
		return val === '' ? 1 : val; 
	} 
}, 
 
getPageSize : function () { 
	var d = document, w = window, iebody = d.compatMode && d.compatMode != 'BackCompat' 
		? d.documentElement : d.body; 
 
	var width = hs.ie ? iebody.clientWidth : 
			(d.documentElement.clientWidth || self.innerWidth), 
		height = hs.ie ? iebody.clientHeight : self.innerHeight; 
 
	hs.page = { 
		width: width, 
		height: height, 
		scrollLeft: hs.ie ? iebody.scrollLeft : pageXOffset, 
		scrollTop: hs.ie ? iebody.scrollTop : pageYOffset 
	}; 
	return hs.page; 
}, 
 
getPosition : function(el)	{ 
	var p = {x: el.offsetLeft, y: el.offsetTop}; 
	while (el.offsetParent)	{ 
		el = el.offsetParent; 
		p.x += el.offsetLeft; 
		p.y += el.offsetTop; 
		if (el != document.body && el != document.documentElement) { 
			p.x -= el.scrollLeft; 
			p.y -= el.scrollTop; 
		} 
	} 
	return p; 
}, 
 
expand : function(a, params, custom, type) { 
	if (!a) a = hs.createElement('a', null, {display: 'none'}, hs.container); 
	if (typeof a.getParams == 'function') return params; 
	try { 
		new hs.Expander(a, params, custom); 
		return false; 
	} catch (e) {return true;} 
}, 
 
 
focusTopmost : function() { 
	var topZ = 0, 
		topmostKey = -1, 
		expanders = hs.expanders, 
		exp, 
		zIndex; 
	for (var i = 0; i < expanders.length; i++) { 
		exp = expanders[i]; 
		if (exp) { 
			zIndex = exp.wrapper.style.zIndex; 
			if (zIndex && zIndex > topZ) { 
				topZ = zIndex; 
				topmostKey = i; 
			} 
		} 
	} 
	if (topmostKey == -1) hs.focusKey = -1; 
	else expanders[topmostKey].focus(); 
}, 
 
getParam : function (a, param) { 
	a.getParams = a.onclick; 
	var p = a.getParams ? a.getParams() : null; 
	a.getParams = null; 
 
	return (p && typeof p[param] != 'undefined') ? p[param] : 
		(typeof hs[param] != 'undefined' ? hs[param] : null); 
}, 
 
getSrc : function (a) { 
	var src = hs.getParam(a, 'src'); 
	if (src) return src; 
	return a.href; 
}, 
 
getNode : function (id) { 
	var node = hs.$(id), clone = hs.clones[id], a = {}; 
	if (!node && !clone) return null; 
	if (!clone) { 
		clone = node.cloneNode(true); 
		clone.id = ''; 
		hs.clones[id] = clone; 
		return node; 
	} else { 
		return clone.cloneNode(true); 
	} 
}, 
 
discardElement : function(d) { 
	if (d) hs.garbageBin.appendChild(d); 
	hs.garbageBin.innerHTML = ''; 
}, 
transit : function (adj, exp) { 
	var last = exp || hs.getExpander(); 
	exp = last; 
	if (hs.upcoming) return false; 
	else hs.last = last; 
	hs.removeEventListener(document, window.opera ? 'keypress' : 'keydown', hs.keyHandler); 
	try { 
		hs.upcoming = adj; 
		adj.onclick(); 
	} catch (e){ 
		hs.last = hs.upcoming = null; 
	} 
	try { 
		exp.close(); 
	} catch (e) {} 
	return false; 
}, 
 
previousOrNext : function (el, op) { 
	var exp = hs.getExpander(el); 
	if (exp) return hs.transit(exp.getAdjacentAnchor(op), exp); 
	else return false; 
}, 
 
previous : function (el) { 
	return hs.previousOrNext(el, -1); 
}, 
 
next : function (el) { 
	return hs.previousOrNext(el, 1); 
}, 
 
keyHandler : function(e) { 
	if (!e) e = window.event; 
	if (!e.target) e.target = e.srcElement; // ie 
	if (typeof e.target.form != 'undefined') return true; // form element has focus 
	var exp = hs.getExpander(); 
 
	var op = null; 
	switch (e.keyCode) { 
		case 70: // f 
			if (exp) exp.doFullExpand(); 
			return true; 
		case 32: // Space 
		case 34: // Page Down 
		case 39: // Arrow right 
		case 40: // Arrow down 
			op = 1; 
			break; 
		case 8:  // Backspace 
		case 33: // Page Up 
		case 37: // Arrow left 
		case 38: // Arrow up 
			op = -1; 
			break; 
		case 27: // Escape 
		case 13: // Enter 
			op = 0; 
	} 
	if (op !== null) { 
		hs.removeEventListener(document, window.opera ? 'keypress' : 'keydown', hs.keyHandler); 
		if (!hs.enableKeyListener) return true; 
 
		if (e.preventDefault) e.preventDefault(); 
    	else e.returnValue = false; 
    	if (exp) { 
			if (op == 0) { 
				exp.close(); 
			} else { 
				hs.previousOrNext(exp.key, op); 
			} 
			return false; 
		} 
	} 
	return true; 
}, 
 
 
registerOverlay : function (overlay) { 
	hs.push(hs.overlays, hs.extend(overlay, {hsId: 'hsId'+ hs.idCounter++} )); 
}, 
 
 
getWrapperKey : function (element, expOnly) { 
	var el, re = /^highslide-wrapper-([0-9]+)$/; 
	// 1. look in open expanders 
	el = element; 
	while (el.parentNode)	{ 
		if (el.id && re.test(el.id)) return el.id.replace(re, "$1"); 
		el = el.parentNode; 
	} 
	// 2. look in thumbnail 
	if (!expOnly) { 
		el = element; 
		while (el.parentNode)	{ 
			if (el.tagName && hs.isHsAnchor(el)) { 
				for (var key = 0; key < hs.expanders.length; key++) { 
					var exp = hs.expanders[key]; 
					if (exp && exp.a == el) return key; 
				} 
			} 
			el = el.parentNode; 
		} 
	} 
	return null; 
}, 
 
getExpander : function (el, expOnly) { 
	if (typeof el == 'undefined') return hs.expanders[hs.focusKey] || null; 
	if (typeof el == 'number') return hs.expanders[el] || null; 
	if (typeof el == 'string') el = hs.$(el); 
	return hs.expanders[hs.getWrapperKey(el, expOnly)] || null; 
}, 
 
isHsAnchor : function (a) { 
	return (a.onclick && a.onclick.toString().replace(/\s/g, ' ').match(/hs.(htmlE|e)xpand/)); 
}, 
 
reOrder : function () { 
	for (var i = 0; i < hs.expanders.length; i++) 
		if (hs.expanders[i] && hs.expanders[i].isExpanded) hs.focusTopmost(); 
}, 
 
mouseClickHandler : function(e) 
{ 
	if (!e) e = window.event; 
	if (e.button > 1) return true; 
	if (!e.target) e.target = e.srcElement; 
 
	var el = e.target; 
	while (el.parentNode 
		&& !(/highslide-(image|move|html|resize)/.test(el.className))) 
	{ 
		el = el.parentNode; 
	} 
	var exp = hs.getExpander(el); 
	if (exp && (exp.isClosing || !exp.isExpanded)) return true; 
 
	if (exp && e.type == 'mousedown') { 
		if (e.target.form) return true; 
		var match = el.className.match(/highslide-(image|move|resize)/); 
		if (match) { 
			hs.dragArgs = { 
				exp: exp , 
				type: match[1], 
				left: exp.x.pos, 
				width: exp.x.size, 
				top: exp.y.pos, 
				height: exp.y.size, 
				clickX: e.clientX, 
				clickY: e.clientY 
			}; 
 
 
			hs.addEventListener(document, 'mousemove', hs.dragHandler); 
			if (e.preventDefault) e.preventDefault(); // FF 
 
			if (/highslide-(image|html)-blur/.test(exp.content.className)) { 
				exp.focus(); 
				hs.hasFocused = true; 
			} 
			return false; 
		} 
	} else if (e.type == 'mouseup') { 
 
		hs.removeEventListener(document, 'mousemove', hs.dragHandler); 
 
		if (hs.dragArgs) { 
			if (hs.styleRestoreCursor && hs.dragArgs.type == 'image') 
				hs.dragArgs.exp.content.style.cursor = hs.styleRestoreCursor; 
			var hasDragged = hs.dragArgs.hasDragged; 
 
			if (!hasDragged &&!hs.hasFocused && !/(move|resize)/.test(hs.dragArgs.type)) { 
				exp.close(); 
			} 
			else if (hasDragged || (!hasDragged && hs.hasHtmlExpanders)) { 
				hs.dragArgs.exp.doShowHide('hidden'); 
			} 
			hs.hasFocused = false; 
			hs.dragArgs = null; 
 
		} else if (/highslide-image-blur/.test(el.className)) { 
			el.style.cursor = hs.styleRestoreCursor; 
		} 
	} 
	return false; 
}, 
 
dragHandler : function(e) 
{ 
	if (!hs.dragArgs) return true; 
	if (!e) e = window.event; 
	var a = hs.dragArgs, exp = a.exp; 
 
	a.dX = e.clientX - a.clickX; 
	a.dY = e.clientY - a.clickY; 
 
	var distance = Math.sqrt(Math.pow(a.dX, 2) + Math.pow(a.dY, 2)); 
	if (!a.hasDragged) a.hasDragged = (a.type != 'image' && distance > 0) 
		|| (distance > (hs.dragSensitivity || 5)); 
 
	if (a.hasDragged && e.clientX > 5 && e.clientY > 5) { 
 
		if (a.type == 'resize') exp.resize(a); 
		else { 
			exp.moveTo(a.left + a.dX, a.top + a.dY); 
			if (a.type == 'image') exp.content.style.cursor = 'move'; 
		} 
	} 
	return false; 
}, 
 
wrapperMouseHandler : function (e) { 
	try { 
		if (!e) e = window.event; 
		var over = /mouseover/i.test(e.type); 
		if (!e.target) e.target = e.srcElement; // ie 
		if (hs.ie) e.relatedTarget = 
			over ? e.fromElement : e.toElement; // ie 
		var exp = hs.getExpander(e.target); 
		if (!exp.isExpanded) return; 
		if (!exp || !e.relatedTarget || hs.getExpander(e.relatedTarget, true) == exp 
			|| hs.dragArgs) return; 
		for (var i = 0; i < exp.overlays.length; i++) (function() { 
			var o = hs.$('hsId'+ exp.overlays[i]); 
			if (o && o.hideOnMouseOut) { 
				if (over) hs.setStyles(o, {visibility: 'visible', display: ''}); 
				hs.animate(o, {opacity: over ? o.opacity : 0}, o.dur); 
			} 
		})(); 
	} catch (e) {} 
}, 
addEventListener : function (el, event, func) { 
	if (el == document && event == 'ready') { 
		hs.push(hs.onReady, func); 
	} 
	try { 
		el.addEventListener(event, func, false); 
	} catch (e) { 
		try { 
			el.detachEvent('on'+ event, func); 
			el.attachEvent('on'+ event, func); 
		} catch (e) { 
			el['on'+ event] = func; 
		} 
	} 
}, 
 
removeEventListener : function (el, event, func) { 
	try { 
		el.removeEventListener(event, func, false); 
	} catch (e) { 
		try { 
			el.detachEvent('on'+ event, func); 
		} catch (e) { 
			el['on'+ event] = null; 
		} 
	} 
}, 
 
preloadFullImage : function (i) { 
	if (hs.continuePreloading && hs.preloadTheseImages[i] && hs.preloadTheseImages[i] != 'undefined') { 
		var img = document.createElement('img'); 
		img.onload = function() { 
			img = null; 
			hs.preloadFullImage(i + 1); 
		}; 
		img.src = hs.preloadTheseImages[i]; 
	} 
}, 
preloadImages : function (number) { 
	if (number && typeof number != 'object') hs.numberOfImagesToPreload = number; 
 
	var arr = hs.getAnchors(); 
	for (var i = 0; i < arr.images.length && i < hs.numberOfImagesToPreload; i++) { 
		hs.push(hs.preloadTheseImages, hs.getSrc(arr.images[i])); 
	} 
 
	// preload outlines 
	if (hs.outlineType)	new hs.Outline(hs.outlineType, function () {hs.preloadFullImage(0)} ); 
	else 
 
	hs.preloadFullImage(0); 
 
	// preload cursor 
	if (hs.restoreCursor) var cur = hs.createElement('img', {src: hs.graphicsDir + hs.restoreCursor}); 
}, 
 
 
init : function () { 
	if (!hs.container) { 
 
		hs.getPageSize(); 
		hs.ieLt7 = hs.ie && hs.uaVersion < 7; 
		for (var x in hs.langDefaults) { 
			if (typeof hs[x] != 'undefined') hs.lang[x] = hs[x]; 
			else if (typeof hs.lang[x] == 'undefined' && typeof hs.langDefaults[x] != 'undefined') 
				hs.lang[x] = hs.langDefaults[x]; 
		} 
 
		hs.container = hs.createElement('div', { 
				className: 'highslide-container' 
			}, { 
				position: 'absolute', 
				left: 0, 
				top: 0, 
				width: '100%', 
				zIndex: hs.zIndexCounter, 
				direction: 'ltr' 
			}, 
			document.body, 
			true 
		); 
		hs.loading = hs.createElement('a', { 
				className: 'highslide-loading', 
				title: hs.lang.loadingTitle, 
				innerHTML: hs.lang.loadingText, 
				href: 'javascript:;' 
			}, { 
				position: 'absolute', 
				top: '-9999px', 
				opacity: hs.loadingOpacity, 
				zIndex: 1 
			}, hs.container 
		); 
		hs.garbageBin = hs.createElement('div', null, {display: 'none'}, hs.container); 
 
		// http://www.robertpenner.com/easing/ 
		Math.linearTween = function (t, b, c, d) { 
			return c*t/d + b; 
		}; 
		Math.easeInQuad = function (t, b, c, d) { 
			return c*(t/=d)*t + b; 
		}; 
 
		hs.hideSelects = hs.ieLt7; 
		hs.hideIframes = ((window.opera && hs.uaVersion < 9) || navigator.vendor == 'KDE' 
			|| (hs.ie && hs.uaVersion < 5.5)); 
	} 
}, 
ready : function() { 
	if (hs.isReady) return; 
	hs.isReady = true; 
	for (var i = 0; i < hs.onReady.length; i++) hs.onReady[i](); 
}, 
 
updateAnchors : function() { 
	var el, els, all = [], images = [],groups = {}, re; 
 
	for (var i = 0; i < hs.openerTagNames.length; i++) { 
		els = document.getElementsByTagName(hs.openerTagNames[i]); 
		for (var j = 0; j < els.length; j++) { 
			el = els[j]; 
			re = hs.isHsAnchor(el); 
			if (re) { 
				hs.push(all, el); 
				if (re[0] == 'hs.expand') hs.push(images, el); 
				var g = hs.getParam(el, 'slideshowGroup') || 'none'; 
				if (!groups[g]) groups[g] = []; 
				hs.push(groups[g], el); 
			} 
		} 
	} 
	hs.anchors = {all: all, groups: groups, images: images}; 
	return hs.anchors; 
 
}, 
 
getAnchors : function() { 
	return hs.anchors || hs.updateAnchors(); 
}, 
 
 
close : function(el) { 
	var exp = hs.getExpander(el); 
	if (exp) exp.close(); 
	return false; 
} 
}; // end hs object 
hs.fx = function( elem, options, prop ){ 
	this.options = options; 
	this.elem = elem; 
	this.prop = prop; 
 
	if (!options.orig) options.orig = {}; 
}; 
hs.fx.prototype = { 
	update: function(){ 
		(hs.fx.step[this.prop] || hs.fx.step._default)(this); 
 
		if (this.options.step) 
			this.options.step.call(this.elem, this.now, this); 
 
	}, 
	custom: function(from, to, unit){ 
		this.startTime = (new Date()).getTime(); 
		this.start = from; 
		this.end = to; 
		this.unit = unit;// || this.unit || "px"; 
		this.now = this.start; 
		this.pos = this.state = 0; 
 
		var self = this; 
		function t(gotoEnd){ 
			return self.step(gotoEnd); 
		} 
 
		t.elem = this.elem; 
 
		if ( t() && hs.timers.push(t) == 1 ) { 
			hs.timerId = setInterval(function(){ 
				var timers = hs.timers; 
 
				for ( var i = 0; i < timers.length; i++ ) 
					if ( !timers[i]() ) 
						timers.splice(i--, 1); 
 
				if ( !timers.length ) { 
					clearInterval(hs.timerId); 
				} 
			}, 13); 
		} 
	}, 
	step: function(gotoEnd){ 
		var t = (new Date()).getTime(); 
		if ( gotoEnd || t >= this.options.duration + this.startTime ) { 
			this.now = this.end; 
			this.pos = this.state = 1; 
			this.update(); 
 
			this.options.curAnim[ this.prop ] = true; 
 
			var done = true; 
			for ( var i in this.options.curAnim ) 
				if ( this.options.curAnim[i] !== true ) 
					done = false; 
 
			if ( done ) { 
				if (this.options.complete) this.options.complete.call(this.elem); 
			} 
			return false; 
		} else { 
			var n = t - this.startTime; 
			this.state = n / this.options.duration; 
			this.pos = this.options.easing(n, 0, 1, this.options.duration); 
			this.now = this.start + ((this.end - this.start) * this.pos); 
			this.update(); 
		} 
		return true; 
	} 
 
}; 
 
hs.extend( hs.fx, { 
	step: { 
 
		opacity: function(fx){ 
			hs.setStyles(fx.elem, {opacity: fx.now}); 
		}, 
 
		_default: function(fx){ 
			try { 
				if ( fx.elem.style && fx.elem.style[ fx.prop ] != null ) 
					fx.elem.style[ fx.prop ] = fx.now + fx.unit; 
				else 
					fx.elem[ fx.prop ] = fx.now; 
			} catch (e) {} 
		} 
	} 
}); 
 
hs.Outline =  function (outlineType, onLoad) { 
	this.onLoad = onLoad; 
	this.outlineType = outlineType; 
	var v = hs.uaVersion, tr; 
 
	this.hasAlphaImageLoader = hs.ie && v >= 5.5 && v < 7; 
	if (!outlineType) { 
		if (onLoad) onLoad(); 
		return; 
	} 
 
	hs.init(); 
	this.table = hs.createElement( 
		'table', { 
			cellSpacing: 0 
		}, { 
			visibility: 'hidden', 
			position: 'absolute', 
			borderCollapse: 'collapse', 
			width: 0 
		}, 
		hs.container, 
		true 
	); 
	var tbody = hs.createElement('tbody', null, null, this.table, 1); 
 
	this.td = []; 
	for (var i = 0; i <= 8; i++) { 
		if (i % 3 == 0) tr = hs.createElement('tr', null, {height: 'auto'}, tbody, true); 
		this.td[i] = hs.createElement('td', null, null, tr, true); 
		var style = i != 4 ? {lineHeight: 0, fontSize: 0} : {position : 'relative'}; 
		hs.setStyles(this.td[i], style); 
	} 
	this.td[4].className = outlineType +' highslide-outline'; 
 
	this.preloadGraphic(); 
}; 
 
hs.Outline.prototype = { 
preloadGraphic : function () { 
	var src = hs.graphicsDir + (hs.outlinesDir || "outlines/")+ this.outlineType +".png"; 
 
	var appendTo = hs.safari && hs.uaVersion < 525 ? hs.container : null; 
	this.graphic = hs.createElement('img', null, {position: 'absolute', 
		top: '-9999px'}, appendTo, true); // for onload trigger 
 
	var pThis = this; 
	this.graphic.onload = function() {pThis.onGraphicLoad();}; 
 
	this.graphic.src = src; 
}, 
 
onGraphicLoad : function () { 
	var o = this.offset = this.graphic.width / 4, 
		pos = [[0,0],[0,-4],[-2,0],[0,-8],0,[-2,-8],[0,-2],[0,-6],[-2,-2]], 
		dim = {height: (2*o) +'px', width: (2*o) +'px'}; 
	for (var i = 0; i <= 8; i++) { 
		if (pos[i]) { 
			if (this.hasAlphaImageLoader) { 
				var w = (i == 1 || i == 7) ? '100%' : this.graphic.width +'px'; 
				var div = hs.createElement('div', null, {width: '100%', height: '100%', position: 'relative', overflow: 'hidden'}, this.td[i], true); 
				hs.createElement ('div', null, { 
						filter: "progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale, src='"+ this.graphic.src + "')", 
						position: 'absolute', 
						width: w, 
						height: this.graphic.height +'px', 
						left: (pos[i][0]*o)+'px', 
						top: (pos[i][1]*o)+'px' 
					}, 
				div, 
				true); 
			} else { 
				hs.setStyles(this.td[i], {background: 'url('+ this.graphic.src +') '+ (pos[i][0]*o)+'px '+(pos[i][1]*o)+'px'}); 
			} 
 
			if (window.opera && (i == 3 || i ==5)) 
				hs.createElement('div', null, dim, this.td[i], true); 
 
			hs.setStyles (this.td[i], dim); 
		} 
	} 
	this.graphic = null; 
	if (hs.pendingOutlines[this.outlineType]) hs.pendingOutlines[this.outlineType].destroy(); 
	hs.pendingOutlines[this.outlineType] = this; 
	if (this.onLoad) this.onLoad(); 
}, 
 
setPosition : function (pos, offset, vis, dur, easing) { 
	var exp = this.exp, 
		stl = exp.wrapper.style, 
		offset = offset || 0, 
		pos = pos || { 
			x: exp.x.pos + offset, 
			y: exp.y.pos + offset, 
			w: exp.x.get('wsize') - 2 * offset, 
			h: exp.y.get('wsize') - 2 * offset 
		}; 
	if (vis) this.table.style.visibility = (pos.h >= 4 * this.offset) 
		? 'visible' : 'hidden'; 
	hs.setStyles(this.table, { 
		left: (pos.x - this.offset) +'px', 
		top: (pos.y - this.offset) +'px', 
		width: (pos.w + 2 * this.offset) +'px' 
	}); 
 
	pos.w -= 2 * this.offset; 
	pos.h -= 2 * this.offset; 
	hs.setStyles (this.td[4], { 
		width: pos.w >= 0 ? pos.w +'px' : 0, 
		height: pos.h >= 0 ? pos.h +'px' : 0 
	}); 
	if (this.hasAlphaImageLoader) this.td[3].style.height 
		= this.td[5].style.height = this.td[4].style.height; 
 
}, 
 
destroy : function(hide) { 
	if (hide) this.table.style.visibility = 'hidden'; 
	else hs.discardElement(this.table); 
} 
}; 
 
hs.Dimension = function(exp, dim) { 
	this.exp = exp; 
	this.dim = dim; 
	this.ucwh = dim == 'x' ? 'Width' : 'Height'; 
	this.wh = this.ucwh.toLowerCase(); 
	this.uclt = dim == 'x' ? 'Left' : 'Top'; 
	this.lt = this.uclt.toLowerCase(); 
	this.ucrb = dim == 'x' ? 'Right' : 'Bottom'; 
	this.rb = this.ucrb.toLowerCase(); 
	this.p1 = this.p2 = 0; 
}; 
hs.Dimension.prototype = { 
get : function(key) { 
	switch (key) { 
		case 'loadingPos': 
			return this.tpos + this.tb + (this.t - hs.loading['offset'+ this.ucwh]) / 2; 
		case 'wsize': 
			return this.size + 2 * this.cb + this.p1 + this.p2; 
		case 'fitsize': 
			return this.clientSize - this.marginMin - this.marginMax; 
		case 'maxsize': 
			return this.get('fitsize') - 2 * this.cb - this.p1 - this.p2 ; 
		case 'opos': 
			return this.pos - (this.exp.outline ? this.exp.outline.offset : 0); 
		case 'osize': 
			return this.get('wsize') + (this.exp.outline ? 2*this.exp.outline.offset : 0); 
		case 'imgPad': 
			return this.imgSize ? Math.round((this.size - this.imgSize) / 2) : 0; 
 
	} 
}, 
calcBorders: function() { 
	// correct for borders 
	this.cb = (this.exp.content['offset'+ this.ucwh] - this.t) / 2; 
 
	this.marginMax = hs['margin'+ this.ucrb]; 
}, 
calcThumb: function() { 
	this.t = this.exp.el[this.wh] ? parseInt(this.exp.el[this.wh]) : 
		this.exp.el['offset'+ this.ucwh]; 
	this.tpos = this.exp.tpos[this.dim]; 
	this.tb = (this.exp.el['offset'+ this.ucwh] - this.t) / 2; 
	if (this.tpos == 0 || this.tpos == -1) { 
		this.tpos = (hs.page[this.wh] / 2) + hs.page['scroll'+ this.uclt]; 
	}; 
}, 
calcExpanded: function() { 
	var exp = this.exp; 
	this.justify = 'auto'; 
 
 
	// size and position 
	this.pos = this.tpos - this.cb + this.tb; 
 
	if (this.maxHeight && this.dim == 'x') 
		exp.maxWidth = Math.min(exp.maxWidth || this.full, exp.maxHeight * this.full / exp.y.full); 
 
	this.size = Math.min(this.full, exp['max'+ this.ucwh] || this.full); 
	this.minSize = exp.allowSizeReduction ? 
		Math.min(exp['min'+ this.ucwh], this.full) :this.full; 
	if (exp.isImage && exp.useBox)	{ 
		this.size = exp[this.wh]; 
		this.imgSize = this.full; 
	} 
	if (this.dim == 'x' && hs.padToMinWidth) this.minSize = exp.minWidth; 
	this.marginMin = hs['margin'+ this.uclt]; 
	this.scroll = hs.page['scroll'+ this.uclt]; 
	this.clientSize = hs.page[this.wh]; 
}, 
setSize: function(i) { 
	var exp = this.exp; 
	if (exp.isImage && (exp.useBox || hs.padToMinWidth)) { 
		this.imgSize = i; 
		this.size = Math.max(this.size, this.imgSize); 
		exp.content.style[this.lt] = this.get('imgPad')+'px'; 
	} else 
	this.size = i; 
 
	exp.content.style[this.wh] = i +'px'; 
	exp.wrapper.style[this.wh] = this.get('wsize') +'px'; 
	if (exp.outline) exp.outline.setPosition(); 
	if (this.dim == 'x' && exp.overlayBox) exp.sizeOverlayBox(true); 
}, 
setPos: function(i) { 
	this.pos = i; 
	this.exp.wrapper.style[this.lt] = i +'px'; 
 
	if (this.exp.outline) this.exp.outline.setPosition(); 
 
} 
}; 
 
hs.Expander = function(a, params, custom, contentType) { 
	if (document.readyState && hs.ie && !hs.isReady) { 
		hs.addEventListener(document, 'ready', function() { 
			new hs.Expander(a, params, custom, contentType); 
		}); 
		return; 
	} 
	this.a = a; 
	this.custom = custom; 
	this.contentType = contentType || 'image'; 
	this.isImage = !this.isHtml; 
 
	hs.continuePreloading = false; 
	this.overlays = []; 
	hs.init(); 
	var key = this.key = hs.expanders.length; 
	// override inline parameters 
	for (var i = 0; i < hs.overrides.length; i++) { 
		var name = hs.overrides[i]; 
		this[name] = params && typeof params[name] != 'undefined' ? 
			params[name] : hs[name]; 
	} 
	if (!this.src) this.src = a.href; 
 
	// get thumb 
	var el = (params && params.thumbnailId) ? hs.$(params.thumbnailId) : a; 
	el = this.thumb = el.getElementsByTagName('img')[0] || el; 
	this.thumbsUserSetId = el.id || a.id; 
 
	// check if already open 
	for (var i = 0; i < hs.expanders.length; i++) { 
		if (hs.expanders[i] && hs.expanders[i].a == a) { 
			hs.expanders[i].focus(); 
			return false; 
		} 
	} 
 
	// cancel other 
	if (!hs.allowSimultaneousLoading) for (var i = 0; i < hs.expanders.length; i++) { 
		if (hs.expanders[i] && hs.expanders[i].thumb != el && !hs.expanders[i].onLoadStarted) { 
			hs.expanders[i].cancelLoading(); 
		} 
	} 
	hs.expanders[key] = this; 
	if (!hs.allowMultipleInstances && !hs.upcoming) { 
		if (hs.expanders[key-1]) hs.expanders[key-1].close(); 
		if (typeof hs.focusKey != 'undefined' && hs.expanders[hs.focusKey]) 
			hs.expanders[hs.focusKey].close(); 
	} 
 
	// initiate metrics 
	this.el = el; 
	this.tpos = this.pageOrigin || hs.getPosition(el); 
	hs.getPageSize(); 
	var x = this.x = new hs.Dimension(this, 'x'); 
	x.calcThumb(); 
	var y = this.y = new hs.Dimension(this, 'y'); 
	y.calcThumb(); 
	this.wrapper = hs.createElement( 
		'div', { 
			id: 'highslide-wrapper-'+ this.key, 
			className: 'highslide-wrapper '+ this.wrapperClassName 
		}, { 
			visibility: 'hidden', 
			position: 'absolute', 
			zIndex: hs.zIndexCounter += 2 
		}, null, true ); 
 
	this.wrapper.onmouseover = this.wrapper.onmouseout = hs.wrapperMouseHandler; 
	if (this.contentType == 'image' && this.outlineWhileAnimating == 2) 
		this.outlineWhileAnimating = 0; 
 
	// get the outline 
	if (!this.outlineType) { 
		this[this.contentType +'Create'](); 
 
	} else if (hs.pendingOutlines[this.outlineType]) { 
		this.connectOutline(); 
		this[this.contentType +'Create'](); 
 
	} else { 
		this.showLoading(); 
		var exp = this; 
		new hs.Outline(this.outlineType, 
			function () { 
				exp.connectOutline(); 
				exp[exp.contentType +'Create'](); 
			} 
		); 
	} 
	return true; 
}; 
 
hs.Expander.prototype = { 
error : function(e) { 
	if (hs.debug) alert ('Line '+ e.lineNumber +': '+ e.message); 
	else window.location.href = this.src; 
}, 
 
connectOutline : function() { 
	var outline = this.outline = hs.pendingOutlines[this.outlineType]; 
	outline.exp = this; 
	outline.table.style.zIndex = this.wrapper.style.zIndex - 1; 
	hs.pendingOutlines[this.outlineType] = null; 
}, 
 
showLoading : function() { 
	if (this.onLoadStarted || this.loading) return; 
 
	this.loading = hs.loading; 
	var exp = this; 
	this.loading.onclick = function() { 
		exp.cancelLoading(); 
	}; 
	var exp = this, 
		l = this.x.get('loadingPos') +'px', 
		t = this.y.get('loadingPos') +'px'; 
	setTimeout(function () { 
		if (exp.loading) hs.setStyles(exp.loading, {left: l, top: t, zIndex: hs.zIndexCounter++})} 
	, 100); 
}, 
 
imageCreate : function() { 
	var exp = this; 
 
	var img = document.createElement('img'); 
    this.content = img; 
    img.onload = function () { 
    	if (hs.expanders[exp.key]) exp.contentLoaded(); 
	}; 
    if (hs.blockRightClick) img.oncontextmenu = function() {return false;}; 
    img.className = 'highslide-image'; 
    hs.setStyles(img, { 
    	visibility: 'hidden', 
    	display: 'block', 
    	position: 'absolute', 
		maxWidth: '9999px', 
		zIndex: 3 
	}); 
    img.title = hs.lang.restoreTitle; 
	if (hs.safari && hs.uaVersion < 525) hs.container.appendChild(img); 
    if (hs.ie && hs.flushImgSize) img.src = null; 
	img.src = this.src; 
 
	this.showLoading(); 
}, 
 
contentLoaded : function() { 
	try { 
		if (!this.content) return; 
		this.content.onload = null; 
		if (this.onLoadStarted) return; 
		else this.onLoadStarted = true; 
 
		var x = this.x, y = this.y; 
 
		if (this.loading) { 
			hs.setStyles(this.loading, {top: '-9999px'}); 
			this.loading = null; 
		} 
			x.full = this.content.width; 
			y.full = this.content.height; 
 
			hs.setStyles(this.content, { 
				width: x.t +'px', 
				height: y.t +'px' 
			}); 
			this.wrapper.appendChild(this.content); 
			hs.container.appendChild(this.wrapper); 
 
		x.calcBorders(); 
		y.calcBorders(); 
 
		hs.setStyles (this.wrapper, { 
			left: (x.tpos + x.tb - x.cb) +'px', 
			top: (y.tpos + x.tb - y.cb) +'px' 
		}); 
		this.getOverlays(); 
 
		var ratio = x.full / y.full; 
		x.calcExpanded(); 
		this.justify(x); 
 
		y.calcExpanded(); 
		this.justify(y); 
		if (this.overlayBox) this.sizeOverlayBox(0, 1); 
 
 
		if (this.allowSizeReduction) { 
				this.correctRatio(ratio); 
			if (this.isImage && this.x.full > (this.x.imgSize || this.x.size)) { 
				this.createFullExpand(); 
				if (this.overlays.length == 1) this.sizeOverlayBox(); 
			} 
		} 
		this.show(); 
 
	} catch (e) { 
		this.error(e); 
	} 
}, 
 
justify : function (p, moveOnly) { 
	var tgtArr, tgt = p.target, dim = p == this.x ? 'x' : 'y'; 
 
		var hasMovedMin = false; 
 
		var allowReduce = p.exp.allowSizeReduction; 
			p.pos = Math.round(p.pos - ((p.get('wsize') - p.t) / 2)); 
		if (p.pos < p.scroll + p.marginMin) { 
			p.pos = p.scroll + p.marginMin; 
			hasMovedMin = true; 
		} 
		if (!moveOnly && p.size < p.minSize) { 
			p.size = p.minSize; 
			allowReduce = false; 
		} 
		if (p.pos + p.get('wsize') > p.scroll + p.clientSize - p.marginMax) { 
			if (!moveOnly && hasMovedMin && allowReduce) { 
				p.size = Math.min(p.size, p.get(dim == 'y' ? 'fitsize' : 'maxsize')); 
			} else if (p.get('wsize') < p.get('fitsize')) { 
				p.pos = p.scroll + p.clientSize - p.marginMax - p.get('wsize'); 
			} else { // image larger than viewport 
				p.pos = p.scroll + p.marginMin; 
				if (!moveOnly && allowReduce) p.size = p.get(dim == 'y' ? 'fitsize' : 'maxsize'); 
			} 
		} 
 
		if (!moveOnly && p.size < p.minSize) { 
			p.size = p.minSize; 
			allowReduce = false; 
		} 
 
 
 
	if (p.pos < p.marginMin) { 
		var tmpMin = p.pos; 
		p.pos = p.marginMin; 
 
		if (allowReduce && !moveOnly) p.size = p.size - (p.pos - tmpMin); 
 
	} 
}, 
 
correctRatio : function(ratio) { 
	var x = this.x, 
		y = this.y, 
		changed = false, 
		xSize = Math.min(x.full, x.size), 
		ySize = Math.min(y.full, y.size), 
		useBox = (this.useBox || hs.padToMinWidth); 
 
	if (xSize / ySize > ratio) { // width greater 
		xSize = ySize * ratio; 
		if (xSize < x.minSize) { // below minWidth 
			xSize = x.minSize; 
			ySize = xSize / ratio; 
		} 
		changed = true; 
 
	} else if (xSize / ySize < ratio) { // height greater 
		ySize = xSize / ratio; 
		changed = true; 
	} 
 
	if (hs.padToMinWidth && x.full < x.minSize) { 
		x.imgSize = x.full; 
		y.size = y.imgSize = y.full; 
	} else if (this.useBox) { 
		x.imgSize = xSize; 
		y.imgSize = ySize; 
	} else { 
		x.size = xSize; 
		y.size = ySize; 
	} 
	changed = this.fitOverlayBox(this.useBox ? null : ratio, changed); 
	if (useBox && y.size < y.imgSize) { 
		y.imgSize = y.size; 
		x.imgSize = y.size * ratio; 
	} 
	if (changed || useBox) { 
		x.pos = x.tpos - x.cb + x.tb; 
		x.minSize = x.size; 
		this.justify(x, true); 
 
		y.pos = y.tpos - y.cb + y.tb; 
		y.minSize = y.size; 
		this.justify(y, true); 
		if (this.overlayBox) this.sizeOverlayBox(); 
	} 
 
 
}, 
fitOverlayBox : function(ratio, changed) { 
	var x = this.x, y = this.y; 
	if (this.overlayBox) { 
		while (y.size > this.minHeight && x.size > this.minWidth 
				&&  y.get('wsize') > y.get('fitsize')) { 
			y.size -= 10; 
			if (ratio) x.size = y.size * ratio; 
			this.sizeOverlayBox(0, 1); 
			changed = true; 
		} 
	} 
	return changed; 
}, 
 
show : function () { 
	var x = this.x, y = this.y; 
	this.doShowHide('hidden'); 
 
	// Apply size change 
	this.changeSize( 
		1, { 
			wrapper: { 
				width : x.get('wsize'), 
				height : y.get('wsize'), 
				left: x.pos, 
				top: y.pos 
			}, 
			content: { 
				left: x.p1 + x.get('imgPad'), 
				top: y.p1 + y.get('imgPad'), 
				width:x.imgSize ||x.size, 
				height:y.imgSize ||y.size 
			} 
		}, 
		hs.expandDuration 
	); 
}, 
 
changeSize : function(up, to, dur) { 
 
	if (this.outline && !this.outlineWhileAnimating) { 
		if (up) this.outline.setPosition(); 
		else this.outline.destroy(); 
	} 
 
 
	if (!up) this.destroyOverlays(); 
 
	var exp = this, 
		x = exp.x, 
		y = exp.y, 
		easing = this.easing; 
	if (!up) easing = this.easingClose || easing; 
	var after = up ? 
		function() { 
 
			if (exp.outline) exp.outline.table.style.visibility = "visible"; 
			setTimeout(function() { 
				exp.afterExpand(); 
			}, 50); 
		} : 
		function() { 
			exp.afterClose(); 
		}; 
	if (up) hs.setStyles( this.wrapper, { 
		width: x.t +'px', 
		height: y.t +'px' 
	}); 
	if (this.fadeInOut) { 
		hs.setStyles(this.wrapper, {opacity: up ? 0 : 1}); 
		hs.extend(to.wrapper, {opacity: up}); 
	} 
	hs.animate( this.wrapper, to.wrapper, { 
		duration: dur, 
		easing: easing, 
		step: function(val, args) { 
			if (exp.outline && exp.outlineWhileAnimating && args.prop == 'top') { 
				var fac = up ? args.pos : 1 - args.pos; 
				var pos = { 
					w: x.t + (x.get('wsize') - x.t) * fac, 
					h: y.t + (y.get('wsize') - y.t) * fac, 
					x: x.tpos + (x.pos - x.tpos) * fac, 
					y: y.tpos + (y.pos - y.tpos) * fac 
				}; 
				exp.outline.setPosition(pos, 0, 1); 
			} 
		} 
	}); 
	hs.animate( this.content, to.content, dur, easing, after); 
	if (up) { 
		this.wrapper.style.visibility = 'visible'; 
		this.content.style.visibility = 'visible'; 
		this.a.className += ' highslide-active-anchor'; 
	} 
}, 
 
 
 
 
afterExpand : function() { 
	this.isExpanded = true; 
	this.focus(); 
	if (hs.upcoming && hs.upcoming == this.a) hs.upcoming = null; 
	this.prepareNextOutline(); 
	var p = hs.page, mX = hs.mouse.x + p.scrollLeft, mY = hs.mouse.y + p.scrollTop; 
	this.mouseIsOver = this.x.pos < mX && mX < this.x.pos + this.x.get('wsize') 
		&& this.y.pos < mY && mY < this.y.pos + this.y.get('wsize'); 
	if (this.overlayBox) this.showOverlays(); 
 
}, 
 
 
prepareNextOutline : function() { 
	var key = this.key; 
	var outlineType = this.outlineType; 
	new hs.Outline(outlineType, 
		function () {try {hs.expanders[key].preloadNext();} catch (e) {}}); 
}, 
 
 
preloadNext : function() { 
	var next = this.getAdjacentAnchor(1); 
	if (next && next.onclick.toString().match(/hs\.expand/)) 
		var img = hs.createElement('img', {src: hs.getSrc(next)}); 
}, 
 
 
getAdjacentAnchor : function(op) { 
	var current = this.getAnchorIndex(), as = hs.anchors.groups[this.slideshowGroup || 'none']; 
	return (as && as[current + op]) || null; 
}, 
 
getAnchorIndex : function() { 
	var arr = hs.getAnchors().groups[this.slideshowGroup || 'none']; 
	if (arr) for (var i = 0; i < arr.length; i++) { 
		if (arr[i] == this.a) return i; 
	} 
	return null; 
}, 
 
 
cancelLoading : function() { 
	hs.discardElement (this.wrapper); 
	hs.expanders[this.key] = null; 
	if (this.loading) hs.loading.style.left = '-9999px'; 
}, 
 
writeCredits : function () { 
	this.credits = hs.createElement('a', { 
		href: hs.creditsHref, 
		target: hs.creditsTarget, 
		className: 'highslide-credits', 
		innerHTML: hs.lang.creditsText, 
		title: hs.lang.creditsTitle 
	}); 
	this.createOverlay({ 
		overlayId: this.credits, 
		position: this.creditsPosition || 'top left' 
	}); 
}, 
 
getInline : function(types, addOverlay) { 
	for (var i = 0; i < types.length; i++) { 
		var type = types[i], s = null; 
		if (!this[type +'Id'] && this.thumbsUserSetId) 
			this[type +'Id'] = type +'-for-'+ this.thumbsUserSetId; 
		if (this[type +'Id']) this[type] = hs.getNode(this[type +'Id']); 
		if (!this[type] && !this[type +'Text'] && this[type +'Eval']) try { 
			s = eval(this[type +'Eval']); 
		} catch (e) {} 
		if (!this[type] && this[type +'Text']) { 
			s = this[type +'Text']; 
		} 
		if (!this[type] && !s) { 
			this[type] = hs.getNode(this.a['_'+ type + 'Id']); 
			if (!this[type]) { 
				var next = this.a.nextSibling; 
				while (next && !hs.isHsAnchor(next)) { 
					if ((new RegExp('highslide-'+ type)).test(next.className || null)) { 
						if (!next.id) this.a['_'+ type + 'Id'] = next.id = 'hsId'+ hs.idCounter++; 
						this[type] = hs.getNode(next.id); 
						break; 
					} 
					next = next.nextSibling; 
				} 
			} 
		} 
 
		if (!this[type] && s) this[type] = hs.createElement('div', 
				{className: 'highslide-'+ type, innerHTML: s} ); 
 
		if (addOverlay && this[type]) { 
			var o = {position: (type == 'heading') ? 'above' : 'below'}; 
			for (var x in this[type+'Overlay']) o[x] = this[type+'Overlay'][x]; 
			o.overlayId = this[type]; 
			this.createOverlay(o); 
		} 
	} 
}, 
 
 
// on end move and resize 
doShowHide : function(visibility) { 
	if (hs.hideSelects) this.showHideElements('SELECT', visibility); 
	if (hs.hideIframes) this.showHideElements('IFRAME', visibility); 
	if (hs.geckoMac) this.showHideElements('*', visibility); 
}, 
showHideElements : function (tagName, visibility) { 
	var els = document.getElementsByTagName(tagName); 
	var prop = tagName == '*' ? 'overflow' : 'visibility'; 
	for (var i = 0; i < els.length; i++) { 
		if (prop == 'visibility' || (document.defaultView.getComputedStyle( 
				els[i], "").getPropertyValue('overflow') == 'auto' 
				|| els[i].getAttribute('hidden-by') != null)) { 
			var hiddenBy = els[i].getAttribute('hidden-by'); 
			if (visibility == 'visible' && hiddenBy) { 
				hiddenBy = hiddenBy.replace('['+ this.key +']', ''); 
				els[i].setAttribute('hidden-by', hiddenBy); 
				if (!hiddenBy) els[i].style[prop] = els[i].origProp; 
			} else if (visibility == 'hidden') { // hide if behind 
				var elPos = hs.getPosition(els[i]); 
				elPos.w = els[i].offsetWidth; 
				elPos.h = els[i].offsetHeight; 
 
 
					var clearsX = (elPos.x + elPos.w < this.x.get('opos') 
						|| elPos.x > this.x.get('opos') + this.x.get('osize')); 
					var clearsY = (elPos.y + elPos.h < this.y.get('opos') 
						|| elPos.y > this.y.get('opos') + this.y.get('osize')); 
				var wrapperKey = hs.getWrapperKey(els[i]); 
				if (!clearsX && !clearsY && wrapperKey != this.key) { // element falls behind image 
					if (!hiddenBy) { 
						els[i].setAttribute('hidden-by', '['+ this.key +']'); 
						els[i].origProp = els[i].style[prop]; 
						els[i].style[prop] = 'hidden'; 
 
					} else if (hiddenBy.indexOf('['+ this.key +']') == -1) { 
						els[i].setAttribute('hidden-by', hiddenBy + '['+ this.key +']'); 
					} 
				} else if ((hiddenBy == '['+ this.key +']' || hs.focusKey == wrapperKey) 
						&& wrapperKey != this.key) { // on move 
					els[i].setAttribute('hidden-by', ''); 
					els[i].style[prop] = els[i].origProp || ''; 
				} else if (hiddenBy && hiddenBy.indexOf('['+ this.key +']') > -1) { 
					els[i].setAttribute('hidden-by', hiddenBy.replace('['+ this.key +']', '')); 
				} 
 
			} 
		} 
	} 
}, 
 
focus : function() { 
	this.wrapper.style.zIndex = hs.zIndexCounter += 2; 
	// blur others 
	for (var i = 0; i < hs.expanders.length; i++) { 
		if (hs.expanders[i] && i == hs.focusKey) { 
			var blurExp = hs.expanders[i]; 
			blurExp.content.className += ' highslide-'+ blurExp.contentType +'-blur'; 
				blurExp.content.style.cursor = hs.ie ? 'hand' : 'pointer'; 
				blurExp.content.title = hs.lang.focusTitle; 
		} 
	} 
 
	// focus this 
	if (this.outline) this.outline.table.style.zIndex 
		= this.wrapper.style.zIndex - 1; 
	this.content.className = 'highslide-'+ this.contentType; 
		this.content.title = hs.lang.restoreTitle; 
 
		if (hs.restoreCursor) { 
			hs.styleRestoreCursor = window.opera ? 'pointer' : 'url('+ hs.graphicsDir + hs.restoreCursor +'), pointer'; 
			if (hs.ie && hs.uaVersion < 6) hs.styleRestoreCursor = 'hand'; 
			this.content.style.cursor = hs.styleRestoreCursor; 
		} 
 
	hs.focusKey = this.key; 
	hs.addEventListener(document, window.opera ? 'keypress' : 'keydown', hs.keyHandler); 
}, 
moveTo: function(x, y) { 
	this.x.setPos(x); 
	this.y.setPos(y); 
}, 
resize : function (e) { 
	var w, h, r = e.width / e.height; 
	w = Math.max(e.width + e.dX, Math.min(this.minWidth, this.x.full)); 
	if (this.isImage && Math.abs(w - this.x.full) < 12) w = this.x.full; 
	h = w / r; 
	if (h < Math.min(this.minHeight, this.y.full)) { 
		h = Math.min(this.minHeight, this.y.full); 
		if (this.isImage) w = h * r; 
	} 
	this.resizeTo(w, h); 
}, 
resizeTo: function(w, h) { 
	this.y.setSize(h); 
	this.x.setSize(w); 
	this.wrapper.style.height = this.y.get('wsize') +'px'; 
}, 
 
close : function() { 
	if (this.isClosing || !this.isExpanded) return; 
	this.isClosing = true; 
 
	hs.removeEventListener(document, window.opera ? 'keypress' : 'keydown', hs.keyHandler); 
 
	try { 
		this.content.style.cursor = 'default'; 
		this.changeSize( 
			0, { 
				wrapper: { 
					width : this.x.t, 
					height : this.y.t, 
					left: this.x.tpos - this.x.cb + this.x.tb, 
					top: this.y.tpos - this.y.cb + this.y.tb 
				}, 
				content: { 
					left: 0, 
					top: 0, 
					width: this.x.t, 
					height: this.y.t 
				} 
			}, hs.restoreDuration 
		); 
	} catch (e) {this.afterClose();} 
}, 
 
createOverlay : function (o) { 
	var el = o.overlayId; 
	if (typeof el == 'string') el = hs.getNode(el); 
	if (o.html) el = hs.createElement('div', {innerHTML: o.html}); 
	if (!el || typeof el == 'string') return; 
	el.style.display = 'block'; 
	this.genOverlayBox(); 
	var width = o.width && /^[0-9]+(px|%)$/.test(o.width) ? o.width : 'auto'; 
	if (/^(left|right)panel$/.test(o.position) && !/^[0-9]+px$/.test(o.width)) width = '200px'; 
	var overlay = hs.createElement( 
		'div', { 
			id: 'hsId'+ hs.idCounter++, 
			hsId: o.hsId 
		}, { 
			position: 'absolute', 
			visibility: 'hidden', 
			width: width, 
			direction: hs.lang.cssDirection || '', 
			opacity: 0 
		},this.overlayBox, 
		true 
	); 
 
	overlay.appendChild(el); 
	hs.extend(overlay, { 
		opacity: 1, 
		offsetX: 0, 
		offsetY: 0, 
		dur: (o.fade === 0 || o.fade === false || (o.fade == 2 && hs.ie)) ? 0 : 250 
	}); 
	hs.extend(overlay, o); 
 
 
	if (this.gotOverlays) { 
		this.positionOverlay(overlay); 
		if (!overlay.hideOnMouseOut || this.mouseIsOver) 
			hs.animate(overlay, {opacity: overlay.opacity}, overlay.dur); 
	} 
	hs.push(this.overlays, hs.idCounter - 1); 
}, 
positionOverlay : function(overlay) { 
	var p = overlay.position || 'middle center', 
		offX = overlay.offsetX, 
		offY = overlay.offsetY; 
	if (overlay.parentNode != this.overlayBox) this.overlayBox.appendChild(overlay); 
	if (/left$/.test(p)) overlay.style.left = offX +'px'; 
 
	if (/center$/.test(p))	hs.setStyles (overlay, { 
		left: '50%', 
		marginLeft: (offX - Math.round(overlay.offsetWidth / 2)) +'px' 
	}); 
 
	if (/right$/.test(p)) overlay.style.right = - offX +'px'; 
 
	if (/^leftpanel$/.test(p)) { 
		hs.setStyles(overlay, { 
			right: '100%', 
			marginRight: this.x.cb +'px', 
			top: - this.y.cb +'px', 
			bottom: - this.y.cb +'px', 
			overflow: 'auto' 
		}); 
		this.x.p1 = overlay.offsetWidth; 
 
	} else if (/^rightpanel$/.test(p)) { 
		hs.setStyles(overlay, { 
			left: '100%', 
			marginLeft: this.x.cb +'px', 
			top: - this.y.cb +'px', 
			bottom: - this.y.cb +'px', 
			overflow: 'auto' 
		}); 
		this.x.p2 = overlay.offsetWidth; 
	} 
 
	if (/^top/.test(p)) overlay.style.top = offY +'px'; 
	if (/^middle/.test(p))	hs.setStyles (overlay, { 
		top: '50%', 
		marginTop: (offY - Math.round(overlay.offsetHeight / 2)) +'px' 
	}); 
	if (/^bottom/.test(p)) overlay.style.bottom = - offY +'px'; 
	if (/^above$/.test(p)) { 
		hs.setStyles(overlay, { 
			left: (- this.x.p1 - this.x.cb) +'px', 
			right: (- this.x.p2 - this.x.cb) +'px', 
			bottom: '100%', 
			marginBottom: this.y.cb +'px', 
			width: 'auto' 
		}); 
		this.y.p1 = overlay.offsetHeight; 
 
	} else if (/^below$/.test(p)) { 
		hs.setStyles(overlay, { 
			position: 'relative', 
			left: (- this.x.p1 - this.x.cb) +'px', 
			right: (- this.x.p2 - this.x.cb) +'px', 
			top: '100%', 
			marginTop: this.y.cb +'px', 
			width: 'auto' 
		}); 
		this.y.p2 = overlay.offsetHeight; 
		overlay.style.position = 'absolute'; 
	} 
}, 
 
getOverlays : function() { 
	this.getInline(['heading', 'caption'], true); 
	if (this.heading && this.dragByHeading) this.heading.className += ' highslide-move'; 
	if (hs.showCredits) this.writeCredits(); 
	for (var i = 0; i < hs.overlays.length; i++) { 
		var o = hs.overlays[i], tId = o.thumbnailId, sg = o.slideshowGroup; 
		if ((!tId && !sg) || (tId && tId == this.thumbsUserSetId) 
				|| (sg && sg === this.slideshowGroup)) { 
			this.createOverlay(o); 
		} 
	} 
	var os = []; 
	for (var i = 0; i < this.overlays.length; i++) { 
		var o = hs.$('hsId'+ this.overlays[i]); 
		if (/panel$/.test(o.position)) this.positionOverlay(o); 
		else hs.push(os, o); 
	} 
	for (var i = 0; i < os.length; i++) this.positionOverlay(os[i]); 
	this.gotOverlays = true; 
}, 
genOverlayBox : function() { 
	if (!this.overlayBox) this.overlayBox = hs.createElement ( 
		'div', { 
			className: this.wrapperClassName 
		}, { 
			position : 'absolute', 
			width: (this.x.size || (this.useBox ? this.width : null) 
				|| this.x.full) +'px', 
			height: (this.y.size || this.y.full) +'px', 
			visibility : 'hidden', 
			overflow : 'hidden', 
			zIndex : hs.ie ? 4 : 'auto' 
		}, 
		hs.container, 
		true 
	); 
}, 
sizeOverlayBox : function(doWrapper, doPanels) { 
	var overlayBox = this.overlayBox, 
		x = this.x, 
		y = this.y; 
	hs.setStyles( overlayBox, { 
		width: x.size +'px', 
		height: y.size +'px' 
	}); 
	if (doWrapper || doPanels) { 
		for (var i = 0; i < this.overlays.length; i++) { 
			var o = hs.$('hsId'+ this.overlays[i]); 
			var ie6 = (hs.ieLt7 || document.compatMode == 'BackCompat'); 
			if (o && /^(above|below)$/.test(o.position)) { 
				if (ie6) { 
					o.style.width = (overlayBox.offsetWidth + 2 * x.cb 
						+ x.p1 + x.p2) +'px'; 
				} 
				y[o.position == 'above' ? 'p1' : 'p2'] = o.offsetHeight; 
			} 
			if (o && ie6 && /^(left|right)panel$/.test(o.position)) { 
				o.style.height = (overlayBox.offsetHeight + 2* y.cb) +'px'; 
			} 
		} 
	} 
	if (doWrapper) { 
		hs.setStyles(this.content, { 
			top: y.p1 +'px' 
		}); 
		hs.setStyles(overlayBox, { 
			top: (y.p1 + y.cb) +'px' 
		}); 
	} 
}, 
 
showOverlays : function() { 
	var b = this.overlayBox; 
	b.className = ''; 
	hs.setStyles(b, { 
		top: (this.y.p1 + this.y.cb) +'px', 
		left: (this.x.p1 + this.x.cb) +'px', 
		overflow : 'visible' 
	}); 
	if (hs.safari) b.style.visibility = 'visible'; 
	this.wrapper.appendChild (b); 
	for (var i = 0; i < this.overlays.length; i++) { 
		var o = hs.$('hsId'+ this.overlays[i]); 
		o.style.zIndex = o.zIndex || 4; 
		if (!o.hideOnMouseOut || this.mouseIsOver) { 
			o.style.visibility = 'visible'; 
			hs.setStyles(o, {visibility: 'visible', display: ''}); 
			hs.animate(o, {opacity: o.opacity}, o.dur); 
		} 
	} 
}, 
 
destroyOverlays : function() { 
	if (!this.overlays.length) return; 
	hs.discardElement(this.overlayBox); 
}, 
 
 
 
createFullExpand : function () { 
	this.fullExpandLabel = hs.createElement( 
		'a', { 
			href: 'javascript:hs.expanders['+ this.key +'].doFullExpand();', 
			title: hs.lang.fullExpandTitle, 
			className: 'highslide-full-expand' 
		} 
	); 
 
	this.createOverlay({ 
		overlayId: this.fullExpandLabel, 
		position: hs.fullExpandPosition, 
		hideOnMouseOut: true, 
		opacity: hs.fullExpandOpacity 
	}); 
}, 
 
doFullExpand : function () { 
	try { 
		if (this.fullExpandLabel) hs.discardElement(this.fullExpandLabel); 
 
		this.focus(); 
		var xSize = this.x.size; 
		this.resizeTo(this.x.full, this.y.full); 
 
		var xpos = this.x.pos - (this.x.size - xSize) / 2; 
		if (xpos < hs.marginLeft) xpos = hs.marginLeft; 
 
		this.moveTo(xpos, this.y.pos); 
		this.doShowHide('hidden'); 
 
	} catch (e) { 
		this.error(e); 
	} 
}, 
 
 
afterClose : function () { 
	this.a.className = this.a.className.replace('highslide-active-anchor', ''); 
 
	this.doShowHide('visible'); 
		if (this.outline && this.outlineWhileAnimating) this.outline.destroy(); 
 
		hs.discardElement(this.wrapper); 
 
	hs.expanders[this.key] = null; 
	hs.reOrder(); 
} 
 
}; 
hs.langDefaults = hs.lang; 
// history 
var HsExpander = hs.Expander; 
if (hs.ie && window == window.top) { 
	(function () { 
		try { 
			document.documentElement.doScroll('left'); 
		} catch (e) { 
			setTimeout(arguments.callee, 50); 
			return; 
		} 
		hs.ready(); 
	})(); 
} 
hs.addEventListener(document, 'DOMContentLoaded', hs.ready); 
hs.addEventListener(window, 'load', hs.ready); 
 
// set handlers 
hs.addEventListener(document, 'ready', function() { 
	if (hs.expandCursor) { 
		var style = hs.createElement('style', {type: 'text/css'}, null, 
			document.getElementsByTagName('HEAD')[0]); 
 
		function addRule(sel, dec) { 
			if (!hs.ie) { 
				style.appendChild(document.createTextNode(sel + " {" + dec + "}")); 
			} else { 
				var last = document.styleSheets[document.styleSheets.length - 1]; 
				if (typeof(last.addRule) == "object") last.addRule(sel, dec); 
			} 
		} 
		function fix(prop) { 
			return 'expression( ( ( ignoreMe = document.documentElement.'+ prop + 
				' ? document.documentElement.'+ prop +' : document.body.'+ prop +' ) ) + \'px\' );'; 
		} 
		if (hs.expandCursor) addRule ('.highslide img', 
			'cursor: url('+ hs.graphicsDir + hs.expandCursor +'), pointer !important;'); 
	} 
}); 
hs.addEventListener(window, 'resize', function() { 
	hs.getPageSize(); 
}); 
hs.addEventListener(document, 'mousemove', function(e) { 
	hs.mouse = {x: e.clientX, y: e.clientY}; 
}); 
hs.addEventListener(document, 'mousedown', hs.mouseClickHandler); 
hs.addEventListener(document, 'mouseup', hs.mouseClickHandler); 
 
hs.addEventListener(document, 'ready', hs.getAnchors); 
hs.addEventListener(window, 'load', hs.preloadImages); 
} 
 
 
 
 
//** Tab Content script v2.0- © Dynamic Drive DHTML code library (http://www.dynamicdrive.com) 
//** Updated Oct 7th, 07 to version 2.0. Contains numerous improvements: 
//   -Added Auto Mode: Script auto rotates the tabs based on an interval, until a tab is explicitly selected 
//   -Ability to expand/contract arbitrary DIVs on the page as the tabbed content is expanded/ contracted 
//   -Ability to dynamically select a tab either based on its position within its peers, or its ID attribute (give the target tab one 1st) 
//   -Ability to set where the CSS classname "selected" get assigned- either to the target tab's link ("A"), or its parent container 
 
////NO NEED TO EDIT BELOW//////////////////////// 
 
function ddtabcontent(tabinterfaceid, picParent){ 
	this.picParent=picParent 
	this.tabinterfaceid=tabinterfaceid //ID of Tab Menu main container 
	this.tabs=document.getElementById(tabinterfaceid).getElementsByTagName("a") //Get all tab links within container 
	this.enabletabpersistence=true 
	this.hottabspositions=[] //Array to store position of tabs that have a "rel" attr defined, relative to all tab links, within container 
	this.subcontentids=[] //Array to store ids of the sub contents ("rel" attr values) 
	this.revcontentids=[] //Array to store ids of arbitrary contents to expand/contact as well ("rev" attr values) 
	this.selectedClassTarget="link" //keyword to indicate which target element to assign "selected" CSS class ("linkparent" or "link") 
} 
 
ddtabcontent.getCookie=function(Name){ 
	var re=new RegExp(Name+"=[^;]+", "i"); //construct RE to search for target name/value pair 
	if (document.cookie.match(re)) //if cookie found 
		return document.cookie.match(re)[0].split("=")[1] //return its value 
	return "" 
} 
 
ddtabcontent.setCookie=function(name, value){ 
	document.cookie = name+"="+value+";path=/" //cookie value is domain wide (path=/) 
} 
 
ddtabcontent.prototype={ 
 
	expandit:function(tabid_or_position){ //PUBLIC function to select a tab either by its ID or position(int) within its peers 
		this.cancelautorun() //stop auto cycling of tabs (if running) 
		var tabref="" 
		try{ 
			if (typeof tabid_or_position=="string" && document.getElementById(tabid_or_position).getAttribute("rel")) //if specified tab contains "rel" attr 
				tabref=document.getElementById(tabid_or_position) 
			else if (parseInt(tabid_or_position)!=NaN && this.tabs[tabid_or_position].getAttribute("rel")) //if specified tab contains "rel" attr 
				tabref=this.tabs[tabid_or_position] 
		} 
		catch(err){alert("Invalid Tab ID or position entered!")} 
		if (tabref!="") //if a valid tab is found based on function parameter 
			this.expandtab(tabref) //expand this tab 
	}, 
 
	setpersist:function(bool){ //PUBLIC function to toggle persistence feature 
			this.enabletabpersistence=bool 
	}, 
 
	setselectedClassTarget:function(objstr){ //PUBLIC function to set which target element to assign "selected" CSS class ("linkparent" or "link") 
		this.selectedClassTarget=objstr || "link" 
	}, 
 
	getselectedClassTarget:function(tabref){ //Returns target element to assign "selected" CSS class to 
		return (this.selectedClassTarget==("linkparent".toLowerCase()))? tabref.parentNode : tabref 
	}, 
 
	expandtab:function(tabref){ 
		var subcontentid=tabref.getAttribute("rel") //Get id of subcontent to expand 
		//Get "rev" attr as a string of IDs in the format ",john,george,trey,etc," to easily search through 
		//var associatedrevids=(tabref.getAttribute("rev"))? ","+tabref.getAttribute("rev").replace(/\s+/, "")+"," : "" 
		var associatedrevid=tabref.getAttribute("rev") 
		this.expandsubcontent(subcontentid) 
		this.expandrevcontent(associatedrevid) 
		for (var i=0; i<this.tabs.length; i++){ //Loop through all tabs, and assign only the selected tab the CSS class "selected" 
			this.getselectedClassTarget(this.tabs[i]).className=(this.tabs[i].getAttribute("rel")==subcontentid)? "selected" : "" 
		} 
		if (this.enabletabpersistence) //if persistence enabled, save selected tab position(int) relative to its peers 
			ddtabcontent.setCookie(this.tabinterfaceid, tabref.tabposition) 
	}, 
 
	expandsubcontent:function(subcontentid){ 
		for (var i=0; i<this.subcontentids.length; i++){ 
			var subcontent=document.getElementById(this.subcontentids[i]) //cache current subcontent obj (in for loop) 
			subcontent.style.display=(subcontent.id==subcontentid)? "block" : "none" //"show" or hide sub content based on matching id attr value 
		} 
	}, 
 
 
	expandrevcontent:function(associatedrevid){ 
/* 
		var allrevids=this.revcontentids 
		for (var i=0; i<allrevids.length; i++){ //Loop through rev attributes for all tabs in this tab interface 
			//if any values stored within associatedrevids matches one within allrevids, expand that DIV, otherwise, contract it 
			document.getElementById(allrevids[i]).style.display=(associatedrevids.indexOf(","+allrevids[i]+",")!=-1)? "block" : "none" 
		} 
*/ 
		if (this.picParent) this.picParent.showChild(associatedrevid) 
	}, 
 
	autorun:function(){ //function to auto cycle through and select tabs based on a set interval 
		var currentTabIndex=this.automode_currentTabIndex //index within this.hottabspositions to begin 
		var hottabspositions=this.hottabspositions //Array containing position numbers of "hot" tabs (those with a "rel" attr) 
		this.expandtab(this.tabs[hottabspositions[currentTabIndex]]) 
		this.automode_currentTabIndex=(currentTabIndex<hottabspositions.length-1)? currentTabIndex+1 : 0 //increment currentTabIndex 
	}, 
 
	cancelautorun:function(){ 
		if (typeof this.autoruntimer!="undefined") 
			clearInterval(this.autoruntimer) 
	}, 
 
	init:function(automodeperiod){ 
		var persistedtab=ddtabcontent.getCookie(this.tabinterfaceid) //get position of persisted tab (applicable if persistence is enabled) 
		var persisterror=true //Bool variable to check whether persisted tab position is valid (can become invalid if user has modified tab structure) 
		this.automodeperiod=automodeperiod || 0 
		for (var i=0; i<this.tabs.length; i++){ 
			this.tabs[i].tabposition=i //remember position of tab relative to its peers 
			if (this.tabs[i].getAttribute("rel")){ 
				var tabinstance=this 
				this.hottabspositions[this.hottabspositions.length]=i //store position of "hot" tab ("rel" attr defined) relative to its peers 
				this.subcontentids[this.subcontentids.length]=this.tabs[i].getAttribute("rel") //store id of sub content ("rel" attr value) 
				this.tabs[i].onclick=function(){ 
					tabinstance.expandtab(this) 
					tabinstance.cancelautorun() //stop auto cycling of tabs (if running) 
					return false 
				} 
				if (this.tabs[i].getAttribute("rev")){ //if "rev" attr defined, store each value within "rev" as an array element 
					this.revcontentids=this.revcontentids.concat(this.tabs[i].getAttribute("rev").split(/\s*,\s*/)) 
				} 
				if (this.enabletabpersistence && parseInt(persistedtab)==i || !this.enabletabpersistence && this.getselectedClassTarget(this.tabs[i]).className=="selected"){ 
					this.expandtab(this.tabs[i]) //expand current tab if it's the persisted tab, or if persist=off, carries the "selected" CSS class 
					persisterror=false //Persisted tab (if applicable) was found, so set "persisterror" to false 
					//If currently selected tab's index(i) is greater than 0, this means its not the 1st tab, so set the tab to begin in automode to 1st tab: 
					this.automode_currentTabIndex=(i>0)? 0 : 1 
				} 
			} 
		} //END for loop 
		if (persisterror) //if an error has occured while trying to retrieve persisted tab (based on its position within its peers) 
			this.expandtab(this.tabs[this.hottabspositions[0]]) //Just select first tab that contains a "rel" attr 
		if (parseInt(this.automodeperiod)>500 && this.hottabspositions.length>1){ 
			this.automode_currentTabIndex=this.automode_currentTabIndex || 0 
			this.autoruntimer=setInterval(function(){tabinstance.autorun()}, this.automodeperiod) 
		} 
	} //END int() function 
 
} //END Prototype assignment 
 
 
 
 
 
function SDMenu(id) { 
  if (!document.getElementById || !document.getElementsByTagName) 
    return false; 
  this.menu = document.getElementById(id); 
  this.submenus = this.menu.getElementsByTagName("div"); 
} 
SDMenu.prototype.init = function() { 
  for (var i = 0; i < this.submenus.length; i++) { 
    if (this.submenus[i].className == "collapsed") { 
      var newHeight = this.submenus[i].getElementsByTagName("span")[0].offsetHeight; 
      this.submenus[i].style.height = newHeight + "px"; 
    } else { 
      this.submenus[i].style.height = "auto"; 
    } 
  } 
}; 
 
 
 
 
 
 
function SDBasket(id) { 
	if (!document.getElementById || !document.getElementsByTagName) 
		return false; 
	this.basket = document.getElementById(id); 
	this.subbaskets = this.basket.getElementsByTagName("div"); 
	this.remember = false; 
	this.speed = 3; 
	this.markCurrent = false; 
	this.oneSmOnly = false; 
} 
SDBasket.prototype.init = function() { 
	var mainInstance = this; 
	for (var i = 0; i < this.subbaskets.length; i++) 
		var span = this.subbaskets[i].getElementsByTagName("span")[0]; 
		span.onclick = function() {mainInstance.toggleBasket(this.parentNode); 
		}; 
	if (this.markCurrent) { 
		var links = this.basket.getElementsByTagName("a"); 
		for (var i = 0; i < links.length; i++) 
			if (links[i].href == document.location.href) { 
				links[i].className = "current"; 
				break; 
			} 
	} 
	if (this.remember) { 
		var regex = new RegExp("sdbasket_" + encodeURIComponent(this.basket.id) + "=([01]+)"); 
		var match = regex.exec(document.cookie); 
		if (match) { 
			var states = match[1].split(""); 
			for (var i = 0; i < states.length; i++) 
				this.subbaskets[i].className = (states[i] == 0 ? "collapsed" : ""); 
		} 
	} 
}; 
SDBasket.prototype.toggleBasket = function(subbasket) { 
	if (subbasket.className == "collapsed") 
		this.expandBasket(subbasket); 
	else 
		this.collapseBasket(subbasket); 
}; 
SDBasket.prototype.expandBasket = function(subbasket) { 
	var fullHeight = subbasket.getElementsByTagName("span")[0].offsetHeight; 
	var links = subbasket.getElementsByTagName("a"); 
	for (var i = 0; i < links.length; i++) 
		fullHeight += links[i].offsetHeight; 
	var moveBy = Math.round(this.speed * links.length); 
 
	var mainInstance = this; 
	var intId = setInterval(function() { 
		var curHeight = subbasket.offsetHeight; 
		var newHeight = curHeight + moveBy; 
		if (newHeight < fullHeight) 
			subbasket.style.height = newHeight + "px"; 
		else { 
			clearInterval(intId); 
			subbasket.style.height = ""; 
			subbasket.className = ""; 
			mainInstance.memorize(); 
		} 
	}, 30); 
	this.collapseOthers(subbasket); 
}; 
SDBasket.prototype.collapseBasket = function(subbasket) { 
	var minHeight = subbasket.getElementsByTagName("span")[0].offsetHeight; 
	var moveBy = Math.round(this.speed * subbasket.getElementsByTagName("a").length); 
	var mainInstance = this; 
	var intId = setInterval(function() { 
		var curHeight = subbasket.offsetHeight; 
		var newHeight = curHeight - moveBy; 
		if (newHeight > minHeight) 
			subbasket.style.height = newHeight + "px"; 
		else { 
			clearInterval(intId); 
			subbasket.style.height = ""; 
			subbasket.className = "collapsed"; 
			mainInstance.memorize(); 
		} 
	}, 30); 
}; 
SDBasket.prototype.collapseOthers = function(subbasket) { 
	if (this.oneSmOnly) { 
		for (var i = 0; i < this.subbaskets.length; i++) 
			if (this.subbaskets[i] != subbasket && this.subbaskets[i].className != "collapsed") 
				this.collapseBasket(this.subbaskets[i]); 
	} 
}; 
SDBasket.prototype.expandAll = function() { 
	var oldOneSmOnly = this.oneSmOnly; 
	this.oneSmOnly = false; 
	for (var i = 0; i < this.subbaskets.length; i++) 
		if (this.subbaskets[i].className == "collapsed") 
			this.expandBasket(this.subbaskets[i]); 
	this.oneSmOnly = oldOneSmOnly; 
}; 
SDBasket.prototype.collapseAll = function() { 
	for (var i = 0; i < this.subbaskets.length; i++) 
		if (this.subbaskets[i].className != "collapsed") 
			this.collapseBasket(this.subbaskets[i]); 
}; 
SDBasket.prototype.memorize = function() { 
	if (this.remember) { 
		var states = new Array(); 
		for (var i = 0; i < this.subbaskets.length; i++) 
			states.push(this.subbaskets[i].className == "collapsed" ? 0 : 1); 
		var d = new Date(); 
		d.setTime(d.getTime() + (30 * 24 * 60 * 60 * 1000)); 
		document.cookie = "sdbasket_" + encodeURIComponent(this.basket.id) + "=" + states.join("") + "; expires=" + d.toGMTString() + "; path=/"; 
	} 
}; 
 
 
 
 
 
 
//** Tab Content script v2.0- © Dynamic Drive DHTML code library (http://www.dynamicdrive.com) 
//** Updated Oct 7th, 07 to version 2.0. Contains numerous improvements: 
//   -Added Auto Mode: Script auto rotates the tabs based on an interval, until a tab is explicitly selected 
//   -Ability to expand/contract arbitrary DIVs on the page as the tabbed content is expanded/ contracted 
//   -Ability to dynamically select a tab either based on its position within its peers, or its ID attribute (give the target tab one 1st) 
//   -Ability to set where the CSS classname "selected" get assigned- either to the target tab's link ("A"), or its parent container 
 
////NO NEED TO EDIT BELOW//////////////////////// 
 
function ddtabcheckout(tabinterfaceid, picParent){ 
	this.picParent=picParent 
	this.tabinterfaceid=tabinterfaceid //ID of Tab Menu main container 
	this.tabs=document.getElementById(tabinterfaceid).getElementsByTagName("a") //Get all tab links within container 
	this.enabletabpersistence=true 
	this.hottabspositions=[] //Array to store position of tabs that have a "rel" attr defined, relative to all tab links, within container 
	this.subcontentids=[] //Array to store ids of the sub contents ("rel" attr values) 
	this.revcontentids=[] //Array to store ids of arbitrary contents to expand/contact as well ("rev" attr values) 
	this.selectedClassTarget="link" //keyword to indicate which target element to assign "selected" CSS class ("linkparent" or "link") 
} 
 
ddtabcheckout.getCookie=function(Name){ 
	var re=new RegExp(Name+"=[^;]+", "i"); //construct RE to search for target name/value pair 
	if (document.cookie.match(re)) //if cookie found 
		return document.cookie.match(re)[0].split("=")[1] //return its value 
	return "" 
} 
 
ddtabcheckout.setCookie=function(name, value){ 
	document.cookie = name+"="+value+";path=/" //cookie value is domain wide (path=/) 
} 
 
ddtabcheckout.prototype={ 
 
	expandit:function(tabid_or_position){ //PUBLIC function to select a tab either by its ID or position(int) within its peers 
		this.cancelautorun() //stop auto cycling of tabs (if running) 
		var tabref="" 
		try{ 
			if (typeof tabid_or_position=="string" && document.getElementById(tabid_or_position).getAttribute("rel")) //if specified tab contains "rel" attr 
				tabref=document.getElementById(tabid_or_position) 
			else if (parseInt(tabid_or_position)!=NaN && this.tabs[tabid_or_position].getAttribute("rel")) //if specified tab contains "rel" attr 
				tabref=this.tabs[tabid_or_position] 
		} 
		catch(err){alert("Invalid Tab ID or position entered!")} 
		if (tabref!="") //if a valid tab is found based on function parameter 
			this.expandtab(tabref) //expand this tab 
	}, 
 
	setpersist:function(bool){ //PUBLIC function to toggle persistence feature 
			this.enabletabpersistence=bool 
	}, 
 
	setselectedClassTarget:function(objstr){ //PUBLIC function to set which target element to assign "selected" CSS class ("linkparent" or "link") 
		this.selectedClassTarget=objstr || "link" 
	}, 
 
	getselectedClassTarget:function(tabref){ //Returns target element to assign "selected" CSS class to 
		return (this.selectedClassTarget==("linkparent".toLowerCase()))? tabref.parentNode : tabref 
	}, 
 
	expandtab:function(tabref){ 
		var subcontentid=tabref.getAttribute("rel") //Get id of subcontent to expand 
		//Get "rev" attr as a string of IDs in the format ",john,george,trey,etc," to easily search through 
		//var associatedrevids=(tabref.getAttribute("rev"))? ","+tabref.getAttribute("rev").replace(/\s+/, "")+"," : "" 
		var associatedrevid=tabref.getAttribute("rev") 
		this.expandsubcontent(subcontentid) 
		this.expandrevcontent(associatedrevid) 
		for (var i=0; i<this.tabs.length; i++){ //Loop through all tabs, and assign only the selected tab the CSS class "selected" 
			this.getselectedClassTarget(this.tabs[i]).className=(this.tabs[i].getAttribute("rel")==subcontentid)? "selected" : "" 
		} 
		if (this.enabletabpersistence) //if persistence enabled, save selected tab position(int) relative to its peers 
			ddtabcheckout.setCookie(this.tabinterfaceid, tabref.tabposition) 
		scroll(0,0) 
	}, 
 
	expandsubcontent:function(subcontentid){ 
		for (var i=0; i<this.subcontentids.length; i++){ 
			var subcontent=document.getElementById(this.subcontentids[i]) //cache current subcontent obj (in for loop) 
			subcontent.style.display=(subcontent.id==subcontentid)? "block" : "none" //"show" or hide sub content based on matching id attr value 
		} 
	}, 
 
 
	expandrevcontent:function(associatedrevid){ 
/* 
		var allrevids=this.revcontentids 
		for (var i=0; i<allrevids.length; i++){ //Loop through rev attributes for all tabs in this tab interface 
			//if any values stored within associatedrevids matches one within allrevids, expand that DIV, otherwise, contract it 
			document.getElementById(allrevids[i]).style.display=(associatedrevids.indexOf(","+allrevids[i]+",")!=-1)? "block" : "none" 
		} 
*/ 
		if (this.picParent) this.picParent.showChild(associatedrevid) 
	}, 
 
	autorun:function(){ //function to auto cycle through and select tabs based on a set interval 
		var currentTabIndex=this.automode_currentTabIndex //index within this.hottabspositions to begin 
		var hottabspositions=this.hottabspositions //Array containing position numbers of "hot" tabs (those with a "rel" attr) 
		this.expandtab(this.tabs[hottabspositions[currentTabIndex]]) 
		this.automode_currentTabIndex=(currentTabIndex<hottabspositions.length-1)? currentTabIndex+1 : 0 //increment currentTabIndex 
	}, 
 
	cancelautorun:function(){ 
		if (typeof this.autoruntimer!="undefined") 
			clearInterval(this.autoruntimer) 
	}, 
 
	init:function(automodeperiod){ 
		var persistedtab=ddtabcheckout.getCookie(this.tabinterfaceid) //get position of persisted tab (applicable if persistence is enabled) 
		var persisterror=true //Bool variable to check whether persisted tab position is valid (can become invalid if user has modified tab structure) 
		this.automodeperiod=automodeperiod || 0 
		for (var i=0; i<this.tabs.length; i++){ 
			this.tabs[i].tabposition=i //remember position of tab relative to its peers 
			if (this.tabs[i].getAttribute("rel")){ 
				var tabinstance=this 
				this.hottabspositions[this.hottabspositions.length]=i //store position of "hot" tab ("rel" attr defined) relative to its peers 
				this.subcontentids[this.subcontentids.length]=this.tabs[i].getAttribute("rel") //store id of sub content ("rel" attr value) 
/* 
DISABLE USER CONTROL OF TAB NAVIGATION. 
				this.tabs[i].onclick=function(){ 
					tabinstance.expandtab(this) 
					tabinstance.cancelautorun() //stop auto cycling of tabs (if running) 
					return false 
				} 
*/ 
				if (this.tabs[i].getAttribute("rev")){ //if "rev" attr defined, store each value within "rev" as an array element 
					this.revcontentids=this.revcontentids.concat(this.tabs[i].getAttribute("rev").split(/\s*,\s*/)) 
				} 
				if (this.enabletabpersistence && parseInt(persistedtab)==i || !this.enabletabpersistence && this.getselectedClassTarget(this.tabs[i]).className=="selected"){ 
					this.expandtab(this.tabs[i]) //expand current tab if it's the persisted tab, or if persist=off, carries the "selected" CSS class 
					persisterror=false //Persisted tab (if applicable) was found, so set "persisterror" to false 
					//If currently selected tab's index(i) is greater than 0, this means its not the 1st tab, so set the tab to begin in automode to 1st tab: 
					this.automode_currentTabIndex=(i>0)? 0 : 1 
				} 
			} 
		} //END for loop 
		if (persisterror) //if an error has occured while trying to retrieve persisted tab (based on its position within its peers) 
			this.expandtab(this.tabs[this.hottabspositions[0]]) //Just select first tab that contains a "rel" attr 
		if (parseInt(this.automodeperiod)>500 && this.hottabspositions.length>1){ 
			this.automode_currentTabIndex=this.automode_currentTabIndex || 0 
			this.autoruntimer=setInterval(function(){tabinstance.autorun()}, this.automodeperiod) 
		} 
	} //END int() function 
 
} //END Prototype assignment 
 
 
 
 
 
 
 
// ------------------------------------------------------------------- 
// DHTML Window Widget- By Dynamic Drive, available at: http://www.dynamicdrive.com 
// v1.0: Script created Feb 15th, 07' 
// v1.01: Feb 21th, 07' (see changelog.txt) 
// v1.02: March 26th, 07' (see changelog.txt) 
// v1.03: May 5th, 07' (see changelog.txt) 
// v1.1:  Oct 29th, 07' (see changelog.txt) 
// ------------------------------------------------------------------- 
 
var dhtmlwindow={ 
imagefiles:['windowfiles/min.gif', 'windowfiles/close.gif', 'windowfiles/restore.gif', 'windowfiles/resize.gif'], //Path to 4 images used by script, in that order 
ajaxbustcache: true, //Bust caching when fetching a file via Ajax? 
ajaxloadinghtml: '<b>Loading Page. Please wait...</b>', //HTML to show while window fetches Ajax Content? 
 
minimizeorder: 0, 
zIndexvalue:100, 
tobjects: [], //object to contain references to dhtml window divs, for cleanup purposes 
lastactivet: {}, //reference to last active DHTML window 
 
init:function(t){ 
	var domwindow=document.createElement("div") //create dhtml window div 
	domwindow.id=t 
	domwindow.className="dhtmlwindow" 
	var domwindowdata='' 
	domwindowdata='<div class="drag-handle">' 
	domwindowdata+='DHTML Window <div class="drag-controls"><img src="'+this.imagefiles[0]+'" title="Minimize" /><img src="'+this.imagefiles[1]+'" title="Close" /></div>' 
	domwindowdata+='</div>' 
	domwindowdata+='<div class="drag-contentarea"></div>' 
	domwindowdata+='<div class="drag-statusarea"><div class="drag-resizearea" style="background: transparent url('+this.imagefiles[3]+') top right no-repeat;">&nbsp;</div></div>' 
	domwindowdata+='</div>' 
	domwindow.innerHTML=domwindowdata 
	document.getElementById("dhtmlwindowholder").appendChild(domwindow) 
	//this.zIndexvalue=(this.zIndexvalue)? this.zIndexvalue+1 : 100 //z-index value for DHTML window: starts at 0, increments whenever a window has focus 
	var t=document.getElementById(t) 
	var divs=t.getElementsByTagName("div") 
	for (var i=0; i<divs.length; i++){ //go through divs inside dhtml window and extract all those with class="drag-" prefix 
		if (/drag-/.test(divs[i].className)) 
			t[divs[i].className.replace(/drag-/, "")]=divs[i] //take out the "drag-" prefix for shorter access by name 
	} 
	//t.style.zIndex=this.zIndexvalue //set z-index of this dhtml window 
	t.handle._parent=t //store back reference to dhtml window 
	t.resizearea._parent=t //same 
	t.controls._parent=t //same 
	t.onclose=function(){return true} //custom event handler "onclose" 
	t.onmousedown=function(){dhtmlwindow.setfocus(this)} //Increase z-index of window when focus is on it 
	t.handle.onmousedown=dhtmlwindow.setupdrag //set up drag behavior when mouse down on handle div 
	t.resizearea.onmousedown=dhtmlwindow.setupdrag //set up drag behavior when mouse down on resize div 
	t.controls.onclick=dhtmlwindow.enablecontrols 
	t.show=function(){dhtmlwindow.show(this)} //public function for showing dhtml window 
	t.hide=function(){dhtmlwindow.hide(this)} //public function for hiding dhtml window 
	t.close=function(){dhtmlwindow.close(this)} //public function for closing dhtml window (also empties DHTML window content) 
	t.setSize=function(w, h){dhtmlwindow.setSize(this, w, h)} //public function for setting window dimensions 
	t.moveTo=function(x, y){dhtmlwindow.moveTo(this, x, y)} //public function for moving dhtml window (relative to viewpoint) 
	t.isResize=function(bol){dhtmlwindow.isResize(this, bol)} //public function for specifying if window is resizable 
	t.isScrolling=function(bol){dhtmlwindow.isScrolling(this, bol)} //public function for specifying if window content contains scrollbars 
	t.load=function(contenttype, contentsource, title){dhtmlwindow.load(this, contenttype, contentsource, title)} //public function for loading content into window 
	this.tobjects[this.tobjects.length]=t 
	return t //return reference to dhtml window div 
}, 
 
open:function(t, contenttype, contentsource, title, attr, recalonload){ 
	var d=dhtmlwindow //reference dhtml window object 
	function getValue(Name){ 
		var config=new RegExp(Name+"=([^,]+)", "i") //get name/value config pair (ie: width=400px,) 
		return (config.test(attr))? parseInt(RegExp.$1) : 0 //return value portion (int), or 0 (false) if none found 
	} 
	if (document.getElementById(t)==null) //if window doesn't exist yet, create it 
		t=this.init(t) //return reference to dhtml window div 
	else 
		t=document.getElementById(t) 
	this.setfocus(t) 
	t.setSize(getValue(("width")), (getValue("height"))) //Set dimensions of window 
	var xpos=getValue("center")? "middle" : getValue("left") //Get x coord of window 
	var ypos=getValue("center")? "middle" : getValue("top") //Get y coord of window 
	//t.moveTo(xpos, ypos) //Position window 
	if (typeof recalonload!="undefined" && recalonload=="recal" && this.scroll_top==0){ //reposition window when page fully loads with updated window viewpoints? 
		if (window.attachEvent && !window.opera) //In IE, add another 400 milisecs on page load (viewpoint properties may return 0 b4 then) 
			this.addEvent(window, function(){setTimeout(function(){t.moveTo(xpos, ypos)}, 400)}, "load") 
		else 
			this.addEvent(window, function(){t.moveTo(xpos, ypos)}, "load") 
	} 
	t.isResize(getValue("resize")) //Set whether window is resizable 
	t.isScrolling(getValue("scrolling")) //Set whether window should contain scrollbars 
	t.style.visibility="visible" 
	t.style.display="block" 
	t.contentarea.style.display="block" 
	t.moveTo(xpos, ypos) //Position window 
	t.load(contenttype, contentsource, title) 
	if (t.state=="minimized" && t.controls.firstChild.title=="Restore"){ //If window exists and is currently minimized? 
		t.controls.firstChild.setAttribute("src", dhtmlwindow.imagefiles[0]) //Change "restore" icon within window interface to "minimize" icon 
		t.controls.firstChild.setAttribute("title", "Minimize") 
		t.state="fullview" //indicate the state of the window as being "fullview" 
	} 
	return t 
}, 
 
setSize:function(t, w, h){ //set window size (min is 150px wide by 100px tall) 
	t.style.width=Math.max(parseInt(w), 150)+"px" 
	t.contentarea.style.height=Math.max(parseInt(h), 100)+"px" 
}, 
 
moveTo:function(t, x, y){ //move window. Position includes current viewpoint of document 
	this.getviewpoint() //Get current viewpoint numbers 
	t.style.left=(x=="middle")? this.scroll_left+(this.docwidth-t.offsetWidth)/2+"px" : this.scroll_left+parseInt(x)+"px" 
	t.style.top=(y=="middle")? this.scroll_top+(this.docheight-t.offsetHeight)/2+"px" : this.scroll_top+parseInt(y)+"px" 
}, 
 
isResize:function(t, bol){ //show or hide resize inteface (part of the status bar) 
	t.statusarea.style.display=(bol)? "block" : "none" 
	t.resizeBool=(bol)? 1 : 0 
}, 
 
isScrolling:function(t, bol){ //set whether loaded content contains scrollbars 
	t.contentarea.style.overflow=(bol)? "auto" : "hidden" 
}, 
 
load:function(t, contenttype, contentsource, title){ //loads content into window plus set its title (3 content types: "inline", "iframe", or "ajax") 
	if (t.isClosed){ 
		alert("DHTML Window has been closed, so no window to load contents into. Open/Create the window again.") 
		return 
	} 
	var contenttype=contenttype.toLowerCase() //convert string to lower case 
	if (typeof title!="undefined") 
		t.handle.firstChild.nodeValue=title 
	if (contenttype=="inline") 
		t.contentarea.innerHTML=contentsource 
	else if (contenttype=="div"){ 
		var inlinedivref=document.getElementById(contentsource) 
		t.contentarea.innerHTML=(inlinedivref.defaultHTML || inlinedivref.innerHTML) //Populate window with contents of inline div on page 
		if (!inlinedivref.defaultHTML) 
			inlinedivref.defaultHTML=inlinedivref.innerHTML //save HTML within inline DIV 
		inlinedivref.innerHTML="" //then, remove HTML within inline DIV (to prevent duplicate IDs, NAME attributes etc in contents of DHTML window 
		inlinedivref.style.display="none" //hide that div 
	} 
	else if (contenttype=="iframe"){ 
		t.contentarea.style.overflow="hidden" //disable window scrollbars, as iframe already contains scrollbars 
		if (!t.contentarea.firstChild || t.contentarea.firstChild.tagName!="IFRAME") //If iframe tag doesn't exist already, create it first 
			t.contentarea.innerHTML='<iframe src="" style="margin:0; padding:0; width:100%; height: 100%" name="_iframe-'+t.id+'"></iframe>' 
		window.frames["_iframe-"+t.id].location.replace(contentsource) //set location of iframe window to specified URL 
		} 
	else if (contenttype=="ajax"){ 
		this.ajax_connect(contentsource, t) //populate window with external contents fetched via Ajax 
	} 
	t.contentarea.datatype=contenttype //store contenttype of current window for future reference 
}, 
 
setupdrag:function(e){ 
	var d=dhtmlwindow //reference dhtml window object 
	var t=this._parent //reference dhtml window div 
	d.etarget=this //remember div mouse is currently held down on ("handle" or "resize" div) 
	var e=window.event || e 
	d.initmousex=e.clientX //store x position of mouse onmousedown 
	d.initmousey=e.clientY 
	d.initx=parseInt(t.offsetLeft) //store offset x of window div onmousedown 
	d.inity=parseInt(t.offsetTop) 
	d.width=parseInt(t.offsetWidth) //store width of window div 
	d.contentheight=parseInt(t.contentarea.offsetHeight) //store height of window div's content div 
	if (t.contentarea.datatype=="iframe"){ //if content of this window div is "iframe" 
		t.style.backgroundColor="#F8F8F8" //colorize and hide content div (while window is being dragged) 
		t.contentarea.style.visibility="hidden" 
	} 
	document.onmousemove=d.getdistance //get distance travelled by mouse as it moves 
	document.onmouseup=function(){ 
		if (t.contentarea.datatype=="iframe"){ //restore color and visibility of content div onmouseup 
			t.contentarea.style.backgroundColor="white" 
			t.contentarea.style.visibility="visible" 
		} 
		d.stop() 
	} 
	return false 
}, 
 
getdistance:function(e){ 
	var d=dhtmlwindow 
	var etarget=d.etarget 
	var e=window.event || e 
	d.distancex=e.clientX-d.initmousex //horizontal distance travelled relative to starting point 
	d.distancey=e.clientY-d.initmousey 
	if (etarget.className=="drag-handle") //if target element is "handle" div 
		d.move(etarget._parent, e) 
	else if (etarget.className=="drag-resizearea") //if target element is "resize" div 
		d.resize(etarget._parent, e) 
	return false //cancel default dragging behavior 
}, 
 
getviewpoint:function(){ //get window viewpoint numbers 
	var ie=document.all && !window.opera 
	var domclientWidth=document.documentElement && parseInt(document.documentElement.clientWidth) || 100000 //Preliminary doc width in non IE browsers 
	this.standardbody=(document.compatMode=="CSS1Compat")? document.documentElement : document.body //create reference to common "body" across doctypes 
	this.scroll_top=(ie)? this.standardbody.scrollTop : window.pageYOffset 
	this.scroll_left=(ie)? this.standardbody.scrollLeft : window.pageXOffset 
	this.docwidth=(ie)? this.standardbody.clientWidth : (/Safari/i.test(navigator.userAgent))? window.innerWidth : Math.min(domclientWidth, window.innerWidth-16) 
	this.docheight=(ie)? this.standardbody.clientHeight: window.innerHeight 
}, 
 
rememberattrs:function(t){ //remember certain attributes of the window when it's minimized or closed, such as dimensions, position on page 
	this.getviewpoint() //Get current window viewpoint numbers 
	t.lastx=parseInt((t.style.left || t.offsetLeft))-dhtmlwindow.scroll_left //store last known x coord of window just before minimizing 
	t.lasty=parseInt((t.style.top || t.offsetTop))-dhtmlwindow.scroll_top 
	t.lastwidth=parseInt(t.style.width) //store last known width of window just before minimizing/ closing 
}, 
 
move:function(t, e){ 
	t.style.left=dhtmlwindow.distancex+dhtmlwindow.initx+"px" 
	t.style.top=dhtmlwindow.distancey+dhtmlwindow.inity+"px" 
}, 
 
resize:function(t, e){ 
	t.style.width=Math.max(dhtmlwindow.width+dhtmlwindow.distancex, 150)+"px" 
	t.contentarea.style.height=Math.max(dhtmlwindow.contentheight+dhtmlwindow.distancey, 100)+"px" 
}, 
 
enablecontrols:function(e){ 
	var d=dhtmlwindow 
	var sourceobj=window.event? window.event.srcElement : e.target //Get element within "handle" div mouse is currently on (the controls) 
	if (/Minimize/i.test(sourceobj.getAttribute("title"))) //if this is the "minimize" control 
		d.minimize(sourceobj, this._parent) 
	else if (/Restore/i.test(sourceobj.getAttribute("title"))) //if this is the "restore" control 
		d.restore(sourceobj, this._parent) 
	else if (/Close/i.test(sourceobj.getAttribute("title"))) //if this is the "close" control 
		d.close(this._parent) 
	return false 
}, 
 
minimize:function(button, t){ 
	dhtmlwindow.rememberattrs(t) 
	button.setAttribute("src", dhtmlwindow.imagefiles[2]) 
	button.setAttribute("title", "Restore") 
	t.state="minimized" //indicate the state of the window as being "minimized" 
	t.contentarea.style.display="none" 
	t.statusarea.style.display="none" 
	if (typeof t.minimizeorder=="undefined"){ //stack order of minmized window on screen relative to any other minimized windows 
		dhtmlwindow.minimizeorder++ //increment order 
		t.minimizeorder=dhtmlwindow.minimizeorder 
	} 
	t.style.left="10px" //left coord of minmized window 
	t.style.width="200px" 
	var windowspacing=t.minimizeorder*10 //spacing (gap) between each minmized window(s) 
	t.style.top=dhtmlwindow.scroll_top+dhtmlwindow.docheight-(t.handle.offsetHeight*t.minimizeorder)-windowspacing+"px" 
}, 
 
restore:function(button, t){ 
	dhtmlwindow.getviewpoint() 
	button.setAttribute("src", dhtmlwindow.imagefiles[0]) 
	button.setAttribute("title", "Minimize") 
	t.state="fullview" //indicate the state of the window as being "fullview" 
	t.style.display="block" 
	t.contentarea.style.display="block" 
	if (t.resizeBool) //if this window is resizable, enable the resize icon 
		t.statusarea.style.display="block" 
	t.style.left=parseInt(t.lastx)+dhtmlwindow.scroll_left+"px" //position window to last known x coord just before minimizing 
	t.style.top=parseInt(t.lasty)+dhtmlwindow.scroll_top+"px" 
	t.style.width=parseInt(t.lastwidth)+"px" 
}, 
 
 
close:function(t){ 
	try{ 
		var closewinbol=t.onclose() 
	} 
	catch(err){ //In non IE browsers, all errors are caught, so just run the below 
		var closewinbol=true 
 } 
	finally{ //In IE, not all errors are caught, so check if variable isn't defined in IE in those cases 
		if (typeof closewinbol=="undefined"){ 
			alert("An error has occured somwhere inside your \"onclose\" event handler") 
			var closewinbol=true 
		} 
	} 
	if (closewinbol){ //if custom event handler function returns true 
		if (t.state!="minimized") //if this window isn't currently minimized 
			dhtmlwindow.rememberattrs(t) //remember window's dimensions/position on the page before closing 
		if (window.frames["_iframe-"+t.id]) //if this is an IFRAME DHTML window 
			window.frames["_iframe-"+t.id].location.replace("about:blank") 
		else 
			t.contentarea.innerHTML="" 
		t.style.display="none" 
		t.isClosed=true //tell script this window is closed (for detection in t.show()) 
	} 
	return closewinbol 
}, 
 
 
setopacity:function(targetobject, value){ //Sets the opacity of targetobject based on the passed in value setting (0 to 1 and in between) 
	if (!targetobject) 
		return 
	if (targetobject.filters && targetobject.filters[0]){ //IE syntax 
		if (typeof targetobject.filters[0].opacity=="number") //IE6 
			targetobject.filters[0].opacity=value*100 
		else //IE 5.5 
			targetobject.style.filter="alpha(opacity="+value*100+")" 
		} 
	else if (typeof targetobject.style.MozOpacity!="undefined") //Old Mozilla syntax 
		targetobject.style.MozOpacity=value 
	else if (typeof targetobject.style.opacity!="undefined") //Standard opacity syntax 
		targetobject.style.opacity=value 
}, 
 
setfocus:function(t){ //Sets focus to the currently active window 
	this.zIndexvalue++ 
	t.style.zIndex=this.zIndexvalue 
	t.isClosed=false //tell script this window isn't closed (for detection in t.show()) 
	this.setopacity(this.lastactivet.handle, 0.5) //unfocus last active window 
	this.setopacity(t.handle, 1) //focus currently active window 
	this.lastactivet=t //remember last active window 
}, 
 
 
show:function(t){ 
	if (t.isClosed){ 
		alert("DHTML Window has been closed, so nothing to show. Open/Create the window again.") 
		return 
	} 
	if (t.lastx) //If there exists previously stored information such as last x position on window attributes (meaning it's been minimized or closed) 
		dhtmlwindow.restore(t.controls.firstChild, t) //restore the window using that info 
	else 
		t.style.display="block" 
	this.setfocus(t) 
	t.state="fullview" //indicate the state of the window as being "fullview" 
}, 
 
hide:function(t){ 
	t.style.display="none" 
}, 
 
ajax_connect:function(url, t){ 
	var page_request = false 
	var bustcacheparameter="" 
	if (window.XMLHttpRequest) // if Mozilla, IE7, Safari etc 
		page_request = new XMLHttpRequest() 
	else if (window.ActiveXObject){ // if IE6 or below 
		try { 
		page_request = new ActiveXObject("Msxml2.XMLHTTP") 
		} 
		catch (e){ 
			try{ 
			page_request = new ActiveXObject("Microsoft.XMLHTTP") 
			} 
			catch (e){} 
		} 
	} 
	else 
		return false 
	t.contentarea.innerHTML=this.ajaxloadinghtml 
	page_request.onreadystatechange=function(){dhtmlwindow.ajax_loadpage(page_request, t)} 
	if (this.ajaxbustcache) //if bust caching of external page 
		bustcacheparameter=(url.indexOf("?")!=-1)? "&"+new Date().getTime() : "?"+new Date().getTime() 
	page_request.open('GET', url+bustcacheparameter, true) 
	page_request.send(null) 
}, 
 
ajax_loadpage:function(page_request, t){ 
	if (page_request.readyState == 4 && (page_request.status==200 || window.location.href.indexOf("http")==-1)){ 
	t.contentarea.innerHTML=page_request.responseText 
	} 
}, 
 
 
stop:function(){ 
	dhtmlwindow.etarget=null //clean up 
	document.onmousemove=null 
	document.onmouseup=null 
}, 
 
addEvent:function(target, functionref, tasktype){ //assign a function to execute to an event handler (ie: onunload) 
	var tasktype=(window.addEventListener)? tasktype : "on"+tasktype 
	if (target.addEventListener) 
		target.addEventListener(tasktype, functionref, false) 
	else if (target.attachEvent) 
		target.attachEvent(tasktype, functionref) 
}, 
 
cleanup:function(){ 
	for (var i=0; i<dhtmlwindow.tobjects.length; i++){ 
		dhtmlwindow.tobjects[i].handle._parent=dhtmlwindow.tobjects[i].resizearea._parent=dhtmlwindow.tobjects[i].controls._parent=null 
	} 
	window.onload=null 
} 
 
} //End dhtmlwindow object 
 
document.write('<div id="dhtmlwindowholder"><span style="display:none">.</span></div>') //container that holds all dhtml window divs on page 
window.onunload=dhtmlwindow.cleanup 
 
 
 
 
 
 
 
 
// ------------------------------------------------------------------- 
// DHTML Modal window- By Dynamic Drive, available at: http://www.dynamicdrive.com 
// v1.0: Script created Feb 27th, 07' 
// v1.01 May 5th, 07' Minor change to modal window positioning behavior (not a bug fix) 
// v1.1: April 16th, 08' Brings it in sync with DHTML Window widget. See changelog.txt for the later for changes. 
// REQUIRES: DHTML Window Widget (v1.01 or higher): http://www.dynamicdrive.com/dynamicindex8/dhtmlwindow/ 
// ------------------------------------------------------------------- 
 
if (typeof dhtmlwindow=="undefined") 
alert('ERROR: Modal Window script requires all files from "DHTML Window widget" in order to work!') 
 
var dhtmlmodal={ 
veilstack: 0, 
open:function(t, contenttype, contentsource, title, attr, recalonload){ 
	var d=dhtmlwindow //reference dhtmlwindow object 
	this.interVeil=document.getElementById("interVeil") //Reference "veil" div 
	this.veilstack++ //var to keep track of how many modal windows are open right now 
	this.loadveil() 
	if (recalonload=="recal" && d.scroll_top==0) 
		d.addEvent(window, function(){dhtmlmodal.adjustveil()}, "load") 
	var t=d.open(t, contenttype, contentsource, title, attr, recalonload) 
	t.controls.firstChild.style.display="none" //Disable "minimize" button 
	t.controls.onclick=function(){dhtmlmodal.close(this._parent, true)} //OVERWRITE default control action with new one 
	t.show=function(){dhtmlmodal.show(this)} //OVERWRITE default t.show() method with new one 
	t.hide=function(){dhtmlmodal.close(this)} //OVERWRITE default t.hide() method with new one 
return t 
}, 
 
 
loadveil:function(){ 
	var d=dhtmlwindow 
	d.getviewpoint() 
	this.docheightcomplete=(d.standardbody.offsetHeight>d.standardbody.scrollHeight)? d.standardbody.offsetHeight : d.standardbody.scrollHeight 
	this.interVeil.style.width=d.docwidth+"px" //set up veil over page 
	this.interVeil.style.height=this.docheightcomplete+"px" //set up veil over page 
	this.interVeil.style.left=0 //Position veil over page 
	this.interVeil.style.top=0 //Position veil over page 
	this.interVeil.style.visibility="visible" //Show veil over page 
	this.interVeil.style.display="block" //Show veil over page 
}, 
 
adjustveil:function(){ //function to adjust veil when window is resized 
	if (this.interVeil && this.interVeil.style.display=="block") //If veil is currently visible on the screen 
		this.loadveil() //readjust veil 
}, 
 
closeveil:function(){ //function to close veil 
	this.veilstack-- 
	if (this.veilstack==0) //if this is the only modal window visible on the screen, and being closed 
		this.interVeil.style.display="none" 
}, 
 
 
close:function(t, forceclose){ //DHTML modal close function 
	t.contentDoc=(t.contentarea.datatype=="iframe")? window.frames["_iframe-"+t.id].document : t.contentarea //return reference to modal window DIV (or document object in the case of iframe 
	if (typeof forceclose!="undefined") 
		t.onclose=function(){return true} 
	if (dhtmlwindow.close(t)) //if close() returns true 
		this.closeveil() 
}, 
 
 
show:function(t){ 
	dhtmlmodal.veilstack++ 
	dhtmlmodal.loadveil() 
	dhtmlwindow.show(t) 
} 
} //END object declaration 
 
 
document.write('<div id="interVeil"></div>') 
dhtmlwindow.addEvent(window, function(){if (typeof dhtmlmodal!="undefined") dhtmlmodal.adjustveil()}, "resize") 
 
 
 
 
/* Buy Now Area Javascript */ 
 
  function CreateTable(parentId, tableId, stepTitle, priceTitle) { 
    var rowCount = 3; 
    var colCount = 1; 
    var parent = document.getElementById(parentId); 
    var srcTable = document.createElement("table"); 
    srcTable.id = tableId; 
    srcTable.border = 0; 
    var tmpRow = null; 
    var tmpCell = null; 
    parent.appendChild(srcTable); 
    for(i=0; i<rowCount; i++) { 
      tmpRow = srcTable.insertRow(i); 
      for(j=0; j<colCount; j++) { 
        tmpCell = tmpRow.insertCell(j); 
        tmpCell.id = tableId + ':' + i + ':' + j; 
        tmpCell = null; 
      } 
      tmpRow = null; 
    } 
    var cell = document.getElementById(tableId + ':0:0'); 
    cell.appendChild(document.createTextNode(stepTitle)); 
    var cell = document.getElementById(tableId + ':1:0'); 
    cell.appendChild(document.createTextNode(priceTitle)); 
  } 
 
  function PopulateTableWithOpenSetControl(tableId, controlId, id, min) { 
    var cell = document.getElementById(tableId + ':2:0'); 
    var input = document.createElement('input'); 
    input.type = 'text'; 
    input.id = controlId; 
    input.name = controlId; 
    input.size = 10; 
    input.value = min; 
    input.onchange = function() {eval('validate' + id + '()');}; 
    cell.appendChild(input); 
    var warning = document.createElement('div'); 
    warning.id = 'warning' + id; 
    warning.name = 'warning' + id; 
//    warning.style.color('red'); 
    cell.appendChild(warning); 
  } 
 
  function PopulateTableWithClosedSetControl(tableId, controlId, options) { 
    var cell = document.getElementById(tableId + ':2:0'); 
    var select = document.createElement('select'); 
    select.id = controlId; 
    select.name = controlId; 
    select.size = 1; 
    var ix; 
    for (ix in options) { 
      var data = options[ix]; 
      var out = document.createElement('option'); 
      out.value = data[0].value; 
      out.innerHTML = data[0].label; 
      select.appendChild(out); 
    } 
    cell.appendChild(select); 
  } 
 
  function SetQuantityStepCount(parentId, count) { 
    var parent = document.getElementById(parentId); 
    var quantityStepCount = document.createTextNode(count); 
    parent.appendChild(quantityStepCount); 
  } 
 
/* END Buy Now Area Javascript */ 
 
 
function validatetab(tabid) { 
 
 var tab = document.getElementById(tabid); 
 
 switch (tabid) { 
 
  case 'tab0': 
 
   var fields = new Array(); 
   fields.push('billingName'); 
   fields.push('billingAddressLine1'); 
   fields.push('billingTown'); 
   fields.push('billingCode'); 
   fields.push('billingCountry'); 
   fields.push('phone'); 
   fields.push('email'); 
 
   if (validate(fields) == 'passed') { 
    if (document.getElementById('shippingOption1').checked) setShippingToBillingAddress(); 
    setConfirmBilling(); 
    tabs.expandit(1); 
   } 
   break; 
 
  case 'tab1': 
   var fields = new Array(); 
   fields.push('shippingName'); 
   fields.push('shippingAddressLine1'); 
   fields.push('shippingTown'); 
   fields.push('shippingCode'); 
   fields.push('shippingCountry'); 
 
   if (document.getElementById('shippingOption2').checked) { 
    if (validate(fields) == 'passed') { 
     setConfirmShipping(); 
     tabs.expandit(2); 
    } 
   } else { 
    resetShipping(); 
    setShippingToBillingAddress(); 
    setConfirmShipping(); 
    tabs.expandit(2); 
   } 
   break; 
 
  case 'tab2': 
   var fields = new Array(); 
   fields.push('ccName'); 
   fields.push('ccNumber'); 
   fields.push('ccExpire'); 
   fields.push('ccType'); 
   fields.push('ccSecurityCode'); 
 
   if (document.getElementById('paymentOption1').checked) { 
    var state = 'passed'; 
 
    state = validate(fields); 
 
    if (document.getElementById('ccType').value == 'Switch' 
    || document.getElementById('ccType').value == 'Delta' 
    || document.getElementById('ccType').value == 'Maestro' 
    || document.getElementById('ccType').value == 'Solo' 
    || document.getElementById('ccType').value == 'JCB' 
    ) { 
      fields = new Array(); 
      fields.push('ccStart'); 
      var stateStart = validate(fields); 
 
      fields = new Array(); 
      fields.push('ccIssue'); 
      var stateIssue = validate(fields); 
 
      if ((stateStart == 'passed') || (stateIssue == 'passed')) { 
        document.getElementById('ccStartPrompt').style.display = 'none'; 
        document.getElementById('ccIssuePrompt').style.display = 'none'; 
      } else { 
        state = 'failed'; 
      } 
    } 
    if (state == 'passed') { 
     setConfirmCC(); 
     tabs.expandit(3); 
    } 
   } else { 
    resetCC(); 
    setConfirmCC(); 
    tabs.expandit(3); 
   } 
   break; 
 
  default: 
 } 
} 
 
function validate(fields) { 
 var state = 'passed'; 
 
 for (var i = 0; i < fields.length; i++) { 
  var str = document.getElementById(fields[i]).value; 
  var prompt = document.getElementById(fields[i] + 'Prompt'); 
  var re = /.+/; 
  if (!str.match(re)) { 
   prompt.style.display = 'block'; 
   state = 'failed'; 
  } else { 
   prompt.style.display = 'none'; 
  } 
 } 
 return state; 
} 
 
function resetShipping() { 
 var fields = new Array(); 
 fields.push('shippingName'); 
 fields.push('shippingAddressLine1'); 
 fields.push('shippingAddressLine2'); 
 fields.push('shippingTown'); 
 fields.push('shippingCounty'); 
 fields.push('shippingCode'); 
 fields.push('shippingCountry'); 
 
 for (var i = 0; i < fields.length; i++) { 
  document.getElementById(fields[i]).value = ''; 
  document.getElementById(fields[i] + 'Prompt').style.display = 'none'; 
 } 
} 
 
function resetCC() { 
 var fields = new Array(); 
 fields.push('ccName'); 
 fields.push('ccNumber'); 
 fields.push('ccStart'); 
 fields.push('ccExpire'); 
 fields.push('ccType'); 
 fields.push('ccSecurityCode'); 
 fields.push('ccIssue'); 
 
 for (var i = 0; i < fields.length; i++) { 
  document.getElementById(fields[i]).value = ''; 
  document.getElementById(fields[i] + 'Prompt').style.display = 'none'; 
 } 
} 
 
function setShippingToBillingAddress() { 
 document.getElementById('shippingName').value = document.getElementById('billingName').value; 
 document.getElementById('shippingAddressLine1').value = document.getElementById('billingAddressLine1').value; 
 document.getElementById('shippingAddressLine2').value = document.getElementById('billingAddressLine2').value; 
 document.getElementById('shippingTown').value = document.getElementById('billingTown').value; 
 document.getElementById('shippingCounty').value = document.getElementById('billingCounty').value; 
 document.getElementById('shippingCode').value = document.getElementById('billingCode').value; 
 document.getElementById('shippingCountry').value = document.getElementById('billingCountry').value; 
} 
 
function setConfirmBilling() { 
 document.getElementById('billingNameConfirm').innerHTML = '<br>' + document.getElementById('billingName').value; 
 document.getElementById('billingAddressLine1Confirm').innerHTML = '<br>' + document.getElementById('billingAddressLine1').value; 
 if (document.getElementById('billingAddressLine2').value != '') { 
  document.getElementById('billingAddressLine2Confirm').innerHTML = '<br>' + document.getElementById('billingAddressLine2').value; 
  document.getElementById('billingAddressLine2Confirm').style.display = "block"; 
 } else { 
  document.getElementById('billingAddressLine2Confirm').innerHTML = ""; 
  document.getElementById('billingAddressLine2Confirm').style.display = "none"; 
 } 
 document.getElementById('billingTownConfirm').innerHTML = '<br>' + document.getElementById('billingTown').value; 
 if (document.getElementById('billingCounty').value != '') { 
  document.getElementById('billingCountyConfirm').innerHTML = '<br>' + document.getElementById('billingCounty').value; 
  document.getElementById('billingCountyConfirm').style.display = "block"; 
 } else { 
  document.getElementById('billingCountyConfirm').innerHTML = ""; 
  document.getElementById('billingCountyConfirm').style.display = "none"; 
 } 
 document.getElementById('billingCodeConfirm').innerHTML = '<br>' + document.getElementById('billingCode').value; 
 document.getElementById('billingCountryConfirm').innerHTML = '<br>' + document.getElementById('billingCountry').value; 
 document.getElementById('phoneConfirm').innerHTML = '<br>' + document.getElementById('phonePrefix').innerHTML + document.getElementById('phone').value; 
 document.getElementById('mobileConfirm').innerHTML = '<br>' + document.getElementById('mobilePrefix').innerHTML + document.getElementById('mobile').value; 
 document.getElementById('emailConfirm').innerHTML = '<br>' + document.getElementById('emailPrefix').innerHTML + document.getElementById('email').value; 
 if (document.getElementById('mailingList').checked) { 
  document.getElementById('mailingListConfirmYes').style.display = "block"; 
  document.getElementById('mailingListConfirmNo').style.display = "none"; 
 } else { 
  document.getElementById('mailingListConfirmYes').style.display = "none"; 
  document.getElementById('mailingListConfirmNo').style.display = "block"; 
 } 
 if (document.getElementById('foundBy').value != '') { 
  document.getElementById('foundByConfirm').innerHTML = '<br>' + document.getElementById('foundByPrefix').innerHTML + document.getElementById('foundBy').value.toLowerCase() + "."; 
  document.getElementById('foundByConfirm').style.display = "block"; 
 } else { 
  document.getElementById('foundByConfirm').innerHTML = ""; 
  document.getElementById('foundByConfirm').style.display = "none"; 
 } 
 if (document.getElementById('info').value != '') { 
  document.getElementById('infoConfirm').innerHTML = '<br>' + document.getElementById('infoPrefix').innerHTML + document.getElementById('info').value; 
  document.getElementById('infoConfirm').style.display = "block"; 
 } else { 
  document.getElementById('infoConfirm').innerHTML = ""; 
  document.getElementById('infoConfirm').style.display = "none"; 
 } 
} 
 
function setConfirmShipping() { 
 if (document.getElementById('shippingOption1').checked) { 
  document.getElementById('shippingNameConfirm').innerHTML = ""; 
  document.getElementById('shippingAddressLine1Confirm').innerHTML = ""; 
  document.getElementById('shippingAddressLine2Confirm').innerHTML = ""; 
  document.getElementById('shippingTownConfirm').innerHTML = ""; 
  document.getElementById('shippingCountyConfirm').innerHTML = ""; 
  document.getElementById('shippingCodeConfirm').innerHTML = ""; 
  document.getElementById('shippingCountryConfirm').innerHTML = ""; 
 
  document.getElementById('shippingOptionConfirmMain').style.display = "block"; 
  document.getElementById('shippingOptionConfirmAlternative').style.display = "none"; 
  document.getElementById('shippingNameConfirm').style.display = "none"; 
  document.getElementById('shippingAddressLine1Confirm').style.display = "none"; 
  document.getElementById('shippingAddressLine2Confirm').style.display = "none"; 
  document.getElementById('shippingTownConfirm').style.display = "none"; 
  document.getElementById('shippingCountyConfirm').style.display = "none"; 
  document.getElementById('shippingCodeConfirm').style.display = "none"; 
  document.getElementById('shippingCountryConfirm').style.display = "none"; 
 } else { 
  document.getElementById('shippingNameConfirm').innerHTML = '<br>' + document.getElementById('shippingName').value; 
  document.getElementById('shippingAddressLine1Confirm').innerHTML = '<br>' + document.getElementById('shippingAddressLine1').value; 
  if (document.getElementById('shippingAddressLine2').value != '') { 
   document.getElementById('shippingAddressLine2Confirm').innerHTML = '<br>' + document.getElementById('shippingAddressLine2').value; 
   document.getElementById('shippingAddressLine2Confirm').style.display = "block"; 
  } else { 
   document.getElementById('shippingAddressLine2Confirm').innerHTML = ""; 
   document.getElementById('shippingAddressLine2Confirm').style.display = "none"; 
  } 
  document.getElementById('shippingTownConfirm').innerHTML = '<br>' + document.getElementById('shippingTown').value; 
  if (document.getElementById('shippingCounty').value != '') { 
   document.getElementById('shippingCountyConfirm').innerHTML = '<br>' + document.getElementById('shippingCounty').value; 
   document.getElementById('shippingCountyConfirm').style.display = "block"; 
  } else { 
   document.getElementById('shippingCountyConfirm').innerHTML = ""; 
   document.getElementById('shippingCountyConfirm').style.display = "none"; 
  } 
  document.getElementById('shippingCodeConfirm').innerHTML = '<br>' + document.getElementById('shippingCode').value; 
  document.getElementById('shippingCountryConfirm').innerHTML = '<br>' + document.getElementById('shippingCountry').value; 
 
  document.getElementById('shippingOptionConfirmMain').style.display = "none"; 
  document.getElementById('shippingOptionConfirmAlternative').style.display = "block"; 
  document.getElementById('shippingNameConfirm').style.display = "block"; 
  document.getElementById('shippingAddressLine1Confirm').style.display = "block"; 
  document.getElementById('shippingTownConfirm').style.display = "block"; 
  document.getElementById('shippingCodeConfirm').style.display = "block"; 
  document.getElementById('shippingCountryConfirm').style.display = "block"; 
 } 
} 
 
function setConfirmCC() { 
 if (document.getElementById('paymentOption1').checked) { 
  document.getElementById('ccNameConfirm').innerHTML = '<br>' + document.getElementById('ccNamePrefix').innerHTML + document.getElementById('ccName').value; 
  document.getElementById('ccNumberConfirm').innerHTML = '<br>' + document.getElementById('ccNumberPrefix').innerHTML + document.getElementById('ccNumber').value; 
  document.getElementById('ccExpireConfirm').innerHTML = '<br>' + document.getElementById('ccExpirePrefix').innerHTML + document.getElementById('ccExpire').value; 
  document.getElementById('ccTypeConfirm').innerHTML = '<br>' + document.getElementById('ccTypePrefix').innerHTML + document.getElementById('ccType').value; 
  document.getElementById('ccSecurityCodeConfirm').innerHTML = '<br>' + document.getElementById('ccSecurityCodePrefix').innerHTML + document.getElementById('ccSecurityCode').value; 
  if (document.getElementById('ccType').value == 'Switch' 
  || document.getElementById('ccType').value == 'Delta' 
  || document.getElementById('ccType').value == 'Maestro' 
  || document.getElementById('ccType').value == 'Solo' 
  || document.getElementById('ccType').value == 'JCB' 
  ) { 
   document.getElementById('ccStartConfirm').innerHTML = '<br>' + document.getElementById('ccStartPrefix').innerHTML + document.getElementById('ccStart').value; 
   document.getElementById('ccStartConfirm').style.display = "block"; 
   document.getElementById('ccIssueConfirm').innerHTML = '<br>' + document.getElementById('ccIssuePrefix').innerHTML + document.getElementById('ccIssue').value; 
   document.getElementById('ccIssueConfirm').style.display = "block"; 
  } else { 
   document.getElementById('ccStartConfirm').innerHTML = ""; 
   document.getElementById('ccStartConfirm').style.display = "none"; 
   document.getElementById('ccIssueConfirm').innerHTML = ""; 
   document.getElementById('ccIssueConfirm').style.display = "none"; 
  } 
 
  document.getElementById('paymentOptionConfirmCard').style.display = "block"; 
/* 
  document.getElementById('paymentOptionConfirmEmail').style.display = "none"; 
  document.getElementById('paymentOptionConfirmPhone').style.display = "none"; 
*/ 
  document.getElementById('paymentOptionConfirmContact').style.display = "none"; 
  document.getElementById('ccNameConfirm').style.display = "block"; 
  document.getElementById('ccNumberConfirm').style.display = "block"; 
  document.getElementById('ccExpireConfirm').style.display = "block"; 
  document.getElementById('ccTypeConfirm').style.display = "block"; 
  document.getElementById('ccSecurityCodeConfirm').style.display = "block"; 
 
 } else { 
/* 
  if (document.getElementById('paymentOption2').checked) { 
   document.getElementById('paymentOptionConfirmEmail').style.display = "block"; 
   document.getElementById('paymentOptionConfirmPhone').style.display = "none"; 
   document.getElementById('paymentOptionConfirm').style.display = "none"; 
  } 
  if (document.getElementById('paymentOption3').checked) { 
   document.getElementById('paymentOptionConfirmEmail').style.display = "none"; 
   document.getElementById('paymentOptionConfirmPhone').style.display = "block"; 
   document.getElementById('paymentOptionConfirm').style.display = "none"; 
  } 
*/ 
  if (document.getElementById('paymentOption4').checked) { 
/* 
   document.getElementById('paymentOptionConfirmEmail').style.display = "none"; 
   document.getElementById('paymentOptionConfirmPhone').style.display = "none"; 
*/ 
   document.getElementById('paymentOptionConfirmContact').style.display = "block"; 
  } 
  document.getElementById('ccNameConfirm').innerHTML = ""; 
  document.getElementById('ccNumberConfirm').innerHTML = ""; 
  document.getElementById('ccStartConfirm').innerHTML = ""; 
  document.getElementById('ccExpireConfirm').innerHTML = ""; 
  document.getElementById('ccTypeConfirm').innerHTML = ""; 
  document.getElementById('ccSecurityCodeConfirm').innerHTML = ""; 
  document.getElementById('ccIssueConfirm').innerHTML = ""; 
 
  document.getElementById('paymentOptionConfirmCard').style.display = "none"; 
  document.getElementById('ccNameConfirm').style.display = "none"; 
  document.getElementById('ccNumberConfirm').style.display = "none"; 
  document.getElementById('ccStartConfirm').style.display = "none"; 
  document.getElementById('ccExpireConfirm').style.display = "none"; 
  document.getElementById('ccTypeConfirm').style.display = "none"; 
  document.getElementById('ccSecurityCodeConfirm').style.display = "none"; 
  document.getElementById('ccIssueConfirm').style.display = "none"; 
 } 
} 

//Chrome CSS Drop Down Menu, Tab Content script v2.0, Slashdot Menu script, DHTML Window Widget - Dynamic Drive DHTML code library (www.dynamicdrive.com).
//This notice MUST stay intact for legal use.
//Visit Dynamic Drive at http://www.dynamicdrive.com/ for full source code
//Chrome Drop Down Menu v2.01- Author: Dynamic Drive (http://www.dynamicdrive.com)
//Last updated: November 14th 06- added iframe shim technique

var cssdropdown={
disappeardelay: 250, //set delay in miliseconds before menu disappears onmouseout
disablemenuclick: false, //when user clicks on a menu item with a drop down menu, disable menu item's link?
enableswipe: 1, //enable swipe effect? 1 for yes, 0 for no
enableiframeshim: 1, //enable "iframe shim" technique to get drop down menus to correctly appear on top of controls such as form objects in IE5.5/IE6? 1 for yes, 0 for no

//No need to edit beyond here////////////////////////
dropmenuobj: null, ie: document.all, firefox: document.getElementById&&!document.all, swipetimer: undefined, bottomclip:0,

getposOffset:function(what, offsettype){
var totaloffset=(offsettype=="left")? what.offsetLeft : what.offsetTop;
var parentEl=what.offsetParent;
while (parentEl!=null){
totaloffset=(offsettype=="left")? totaloffset+parentEl.offsetLeft : totaloffset+parentEl.offsetTop;
parentEl=parentEl.offsetParent;
}
return totaloffset;
},


swipeeffect:function(){
if (this.bottomclip<parseInt(this.dropmenuobj.offsetHeight)){
this.bottomclip+=10+(this.bottomclip/10) //unclip drop down menu visibility gradually
this.dropmenuobj.style.clip="rect(0 auto "+this.bottomclip+"px 0)"
}
else
return
this.swipetimer=setTimeout("cssdropdown.swipeeffect()", 10)
},

showhide:function(obj, e){
if (this.ie || this.firefox)
this.dropmenuobj.style.left=this.dropmenuobj.style.top="-500px"
if (e.type=="click" && obj.visibility==hidden || e.type=="mouseover"){
if (this.enableswipe==1){
if (typeof this.swipetimer!="undefined")
clearTimeout(this.swipetimer)
obj.clip="rect(0 auto 0 0)" //hide menu via clipping
this.bottomclip=0
this.swipeeffect()
}
obj.visibility="visible"
}
else if (e.type=="click")
obj.visibility="hidden"
},

iecompattest:function(){
return (document.compatMode && document.compatMode!="BackCompat")? document.documentElement : document.body
},

clearbrowseredge:function(obj, whichedge){
var edgeoffset=0
if (whichedge=="rightedge"){
var windowedge=this.ie && !window.opera? this.iecompattest().scrollLeft+this.iecompattest().clientWidth-15 : window.pageXOffset+window.innerWidth-15
this.dropmenuobj.contentmeasure=this.dropmenuobj.offsetWidth
if (windowedge-this.dropmenuobj.x < this.dropmenuobj.contentmeasure)  //move menu to the left?
edgeoffset=this.dropmenuobj.contentmeasure-obj.offsetWidth
}
else{
var topedge=this.ie && !window.opera? this.iecompattest().scrollTop : window.pageYOffset
var windowedge=this.ie && !window.opera? this.iecompattest().scrollTop+this.iecompattest().clientHeight-15 : window.pageYOffset+window.innerHeight-18
this.dropmenuobj.contentmeasure=this.dropmenuobj.offsetHeight
if (windowedge-this.dropmenuobj.y < this.dropmenuobj.contentmeasure){ //move up?
edgeoffset=this.dropmenuobj.contentmeasure+obj.offsetHeight
if ((this.dropmenuobj.y-topedge)<this.dropmenuobj.contentmeasure) //up no good either?
edgeoffset=this.dropmenuobj.y+obj.offsetHeight-topedge
}
}
return edgeoffset
},

dropit:function(obj, e, dropmenuID){
if (this.dropmenuobj!=null) //hide previous menu
this.dropmenuobj.style.visibility="hidden" //hide menu
this.clearhidemenu()
if (this.ie||this.firefox){
obj.onmouseout=function(){cssdropdown.delayhidemenu()}
obj.onclick=function(){return !cssdropdown.disablemenuclick} //disable main menu item link onclick?
this.dropmenuobj=document.getElementById(dropmenuID)
this.dropmenuobj.onmouseover=function(){cssdropdown.clearhidemenu()}
this.dropmenuobj.onmouseout=function(e){cssdropdown.dynamichide(e)}
this.dropmenuobj.onclick=function(){cssdropdown.delayhidemenu()}
this.showhide(this.dropmenuobj.style, e)
this.dropmenuobj.x=this.getposOffset(obj, "left")
this.dropmenuobj.y=this.getposOffset(obj, "top")
this.dropmenuobj.style.left=this.dropmenuobj.x-this.clearbrowseredge(obj, "rightedge")+"px"
this.dropmenuobj.style.top=this.dropmenuobj.y-this.clearbrowseredge(obj, "bottomedge")+obj.offsetHeight+1+"px"
this.positionshim() //call iframe shim function
}
},

positionshim:function(){ //display iframe shim function
if (this.enableiframeshim && typeof this.shimobject!="undefined"){
if (this.dropmenuobj.style.visibility=="visible"){
this.shimobject.style.width=this.dropmenuobj.offsetWidth+"px"
this.shimobject.style.height=this.dropmenuobj.offsetHeight+"px"
this.shimobject.style.left=this.dropmenuobj.style.left
this.shimobject.style.top=this.dropmenuobj.style.top
}
this.shimobject.style.display=(this.dropmenuobj.style.visibility=="visible")? "block" : "none"
}
},

hideshim:function(){
if (this.enableiframeshim && typeof this.shimobject!="undefined")
this.shimobject.style.display='none'
},

contains_firefox:function(a, b) {
while (b.parentNode)
if ((b = b.parentNode) == a)
return true;
return false;
},

dynamichide:function(e){
var evtobj=window.event? window.event : e
if (this.ie&&!this.dropmenuobj.contains(evtobj.toElement))
this.delayhidemenu()
else if (this.firefox&&e.currentTarget!= evtobj.relatedTarget&& !this.contains_firefox(evtobj.currentTarget, evtobj.relatedTarget))
this.delayhidemenu()
},

delayhidemenu:function(){
this.delayhide=setTimeout("cssdropdown.dropmenuobj.style.visibility='hidden'; cssdropdown.hideshim()",this.disappeardelay) //hide menu
},

clearhidemenu:function(){
if (this.delayhide!="undefined")
clearTimeout(this.delayhide)
},

startchrome:function(){
for (var ids=0; ids<arguments.length; ids++){
var menuitems=document.getElementById(arguments[ids]).getElementsByTagName("a")
for (var i=0; i<menuitems.length; i++){
if (menuitems[i].getAttribute("rel")){
var relvalue=menuitems[i].getAttribute("rel")
menuitems[i].onmouseover=function(e){
var event=typeof e!="undefined"? e : window.event
cssdropdown.dropit(this,event,this.getAttribute("rel"))
}
}
}
}
if (window.createPopup && !window.XmlHttpRequest){ //if IE5.5 to IE6, create iframe for iframe shim technique
document.write('<IFRAME id="iframeshim"  src="" style="display: none; left: 0; top: 0; z-index: 90; position: absolute; filter: progid:DXImageTransform.Microsoft.Alpha(style=0,opacity=0)" frameBorder="0" scrolling="no"></IFRAME>')
this.shimobject=document.getElementById("iframeshim") //reference iframe object
}
}

}


