// Determine browser.
    var NS4 = (document.layers);
    var IE4 = (document.all);
    var IE5 = (IE4 && navigator.appVersion.indexOf("5.")!=-1);
  var isMac = (navigator.appVersion.indexOf("Mac") != -1);
var isDHTML = (NS4 || (IE4 && !isMac) || (IE5 && isMac));

// reload protection for NS4 Browsers 
if (NS4) {
	origWidth = innerWidth;
	origHeight = innerHeight;
}
function IG_reDoNS() {
	if (innerWidth != origWidth || innerHeight != origHeight) location.reload();
}
if (NS4) onresize = IG_reDoNS;
//----------------------------------------------------------------
// Layer visibility.
//----------------------------------------------------------------

function IG_setLayerVis(layer, bVis) {

  if (NS4)
    layer.visibility = (bVis)? "show" : "hide";
  if (IE4)
    layer.style.visibility = (bVis)? "visible" : "hidden";
}

function IG_isVisible(layer) {

  if (NS4 && layer.visibility == "show")
    return(true);
  if (IE4 && layer.style.visibility == "visible")
    return(true);

  return(false);
}

//----------------------------------------------------------------
// Layer positioning.
//----------------------------------------------------------------

function IG_moveLayerTo(layer, x, y) {

  if (NS4)
    layer.moveTo(x, y);
  if (IE4) {
    layer.style.left = x;
    layer.style.top  = y;
  }
}

function IG_moveLayerBy(layer, dx, dy) {

  if (NS4)
    layer.moveBy(dx, dy);
  if (IE4) {
    layer.style.pixelLeft += dx;
    layer.style.pixelTop  += dy;
  }
}

function IG_getLayerLeft(layer) {

  if (NS4)
    return(layer.left);
  if (IE4)
    return(layer.style.pixelLeft);
  return(-1);
}

function IG_getLayerTop(layer) {

  if (NS4)
    return(layer.top);
  if (IE4)
    return(layer.style.pixelTop);
  return(-1);
}

function IG_getRight(layer) {

  if (NS4)
    return(layer.left + getWidth(layer));
  if (IE4)
    return(layer.style.pixelLeft + getWidth(layer));
  return(-1);
}

function IG_getBottom(layer) {

  if (NS4)
    return(layer.top + getHeight(layer));
  else if (IE4)
    return(layer.style.pixelTop + getHeight(layer));
  return(-1);
}

function IG_getPageLeft(layer) {

  if (NS4)
    return(layer.pageX);
  if (IE4)
    return(layer.offsetLeft);
  return(-1);
}

function IG_getPageTop(layer) {

  if (NS4)
    return(layer.pageY);
  if (IE4)
    return(layer.offsetTop);
  return(-1);
}

function IG_getWidth(layer) {

  if (NS4) {
    if (layer.document.width)
      return(layer.document.width);
    else
      return(layer.clip.right - layer.clip.left);
  }
  if (IE4) {
    if (layer.style.pixelWidth)
      return(layer.style.pixelWidth);
    else
      return(layer.clientWidth);
  }
  return(-1);
}

function IG_getHeight(layer) {

  if (NS4) {
    if (layer.document.height)
      return(layer.document.height);
    else
      return(layer.clip.bottom - layer.clip.top);
  }
  if (IE4) {
    if (false && layer.style.pixelHeight)
      return(layer.style.pixelHeight);
    else
      return(layer.clientHeight);
  }
  return(-1);
}

function IG_getzIndex(layer) {

  if (NS4)
    return(layer.zIndex);
  if (IE4)
    return(layer.style.zIndex);

  return(-1);
}

function IG_setzIndex(layer, z) {

  if (NS4)
    layer.zIndex = z;
  if (IE4)
    layer.style.zIndex = z;
}

//----------------------------------------------------------------
// Layer clipping.
//----------------------------------------------------------------
function IG_clipLayer(layer, clipleft, cliptop, clipright, clipbottom) {

  if (NS4) {
    layer.clip.left   = clipleft;
    layer.clip.top    = cliptop;
    layer.clip.right  = clipright;
    layer.clip.bottom = clipbottom;
  }
  if (IE4)
    layer.style.clip = 'rect(' + cliptop + ' ' +  clipright + ' ' + clipbottom + ' ' + clipleft +')';
}

function IG_getClipLeft(layer) {

  if (NS4)
    return(layer.clip.left);
  if (IE4) {
    var str =  layer.style.clip;
    if (!str)
      return(0);
    var clip = IG_getIEClipValues(layer.style.clip);
    return(clip[3]);
  }
  return(-1);
}

function IG_getClipTop(layer) {

  if (NS4)
    return(layer.clip.top);
  if (IE4) {
    var str =  layer.style.clip;
    if (!str)
      return(0);
    var clip = IG_getIEClipValues(layer.style.clip);
    return(clip[0]);
  }
  return(-1);
}

function IG_getClipRight(layer) {

  if (NS4)
    return(layer.clip.right);
  if (IE4) {
    var str =  layer.style.clip;
    if (!str)
      return(layer.style.pixelWidth);
    var clip = IG_getIEClipValues(layer.style.clip);
    return(clip[1]);
  }
  return(-1);
}

function IG_getClipBottom(layer) {

  if (NS4)
    return(layer.clip.bottom);
  if (IE4) {
    var str =  layer.style.clip;
    if (!str)
      return(layer.style.pixelHeight);
    var clip = IG_getIEClipValues(layer.style.clip);
    return(clip[2]);
  }
  return(-1);
}

function IG_getClipWidth(layer) {

  if (NS4)
    return(layer.clip.width);
  if (IE4) {
    var str = layer.style.clip;
    if (!str)
      return(layer.style.pixelWidth);
    var clip = IG_getIEClipValues(layer.style.clip);
    return(clip[1] - clip[3]);
  }
  return(-1);
}

function IG_getClipHeight(layer) {

  if (NS4)
    return(layer.clip.height);
  if (IE4) {
    var str =  layer.style.clip;
    if (!str)
      return(layer.style.pixelHeight);
    var clip = IG_getIEClipValues(layer.style.clip);
    return(clip[2] - clip[0]);
  }
  return(-1);
}

function IG_getIEClipValues(str) {

  var clip = new Array();
  var i;

  // Parse out the clipping values for IE layers.

  i = str.indexOf("(");
  clip[0] = parseInt(str.substring(i + 1, str.length), 10);
  i = str.indexOf(" ", i + 1);
  clip[1] = parseInt(str.substring(i + 1, str.length), 10);
  i = str.indexOf(" ", i + 1);
  clip[2] = parseInt(str.substring(i + 1, str.length), 10);
  i = str.indexOf(" ", i + 1);
  clip[3] = parseInt(str.substring(i + 1, str.length), 10);
  return(clip);
}

//----------------------------------------------------------------
// Layer scrolling.
//----------------------------------------------------------------
function IG_scrollLayerTo(layer, x, y, bound) {

  var dx = IG_getClipLeft(layer) - x;
  var dy = IG_getClipTop(layer) - y;

  IG_scrollLayerBy(layer, -dx, -dy, bound);
}

function IG_scrollLayerBy(layer, dx, dy, bound) {

  var cl = IG_getClipLeft(layer);
  var ct = IG_getClipTop(layer);
  var cr = IG_getClipRight(layer);
  var cb = IG_getClipBottom(layer);

  if (bound) {
    if (cl + dx < 0)

      dx = -cl;

    else if (cr + dx > IG_getWidth(layer))
      dx = IG_getWidth(layer) - cr;
    if (ct + dy < 0)

      dy = -ct;

    else if (cb + dy > IG_getHeight(layer))
      dy = IG_getHeight(layer) - cb;
  }

  IG_clipLayer(layer, cl + dx, ct + dy, cr + dx, cb + dy);
  IG_moveLayerBy(layer, -dx, -dy);
}

//----------------------------------------------------------------
// Layer background.
//----------------------------------------------------------------
function IG_setBgColor(layer, color) {

  if (NS4)
    layer.bgColor = color;
  if (IE4)
    layer.style.backgroundColor = color;
}

function IG_setBgImage(layer, src) {

  if (NS4)
    layer.background.src = src;
  if (IE4)
    layer.style.backgroundImage = "url(" + src + ")";
}

//----------------------------------------------------------------
// Layer utilities.
//----------------------------------------------------------------
function IG_beginLayer(objBase,strName,z,vis,l,t,w,h,extra,ieStyleExtra){
	
	if (h==null) h=0;  
	if (w==null) w='100%';  
	if (w==0) w=1;  
	if (t==null) t=0;  
	if (l==null) l=0;  
	(vis==false)? vis= (IE4)? "hidden" : "hide" : vis= (IE4)? "visible" : "show";
	if (vis==null) vis= (IE4)? "hidden" : "hide";  
	if (z==null) z=10; 
	if (extra==null) extra='';   
	if (ieStyleExtra==null) ieStyleExtra='';   
	if (IE4){ 
		var px = (isNaN(w))? '':'px'; 
	}
	if (IE4){
		document.write('<DIV ID="'+strName+'" STYLE="position:absolute; overflow:none; left:'+l+'px; top:'+t+'px; width:'+w+px+'; height:'+h+'px; visibility:'+vis+'; z-index:'+z+';');
		if (ieStyleExtra.length > 0){
			document.write(' '+ieStyleExtra);
		}
		document.writeln('" '+extra+'>');
	}
	if (NS4){
		objBase.document.writeln('<LAYER NAME="'+strName+'" left="'+l+'" top="'+t+'" width="'+w+'" height="'+h+'" visibility="'+vis+'" z-index="'+z+'" '+extra+'>'); 
	}
}
	
function IG_writeLayer(objBase,strName,content,z,vis,l,t,w,h,extra){
	IG_beginLayer(objBase,strName,z,vis,l,t,w,h,extra);
	if (IE4) document.writeln(content +'</DIV>');
	if (NS4) objBase.document.writeln(content +'</LAYER>'); 
}
	
function IG_endLayer(objBase){ 
	if (IE4) {document.writeln('</DIV>');}
	if (NS4) {objBase.document.writeln('</LAYER>');} 
}

function IG_setLayerResize(layer, nWidth, nHeight) {
	if (layer==null) layer=this; 
	
	if (IE4){
		layer.style.width = nWidth;
		layer.style.height = nHeight;
		return;
	} 
	
	if (NS4){
		layer.resizeTo(nWidth, nHeight);
		return;
	} 
}

function IG_setLayerContent(layer, strText) {
		
	if (NS4){
		layer.document.open();
		layer.document.write(strText);
		layer.document.close();
	}
	else if (IE4){
		layer.innerHTML = strText;
	}
}

function IG_findLayer(name, doc) {

  var i, layer;

  for (i = 0; i < doc.layers.length; i++) {
    layer = doc.layers[i];
    if (layer.name == name)
      return layer;
    if (layer.document.layers.length > 0) {
      layer = IG_findLayer(name, layer.document);
      if (layer != null)
        return layer;
    }
  }

  return null;
}


function IG_getLayer(name) {
name=name
  if (NS4){
    return IG_findLayer(name, document);}
  if (IE4){
    return document.all[name];}

  return null;
}


//----------------------------------------------------------------
// Window and page properties.
//----------------------------------------------------------------

function IG_getWindowWidth() {

  if (NS4)
    return(window.innerWidth);
  if (IE4)
    return(document.body.clientWidth);
  return(-1);
}

function IG_getWindowHeight() {

  if (NS4)
    return(window.innerHeight);
  if (IE4)
    return(document.body.clientHeight);
  return(-1);
}

function IG_getPageWidth() {

  if (NS4)
    return(document.width);
  if (IE4)
    return(document.body.scrollWidth);
  return(-1);
}

function IG_getPageHeight() {

  if (NS4)
    return(document.height);
  if (IE4)
    return(document.body.scrollHeight);
  return(-1);
}

function IG_getPageScrollX() {

  if (NS4)
    return(window.pageXOffset);
  if (IE4)
    return(document.body.scrollLeft);
  return(-1);
}

function IG_getPageScrollY() {

  if (NS4)
    return(window.pageYOffset);
  if (IE4)
    return(document.body.scrollTop);
  return(-1);
}

//----------------------------------------------------------------
// Functions to get anchor locations in the document.
// make sure to call this function after the page loads
//----------------------------------------------------------------
function IG_getLeft(ll) {
  if (ll.offsetParent){return (ll.offsetLeft + IG_getLeft(ll.offsetParent));}
  else {return (ll.offsetLeft);}
}

function IG_getTop(ll) {
  if (ll.offsetParent){return (ll.offsetTop + IG_getTop(ll.offsetParent));}
  else {return (ll.offsetTop);}
}

function IG_getAnchorPos(anchorName, valNeeded){
  if (anchorName==null && valNeeded==null && (this)){
	anchorName = this.anchorName;
	this.anchorObj = (IE4) ? eval("document.all['"+anchorName+"']") : 	eval("document.anchors['"+anchorName+"']");

    if (IE4){
        this.topanchorPos = IG_getTop(this.anchorObj);
        this.leftanchorPos = IG_getLeft(this.anchorObj);
    }
    if (NS4){
        this.topanchorPos = this.anchorObj.y;
        this.leftanchorPos = this.anchorObj.x;
    }
    return;
  }
  anchorObj = (IE4)? eval("document.all['"+anchorName+"']") : 	eval("document.anchors['"+anchorName+"']");
  if (valNeeded=="left"){return (IE4)? IG_getLeft(anchorObj) : anchorObj.x;}
  if (valNeeded=="top"){return (IE4)? IG_getTop(anchorObj) : anchorObj.y;}
}