// JavaScript Document// begin absolutely positioned scrollable area object scripts /*Extension developed by David G. Miles (www.z3roadster.net/dreamweaver)Original Scrollable Area code developed by Thomas Brattli To add more shock to your site, visit www.DHTML Shock.com*/function verifyCompatibleBrowser(){     this.ver=navigator.appVersion     this.dom=document.getElementById?1:0     this.ie5=(this.ver.indexOf("MSIE 5")>-1 && this.dom)?1:0;     this.ie4=(document.all && !this.dom)?1:0;     this.ns5=(this.dom && parseInt(this.ver) >= 5) ?1:0;      this.ns4=(document.layers && !this.dom)?1:0;     this.bw=(this.ie5 || this.ie4 || this.ns4 || this.ns5)     return this } bw=new verifyCompatibleBrowser()   var speed=50  var loop, timer  function ConstructObject(obj,nest){     nest=(!nest) ? '':'document.'+nest+'.'     this.el=bw.dom?document.getElementById(obj):bw.ie4?document.all[obj]:bw.ns4?eval(nest+'document.'+obj):0;     this.css=bw.dom?document.getElementById(obj).style:bw.ie4?document.all[obj].style:bw.ns4?eval(nest+'document.'+obj):0;     this.scrollHeight=bw.ns4?this.css.document.height:this.el.offsetHeight     this.clipHeight=bw.ns4?this.css.clip.height:this.el.offsetHeight     this.up=MoveAreaUp;this.down=MoveAreaDown;     this.MoveArea=MoveArea; this.x; this.y;     this.obj = obj + "Object"     eval(this.obj + "=this")     return this } function MoveArea(x,y){     this.x=x;this.y=y     this.css.left=this.x     this.css.top=this.y }  function MoveAreaDown(move){ 	if(this.y>-this.scrollHeight+objContainer.clipHeight){     this.MoveArea(0,this.y-move)     if(loop) setTimeout(this.obj+".down("+move+")",speed) 	} } function MoveAreaUp(move){ 	if(this.y<0){     this.MoveArea(0,this.y-move)     if(loop) setTimeout(this.obj+".up("+move+")",speed) 	} }  function PerformScroll(speed){ 	if(initialised){ 		loop=true; 		if(speed>0) objScroller.down(speed) 		else objScroller.up(speed) 	} }  function CeaseScroll(){     loop=false     if(timer) clearTimeout(timer) } var initialised; function InitialiseScrollableArea(){     objContainer=new ConstructObject('container')     objScroller=new ConstructObject('content','container')     objScroller.MoveArea(0,0)     objContainer.css.visibility='visible'     initialised=true; } // end absolutely positioned scrollable area object scripts // Rollover  v2.0.1// documentation: http://www.dithered.com/javascript/rollover/index.html// license: http://creativecommons.org/licenses/by/1.0/// code by Chris Nott (chris[at]dithered[dot]com)function isDefined(property) {  return (typeof property != 'undefined');}var rolloverInitialized = false;function rolloverInit() {   if (!rolloverInitialized && isDefined(document.images)) {            // get all images (including all <input type="image">s)      // use getElementsByTagName() if supported      var images = new Array();      if (isDefined(document.getElementsByTagName)) {         images = document.getElementsByTagName('img');         var inputs = document.getElementsByTagName('input');         for (var i = 0; i < inputs.length; i++) {            if (inputs[i].type == 'image') {               images[images.length] = inputs[i];            }         }      }            // otherwise, use document.images and document.forms collections      // remove if not supporting IE4, Opera 4-5      else {         images = document.images;         inputs = new Array();         for (var formIndex = 0; formIndex < document.forms.length; formIndex++) {            for (var elementIndex = 0; elementIndex < document.forms.elements.length; elementIndex++) {               if (isDefined(document.forms.elements[i].src)) {                  inputs[inputs.length] = document.forms.elements[i];               }            }         }      }            // get all images with '_off.' in src value      for (var i = 0; i < images.length; i++) {         if (images[i].src.indexOf('_off.') != -1) {            var image = images[i];                        // store the off state filename in a property of the image object            image.offImage = new Image();            image.offImage.src = image.src;                        // store the on state filename in a property of the image object            // (also preloads the on state image)            image.onImage = new Image();            image.onImage.imageElement = image;                        // add onmouseover and onmouseout event handlers once the on state image has loaded            // Safari's onload is screwed up for off-screen images; temporary fix            if (navigator.userAgent.toLowerCase().indexOf('safari') != - 1) {               image.onmouseover = function() {                  this.src = this.onImage.src;               };               image.onmouseout = function() {                  this.src = this.offImage.src;               };            }            else {               image.onImage.onload = function() {                  this.imageElement.onmouseover = function() {                     this.src = this.onImage.src;                  };                  this.imageElement.onmouseout = function() {                     this.src = this.offImage.src;                  };               };            }                        // set src of on state image after defining onload event handler            // so cached images (that load instantly in IE) will trigger onload            image.onImage.src = image.src.replace(/_off\./, '_on.');         }      }   }   rolloverInitialized = true;}// call rolloverInit when document finishes loadingif (isDefined(window.addEventListener)) {   window.addEventListener('load', rolloverInit, false);}else if (isDefined(window.attachEvent)) {   window.attachEvent('onload', rolloverInit);}