From: <Saved by Windows Internet Explorer 7>
Subject: Natural gas: Two oil-field companies acknowledge fracking with diesel -- 02/19/2010 -- www.eenews.net
Date: Fri, 19 Feb 2010 13:35:58 -0600
MIME-Version: 1.0
Content-Type: multipart/related;
	type="text/html";
	boundary="----=_NextPart_000_0000_01CAB168.786EE890"
X-MimeOLE: Produced By Microsoft MimeOLE V6.00.2900.3350

This is a multi-part message in MIME format.

------=_NextPart_000_0000_01CAB168.786EE890
Content-Type: text/html;
	charset="utf-8"
Content-Transfer-Encoding: quoted-printable
Content-Location: http://www.eenews.net/Greenwire/print/2010/02/19/1

=EF=BB=BF<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" =
"http://www.w3c.org/TR/1999/REC-html401-19991224/loose.dtd">
<HTML><HEAD><TITLE>Natural gas: Two oil-field companies acknowledge =
fracking with diesel -- 02/19/2010 -- www.eenews.net</TITLE>
<META http-equiv=3DContent-Type content=3D"text/html; charset=3Dutf-8">
<META=20
content=3D"Two of the world's largest oil-field services companies have =
acknowledged to Congress that they used diesel in hydraulic fracturing =
after telling federal regulators they would stop injecting the fuel near =
underground water supplies. Halliburton and BJ Services acknowledged to =
the House Oversight and Government Reform Committee in January 2008 that =
they had used diesel in the controversial process that has expanded =
access to vast natural gas plays. "=20
name=3Ddescription>
<META content=3D"natural gas" name=3Dkeywords><LINK media=3Dscreen=20
href=3D"http://www.eenews.net/stylesheets/structural_styles.css?126564549=
8"=20
type=3Dtext/css rel=3DStylesheet><LINK media=3Dall=20
href=3D"http://www.eenews.net/rcss/2/new_dyn_pub_styles.css?1265230466"=20
type=3Dtext/css rel=3DStylesheet><LINK media=3Dprint=20
href=3D"http://www.eenews.net/stylesheets/printer_styles.css?1265230393" =

type=3Dtext/css rel=3DStylesheet>
<SCRIPT =
src=3D"http://www.eenews.net/javascripts/prototype.js?1218125236"=20
type=3Dtext/javascript></SCRIPT>

<SCRIPT src=3D"http://www.eenews.net/javascripts/effects.js?1218125236"=20
type=3Dtext/javascript></SCRIPT>

<SCRIPT src=3D"http://www.eenews.net/javascripts/dragdrop.js?1218125236" =

type=3Dtext/javascript></SCRIPT>

<SCRIPT src=3D"http://www.eenews.net/javascripts/controls.js?1218125236" =

type=3Dtext/javascript></SCRIPT>

<SCRIPT =
src=3D"http://www.eenews.net/javascripts/application.js?1181426390"=20
type=3Dtext/javascript></SCRIPT>

<SCRIPT =
src=3D"http://www.eenews.net/javascripts/custom_effects.js?1181426390"=20
type=3Dtext/javascript></SCRIPT>

<SCRIPT language=3DJavaScript>=0A=
<!--=0A=
function MM_jumpMenu(targ,selObj,restore){ //v3.0=0A=
  =
eval(targ+".location=3D'"+selObj.options[selObj.selectedIndex].value+"'")=
;=0A=
  if (restore) selObj.selectedIndex=3D0;=0A=
}=0A=
//-->=0A=
</SCRIPT>
<!--[if lte ie 6]>=0A=
=0A=
<link=0A=
  rel=3D"stylesheet"=0A=
  type=3D"text/css"=0A=
  href=3D"/rcss/2/ie_6_and_below_dyn.css"=0A=
/>=0A=
=0A=
<![endif]--><LINK=20
title=3D"Greenwire -- The Leader in Energy &amp; Environmental Policy =
News"=20
href=3D"/rss/greenwire.xml" type=3Dapplication/rss+xml rel=3Dalternate>
<META content=3D"MSHTML 6.00.6000.16981" name=3DGENERATOR></HEAD>
<BODY><A id=3Dtop name=3Dtop></A>
<DIV id=3Dheader_container>
<DIV class=3Dheader_leaderboard><!--/* OpenX Javascript Tag v2.6.5 */-->
<SCRIPT type=3Dtext/javascript><!--//<![CDATA[
   var m3_u =3D =
(location.protocol=3D=3D'https:'?'https://adserver.eenews.net/www/deliver=
y/ajs.php':'http://adserver.eenews.net/www/delivery/ajs.php');
   var m3_r =3D Math.floor(Math.random()*99999999999);
   if (!document.MAX_used) document.MAX_used =3D ',';
   document.write ("<scr"+"ipt type=3D'text/javascript' src=3D'"+m3_u);
   document.write =
("?zoneid=3D18&amp;source=3Dheader&amp;target=3D_blank");
   document.write ('&amp;cb=3D' + m3_r);
   if (document.MAX_used !=3D ',') document.write ("&amp;exclude=3D" + =
document.MAX_used);
   document.write (document.charset ? '&amp;charset=3D'+document.charset =
: (document.characterSet ? '&amp;charset=3D'+document.characterSet : =
''));
   document.write ("&amp;loc=3D" + escape(window.location));
   if (document.referrer) document.write ("&amp;referer=3D" + =
escape(document.referrer));
   if (document.context) document.write ("&context=3D" + =
escape(document.context));
   if (document.mmm_fo) document.write ("&amp;mmm_fo=3D1");
   document.write ("'><\/scr"+"ipt>");
//]]>--></SCRIPT>
<NOSCRIPT><A=20
href=3D"http://adserver.eenews.net/www/delivery/ck.php?n=3Da1c74cbf&amp;c=
b=3D0.143783841752006"=20
target=3D_blank><IMG alt=3D""=20
src=3D"http://adserver.eenews.net/www/delivery/avw.php?zoneid=3D18&amp;so=
urce=3Dheader&amp;n=3Da1c74cbf"=20
border=3D0></A></NOSCRIPT> </DIV>
<DIV class=3Dpubs_nav_new id=3Dnavigation>
<UL>
  <LI><A class=3Dsecondary_top_links =
href=3D"http://www.eenews.net/">E&amp;E=20
  Home</A>=20
  <LI><A class=3Dsecondary_top_links=20
  href=3D"http://www.eenews.net/eep/learn_more/">About</A>=20
  <LI><A class=3Dsecondary_top_links=20
  =
href=3D"http://www.eenews.net/eep/learn_more/staff_directory">Contact</A>=
=20
  <LI><A class=3Dsecondary_top_links_trial=20
  href=3D"http://www.eenews.net/trial">Start a Trial</A>=20
  <LI><A class=3D"secondary_top_links_trial secondary_top_links_last"=20
  href=3D"http://www.eenews.net/subscribe">Subscribe</A> </LI></UL>
<UL>
  <LI><A class=3Dtab_cw =
href=3D"http://www.eenews.net/cw/">ClimateWire</A>=20
  <LI><A class=3Dtab_eed =
href=3D"http://www.eenews.net/eed/">E&amp;E&nbsp;Daily</A>=20
  <LI><A class=3Dtabcurrent =
href=3D"http://www.eenews.net/gw/">Greenwire</A>=20
  <LI><A class=3Dtab_pm =
href=3D"http://www.eenews.net/pm/">E&amp;ENews&nbsp;PM</A>=20
  <LI style=3D"MARGIN-RIGHT: -2px">=20
  <LI><A class=3Dtab_tv href=3D"http://www.eenews.net/tv/">E&amp;ETV</A> =

  <LI><A class=3Dtab_ll =
href=3D"http://www.eenews.net/ll/">Land&nbsp;Letter</A>=20
  <LI><A class=3Dtab_sr =
href=3D"http://www.eenews.net/special_reports">Reports</A>=20
  </LI></UL></DIV>
<DIV id=3Dheader><IMG class=3Dtagline=20
alt=3D"Greenwire -- The Leader in Energy &amp; Environmental Policy =
News"=20
src=3D"http://www.eenews.net/images/greenwire_tagline.gif?1265230393" =
border=3D0> <A=20
title=3D"Greenwire -- The Leader in Energy &amp; Environmental Policy =
News"=20
href=3D"http://www.eenews.net/gw/"><IMG class=3Dlogo=20
alt=3D"Greenwire -- The Leader in Energy &amp; Environmental Policy =
News"=20
src=3D"http://www.eenews.net/images/greenwire_header_new2.gif?1265230393"=
=20
border=3D0></A> </DIV></DIV>
<DIV id=3Dcontent_container>
<DIV class=3Dsite_container>
<TABLE class=3Dedition_date cellSpacing=3D0 cellPadding=3D0 border=3D0>
  <TBODY>
  <TR>
    <TD id=3Ded_left>
      <DIV class=3Drecent_editions_tabs>
      <P><A class=3Dbreadcrumb_link=20
      =
href=3D"http://www.eenews.net/gw/2010/02/19/"><STRONG>&lt;&lt;</STRONG> =
Back=20
      to table of contents</A> </P></DIV></TD>
    <TD id=3Ded_right>
      <FORM class=3Dsearch_box action=3D/search method=3Dget><LABEL><A=20
      title=3D"Search Stories and Videos"=20
      href=3D"http://www.eenews.net/search">Search:</A></LABEL> <INPUT=20
      class=3Dsearch onfocus=3Dthis.select() size=3D22 value=3D"Enter =
keyword"=20
      name=3Dkeyword><INPUT type=3Dsubmit value=3Dgo! name=3Dcommit>=20
  </FORM></TD></TR></TBODY></TABLE>
<DIV class=3Dzones_container>
<DIV class=3Dzones_inner_container>
<DIV class=3Dstory_well>
<H2 style=3D"MARGIN-TOP: 3em">1. <SPAN>NATURAL GAS:</SPAN> Two oil-field =
companies=20
acknowledge fracking with diesel <SPAN =
class=3Dorigin>(02/19/2010)</SPAN></H2>
<H5 class=3Dreporter>Mike Soraghan, E&amp;E reporter</H5>
<P>Two of the world's largest oil-field services companies have =
acknowledged to=20
Congress that they used diesel in hydraulic fracturing after telling =
federal=20
regulators they would stop injecting the fuel near underground water=20
supplies.</P>
<P>Halliburton and BJ Services acknowledged to the House Oversight and=20
Government Reform Committee in January 2008 that they had used diesel in =
the=20
controversial process that has expanded access to vast natural gas =
plays.</P>
<P>BJ Services acknowledged it had violated a December 2003 "memorandum =
of=20
agreement" that it and other companies signed with U.S. EPA agreeing to =
limit=20
the amount of diesel they use in fracturing.</P>
<P>The chairman of the oversight panel at the time, Democrat Henry =
Waxman=20
(Calif.) is now chairman of the Energy and Commerce Committee, which =
launched an=20
investigation yesterday into fracturing practices.</P>
<P>The companies' acknowledgement was included in a memo from Waxman to=20
committee members that was released to the public yesterday with the=20
announcement of the probe. Waxman said that after sending questions to =
major=20
fracturing companies, a BJ Services attorney reported that the company =
used=20
1,706 gallons of diesel-based slurry in two dozen coalbed methane =
fracturing=20
jobs in Arkansas and Oklahoma from 2005 to 2007.</P>
<P>"In a letter to the Oversight Committee, counsel for BJ Services =
acknowledged=20
that these events 'were in violation of the MOA' and expressed a =
commitment to=20
uncovering how they occurred," Waxman's memo states. The letter also =
says, "BJ=20
Services subsequently sent a reminder to 'all employees who design or =
perform=20
fracturing operations about the requirements of the MOA.'"</P>
<P>As part of the same oversight committee investigation, Halliburton =
reported=20
using fluids containing diesel fuel from 2005 to 2007 to fracture oil =
and gas=20
wells in 15 states. Specifically, Halliburton reported using more than =
807,000=20
gallons of seven diesel-based fluids over the three-year period.</P>
<P>Waxman's memo says the companies didn't specify whether the fluids =
were=20
injected into wells located in or near underground sources of drinking =
water,=20
which could create contamination risks. In addition, the memo says, it =
could be=20
a violation of the Safe Drinking Water Act if the fluids contain diesel=20
fuel.</P>
<P>Hydraulic fracturing blasts sand, water and chemicals deep into a =
wellbore to=20
break compact rock. Though the industry has used the process for =
decades,=20
questions about drinking have mounted in the past few years as the =
process has=20
opened up vast reserves in new areas, such as Texas and New York.</P>
<P>Halliburton officials said the suggestions that its use of diesel may =
have=20
violated the agreement are "completely inaccurate."</P>
<P>"The terms of the MOA specifically cover coalbed methane gas =
development=20
activities occurring in association with Underground Sources of Drinking =
Water,=20
and not [fracturing] projects in other unconventional gas development =
activities=20
or conventional formations," company spokeswoman Diana Gabriel said in a =
written=20
statement to E&amp;E. "Halliburton is firmly committed to full =
compliance with=20
the MOA and has, in fact, voluntarily gone further to cease the use of =
diesel in=20
its liquid gel concentrates regardless of the type of [fracturing] job =
in which=20
they are used."</P>
<P>But BJ Services' admission that it may have violated the agreement =
raises the=20
question of whether it injected diesel into drinking water. The =
agreement covers=20
only fracturing in coalbed methane wells in underground sources of =
drinking=20
water.</P>
<P>BJ Services didn't respond by press time to E&amp;E's request for =
comment,=20
but told the <I>Houston Chronicle</I> it had reported the incidents to =
the EPA=20
on its own.</P>
<P>Jeff Smith, chief financial officer of BJ Services, told the =
newspaper some=20
of the company's units "inadvertently performed a few jobs" with diesel, =
with=20
the last one occurring in 2007.</P>
<P>"The company self-reported the incidents to the EPA and took measures =
to stop=20
it from happening in the future. The company's technology center in =
Tomball also=20
figured out a way to replace diesel in frac jobs with mineral oil-based =
products=20
instead, to improve the ecological footprint of the fracking fluids," =
Smith told=20
the <I>Chronicle</I>, which published his statement in a blog.</P>
<H3>Agreement key to regulatory exemption</H3>
<P>The agreement not to use diesel was aimed at calming fears about =
groundwater=20
contamination when Congress decided to exempt fracturing from federal =
drinking=20
water laws in the 2005 energy bill. The agreement was signed by =
Halliburton, BJ=20
Services and Schlumberger, which then did nearly all the fracturing work =
in the=20
United States. It included no enforcement penalties.</P>
<P>Congressional Republicans were responding to industry requests to =
head off=20
potential federal regulation and leave it to the states. But Democrats=20
consistently complained that their efforts would allow oil companies to =
inject=20
diesel into drinking water. So in the final version of the bill, =
fracturing was=20
exempted from the Safe Drinking Water Act unless diesel was used.</P>
<P>At the time, industry representatives said use of diesel was rare in =
any type=20
of fracturing and specifically not used near drinking water sources.</P>
<P>"Diesel itself had been used so rarely and so specifically in =
formations that=20
are not classified as drinking water sources, and there has been no =
evidence of=20
any contamination of water because of diesel or its use in fracturing =
fluids,"=20
Bill Whitsitt of the Domestic Petroleum Council said in 2004.</P>
<P>Rep. Diana DeGette (D-Denver), vice chairwoman of Waxman's committee, =
has=20
introduced legislation (<A=20
href=3D"http://www.eenews.net/features/bills/111/House/010709102826.pdf">=
<B>H.R.=20
2766</B></A>) that would require drilling companies to disclose the =
chemicals=20
used in their fracturing fluids under the Safe Drinking Water Act. She =
has said=20
she is not trying to ban the practice, but her proposal has run into =
staunch=20
opposition from the industry, which maintains that the drilling practice =
is safe=20
and fairly regulated by the states. Sen. Bob Casey (D-Pa.) has =
introduced=20
companion legislation in the Senate.</P>
<P>Last year, Congress ordered EPA to study the impact of fracturing on =
drinking=20
water, which would follow on a 2004 EPA study that found no risk of=20
contamination of drinking water from fracturing in coalbed methane =
wells. The=20
report, though, did cite the use of diesel in fracturing as a =
concern.</P>
<P>Yesterday, Waxman and Rep. Ed Markey (D-Mass.) announced their =
investigation=20
by sending letters to eight oil-field services firms seeking data and =
documents=20
on the types and quantities of chemicals used in hydraulic fracturing =
fluids,=20
the proximity of injections to underground drinking water sources, =
questions=20
about the technique's environmental and health impacts, and the chemical =

contents of wastewater produced by fracturing operations.</P>
<P>"Hydraulic fracturing could help us unlock vast domestic natural gas =
reserves=20
once thought unattainable, strengthening America's energy independence =
and=20
reducing carbon emissions," Waxman said in a statement. "As we use this=20
technology in more parts of the country on a much larger scale, we must =
ensure=20
that we are not creating new environmental and public health =
problems."</P>
<P>But some in the industry see political maneuvering behind Waxman's=20
investigation and its timing, since the EPA is already doing a =
study.</P>
<P>"While an inquisition targeting chemicals is a hell of a lot sexier =
than a=20
fact-based dialogue on pathways of exposure, it unfortunately misses the =
point,"=20
said Chris Tucker of the industry group Energy in Depth.</P>
<DIV style=3D"DISPLAY: none"><IMG=20
src=3D"http://www.eenews.net/2/Story/7015/print_display/87731/ident.gif?r=
=3Dyx4zy8kx65">=20
</DIV></DIV>
<DIV class=3Dstory_well style=3D"MARGIN-TOP: 2.5em">
<P class=3Dtop_link><A =
href=3D"http://www.eenews.net/gw/2010/02/19/">Back to table=20
of contents</A></P></DIV>
<DIV id=3Dleaderboard_ad_728x90 style=3D"CLEAR: both">
<P>Advertisement</P><!--/* OpenX Javascript Tag v2.6.5 */-->
<SCRIPT type=3Dtext/javascript><!--//<![CDATA[
   var m3_u =3D =
(location.protocol=3D=3D'https:'?'https://adserver.eenews.net/www/deliver=
y/ajs.php':'http://adserver.eenews.net/www/delivery/ajs.php');
   var m3_r =3D Math.floor(Math.random()*99999999999);
   if (!document.MAX_used) document.MAX_used =3D ',';
   document.write ("<scr"+"ipt type=3D'text/javascript' src=3D'"+m3_u);
   document.write =
("?zoneid=3D18&amp;source=3Dfooter&amp;target=3D_blank");
   document.write ('&amp;cb=3D' + m3_r);
   if (document.MAX_used !=3D ',') document.write ("&amp;exclude=3D" + =
document.MAX_used);
   document.write (document.charset ? '&amp;charset=3D'+document.charset =
: (document.characterSet ? '&amp;charset=3D'+document.characterSet : =
''));
   document.write ("&amp;loc=3D" + escape(window.location));
   if (document.referrer) document.write ("&amp;referer=3D" + =
escape(document.referrer));
   if (document.context) document.write ("&context=3D" + =
escape(document.context));
   if (document.mmm_fo) document.write ("&amp;mmm_fo=3D1");
   document.write ("'><\/scr"+"ipt>");
//]]>--></SCRIPT>
<NOSCRIPT><A=20
href=3D"http://adserver.eenews.net/www/delivery/ck.php?n=3Da1a0d165&amp;c=
b=3D0.102497703055727"=20
target=3D_blank><IMG alt=3D""=20
src=3D"http://adserver.eenews.net/www/delivery/avw.php?zoneid=3D18&amp;so=
urce=3Dfooter&amp;n=3Da1a0d165"=20
border=3D0></A></NOSCRIPT> </DIV></DIV></DIV></DIV>
<DIV class=3Dfooter_container>
<DIV class=3Dsecondary_nav><A class=3Dsecondary_item=20
href=3D"http://www.eenews.net/">E&amp;E Home</A> <A =
class=3Dsecondary_item=20
href=3D"http://www.eenews.net/eep/learn_more/">About</A> <A =
class=3Dsecondary_item=20
href=3D"http://www.eenews.net/trial/">Start a Trial</A> <A =
class=3Dsecondary_item=20
href=3D"http://www.eenews.net/email_alerts/">Get E-mail Alerts</A> <A=20
class=3Dsecondary_item =
href=3D"http://www.eenews.net/eep/advertise/">Advertise</A>=20
<A class=3Dsecondary_item=20
href=3D"http://www.eenews.net/eep/learn_more/staff_directory/">Staff =
Directory</A>=20
<A class=3Dsecondary_item=20
href=3D"http://www.eenews.net/special_reports/">Reports</A> <A=20
class=3Dsecondary_item href=3D"http://www.eenews.net/public/">Public =
Site</A> <A=20
class=3Dsecondary_item_last href=3D"http://www.eenews.net/rss/">RSS</A> =
</DIV>
<DIV class=3Dfooter>
<DIV class=3Dfooter_left><A href=3D"http://www.eenews.net/"><IMG=20
alt=3D"E&amp;E Publishing, LLC www.eenews.net"=20
src=3D"http://www.eenews.net/images/eepublishing_footer.png?1181426425"=20
border=3D0></A></DIV>
<DIV class=3Dfooter_right><A href=3D"http://www.eenews.net/cw/"><IMG =
alt=3DClimateWire=20
src=3D"http://www.eenews.net/images/climatewire_footer.png?1204998037"=20
border=3D0></A><A href=3D"http://www.eenews.net/eed/"><IMG=20
alt=3D"Environment &amp; Energy Daily"=20
src=3D"http://www.eenews.net/images/eedaily_footer.png?1204998037" =
border=3D0></A><A=20
href=3D"http://www.eenews.net/gw/"><IMG alt=3DGreenwire=20
src=3D"http://www.eenews.net/images/greenwire_footer.png?1204998037"=20
border=3D0></A><A href=3D"http://www.eenews.net/ll/"><IMG alt=3D"Land =
Letter"=20
src=3D"http://www.eenews.net/images/landletter_footer.png?1204998037"=20
border=3D0></A><A href=3D"http://www.eenews.net/pm/"><IMG =
alt=3DE&amp;ENewsPM=20
src=3D"http://www.eenews.net/images/eenewspm_footer.png?1204998037"=20
border=3D0></A><A href=3D"http://www.eenews.net/tv/"><IMG =
alt=3DE&amp;ETV=20
src=3D"http://www.eenews.net/images/eetv_footer.gif?1181426425" =
border=3D0></A>=20
<DIV class=3DtagLine>The Premier Information Source for Professionals =
Who Track=20
Environmental and Energy Policy. </DIV>
<DIV class=3Dcopyright>=C2=A9 1996-2010 E&amp;E Publishing, LLC <A=20
href=3D"http://www.eenews.net/eep/learn_more/privacy_policy/">Privacy=20
Policy</A>&nbsp;&nbsp;<A=20
href=3D"http://www.eenews.net/eep/learn_more/site_map/">Site =
Map</A></DIV></DIV>
<DIV style=3D"CLEAR: both">&nbsp;</DIV></DIV></DIV>
<DIV class=3Dbottom_bar align=3Dcenter> </DIV></DIV>
<DIV style=3D"DISPLAY: none"></DIV></BODY></HTML>

------=_NextPart_000_0000_01CAB168.786EE890
Content-Type: application/octet-stream
Content-Transfer-Encoding: base64
Content-Location: http://adserver.eenews.net/www/delivery/avw.php?zoneid=18&source=header&n=a1c74cbf

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

------=_NextPart_000_0000_01CAB168.786EE890
Content-Type: application/octet-stream
Content-Transfer-Encoding: base64
Content-Location: http://www.eenews.net/images/greenwire_tagline.gif?1265230393

R0lGODlhrgEeAPcAAFFtKz5YGYKcXUFcGqGyiIWhXnuSWujs4WWBPYSYaMLMtFRwLKi9i2OGMomf
arHCmFyDJXKUQqq4lrPFmcnWtr7GsqK0iNne0WeLNMbStY2edo6mbJ2thr3Mp2N+PIKVZ3WKWNHa
xLnGpp2zfLK9o1+AMaa6il19MNzj0n+YW5KleGB6Op6wh56uhnyaULfEpW+JS1p5LpaqeXSQTXKM
TaS3iZuqhYGbXFd0LXCJTHqZUHiVT4aiXlh3LmuKP5qve5imhIuia66/l22FSoSeXmV6R1hvOGWI
M1BrKv///1N2IUZkHEtrHlqAJERhG1h9I1V5Ild7I0hmHZitell/JFuCJVd8I1h+JLzKp0ppHluB
JFByIExsHp21fFZ7I/P18ENgG1yCJUViHElnHVZ6Ik1tH5Cid7TApJuyfFN3IlR4IluBJUloHbS/
pEtqHkVjHJqwe+nu4lBzILrIplR3IlJ1Ic3Vwk9xIFl+JEdlHPT28L7NqE9wIEpqHkZjHJKsbkdm
HVF0IUhnHbvKp4ekX/T38EBbGkxtH0NfG97m09LbxFJ0IX2cUZmvek5vH0xsH5Gjd1Z6I05uH7zL
p1FzIUJeG9Texd3k07bCpU1uH0JdGvL08LO/pLvJp4+hd7XBpOjt4kdlHYyka+fr4ZCpbY6gdrfD
pdrg0pWpebjFpay8lvP08N7l09vh0kJfG87Ww73Lp5SneJyrhqu6lvP28I+gdp20fHeNWcHLs7O+
o9LcxMHKs9vi0q/AmFt6L87Xw7rJp7XApNPdxc3UwsDJs7XCpebq4b3NqJiuesLMs6m3lbnHptPe
xYecaV94On6QZnSPTcPOtJuxe8fTtsDKs629l9DYw22NQMfUtmiHP5Chd3SIV3iPWVNvLHyTW+bp
4G+QQcvSwZKkd87Wwqi1lW2GSm6HS6W5it3l06m3ln6XW87VwpeseoabaT9ZGWaEPmOHM8/Yw7bD
pZelhNDZxI+obFx7L2F7O4OXaMzUwktjKGCCMWuDSZmohZqohWyESSH5BAAAAAAALAAAAACuAR4A
AAj/ACEIHEiwoMGDCBMqXMiwocOHECNKnEixosWLGDNq3Mixo8ePIEOKHEmypMmTKFOqXMmypcuX
MGPKnEmzps2bOHPq3Mmzp8+fQIMKHUq0qNGjSJMqXcq0qdOnUKNKZbknidWrSSBULZhkj0CsVw12
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
2rzN3NzN3vzN4BzO4jzO5FzO5nzO6JzORhEQADs=

------=_NextPart_000_0000_01CAB168.786EE890
Content-Type: application/octet-stream
Content-Transfer-Encoding: base64
Content-Location: http://www.eenews.net/images/greenwire_header_new2.gif?1265230393

R0lGODlhkAE8APcAAEFcGq3AknqMYZutgWaKM0ViHMHQrVFsKt3i1GuESLbGnjxWGG2NP1yDJZmw
d+fq4vP08dDYxsrWuoWhXJ6yg6a2j3WMVoigZ7G/ncDOrIabZYWUb46hc6GujWOGMn6YWZatdqW0
j7PCnV1+L6K2hHGNSmmJPmJ+O46paaO4hJ+sjLfBqHCTQOru48fRuUpiJ9DWxoukaLzJq1x1OLvH
qujs426AUnyVWIGWZJ6rjJSqdVlwN01mKNTcx4mbcXSKVau3mujr4rfIn2N5RXWSTKy4mlp6LnqS
V8LLt3eUTL3Kq6y/ksjSuW6CU5alf4GdWpKodNvg1GGCMcXPuFRrNVd1LWx/Um6ISYCbWbnEqnua
Tq67m5CldMTNt7/NrKKxjsnVuk9pKYaWb36RY7a/qGmBR2aEPIudcf///3iXTV54OVVzLFqAJFuC
JVd8I1yCJVl/JFh9I1uBJVN2IVJ1IVV5Ik9xIFByIEtrHluBJEppHlR4IkloHVZ7I1F0IVl+JFh+
JE5vH0xsH0pqHkZkHE1tH05uH0RhG01uH0NfG1N3IlR3IlZ6IklnHfT28U9wIFd7I0xsHkhmHUNg
G0xtH6u+kUtqHkdlHUJeG1Z6I1J0IUBbGkdlHFFzIT1XGfX38dXeyD5ZGUhnHUJfG6q8kc/VxUdm
HVBzIPT38dbgyODn1kFdGj9ZGdbfyD9aGc7VxYOfW6e4kNTdyD9aGt7k1UVjHOrv5NLax9Pbx6i6
kM/WxtPcx6i5kNXfyIOeW87Uxau9kam6kF+AMMzXup2pjKGwjdLbx4KeWqq7kc/WxWmHPb7Lq52q
jKOyjlNwK4ShW7LBncPMtzxVGN7l1am7kHmYTfP18dLZx52pi4eYcOnu48zYu9/m1rrFqqSzjqKw
jTtUGIOgW9zh1N/l1W6PP9rf1JengN/m1bPDnWuMP3OQS22AUnCRP1RxK4KeW1l3LXqZTXqZTkdf
JoyecbC9nLTEnjpTF3ePVpipgHGGVJGffd3j1bjCqYifZ3KIVLnEqSH5BAAAAAAALAAAAACQATwA
AAj/ABsIHEiwoMGDCBMqXMiwocOHECNKnEixosWLGDNq3Mixo8ePIEOKHEmypMmTKFOqXMmypcuX
MGPKnEmzps2bOHPq3Mmzp8+fQIMKHUq0qNGjSJMqXcq0qdOnUKNKnUq1qtWrWLNqRcpCiAEUbdq8
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

------=_NextPart_000_0000_01CAB168.786EE890
Content-Type: application/octet-stream
Content-Transfer-Encoding: base64
Content-Location: http://www.eenews.net/2/Story/7015/print_display/87731/ident.gif?r=yx4zy8kx65

R0lGODlhAQABAIAAAP///wAAACH5BAEAAAAALAAAAAABAAEAAAICRAEAOw==

------=_NextPart_000_0000_01CAB168.786EE890
Content-Type: application/octet-stream
Content-Transfer-Encoding: base64
Content-Location: http://adserver.eenews.net/www/delivery/avw.php?zoneid=18&source=footer&n=a1a0d165

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

------=_NextPart_000_0000_01CAB168.786EE890
Content-Type: application/octet-stream
Content-Transfer-Encoding: base64
Content-Location: http://www.eenews.net/images/eepublishing_footer.png?1181426425

iVBORw0KGgoAAAANSUhEUgAAAKIAAABHCAMAAACzpWwYAAAABGdBTUEAANbY1E9YMgAAABl0RVh0
U29mdHdhcmUAQWRvYmUgSW1hZ2VSZWFkeXHJZTwAAAMAUExURWaFo9nh6LPC0Y2ku4CZs0BmjMDN
2fb4+qCzxuzw9HqVr+Pp7sbR3XCNqYOctam6y73K19DZ45arwODm7BBAcDBZg/Dz9iBNeVBzlmCA
oJCmvLDA0AAAAAAzZv///x8fHyAgICEhISIiIiMjIyQkJCUlJSYmJicnJygoKCkpKSoqKisrKyws
LC0tLS4uLi8vLzAwMDExMTIyMjMzMzQ0NDU1NTY2Njc3Nzg4ODk5OTo6Ojs7Ozw8PD09PT4+Pj8/
P0BAQEFBQUJCQkNDQ0REREVFRUZGRkdHR0hISElJSUpKSktLS0xMTE1NTU5OTk9PT1BQUFFRUVJS
UlNTU1RUVFVVVVZWVldXV1hYWFlZWVpaWltbW1xcXF1dXV5eXl9fX2BgYGFhYWJiYmNjY2RkZGVl
ZWZmZmdnZ2hoaGlpaWpqamtra2xsbG1tbW5ubm9vb3BwcHFxcXJycnNzc3R0dHV1dXZ2dnd3d3h4
eHl5eXp6ent7e3x8fH19fX5+fn9/f4CAgIGBgYKCgoODg4SEhIWFhYaGhoeHh4iIiImJiYqKiouL
i4yMjI2NjY6Ojo+Pj5CQkJGRkZKSkpOTk5SUlJWVlZaWlpeXl5iYmJmZmZqampubm5ycnJ2dnZ6e
np+fn6CgoKGhoaKioqOjo6SkpKWlpaampqenp6ioqKmpqaqqqqurq6ysrK2tra6urq+vr7CwsLGx
sbKysrOzs7S0tLW1tba2tre3t7i4uLm5ubq6uru7u7y8vL29vb6+vr+/v8DAwMHBwcLCwsPDw8TE
xMXFxcbGxsfHx8jIyMnJycrKysvLy8zMzM3Nzc7Ozs/Pz9DQ0NHR0dLS0tPT09TU1NXV1dbW1tfX
19jY2NnZ2dra2tvb29zc3N3d3d7e3t/f3+Dg4OHh4eLi4uPj4+Tk5OXl5ebm5ufn5+jo6Onp6erq
6uvr6+zs7O3t7e7u7u/v7/Dw8PHx8fLy8vPz8/T09PX19fb29vf39/j4+Pn5+fr6+vv7+/z8/P39
/f7+/v///0B5CWgAAAPwSURBVHja7JmJcuMgDEAFJObynaPp4f//TFbicGwnTtN2D2bWdApYYPwQ
IIkWXPYJNsQNcUPcEDfEDfE/R+z2y6RyQzwXb8MwnIqQdljf5bfQBWLt08Nr/oiH/BHdKX/EXf6I
Xd6Ir0R3zBrxRHQ7lTHiIZM1foD4lj1id8wa8Yi+ORvfdx8RfbS6DPnvxX3+iO/5IzqPeMjZLro9
IVb7nBHfC3IxWSP6KHz4MiJjTD5qt5+0SxzgCUS6EcxToRUIrqrGKTClY0owgQJhmMOKKokNS61r
znqwvu44di0NlPhksF2hyBpqL8f5GFAslkFYmrKrzDNajNeWC9YPFSE6Bty5FjgDQWNyBOBOmkpi
JUybyh47OeQOMuoqcHheERVqR1fYLimLScR3U8moYwnPI57Dou9HRAlihuiHniJCh5XmBrEFnAoi
KrDUvo4oQNJXnkfcBUS1jliDniPWyMDsEpEp7IyIlf+WLdcQNfg1bp5GxFDCI55XF7ol4RRRAU7C
uRtEjWpkmC/1s0AMg39y1T+FMOIFC/oNJ/riEY2oRekmiCjAozNDlMgIgvZnLYS4IroGJ8duCb6O
eNjFtPcHG5P3LippcRwlLTRlAbGMpW4q6G+0iGcETzYjLZaN6PUcsYslewJxcvVLkc6xoAh8DdFC
FXFMWGjaarjjbhBJ6bhVYaGqgCZSaUNT/wCRC6H0DJHo8PGwRCwXiDpgCXq7qe4gohoZni55B7GL
iEw442GqdcTeSFtVcoqoPKJHi6YC6mRX/PlRAaeNiNRJqDuIaO0Y/pYBUbbyiqgiYiN8J9etGx2L
34sqHxH3EVG2wQ/gQNC6UtDBUKwBJdHvtKyrgErZV0zy2svQEKIJsjVYrTyQIRrD8MU+TVjX/l2R
Shy9trJeR2SkoDni25AQ2eg7Gef4SS8gd6tZSNo/dpyXQUa2mll0yVYHt6wps5xzNJ2y9rYxvmtT
GTq0+oEWAU2XSHsxuec/EbpY8c1Ix0BdNzIhvhZFcflDiN8OxlqAZm50zi95IZbGkJ/C3aLH4/L2
9xE/1hEbYLgbe80UlyNi5xHfiy99YvlDwo+YfVxroS0IrvL4fA/RW1QOGE6h0bt6F4942v0QMRIt
snECyx4riMqbqhqXupYTRHWgUOfHiB9BP4ki1KIWJ4ixxwqigD4YHtFPfXRwMb9Bi9csrf21spCv
ITbgXV8D5KTmiJevXfsT1ZinHTdqMT5et+JU/mgvkv/D6wgYuUD8538lSycao1G8wnFDxnGGqIZc
EDE4ADBcYkTWzBBf8kG8G9L6/2Hlh6jC3SX8o/I4DFlqMbO0IW6IG+KGuCFuiBtinumXAAMABH3X
KKtO+coAAAAASUVORK5CYII=

------=_NextPart_000_0000_01CAB168.786EE890
Content-Type: application/octet-stream
Content-Transfer-Encoding: base64
Content-Location: http://www.eenews.net/images/climatewire_footer.png?1204998037

iVBORw0KGgoAAAANSUhEUgAAAHYAAAAnCAMAAADtq0xxAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJ
bWFnZVJlYWR5ccllPAAAADNQTFRFaGqwzM3kmpvKQkSc2drrTlGiW12p8vP4wMHegYO9s7TX5uby
pqjQjo/EdHa2NTiV////ml4adQAAAgdJREFUeNrsltuWpCAMRbkKCpr8/9fOScAu7Var+2Vmei14
AEuSbHLDMvxPhhnYgR3YgR3Ygf2fsNbav4gNTkYuTETMq/lRLPpJ9yXww9GPhm2kNkzDGpm+PyIJ
JpAuhTZ+UD9gM1h+dc7s2HfeuvP+TA5zJV0Wqvyg/tpJHm6mFuuGfTc+CWWaFA4/mTcK38vtAl/T
yaJ6iykg2jEknWFXUhGr5oBEIk94mBMnIuhHTx4GfGTxNqi247BBNlxhsTGfHTF98pLvKMbFH0wC
zNzqQI87ST3whJeFZg9HrdjCphVt44KneSNfLrCwVW+wdZG0u0XfurQnUH8iNz7ImQOvtOIQy0YL
HvOOnYpUG346bF9i7TU2iyN97jWv3qnQokGycg5J7kzF4cUk8W7YItXtVclcY901lk+z3XqTNSHX
mw7KktwYYT4WJTRsO+Wu8wXbS/AdVtrMTCdsNDIWiUZtOa2arwM26j20XFfyq+jvsYa0Yo5Bnj4a
mSLyChGvlj6wLcg31wUaw2t2w/yA9dImdccmlC4JilNpwcSyIgB8xMJ0vcUGaRQEDMsDduu95Fep
sGiCJHcyRguD1K3cW/GFlTfWuvXyTi7m4k7+jNXDrZpcfbRcta/VH6PlkbTsj1jOKrPdfIFKdq7a
9HglJmslnja8vo9Y3iipTBn/LgZ2YH8z9o8AAwDcUwyL0XYGAQAAAABJRU5ErkJggg==

------=_NextPart_000_0000_01CAB168.786EE890
Content-Type: application/octet-stream
Content-Transfer-Encoding: base64
Content-Location: http://www.eenews.net/images/eedaily_footer.png?1204998037

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
YII=

------=_NextPart_000_0000_01CAB168.786EE890
Content-Type: application/octet-stream
Content-Transfer-Encoding: base64
Content-Location: http://www.eenews.net/images/greenwire_footer.png?1204998037

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
ZvynOkc1AAAAAElFTkSuQmCC

------=_NextPart_000_0000_01CAB168.786EE890
Content-Type: application/octet-stream
Content-Transfer-Encoding: base64
Content-Location: http://www.eenews.net/images/landletter_footer.png?1204998037

iVBORw0KGgoAAAANSUhEUgAAAIIAAAAnCAMAAAD0DGCSAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJ
bWFnZVJlYWR5ccllPAAAAwBQTFRFq49zrKySybelcEEReXlN3NDE4+Par5V6hoZd/fz7mnhWgFUr
vr6psJZ839TJfX1Rv6mU7u7o1ce50MCw/f384dfN1si6fVEmjo5pp4lsw6+bmHZU8vLuvaeR08S1
k29LYmIudUcZyrimwKuWZGQwjWdBh1832Mu+vKaQek4i+Pj2ysq5pohqXV0mo4Rlglguy7moXl4p
bm4+n39fs5mA+/r5s7OZaTYEp6eKjmlDoIBgflModnZIbz8Pk5Nul3RRkGtGlHBMsph+4tjOdEYY
t5+HWloinZ19u7ukcHBBgYFXazkIrJB0zc2+ZmY0ZzQBf39UoqKEi2Q9iGA4eEseYWEsW1slaGg2
jIxmlXJP6eHaqo1xzLuq+ff1z7+vm3lYu6SNnX1c/v39/v7++vn3+Pb0uKGJoYFi8OvmckMU6+Xe
6+TdqYxvx7Wi9vPw59/XajgG5d3Ubj0N6ODYimM88+/rbTwLoYJj+vj2iWI7lnNQ7+nk5dzThFsy
pIVn8u7qZWUyuKCIpIZo7uji6uPc9fLv5NvSlXFO49nQ9PHtzr6ubT0M9PDs1MW3qItu7Obgdkkb
m3pZc0QVtJuC+PXztZyDxbGe9fHutp2FvKWPqY1wzbyrnHta8ezn4NXL0sO07unjeU0gl3VS9/Xy
9/f0aWk3x7Sh5t3V8e3o8PDs8u3p/Pv6xsazzb2srZJ36eLbiopjnn1d28/D8PDr7OXf3tPIkWxH
km1JrpN4tLSbYmIt3dLHek0hhV00rZF27efh6OHZ+/v68/PvaWk4ZmYyfn5T0MGxc3NFbDsK7e3n
2dnMvLyl+Pj1zr2tqKiLg1oxhVwzwsKtzMy75eXduaKLi4tkY2MvjGU/sLCVuqOM3NHF///+w8Ow
gYFYYGAr9PTx9fXy9/TxmJh2uLihxbKfxrOgkZFsooNkdHRGaGg0wa2Ywq2Z2c3A2s3Bhl01+/n4
3t7T4ODXxMSwxcWy18m8tZ2EaWk20dHB09PGeHhLn5+AiWE6xLCcZmYzZjMA/////ykSdwAABN9J
REFUeNrs1mlUE1cUAGAwSCARGzWC0SKy2ggYimjQVqrWokIl2lYsBjoSCEkIYQk7VnYFhEAARZRF
iQrWreKGxd22tHRfoaWtdl/U0s0u1ubezkwMLUuoPe1Rf+T9mHfPe3Mm37x3c99Y4G1vFmaCmWAm
mAl3NOHxG23CrIOG4N1Ft5qw0tCe3bdzebshXHaTDyl7NeH/IejptnL5ORxj5UbHd5GjGT5OBBEW
VzgMoPYx5w4qKI7TEVm6mvj/TLgbkTvKu48gid8vLI2TzzT9iB0agWgDFUTL5yemXNnM7T99Npq8
JM+8ecI3X1LhmF9yjQTEVQq1ari3kERnwxOGcBPkSwdOz1GSl3r5zRN2PUOFO6+5/UV4WsvY/w9L
aSRsAYuMAXMlc1sQlcHb/wVhMb2kv6/42ypoGeF9Nx1qPkp1qY24btsaeiS2efdxI2E1iCP6bh3t
00imkgzGygtY0FNATowPH03nzI6IybZDErraydXfNYoKXwmYotd3TbEaSMjhuUeyp68q2eSe7bKW
0X2VxOZlRhIn0wYTSqZHtrHTC/xK4RhBqMGp6ESUrJXlIIvYkH5KM4+/dUjCkiWhgVNW+tMb8XWX
d6B+SdAAQrRj4vEeFuRtZIG6+2EWRErRJy2yxy5tCIJ4dsfV61CtOQYxLj6zwVG1h9m7bWQbcCY6
Q2YROA1J8H9r8SJfb3rxD9/bPuG9H/f5DyCkFkEPjoVW1PAVHCx2FhQ29LLX4I420SDCegUnA2Pg
PjwNFYj5UIIFwa7SvXWwcHu56BHlpaNDEshEvPjhwVBrxA9eDpn1Njny2QCC9HNmfDIP6vFIb0o0
JpxqSh4HYnKcNzgXatWVFmIdgx8fB+sRZRCLPiIZr3yOAqK2QLOpdKRroXXABMTOZXRGPBUwKB3L
Lmd3QyQmrE1Zh08K+IWO4Ect+mDCAXV2tV+e4whbnpHAFNpV+9VyHCUx8G2UCcIKa+p6McgTX7Ok
Iu7SF/oTuBnybO1D99CEzM0kwWH8ApqwdRBBKha2GIa8jAQWGP5B5PbYmyKEfEp3L1376SM6+Njm
Wn+CciITvsBxJOHsDUIjE5g0oaM/wVYzCTjU72i+40ESYjocQaaI2jN0kQxD0If8QPfLA3+je8/Q
vtJkqL+X2hze4KIKZFjca9iIM39AWypVmuqMpek0/Ye3X5Ad/HoP4vawsnJ4EKUzQIk1wiqyTsQ2
zXwHrpgkPGfTSacAXaPxe1+3vgLtuqdh9xrVMRftyamx6eBUGM5+NBWTBE1JjQuhNqeCAJ5cYijQ
rat2N+Qke7yf5AHd9o1ZTEkc5G1rJECl2dAEgskj3WXoByNMV8eugE7qJQ5T+24ddIGujtzUcGHw
9bh8Xv3ceTks0LL4pRB2IJGtWWfvoBgRxUxTz6gsBS2HPIw+qZifyNDx8sVs0VSMUQCAuhgvzxW+
2PJzcBVDyXEmR6oS5EWJmWdMF+guq6Xnp51D22nnf73/gqFAx8e4E4QujGyECscLtKuTJ7VxWllZ
XqrTRVnTkyR2zgy7rzzqqNOpoyiskniAutWLrAWuDtqUQ4gbCS3HdmMWu2YvXuZrBSewXFepS5eY
PiPcVjxv+SZ6Wtp45/adEbfwq8nwvZDr5ssNzc3V628HwfwFbSaYCWbCnUL4U4ABAKXojRr/OTwS
AAAAAElFTkSuQmCC

------=_NextPart_000_0000_01CAB168.786EE890
Content-Type: application/octet-stream
Content-Transfer-Encoding: base64
Content-Location: http://www.eenews.net/images/eenewspm_footer.png?1204998037

iVBORw0KGgoAAAANSUhEUgAAAIcAAAAnCAMAAAASJavWAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJ
bWFnZVJlYWR5ccllPAAAAwBQTFRFgICAZoyMmbOzzdnZQEBAwMDAcZSU0NDQQHBw3OXlpry8gKCg
4ODgEBAQoKCgcHBwICAg8/b2MDAws8bGWYOD7fLyc5aWjampsLCwUFBQ2ePjTXl5epubkJCQYGBg
jKmp9vj45uzs8PDwwNDQla+vuMrK5evrwdHRnba2ytfXr8PDg6Ki097eM2ZmAAAA////MDAwMTEx
MjIyMzMzNDQ0NTU1NjY2Nzc3ODg4OTk5Ojo6Ozs7PDw8PT09Pj4+Pz8/QEBAQUFBQkJCQ0NDRERE
RUVFRkZGR0dHSEhISUlJSkpKS0tLTExMTU1NTk5OT09PUFBQUVFRUlJSU1NTVFRUVVVVVlZWV1dX
WFhYWVlZWlpaW1tbXFxcXV1dXl5eX19fYGBgYWFhYmJiY2NjZGRkZWVlZmZmZ2dnaGhoaWlpampq
a2trbGxsbW1tbm5ub29vcHBwcXFxcnJyc3NzdHR0dXV1dnZ2d3d3eHh4eXl5enp6e3t7fHx8fX19
fn5+f39/gICAgYGBgoKCg4ODhISEhYWFhoaGh4eHiIiIiYmJioqKi4uLjIyMjY2Njo6Oj4+PkJCQ
kZGRkpKSk5OTlJSUlZWVlpaWl5eXmJiYmZmZmpqam5ubnJycnZ2dnp6en5+foKCgoaGhoqKio6Oj
pKSkpaWlpqamp6enqKioqampqqqqq6urrKysra2trq6ur6+vsLCwsbGxsrKys7OztLS0tbW1tra2
t7e3uLi4ubm5urq6u7u7vLy8vb29vr6+v7+/wMDAwcHBwsLCw8PDxMTExcXFxsbGx8fHyMjIycnJ
ysrKy8vLzMzMzc3Nzs7Oz8/P0NDQ0dHR0tLS09PT1NTU1dXV1tbW19fX2NjY2dnZ2tra29vb3Nzc
3d3d3t7e39/f4ODg4eHh4uLi4+Pj5OTk5eXl5ubm5+fn6Ojo6enp6urq6+vr7Ozs7e3t7u7u7+/v
8PDw8fHx8vLy8/Pz9PT09fX19vb29/f3+Pj4+fn5+vr6+/v7/Pz8/f39/v7+////nPZtLgAAAwlJ
REFUeNrslv+NqkAQxw822fAjJBJEEiVRo96d50EsgRIswRIogRIsgRIsgRIogRLsYN7M7MLjmROT
9y559wfzB+7OCPtx5juDL/Az7GXkGDlGjpFj5HhsRqLMmgXd1lAhq7ce5rBt+2/Pr+440KZ+u/Up
Mk8ecwRGYpimOU1M3ISHj338Tm4zSVx0W4mALMsuAGWWlZBnynLcnQAu5INTlgFcJ2maHqs7jmTW
bjcUcQY48EQi8C26OhLgXb6SO0ECAIFXPMBroEjTArJUWVbi5UbbE9xwCxcdqDTHwjCmfOhac0T0
zNlzDnDpukWGdxn+5oAFc6TnO44GL1cmhCsFPHJSRjSH2f56R3MsOnkMckSwoVs/5HYv99By+BFE
iiOtW45jhVYDlqGoKdBgoKpwkUM5yeseByS8wK3FidHyGOLwE7UOpVyG0HFs+BaVgT4HnnZGFxej
RB8QR3os6k6nZvvzmWPGiSHNGUMcBqqUl6uPWMZhyD1DOrU0h856VxfUJQnkTOucizHRgX4+RFcX
c9Eq1hzicIXLHKvlFpaYEHvJHI6Yao5Mnd/nIIF4qTo+B6g1SKsPVwiH1TDn012sDddJPNEHfivA
brEhjOUOlrouwoA16YNlqTkmRVFgs6oMqDa50mPKk8c6+rNvDZWFgBCQYfaMIyAtxMgBeynfnLZf
AohM4oBzx5Hp2058KifoBuX5mClX9dUcM9dUKpNS/LxvDTjIN6D5IT97fas4Gq/l8HiOgZoYkKta
5Kxk+k7T47BcX5XJBBTIFBdz8XyOGbCTMY6w1UE6vTlGHBOg8dGfH6gI/rgqeTCmmjOdPoToxrwJ
kQKDxxxzl27azDC82sr47dPZYmVWgpIogilzpAA3746DRlcOjZaH1unp1u/bHsdGT/kBDqFtTm+5
3W5nw6ttr1qvWAMODAw1VdVAXSmj9qzJQcEbP+daFJe7+dHj8JkjGOAoi2+15msOmKqXzWOONtXf
ZNUDjki9Y/47BwG4P4ADWB4DHOP/5JFj5Bg5Ro5/sF8CDAB5f6p1GswNUQAAAABJRU5ErkJggg==

------=_NextPart_000_0000_01CAB168.786EE890
Content-Type: application/octet-stream
Content-Transfer-Encoding: base64
Content-Location: http://www.eenews.net/images/eetv_footer.gif?1181426425

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

------=_NextPart_000_0000_01CAB168.786EE890
Content-Type: application/octet-stream
Content-Transfer-Encoding: quoted-printable
Content-Location: http://www.eenews.net/stylesheets/structural_styles.css?1265645498

.xml-icon {
	BORDER-RIGHT: #3f1a01 1px solid; PADDING-RIGHT: 3px; BORDER-TOP: =
#ffc8a4 1px solid; PADDING-LEFT: 3px; FONT-WEIGHT: bold; FONT-SIZE: =
11px; PADDING-BOTTOM: 1px; MARGIN: 0px; BORDER-LEFT: #ffc8a4 1px solid; =
CURSOR: pointer; COLOR: #fff; PADDING-TOP: 0px; BORDER-BOTTOM: #3f1a01 =
1px solid; FONT-FAMILY: Tahoma, Verdana, Arial, Helvetica, sans-serif; =
BACKGROUND-COLOR: #ff6600; TEXT-ALIGN: center
}
BODY {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-SIZE: 76%; BACKGROUND: =
#ededed fixed; PADDING-BOTTOM: 0px; MARGIN: 0px auto; PADDING-TOP: 0px; =
FONT-FAMILY: Arial, Helvetica, sans-serif
}
A {
	COLOR: #990000
}
A:hover {
	COLOR: #ff0000
}
STRONG.highlight {
	FONT-WEIGHT: bold; BACKGROUND: #ffff00; COLOR: #000000
}
#content_container {
	BORDER-RIGHT: #666666 2px solid; MARGIN-TOP: 0px; BACKGROUND: #ffffff; =
MARGIN-LEFT: auto; BORDER-LEFT: #666666 2px solid; WIDTH: 900px; =
MARGIN-RIGHT: auto; PADDING-TOP: 0em; TOP: 0px
}
#content {
	PADDING-RIGHT: 1em; PADDING-LEFT: 0px; FLOAT: left; PADDING-BOTTOM: =
1em; WIDTH: 500px; PADDING-TOP: 0px
}
H1.date {
	MARGIN-TOP: 1em; FONT-SIZE: 1.35em; MARGIN-BOTTOM: 0px; PADDING-BOTTOM: =
0.5em; COLOR: #666666; LINE-HEIGHT: 1.25em; TEXT-ALIGN: left
}
H1.date SPAN.customize {
	DISPLAY: block; FONT-SIZE: 80%; MARGIN: 0px; TEXT-TRANSFORM: uppercase; =
COLOR: #666666
}
H1.date A {
	COLOR: #990000; TEXT-DECORATION: underline
}
H1.date A:hover {
	COLOR: #ff0000; TEXT-DECORATION: underline
}
SPAN.full_edition_link {
	PADDING-RIGHT: 0px; DISPLAY: block; PADDING-LEFT: 0px; FONT-WEIGHT: =
normal; FONT-SIZE: 75%; PADDING-BOTTOM: 0px; MARGIN: 0px; =
TEXT-TRANSFORM: uppercase; COLOR: #990000; PADDING-TOP: 0px
}
SPAN.full_edition_link A {
	COLOR: #990000; TEXT-DECORATION: underline
}
SPAN.full_edition_link A:hover {
	COLOR: #ff0000
}
#TOC {
	MARGIN-TOP: 1em; PADDING-BOTTOM: 2em
}
#customize_TOC {
	MARGIN-TOP: 1em; PADDING-BOTTOM: 2em
}
#single_story_TOC {
	MARGIN-TOP: 1em; PADDING-BOTTOM: 2em
}
#TOC DIV.section H1 {
	CLEAR: left; FONT-SIZE: 100%; MARGIN: 1.25em 0px 2px; VERTICAL-ALIGN: =
middle; TEXT-TRANSFORM: uppercase
}
#customize_TOC DIV.section H1 {
	CLEAR: left; FONT-SIZE: 100%; MARGIN: 1.25em 0px 2px; VERTICAL-ALIGN: =
middle; TEXT-TRANSFORM: uppercase
}
#single_story_TOC DIV.section H1 {
	CLEAR: left; FONT-SIZE: 100%; MARGIN: 1.25em 0px 2px; VERTICAL-ALIGN: =
middle; TEXT-TRANSFORM: uppercase
}
#spotlight H1 {
	PADDING-RIGHT: 0.25em; PADDING-LEFT: 0.25em; FONT-SIZE: 115%; =
PADDING-BOTTOM: 0.25em; VERTICAL-ALIGN: middle; TEXT-TRANSFORM: =
uppercase; PADDING-TOP: 0.25em
}
#spotlight H1 SPAN {
	DISPLAY: block; FONT-WEIGHT: normal; FLOAT: right; TEXT-TRANSFORM: =
none; TEXT-ALIGN: right
}
#TOC DIV.section H3 {
	PADDING-LEFT: 1.5em; FONT-WEIGHT: bold; FONT-SIZE: 125%; =
PADDING-BOTTOM: 0.5em; MARGIN: 0.5em 0px; TEXT-INDENT: -0.75em; =
BORDER-BOTTOM: #eee 1px solid
}
#TOC DIV.section H3.two_digits {
	TEXT-INDENT: -1.25em
}
#customize_TOC DIV.section H3 {
	PADDING-LEFT: 2.75em; FONT-WEIGHT: bold; FONT-SIZE: 125%; =
PADDING-BOTTOM: 0.5em; MARGIN: 0.5em 0px 0.5em 0em; TEXT-INDENT: -2.3em; =
BORDER-BOTTOM: #eee 1px solid
}
#customize_TOC DIV.section H3.two_digits {
	PADDING-LEFT: 3.05em; TEXT-INDENT: -2.65em
}
#single_story_TOC DIV.section H3 {
	PADDING-LEFT: 1.75em; FONT-WEIGHT: normal; FONT-SIZE: 110%; =
PADDING-BOTTOM: 0.25em; MARGIN: 0.5em 0px 0.25em; TEXT-INDENT: -1em; =
BORDER-BOTTOM: #eee 1px solid
}
#single_story_TOC DIV.section H3.two_digits {
	TEXT-INDENT: -1.45em
}
#TOC DIV.section H3 A {
	COLOR: #000000; TEXT-DECORATION: none
}
#customize_TOC DIV.section H3 A {
	COLOR: #000000; TEXT-DECORATION: none
}
#single_story_TOC DIV.section H3 A {
	COLOR: #000000; TEXT-DECORATION: none
}
#TOC DIV.section H3 A SPAN {
	DISPLAY: inline; FONT-WEIGHT: bold; FONT-SIZE: 80%; VERTICAL-ALIGN: =
middle; TEXT-TRANSFORM: uppercase; TEXT-DECORATION: none
}
#TOC DIV.section H3 SPAN {
	DISPLAY: inline; FONT-WEIGHT: bold; FONT-SIZE: 80%; VERTICAL-ALIGN: =
middle; TEXT-TRANSFORM: uppercase; TEXT-DECORATION: none
}
#customize_TOC DIV.section H3 A SPAN {
	DISPLAY: inline; FONT-WEIGHT: bold; FONT-SIZE: 80%; VERTICAL-ALIGN: =
middle; TEXT-TRANSFORM: uppercase; TEXT-DECORATION: none
}
#customize_TOC DIV.section H3 SPAN {
	DISPLAY: inline; FONT-WEIGHT: bold; FONT-SIZE: 80%; VERTICAL-ALIGN: =
middle; TEXT-TRANSFORM: uppercase; TEXT-DECORATION: none
}
#single_story_TOC DIV.section H3 A SPAN {
	DISPLAY: inline; FONT-WEIGHT: bold; FONT-SIZE: 80%; VERTICAL-ALIGN: =
middle; TEXT-TRANSFORM: uppercase; TEXT-DECORATION: none
}
#single_story_TOC DIV.section H3 SPAN {
	DISPLAY: inline; FONT-WEIGHT: bold; FONT-SIZE: 80%; VERTICAL-ALIGN: =
middle; TEXT-TRANSFORM: uppercase; TEXT-DECORATION: none
}
#TOC DIV.section H3 A:hover {
	COLOR: #990000; TEXT-DECORATION: underline
}
#TOC DIV.section A:hover SPAN {
	COLOR: #990000; TEXT-DECORATION: underline
}
#customize_TOC DIV.section H3 A:hover {
	COLOR: #990000; TEXT-DECORATION: underline
}
#customize_TOC DIV.section A:hover SPAN {
	COLOR: #990000; TEXT-DECORATION: underline
}
#single_story_TOC DIV.section H3 A:hover {
	COLOR: #990000; TEXT-DECORATION: underline
}
#single_story_TOC DIV.section A:hover SPAN {
	COLOR: #990000; TEXT-DECORATION: underline
}
#TOC P {
	PADDING-LEFT: 1em; FONT-SIZE: 100%; MARGIN: 0.75em 2.75em 0.75em 0.5em
}
#customize_TOC P {
	PADDING-LEFT: 1em; FONT-SIZE: 100%; MARGIN: 0.75em 2.75em 0.75em 0.5em
}
#single_story_TOC P {
	PADDING-LEFT: 1em; FONT-SIZE: 100%; MARGIN: 0.75em 2.75em 0.75em 0.5em
}
#TOC DIV.section P {
	PADDING-LEFT: 1.5em; FONT-SIZE: 100%; MARGIN: 0px 2.75em 1.25em 0.5em
}
#customize_TOC DIV.section P {
	PADDING-LEFT: 1.5em; FONT-SIZE: 100%; MARGIN: 0px 2.75em 1.25em 0.5em
}
#single_story_TOC DIV.section P {
	PADDING-LEFT: 1.5em; FONT-SIZE: 100%; MARGIN: 0px 2.75em 1.25em 0.5em
}
#spotlight H2 {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-SIZE: 1.5em; MARGIN-BOTTOM: =
0px; PADDING-BOTTOM: 0px
}
#spotlight H2 A:hover {
	COLOR: #990000; TEXT-DECORATION: underline
}
#spotlight H2 A:hover SPAN {
	COLOR: #990000; TEXT-DECORATION: underline
}
#spotlight {
	MARGIN: 0px 0px 0px 1.75em
}
#spotlight H2 A {
	COLOR: #000000; TEXT-DECORATION: none
}
#spotlight H2 {
	TEXT-INDENT: -0.9em
}
#spotlight A SPAN {
	DISPLAY: inline; FONT-SIZE: 80%; TEXT-TRANSFORM: uppercase; =
TEXT-DECORATION: none
}
#spotlight SPAN {
	DISPLAY: inline; FONT-SIZE: 80%; TEXT-TRANSFORM: uppercase; =
TEXT-DECORATION: none
}
#spotlight P {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: 1em =
0px; PADDING-TOP: 0px; TEXT-ALIGN: left
}
#email_content_container {
	BORDER-RIGHT: #666666 2px solid; MARGIN-TOP: 0px; PADDING-LEFT: 15px; =
BACKGROUND: #ffffff; MARGIN-LEFT: auto; BORDER-LEFT: #666666 2px solid; =
WIDTH: 535px; MARGIN-RIGHT: auto; PADDING-TOP: 1em; BORDER-BOTTOM: =
#666666 2px solid; TOP: 0px
}
#email_content_container #content {
	FLOAT: none
}
#email_header_container {
	MARGIN-TOP: 0px; Z-INDEX: 10; WIDTH: 100%; TOP: 0px
}
#email_header_container #header {
	WIDTH: 550px
}
#email_header_container #header_for_email {
	WIDTH: 550px
}
#email_header_container .pubs_nav {
	WIDTH: 550px
}
#story_head SPAN {
	TEXT-TRANSFORM: uppercase
}
#header_container {
	MARGIN-TOP: 0px; Z-INDEX: 10; WIDTH: 100%; TOP: 0px
}
#header {
	MARGIN: auto; WIDTH: 900px; BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: =
none; BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: none
}
#header_for_email {
	MARGIN: auto; WIDTH: 900px; BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: =
none; BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: none
}
.pubs_nav {
	BORDER-RIGHT: #666666 2px solid; PADDING-RIGHT: 0px; PADDING-LEFT: 0px; =
BACKGROUND: #333333; PADDING-BOTTOM: 0px; MARGIN: 0px auto; BORDER-LEFT: =
#666666 2px solid; WIDTH: 900px; PADDING-TOP: 1em; TEXT-ALIGN: left
}
.pubs_nav_new {
	BORDER-RIGHT: #666666 2px solid; PADDING-RIGHT: 0px; PADDING-LEFT: 0px; =
BACKGROUND: #333333; PADDING-BOTTOM: 0px; MARGIN: 0px auto; BORDER-LEFT: =
#666666 2px solid; WIDTH: 900px; PADDING-TOP: 1em; TEXT-ALIGN: left
}
.pubs_nav UL {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0.5em; MARGIN: =
0px; PADDING-TOP: 0.5em
}
.pubs_nav LI {
	BORDER-RIGHT: #999999 1px solid; PADDING-RIGHT: 2.25em; DISPLAY: =
inline; PADDING-LEFT: 2.25em; FONT-SIZE: 100%; BACKGROUND: #333333; =
PADDING-BOTTOM: 0px; COLOR: #ffffff; PADDING-TOP: 0px; LIST-STYLE-TYPE: =
none
}
.pubs_nav A {
	COLOR: #ffffff; TEXT-DECORATION: none
}
.pubs_nav A:hover {
	COLOR: #cccccc
}
.pubs_nav LI IMG {
	BORDER-RIGHT: #999999 1px solid; PADDING-RIGHT: 0px; BORDER-TOP: =
#999999 1px solid; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: 0px =
5px 0px 0px; VERTICAL-ALIGN: middle; BORDER-LEFT: #999999 1px solid; =
PADDING-TOP: 0px; BORDER-BOTTOM: #999999 1px solid
}
#last_pub {
	BORDER-RIGHT-STYLE: none
}
.search_nav {
	BORDER-RIGHT: #666666 2px solid; PADDING-RIGHT: 0px; PADDING-LEFT: 0px; =
BACKGROUND: #e8e7d0; PADDING-BOTTOM: 0.4em; MARGIN: 0px auto; =
BORDER-LEFT: #666666 2px solid; WIDTH: 900px; PADDING-TOP: 0.4em; =
BORDER-BOTTOM: #666666 1px solid; TEXT-ALIGN: center
}
.search_nav FORM {
	DISPLAY: inline
}
.search_nav FORM LABEL {
	FONT-WEIGHT: bold; FONT-SIZE: 80%; MARGIN-LEFT: 1em; VERTICAL-ALIGN: =
middle
}
.search_nav UL {
	PADDING-RIGHT: 0px; DISPLAY: inline; PADDING-LEFT: 0px; PADDING-BOTTOM: =
0px; MARGIN: 0px; PADDING-TOP: 0px
}
.search_nav LI {
	BORDER-RIGHT: #666666 1px solid; PADDING-RIGHT: 0.75em; DISPLAY: =
inline; PADDING-LEFT: 0.75em; FONT-SIZE: 100%; PADDING-BOTTOM: 0px; =
COLOR: #000000; PADDING-TOP: 0px; LIST-STYLE-TYPE: none
}
.search_nav A {
	COLOR: #000000; TEXT-DECORATION: none
}
.search_nav A:hover {
	COLOR: #999999
}
.search_nav LI IMG {
	BORDER-RIGHT: #bbcad5 1px solid; PADDING-RIGHT: 0px; BORDER-TOP: =
#bbcad5 1px solid; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: 0px =
5px 0px 0px; VERTICAL-ALIGN: middle; BORDER-LEFT: #bbcad5 1px solid; =
PADDING-TOP: 0px; BORDER-BOTTOM: #bbcad5 1px solid
}
#last_search {
	BORDER-RIGHT-STYLE: none
}
#banner_ad {
	PADDING-RIGHT: 2px; MARGIN-TOP: 0.5em; PADDING-LEFT: 15px; BACKGROUND: =
url(http://www.eenews.net/images/advert_text.png) #ffffff no-repeat left =
center; FLOAT: right; PADDING-BOTTOM: 2px; MARGIN-RIGHT: 0.4em; =
PADDING-TOP: 2px
}
#trial_ad {
	PADDING-RIGHT: 2px; MARGIN-TOP: 0.5em; PADDING-LEFT: 2px; BACKGROUND: =
#ffffff; FLOAT: right; PADDING-BOTTOM: 2px; MARGIN-RIGHT: 0.4em; =
PADDING-TOP: 2px
}
#box_ad_336x280 {
	MARGIN: 0px auto auto; TEXT-ALIGN: center
}
.search_box #box_ad_336x280 {
	MARGIN-TOP: 0px
}
#box_ad_336x280 P {
	FONT-SIZE: 90%; PADDING-BOTTOM: 0.25em; MARGIN: 0px; COLOR: #000000; =
PADDING-TOP: 0px; TEXT-ALIGN: center
}
#leaderboard_ad_728x90 {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 1em; MARGIN: =
0.5em 0px 0px; PADDING-TOP: 0px; TEXT-ALIGN: center
}
#leaderboard_ad_728x90 P {
	FONT-SIZE: 90%; PADDING-BOTTOM: 0.25em; MARGIN: 0px; PADDING-TOP: =
0.25em
}
#tv_player {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: =
auto; PADDING-TOP: 0px; TEXT-ALIGN: center
}
#tv_advert {
	PADDING-RIGHT: 0px; MARGIN-TOP: 0px; PADDING-LEFT: 0px; BACKGROUND: =
#7e7e7e; MARGIN-BOTTOM: 1em; PADDING-BOTTOM: 2px; PADDING-TOP: 0px; =
TEXT-ALIGN: center
}
#tv_advert_300 {
	PADDING-RIGHT: 2px; PADDING-LEFT: 2px; BACKGROUND: #7e7e7e; =
PADDING-BOTTOM: 2px; MARGIN: auto auto 30px; WIDTH: 300px; PADDING-TOP: =
0px; TEXT-ALIGN: center
}
#box_ad_300x250 {
	PADDING-RIGHT: 2px; PADDING-LEFT: 2px; BACKGROUND: #7e7e7e; =
PADDING-BOTTOM: 2px; MARGIN: auto auto 30px; WIDTH: 300px; PADDING-TOP: =
0px; TEXT-ALIGN: center
}
#box_ad_336x280 {
	PADDING-RIGHT: 2px; PADDING-LEFT: 2px; BACKGROUND: #7e7e7e; =
PADDING-BOTTOM: 2px; MARGIN: auto auto 30px; WIDTH: 300px; PADDING-TOP: =
0px; TEXT-ALIGN: center
}
#box_ad_336x280 {
	WIDTH: 336px
}
.anchor_ad {
	CLEAR: both
}
#tv_advert P {
	FONT-SIZE: 90%; BACKGROUND: #ffffff; PADDING-BOTTOM: 0.25em; MARGIN: =
0px -2px 2px; COLOR: #000000; PADDING-TOP: 1em; FONT-STYLE: italic; =
TEXT-ALIGN: center
}
#tv_advert_300 P {
	FONT-SIZE: 90%; BACKGROUND: #ffffff; PADDING-BOTTOM: 0.25em; MARGIN: =
0px -2px 2px; COLOR: #000000; PADDING-TOP: 1em; FONT-STYLE: italic; =
TEXT-ALIGN: center
}
#box_ad_300x250 P {
	FONT-SIZE: 90%; BACKGROUND: #ffffff; PADDING-BOTTOM: 0.25em; MARGIN: =
0px -2px 2px; COLOR: #000000; PADDING-TOP: 1em; FONT-STYLE: italic; =
TEXT-ALIGN: center
}
#box_ad_336x280 P {
	FONT-SIZE: 90%; BACKGROUND: #ffffff; PADDING-BOTTOM: 0.25em; MARGIN: =
0px -2px 2px; COLOR: #000000; PADDING-TOP: 1em; FONT-STYLE: italic; =
TEXT-ALIGN: center
}
#box_ad_300x250 {
	MARGIN-BOTTOM: 3em
}
#box_ad_336x280 {
	MARGIN-BOTTOM: 3em
}
#tv_ad_promo {
	BORDER-RIGHT: #243a71 2px solid; PADDING-RIGHT: 0px; BORDER-TOP: =
#243a71 2px solid; PADDING-LEFT: 0px; BACKGROUND: #ffffff; =
PADDING-BOTTOM: 0px; MARGIN: 0px; BORDER-LEFT: #243a71 2px solid; =
PADDING-TOP: 0px; BORDER-BOTTOM: #243a71 2px solid; TEXT-ALIGN: left
}
A #tv_ad_promo {
	TEXT-DECORATION: none
}
A #tv_ad_promo H3.event_head {
	PADDING-RIGHT: 10px; FONT-WEIGHT: normal; FONT-SIZE: 90%; BACKGROUND: =
url(http://www.eenews.net/images/eetv_headline_header.png) #990000 =
no-repeat left top; MARGIN: 0px; TEXT-TRANSFORM: uppercase; COLOR: =
#ffffff; PADDING-TOP: 17px; HEIGHT: 15px; TEXT-ALIGN: right; =
TEXT-DECORATION: none
}
A #tv_ad_promo H3.onpoint_head {
	PADDING-RIGHT: 10px; FONT-WEIGHT: normal; FONT-SIZE: 90%; BACKGROUND: =
url(http://www.eenews.net/images/OnPoint_headline_header.png) #243a71 =
no-repeat left top; MARGIN: 0px; TEXT-TRANSFORM: uppercase; COLOR: =
#ffffff; PADDING-TOP: 17px; HEIGHT: 15px; TEXT-ALIGN: right; =
TEXT-DECORATION: none
}
A #tv_ad_promo H4 {
	FONT-SIZE: 12px; MARGIN: 0.5em 0px 0px; COLOR: #000000; =
TEXT-DECORATION: none
}
A #tv_ad_promo H4 SPAN.slug {
	TEXT-TRANSFORM: uppercase; COLOR: #990000; TEXT-DECORATION: underline
}
A #tv_ad_promo IMG {
	BORDER-RIGHT: #000 1px solid; BORDER-TOP: #000 1px solid; FLOAT: left; =
MARGIN: 0.5em 0.5em 1.5em; BORDER-LEFT: #000 1px solid; BORDER-BOTTOM: =
#000 1px solid
}
A #tv_ad_promo P.watch {
	FONT-SIZE: 90%; BACKGROUND: #ffffff; PADDING-BOTTOM: 0.25em; MARGIN: =
0px 0px 2px; VERTICAL-ALIGN: middle; COLOR: #990000; PADDING-TOP: 0px; =
FONT-STYLE: normal; TEXT-ALIGN: left
}
A #tv_ad_promo P.watch IMG {
	FLOAT: none; MARGIN: 0px 0.5em 0px 0px; VERTICAL-ALIGN: middle; =
BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: =
none; BORDER-BOTTOM-STYLE: none
}
A #tv_ad_promo P.bottom {
	CLEAR: both; PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: =
0px; MARGIN: 0px; PADDING-TOP: 0px; HEIGHT: 1px
}
#tv_ad_promo_pm {
	BORDER-RIGHT: #243a71 2px solid; PADDING-RIGHT: 0px; BORDER-TOP: =
#243a71 2px solid; PADDING-LEFT: 0px; BACKGROUND: #ffffff; =
PADDING-BOTTOM: 0px; MARGIN: 0px; BORDER-LEFT: #243a71 2px solid; =
PADDING-TOP: 0px; BORDER-BOTTOM: #243a71 2px solid; TEXT-ALIGN: left
}
A #tv_ad_promo_pm {
	TEXT-DECORATION: none
}
A #tv_ad_promo_pm H3 {
	PADDING-RIGHT: 10px; FONT-WEIGHT: normal; FONT-SIZE: 90%; BACKGROUND: =
url(http://www.eenews.net/images/eetv_headline_header.png) #990000 =
no-repeat left top; MARGIN: 0px; TEXT-TRANSFORM: uppercase; COLOR: =
#ffffff; PADDING-TOP: 17px; HEIGHT: 15px; TEXT-ALIGN: right; =
TEXT-DECORATION: none
}
A #tv_ad_promo_pm H4 {
	FONT-SIZE: 12px; MARGIN: 0.5em 0px 0px 0.5em; COLOR: #000000; =
TEXT-DECORATION: none
}
A #tv_ad_promo_pm H4 SPAN.slug {
	TEXT-TRANSFORM: uppercase; COLOR: #990000; TEXT-DECORATION: underline
}
A #tv_ad_promo_pm IMG {
	BORDER-RIGHT: #000 1px solid; BORDER-TOP: #000 1px solid; FLOAT: left; =
MARGIN: 0.5em 0.5em 1.5em; BORDER-LEFT: #000 1px solid; BORDER-BOTTOM: =
#000 1px solid
}
A #tv_ad_promo_pm P.watch {
	FONT-SIZE: 90%; BACKGROUND: #ffffff; PADDING-BOTTOM: 0.25em; MARGIN: =
0px 0px 2px 0.5em; VERTICAL-ALIGN: middle; COLOR: #990000; PADDING-TOP: =
0px; FONT-STYLE: normal; TEXT-ALIGN: left
}
A #tv_ad_promo_pm P.watch IMG {
	FLOAT: none; MARGIN: 0px 0.5em 0px 0px; VERTICAL-ALIGN: middle; =
BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: =
none; BORDER-BOTTOM-STYLE: none
}
A #tv_ad_promo_pm P.bottom {
	CLEAR: both; PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: =
0px; MARGIN: 0px; PADDING-TOP: 0px; HEIGHT: 1px
}
#sponsor_block H4 {
	MARGIN-TOP: 0px; PADDING-LEFT: 1em; FONT-WEIGHT: normal; FONT-SIZE: =
11px; MARGIN-BOTTOM: 1em; PADDING-TOP: 0.5em; FONT-STYLE: italic; =
TEXT-ALIGN: left
}
#sponsor_block {
	BORDER-RIGHT: #7f7f7f 1px solid; MARGIN: 0.25em 0.66em 0px 0.67em; =
BORDER-LEFT: #7f7f7f 1px solid; WIDTH: 319px; BORDER-BOTTOM: #7f7f7f 1px =
solid; HEIGHT: 100px
}
.toolbox {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; MARGIN-BOTTOM: 1em; =
PADDING-BOTTOM: 0.5em; PADDING-TOP: 0.1em
}
.story_well .toolbox {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; MARGIN-BOTTOM: 1em; =
PADDING-BOTTOM: 0.5em; PADDING-TOP: 0.1em
}
.toolbox LABEL {
	FONT-WEIGHT: bold; FONT-SIZE: 90%; VERTICAL-ALIGN: middle; =
TEXT-TRANSFORM: uppercase
}
.story_well .toolbox LABEL {
	FONT-WEIGHT: bold; FONT-SIZE: 90%; VERTICAL-ALIGN: middle; =
TEXT-TRANSFORM: uppercase
}
.toolbox LI {
	DISPLAY: block; PADDING-TOP: 0.25em
}
.toolbox UL {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: =
0.5em 1em; PADDING-TOP: 0px; LIST-STYLE-TYPE: none
}
UL.story_tool_btns LI {
	PADDING-RIGHT: 0em; DISPLAY: inline; PADDING-LEFT: 1em; PADDING-BOTTOM: =
0.25em; MARGIN: 0px; PADDING-TOP: 0.25em
}
.toolbox UL.story_tool_btns LI {
	PADDING-RIGHT: 0em; DISPLAY: inline; PADDING-LEFT: 1em; PADDING-BOTTOM: =
0.25em; MARGIN: 0px; PADDING-TOP: 0.25em
}
UL.edition_tool_btns LI {
	PADDING-RIGHT: 0em; DISPLAY: inline; PADDING-LEFT: 1em; PADDING-BOTTOM: =
0.25em; MARGIN: 0px; PADDING-TOP: 0.25em
}
UL.story_tool_btns LI A {
	FONT-WEIGHT: bold; FONT-SIZE: 90%; TEXT-TRANSFORM: uppercase; =
TEXT-DECORATION: none
}
.toolbox UL.story_tool_btns LI A {
	FONT-WEIGHT: bold; FONT-SIZE: 90%; TEXT-TRANSFORM: uppercase; =
TEXT-DECORATION: none
}
UL.edition_tool_btns LI A {
	FONT-WEIGHT: bold; FONT-SIZE: 90%; TEXT-TRANSFORM: uppercase; =
TEXT-DECORATION: none
}
UL.story_tool_btns {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-SIZE: 90%; PADDING-BOTTOM: =
0.5em; MARGIN: 1em 0px 0em 0.5em; PADDING-TOP: 0px; LIST-STYLE-TYPE: =
none
}
.toolbox UL.story_tool_btns {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-SIZE: 90%; PADDING-BOTTOM: =
0.5em; MARGIN: 1em 0px 0em 0.5em; PADDING-TOP: 0px; LIST-STYLE-TYPE: =
none
}
UL.edition_tool_btns {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-SIZE: 90%; PADDING-BOTTOM: =
0.5em; MARGIN: 1em 0px 0em 0.5em; PADDING-TOP: 0px; BORDER-BOTTOM: #ccc =
1px solid; LIST-STYLE-TYPE: none
}
UL.edition_tool_btns LI {
	MARGIN-LEFT: 1em; BORDER-LEFT: #ccc 1px solid
}
.story_tool_btns IMG {
	PADDING-RIGHT: 0.5em; VERTICAL-ALIGN: middle
}
.edition_tool_btns IMG {
	PADDING-RIGHT: 0.5em; VERTICAL-ALIGN: middle
}
#last_tool {
	PADDING-RIGHT: 0px; BORDER-RIGHT-STYLE: none
}
#first_tool {
	PADDING-LEFT: 0px; BORDER-LEFT-STYLE: none
}
.edition_tool_btns LI#first_tool_edition {
	PADDING-LEFT: 0px; MARGIN-LEFT: -3em; BORDER-LEFT-STYLE: none
}
#last_tool IMG {
=09
}
H1.toolbox {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; FONT-SIZE: 100%; =
PADDING-BOTTOM: 0.25em; MARGIN: 1em 0px 0px; TEXT-TRANSFORM: uppercase; =
BORDER-TOP-STYLE: none; TEXT-INDENT: 0px; PADDING-TOP: 0.3em; =
BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: =
none
}
.story_well H1.toolbox {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; FONT-SIZE: 100%; =
PADDING-BOTTOM: 0.25em; MARGIN: 1em 0px 0px; TEXT-TRANSFORM: uppercase; =
BORDER-TOP-STYLE: none; TEXT-INDENT: 0px; PADDING-TOP: 0.3em; =
BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: =
none
}
.toolbox H2 {
	FONT-SIZE: 100%; MARGIN: 1em 0px 0px; TEXT-TRANSFORM: uppercase; =
TEXT-INDENT: 0px
}
.story_well .toolbox H2 {
	FONT-SIZE: 100%; MARGIN: 1em 0px 0px; TEXT-TRANSFORM: uppercase; =
TEXT-INDENT: 0px
}
.toolbox H2 A:hover {
	COLOR: #990000
}
.story_well .toolbox H2 A:hover {
	COLOR: #990000
}
.toolbox H2 A {
	TEXT-DECORATION: none
}
.story_well .toolbox H2 A {
	TEXT-DECORATION: none
}
.toolbox P {
	MARGIN-TOP: 0.5em; FONT-SIZE: 95%; MARGIN-BOTTOM: 0.5em
}
.toolbox FORM {
	MARGIN: 0.5em 0px 0px; TEXT-ALIGN: left
}
.toolbox SELECT {
	MARGIN: 0.25em 0px; VERTICAL-ALIGN: middle
}
.toolbox LABEL {
	MARGIN: 0.25em 0px; VERTICAL-ALIGN: middle
}
.toolbox INPUT {
	MARGIN: 0.25em 0px; VERTICAL-ALIGN: middle
}
.toolbox_container {
	CLEAR: both; PADDING-RIGHT: 0.5em; PADDING-LEFT: 1em; BACKGROUND: =
#ffffff; FLOAT: right; MARGIN-BOTTOM: 1em; WIDTH: 304px; MARGIN-RIGHT: =
-5em
}
#more_content_container {
	BORDER-RIGHT: #185983 1px solid; PADDING-RIGHT: 10px; BORDER-TOP: =
#185983 1px solid; PADDING-LEFT: 10px; PADDING-BOTTOM: 10px; MARGIN: 0px =
1em 1em; BORDER-LEFT: #185983 1px solid; PADDING-TOP: 10px; =
BORDER-BOTTOM: #185983 1px solid
}
#more_content_header {
	CLEAR: both; PADDING-RIGHT: 10px; PADDING-LEFT: 10px; BACKGROUND: =
url(http://www.eenews.net/images/white_left_corner.png) #024165 =
no-repeat left top; PADDING-BOTTOM: 0.25em; MARGIN: 1em 1em 0px; COLOR: =
#ffffff; PADDING-TOP: 0.25em
}
#more_content_header H1 {
	PADDING-RIGHT: 1em; DISPLAY: inline; PADDING-LEFT: 0px; FONT-SIZE: =
1.5em; PADDING-BOTTOM: 0px; MARGIN: 0px; COLOR: #ffffff; PADDING-TOP: =
0px
}
#more_content_container H1 {
	PADDING-RIGHT: 0px; MARGIN-TOP: 0.5em; PADDING-LEFT: 0px; FONT-SIZE: =
1.25em; MARGIN-BOTTOM: 0px; PADDING-BOTTOM: 0px; TEXT-TRANSFORM: =
uppercase; COLOR: #326497; PADDING-TOP: 0px; BORDER-BOTTOM: #999999 2px =
solid
}
.more_content_left_column {
	FLOAT: left; WIDTH: 50%
}
.more_content_right_column {
	FLOAT: left; WIDTH: 50%
}
.more_content_block {
	FONT-SIZE: 100%; MARGIN: 1em
}
.more_content_block H2.sr {
	BACKGROUND: =
url(http://www.eenews.net/images/tool_box_header_bg_green.png) #8e9e76 =
no-repeat left top; COLOR: #ffffff
}
.more_content_block H2.enterprise {
	BACKGROUND: =
url(http://www.eenews.net/images/tool_box_header_bg_tan.png) #ca9a7d =
no-repeat left top; COLOR: #ffffff
}
.more_content_block H2.op {
	BACKGROUND: url(http://www.eenews.net/images/op_promo_bg.png) #3d5896 =
no-repeat left top; COLOR: #ffffff; BORDER-BOTTOM: #000000 1px solid
}
.more_content_block H2 {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; FONT-SIZE: 115%; BACKGROUND: =
#cccccc; PADDING-BOTTOM: 0px; PADDING-TOP: 0.5em; BORDER-BOTTOM: #666666 =
1px solid
}
.more_content_block H2 SPAN {
	FONT-WEIGHT: normal; FONT-SIZE: 85%; TEXT-TRANSFORM: uppercase; =
TEXT-ALIGN: right
}
.more_content_block P {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; PADDING-BOTTOM: 0.5em; =
MARGIN: 0px; PADDING-TOP: 0.5em
}
.more_content_block IMG {
	BORDER-RIGHT: #2c4585 1px solid; BORDER-TOP: #2c4585 1px solid; FLOAT: =
left; MARGIN: 0.5em; BORDER-LEFT: #2c4585 1px solid; BORDER-BOTTOM: =
#2c4585 1px solid
}
.more_content_block H3 {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; FONT-SIZE: 115%; =
PADDING-BOTTOM: 0.25em; MARGIN: 0px; PADDING-TOP: 0px
}
.more_content_block H3 A {
	COLOR: #990000; TEXT-DECORATION: none
}
.more_content_block H3 A:hover {
	COLOR: #ff0000
}
.more_content_block P {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; PADDING-BOTTOM: 0.5em; =
MARGIN: 0px; PADDING-TOP: 0.5em
}
.more_content_block P.latest_head {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-WEIGHT: bold; FONT-SIZE: =
80%; PADDING-BOTTOM: 0px; MARGIN: 1em 0.75em 0.5em; TEXT-TRANSFORM: =
uppercase; PADDING-TOP: 0px; BORDER-BOTTOM: #000000 1px solid
}
.more_content_block P A {
	COLOR: #000000; TEXT-DECORATION: none
}
.more_content_block P A:hover {
	COLOR: #000000
}
.more_content_op {
	FONT-SIZE: 100%; MARGIN: 1em
}
.more_content_op H2 {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; FONT-SIZE: 115%; BACKGROUND: =
url(http://www.eenews.net/images/op_promo_bg.png) #3d5896 no-repeat left =
top; PADDING-BOTTOM: 0px; MARGIN: 0px; COLOR: #ffffff; PADDING-TOP: =
0.5em; BORDER-BOTTOM: #000000 1px solid
}
.more_content_op H2 SPAN {
	FONT-WEIGHT: normal; FONT-SIZE: 85%; TEXT-TRANSFORM: uppercase; =
TEXT-ALIGN: right
}
.more_content_op H3 {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-SIZE: 115%; PADDING-BOTTOM: =
0px; MARGIN: 0px; PADDING-TOP: 0.5em
}
.more_content_op H3 A {
	COLOR: #2c4585; TEXT-DECORATION: none
}
.more_content_op H3 A:hover {
	COLOR: #990000
}
.more_content_op P {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; PADDING-BOTTOM: 0.5em; =
MARGIN: 0px; PADDING-TOP: 0.5em
}
.more_content_op P A {
	COLOR: #000000; TEXT-DECORATION: none
}
.more_content_op P A:hover {
	COLOR: #000000
}
.more_content_op IMG {
	BORDER-RIGHT: #2c4585 1px solid; BORDER-TOP: #2c4585 1px solid; FLOAT: =
left; MARGIN: 1em 0.5em 0.5em; BORDER-LEFT: #2c4585 1px solid; =
BORDER-BOTTOM: #2c4585 1px solid
}
.more_content_listing {
	MARGIN-TOP: 0px; PADDING-LEFT: 0.5em; FLOAT: right; MARGIN-BOTTOM: 0px; =
TEXT-ALIGN: right
}
.more_content_listing IMG {
	VERTICAL-ALIGN: middle; MARGIN-RIGHT: 0.25em
}
.more_content_listing A:hover {
	COLOR: #ff0000
}
.story_well {
	PADDING-RIGHT: 9em; PADDING-LEFT: 8em; MARGIN-LEFT: 1em; MARGIN-RIGHT: =
1em
}
.story_well H1 {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; FONT-SIZE: 110%; =
PADDING-BOTTOM: 0.25em; MARGIN: 2em -4em 1.5em -1.75em; VERTICAL-ALIGN: =
middle; TEXT-TRANSFORM: uppercase; PADDING-TOP: 0.5em
}
.story_well H2 {
	FONT-SIZE: 1.5em; MARGIN-BOTTOM: 0px; PADDING-BOTTOM: 0px; TEXT-INDENT: =
-1.2em
}
.story_well H2 SPAN {
	TEXT-TRANSFORM: uppercase
}
.story_well H3 {
	FONT-SIZE: 1.25em; MARGIN-BOTTOM: 0px; PADDING-BOTTOM: 0px
}
.story_well H5.reporter {
	MARGIN-TOP: 2em; FONT-SIZE: 100%; MARGIN-BOTTOM: 0px; PADDING-BOTTOM: =
0px
}
.story_well H5 {
	MARGIN-TOP: 0.25em; FONT-SIZE: 100%; MARGIN-BOTTOM: 0px; =
PADDING-BOTTOM: 0px; PADDING-TOP: 0px
}
.top_link {
	PADDING-RIGHT: 0.5em; BORDER-TOP: #cccccc 1px solid; MARGIN-TOP: 1em; =
PADDING-LEFT: 0.5em; MARGIN-BOTTOM: 3em; PADDING-BOTTOM: 0.5em; =
TEXT-TRANSFORM: uppercase; PADDING-TOP: 0.5em; BORDER-BOTTOM: #cccccc =
1px solid; TEXT-ALIGN: center
}
.top_link A {
	FONT-WEIGHT: bold; COLOR: #666666; TEXT-DECORATION: none
}
.top_link A:hover {
	COLOR: #990000; TEXT-DECORATION: underline
}
.top_link_index {
	PADDING-RIGHT: 0.5em; BORDER-TOP: #cccccc 1px solid; PADDING-LEFT: =
0.5em; PADDING-BOTTOM: 0.5em; MARGIN: 1em; TEXT-TRANSFORM: uppercase; =
PADDING-TOP: 0.5em; BORDER-BOTTOM: #cccccc 1px solid; TEXT-ALIGN: center
}
.top_link_index A {
	FONT-WEIGHT: bold; COLOR: #666666; TEXT-DECORATION: none
}
.top_link_index A:hover {
	COLOR: #990000; TEXT-DECORATION: underline
}
.footer_container {
	CLEAR: both; BACKGROUND: #ffffff; MARGIN: 0px auto; PADDING-TOP: 0px
}
.footer {
	BACKGROUND: #ffffff; MARGIN: 15px auto 0px; WIDTH: 870px; TEXT-ALIGN: =
left
}
.bottom_nav {
	CLEAR: both; BORDER-TOP: #43759b 2px solid; FONT-SIZE: 90%; BACKGROUND: =
#024165; PADDING-BOTTOM: 2px; COLOR: #ffffff; PADDING-TOP: 2px
}
.bottom_nav A {
	FONT-WEIGHT: normal; COLOR: #ffffff; TEXT-DECORATION: none
}
.bottom_nav A:hover {
	FONT-WEIGHT: normal; COLOR: #bbcad5; TEXT-DECORATION: underline
}
.footer_right {
	FLOAT: right; WIDTH: 700px
}
.footer_left {
	FLOAT: left
}
.bottom_nav UL {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: =
0px; WIDTH: 777px; PADDING-TOP: 0px; LIST-STYLE-TYPE: none
}
.bottom_nav LI {
	BORDER-RIGHT: #43759b 1px solid; PADDING-RIGHT: 6px; DISPLAY: inline; =
PADDING-LEFT: 6px; PADDING-BOTTOM: 2px; LINE-HEIGHT: 2.5em; PADDING-TOP: =
0px
}
.bottom_nav LI.lastItem {
	BORDER-RIGHT-STYLE: none
}
.copyright {
	CLEAR: both; PADDING-LEFT: 7px; FONT-SIZE: 80%; PADDING-BOTTOM: 0px; =
COLOR: #999999; PADDING-TOP: 0px; TEXT-ALIGN: left
}
.tagLine {
	BORDER-TOP: #cccccc 1px solid; PADDING-LEFT: 7px; FONT-SIZE: 100%; =
PADDING-BOTTOM: 10px; COLOR: #999999; PADDING-TOP: 8px; FONT-STYLE: =
italic
}
.clear_both {
	CLEAR: both
}
.anchor {
	PADDING-TOP: 10em
}
.jump_anchor {
	PADDING-TOP: 2em
}
.date A.anchor {
	TEXT-DECORATION: none
}
.search_box {
	CLEAR: both; PADDING-LEFT: 3em
}
.search_box_header {
	FONT-SIZE: 1.5em; MARGIN-LEFT: -1em
}
.search_description {
	MARGIN-RIGHT: 376px
}
#right_column_search {
	PADDING-RIGHT: 0.5em; FLOAT: right; MARGIN-BOTTOM: 1em; WIDTH: 340px; =
PADDING-TOP: 1em
}
#search_form FIELDSET {
	BORDER-RIGHT: #ffffff 0px solid; PADDING-RIGHT: 0px; BORDER-TOP: =
#ffffff 0px solid; DISPLAY: block; PADDING-LEFT: 100px; PADDING-BOTTOM: =
0px; MARGIN: 0.75em 0px; VERTICAL-ALIGN: middle; BORDER-LEFT: #ffffff =
0px solid; PADDING-TOP: 0px; BORDER-BOTTOM: #ffffff 0px solid
}
#search_form FIELDSET H3 {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-SIZE: 100%; FLOAT: left; =
PADDING-BOTTOM: 0px; MARGIN: 0px 0.5em 0px -100px; VERTICAL-ALIGN: =
middle; WIDTH: 90px; PADDING-TOP: 0px; TEXT-ALIGN: right
}
#search_form H3 {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-SIZE: 100%; PADDING-BOTTOM: =
0px; MARGIN: 0px; VERTICAL-ALIGN: middle; PADDING-TOP: 0px; TEXT-ALIGN: =
right
}
#search_form TD {
	PADDING-RIGHT: 0.25em; PADDING-LEFT: 0.25em; PADDING-BOTTOM: 0.25em; =
MARGIN: 0px; PADDING-TOP: 0.25em
}
#search_form TABLE.form_on_results {
	PADDING-RIGHT: 50px; MARGIN: auto
}
#search_form TD FIELDSET {
	BORDER-RIGHT: #ffffff 0px solid; PADDING-RIGHT: 0px; BORDER-TOP: =
#ffffff 0px solid; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: 0px; =
VERTICAL-ALIGN: middle; BORDER-LEFT: #ffffff 0px solid; PADDING-TOP: =
0px; BORDER-BOTTOM: #ffffff 0px solid
}
#search_form FIELDSET LABEL {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: =
0px; VERTICAL-ALIGN: middle; PADDING-TOP: 0px; TEXT-ALIGN: right
}
#search_form FIELDSET LABEL SELECT.first {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: =
0px; VERTICAL-ALIGN: middle; PADDING-TOP: 0px
}
#search_form FIELDSET LABEL INPUT.first {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: =
0px; VERTICAL-ALIGN: middle; PADDING-TOP: 0px
}
UL.search_tabs {
	PADDING-RIGHT: 0px; DISPLAY: block; PADDING-LEFT: 1em; PADDING-BOTTOM: =
0px; MARGIN: 0px; PADDING-TOP: 0px; BORDER-BOTTOM: #98b1cb 1px solid; =
HEIGHT: 2em
}
UL.search_tabs LI {
	BORDER-RIGHT: #98b1cb 1px solid; PADDING-RIGHT: 1em; BORDER-TOP: =
#98b1cb 1px solid; DISPLAY: block; PADDING-LEFT: 1em; FONT-WEIGHT: bold; =
FONT-SIZE: 100%; BACKGROUND: =
url(http://www.eenews.net/images/blue_btn_rev_bg_09.png) repeat-x center =
top; FLOAT: left; PADDING-BOTTOM: 0.25em; MARGIN: 0px; TEXT-TRANSFORM: =
uppercase; COLOR: #326497; PADDING-TOP: 0.5em; LIST-STYLE-TYPE: none
}
UL.search_tabs LI A {
	COLOR: #024165; TEXT-DECORATION: none
}
UL.search_tabs LI A:hover {
	COLOR: #98b1cb
}
UL.search_tabs #first_tab {
	BORDER-LEFT: #98b1cb 1px solid
}
UL.search_tabs LI.selected {
	BACKGROUND: #ffffff; COLOR: #326497; BORDER-BOTTOM: #ffffff 2px solid
}
UL.search_tabs LI.selected A {
	COLOR: #326497
}
UL.search_tabs LI.results_header {
	PADDING-RIGHT: 3em; PADDING-LEFT: 0px; FONT-SIZE: 1.5em; BACKGROUND: =
none transparent scroll repeat 0% 0%; PADDING-BOTTOM: 0px; MARGIN: 0px; =
TEXT-TRANSFORM: none; COLOR: #024165; BORDER-TOP-STYLE: none; =
PADDING-TOP: 0px; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none; =
BORDER-BOTTOM-STYLE: none
}
.search_box_results {
	MARGIN-TOP: 1em; MARGIN-LEFT: 3em; MARGIN-RIGHT: auto
}
.key_docs_results {
	MARGIN-TOP: 2em; MARGIN-LEFT: 0px; MARGIN-RIGHT: auto
}
#search_results_well {
	PADDING-RIGHT: 5em; PADDING-LEFT: 5em; MARGIN: 0em 1em 3em; =
PADDING-TOP: 1em
}
#search_results_well .search_box_results {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 1em; =
PADDING-TOP: 0.25em
}
#results {
	CLEAR: left; PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: =
0px; MARGIN: 0px; PADDING-TOP: 0.5em
}
#results TD.number {
	FONT-WEIGHT: normal; FONT-SIZE: 100%; COLOR: #000000; TEXT-ALIGN: right
}
#key_docs TD.number {
	FONT-WEIGHT: normal; FONT-SIZE: 100%; COLOR: #000000; TEXT-ALIGN: right
}
#results P.results_description {
	PADDING-RIGHT: 1em; PADDING-LEFT: 1em; FONT-WEIGHT: bold; FLOAT: left; =
PADDING-BOTTOM: 0.5em; MARGIN: 0px; PADDING-TOP: 0.5em
}
#results P.results_page_btn {
	PADDING-RIGHT: 1em; PADDING-LEFT: 1em; FONT-WEIGHT: bold; =
PADDING-BOTTOM: 0.5em; MARGIN: 0px; PADDING-TOP: 0.5em; TEXT-ALIGN: =
right
}
.results_nav {
	BORDER-BOTTOM: #cccccc 1px dotted
}
#results TABLE {
	BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: =
none; BORDER-BOTTOM-STYLE: none
}
#key_docs TABLE {
	MARGIN: 0px 1em; WIDTH: 96%; BORDER-TOP-STYLE: none; =
BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: =
none
}
#results .list_odd TD {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; BACKGROUND: #ffffff; =
PADDING-BOTTOM: 0.75em; MARGIN: 0px; VERTICAL-ALIGN: middle; =
BORDER-TOP-STYLE: none; PADDING-TOP: 0.75em; BORDER-RIGHT-STYLE: none; =
BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: none
}
#key_docs .list_odd TD {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; BACKGROUND: #ffffff; =
PADDING-BOTTOM: 0.75em; MARGIN: 0px; VERTICAL-ALIGN: middle; =
BORDER-TOP-STYLE: none; PADDING-TOP: 0.75em; BORDER-RIGHT-STYLE: none; =
BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: none
}
#results .list_even TD {
	PADDING-RIGHT: 0.5em; BORDER-TOP: #cccccc 1px dotted; PADDING-LEFT: =
0.5em; BACKGROUND: #efefef; PADDING-BOTTOM: 0.75em; MARGIN: 0px; =
VERTICAL-ALIGN: middle; PADDING-TOP: 0.75em; BORDER-BOTTOM: #cccccc 1px =
dotted; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none
}
#key_docs .list_even TD {
	PADDING-RIGHT: 0.5em; BORDER-TOP: #cccccc 1px dotted; PADDING-LEFT: =
0.5em; BACKGROUND: #efefef; PADDING-BOTTOM: 0.75em; MARGIN: 0px; =
VERTICAL-ALIGN: middle; PADDING-TOP: 0.75em; BORDER-BOTTOM: #cccccc 1px =
dotted; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none
}
#results .sorting_tools TD {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; PADDING-BOTTOM: 0.5em; =
MARGIN: 0px; VERTICAL-ALIGN: middle; PADDING-TOP: 0.5em; BORDER-BOTTOM: =
#cccccc 1px dotted
}
#key_docs .sorting_tools TD {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; PADDING-BOTTOM: 0.5em; =
MARGIN: 0px; VERTICAL-ALIGN: middle; PADDING-TOP: 0.5em; BORDER-BOTTOM: =
#cccccc 1px dotted
}
#results .list_odd {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; BACKGROUND: #ffffff; =
PADDING-BOTTOM: 1.25em; PADDING-TOP: 1.25em
}
#key_docs .list_odd {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; BACKGROUND: #ffffff; =
PADDING-BOTTOM: 1.25em; PADDING-TOP: 1.25em
}
#results .list_even {
	PADDING-RIGHT: 0.5em; BORDER-TOP: #cccccc 1px dotted; PADDING-LEFT: =
0.5em; BACKGROUND: #efefef; PADDING-BOTTOM: 1.25em; PADDING-TOP: 1.25em; =
BORDER-BOTTOM: #cccccc 1px dotted
}
#key_docs .list_even {
	PADDING-RIGHT: 0.5em; BORDER-TOP: #cccccc 1px dotted; PADDING-LEFT: =
0.5em; BACKGROUND: #efefef; PADDING-BOTTOM: 1.25em; PADDING-TOP: 1.25em; =
BORDER-BOTTOM: #cccccc 1px dotted
}
.Greenwire SPAN {
	COLOR: #336633
}
.Greenwire SPAN A {
	COLOR: #336633
}
.story_well H2.Greenwire {
	TEXT-INDENT: 0px
}
.story_well H2.Greenwire SPAN {
	TEXT-TRANSFORM: uppercase
}
.onpoint SPAN {
	COLOR: #3d5896
}
.onpoint SPAN A {
	COLOR: #3d5896
}
.EEDaily SPAN {
	COLOR: #326497
}
.EEDaily SPAN A {
	COLOR: #326497
}
.story_well H2.EEDaily {
	TEXT-INDENT: 0px
}
.story_well H2.EEDaily SPAN {
	TEXT-TRANSFORM: uppercase
}
.eenewspm SPAN {
	COLOR: #336666
}
.eenewspm SPAN A {
	COLOR: #336666
}
.story_well H2.eenewspm {
	TEXT-INDENT: 0px
}
.story_well H2.eenewspm SPAN {
	TEXT-TRANSFORM: uppercase
}
.Landletter SPAN {
	COLOR: #666633
}
.Landletter SPAN A {
	COLOR: #666633
}
.climatewire SPAN {
	COLOR: #333399
}
.climatewire SPAN A {
	COLOR: #333399
}
.story_well H2.Landletter {
	TEXT-INDENT: 0px
}
.story_well H2.Landletter SPAN {
	TEXT-TRANSFORM: uppercase
}
#results H3 SPAN {
	FONT-WEIGHT: bold; TEXT-TRANSFORM: uppercase
}
#results H3 A:hover SPAN {
	COLOR: #990000
}
#results H3 A SPAN {
	TEXT-DECORATION: underline
}
#results H3 {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-WEIGHT: normal; FONT-SIZE: =
115%; PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-TOP: 0px
}
#results H3 A {
	COLOR: #000000; TEXT-DECORATION: none
}
#results H3 A:hover {
	COLOR: #990000
}
#results P {
	FONT-SIZE: 100%; MARGIN: 0.25em 1.87em 0px
}
#results P.publication {
	FONT-WEIGHT: normal; FONT-SIZE: 100%; MARGIN: 0.25em 0px 0px; COLOR: =
#666666; FONT-STYLE: italic
}
#search_results_well H1.results_header {
	MARGIN-TOP: 1em; FONT-SIZE: 1.5em; MARGIN-BOTTOM: 0.5em; =
PADDING-BOTTOM: 0.25em; MARGIN-LEFT: -3em; COLOR: #024165; =
BORDER-BOTTOM: #024165 1px solid
}
#results TD.publication {
	FONT-WEIGHT: normal; FONT-SIZE: 100%; COLOR: #666666; FONT-STYLE: =
italic
}
#key_docs TD.publication {
	WIDTH: 15%
}
#key_docs TD.date {
	WIDTH: 8%
}
#results TD.publication IMG {
	BORDER-RIGHT: #666666 1px solid; BORDER-TOP: #666666 1px solid; =
VERTICAL-ALIGN: middle; BORDER-LEFT: #666666 1px solid; MARGIN-RIGHT: =
0.5em; BORDER-BOTTOM: #666666 1px solid
}
#key_docs TD.publication IMG {
	BORDER-RIGHT: #666666 1px solid; BORDER-TOP: #666666 1px solid; =
VERTICAL-ALIGN: middle; BORDER-LEFT: #666666 1px solid; MARGIN-RIGHT: =
0.5em; BORDER-BOTTOM: #666666 1px solid
}
#results TD.date {
	FONT-WEIGHT: normal; FONT-SIZE: 115%; COLOR: #666666; FONT-STYLE: =
normal
}
#key_docs TD.date {
	FONT-WEIGHT: normal; FONT-SIZE: 115%; COLOR: #666666; FONT-STYLE: =
normal
}
#spotlight H2 A SPAN.sr_top_date {
	FONT-WEIGHT: normal; FONT-SIZE: 75%; TEXT-TRANSFORM: none; COLOR: =
#666666; TEXT-DECORATION: none
}
#results TD.number {
	FONT-WEIGHT: normal; FONT-SIZE: 100%; COLOR: #000000; TEXT-ALIGN: right
}
#key_docs TD.number {
	FONT-WEIGHT: normal; FONT-SIZE: 100%; COLOR: #000000; TEXT-ALIGN: right
}
#results P.results_description {
	PADDING-RIGHT: 1em; PADDING-LEFT: 1em; FONT-WEIGHT: bold; FLOAT: left; =
PADDING-BOTTOM: 0.5em; MARGIN: 0px; PADDING-TOP: 0.5em
}
#results P.results_page_btn {
	PADDING-RIGHT: 1em; PADDING-LEFT: 1em; FONT-WEIGHT: bold; =
PADDING-BOTTOM: 0.5em; MARGIN: 0px; PADDING-TOP: 0.5em; TEXT-ALIGN: =
right
}
.results_nav {
	BORDER-BOTTOM: #cccccc 1px dotted
}
#results TABLE {
	BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: =
none; BORDER-BOTTOM-STYLE: none
}
#key_docs TABLE {
	MARGIN: 0px 1em; WIDTH: 96%; BORDER-TOP-STYLE: none; =
BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: =
none
}
#results .list_odd TD {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; BACKGROUND: #ffffff; =
PADDING-BOTTOM: 0.75em; MARGIN: 0px; VERTICAL-ALIGN: middle; =
BORDER-TOP-STYLE: none; PADDING-TOP: 0.75em; BORDER-RIGHT-STYLE: none; =
BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: none
}
#key_docs .list_odd TD {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; BACKGROUND: #ffffff; =
PADDING-BOTTOM: 0.75em; MARGIN: 0px; VERTICAL-ALIGN: middle; =
BORDER-TOP-STYLE: none; PADDING-TOP: 0.75em; BORDER-RIGHT-STYLE: none; =
BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: none
}
#results .list_even TD {
	PADDING-RIGHT: 0.5em; BORDER-TOP: #cccccc 1px dotted; PADDING-LEFT: =
0.5em; BACKGROUND: #efefef; PADDING-BOTTOM: 0.75em; MARGIN: 0px; =
VERTICAL-ALIGN: middle; PADDING-TOP: 0.75em; BORDER-BOTTOM: #cccccc 1px =
dotted; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none
}
#key_docs .list_even TD {
	PADDING-RIGHT: 0.5em; BORDER-TOP: #cccccc 1px dotted; PADDING-LEFT: =
0.5em; BACKGROUND: #efefef; PADDING-BOTTOM: 0.75em; MARGIN: 0px; =
VERTICAL-ALIGN: middle; PADDING-TOP: 0.75em; BORDER-BOTTOM: #cccccc 1px =
dotted; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none
}
#results .sorting_tools TD {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; PADDING-BOTTOM: 0.5em; =
MARGIN: 0px; VERTICAL-ALIGN: middle; PADDING-TOP: 0.5em; BORDER-BOTTOM: =
#cccccc 1px dotted
}
#key_docs .sorting_tools TD {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; PADDING-BOTTOM: 0.5em; =
MARGIN: 0px; VERTICAL-ALIGN: middle; PADDING-TOP: 0.5em; BORDER-BOTTOM: =
#cccccc 1px dotted
}
#results .list_odd {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; BACKGROUND: #ffffff; =
PADDING-BOTTOM: 1.25em; PADDING-TOP: 1.25em
}
#key_docs .list_odd {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; BACKGROUND: #ffffff; =
PADDING-BOTTOM: 1.25em; PADDING-TOP: 1.25em
}
#results .list_even {
	PADDING-RIGHT: 0.5em; BORDER-TOP: #cccccc 1px dotted; PADDING-LEFT: =
0.5em; BACKGROUND: #efefef; PADDING-BOTTOM: 1.25em; PADDING-TOP: 1.25em; =
BORDER-BOTTOM: #cccccc 1px dotted
}
#key_docs .list_even {
	PADDING-RIGHT: 0.5em; BORDER-TOP: #cccccc 1px dotted; PADDING-LEFT: =
0.5em; BACKGROUND: #efefef; PADDING-BOTTOM: 1.25em; PADDING-TOP: 1.25em; =
BORDER-BOTTOM: #cccccc 1px dotted
}
H2.result_logo {
	TEXT-INDENT: 0px
}
.story_well H2.result_logo {
	TEXT-INDENT: 0px
}
H2.result_date {
	FONT-SIZE: 1.5em; PADDING-BOTTOM: 0.5em; COLOR: #666666; TEXT-INDENT: =
0px; BORDER-BOTTOM: #cccccc 1px solid; TEXT-ALIGN: left
}
.story_well H2.result_date {
	FONT-SIZE: 1.5em; PADDING-BOTTOM: 0.5em; COLOR: #666666; TEXT-INDENT: =
0px; BORDER-BOTTOM: #cccccc 1px solid; TEXT-ALIGN: left
}
H1.sr_advert {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; FONT-SIZE: 100%; BACKGROUND: =
url(http://www.eenews.net/images/sr_tool_box_header_bg.png) #024165 =
no-repeat left top; PADDING-BOTTOM: 0.25em; MARGIN: 1em 0px 0px; =
TEXT-TRANSFORM: uppercase; COLOR: #ffffff; BORDER-TOP-STYLE: none; =
TEXT-INDENT: 0px; PADDING-TOP: 0.3em; BORDER-RIGHT-STYLE: none; =
BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: none
}
DIV.sr_advert {
	BORDER-RIGHT: #000000 2px solid; BORDER-TOP: #000000 2px solid; =
BORDER-LEFT: #000000 2px solid; BORDER-BOTTOM: #000000 2px solid; =
TEXT-ALIGN: center
}
DIV.link_btns {
	BORDER-RIGHT: #000000 2px solid; BORDER-TOP: #000000 2px solid; =
MARGIN-TOP: 1em; MARGIN-BOTTOM: 1em; BORDER-LEFT: #000000 2px solid; =
BORDER-BOTTOM: #000000 2px solid; TEXT-ALIGN: center
}
P.sr_advert {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; FONT-SIZE: 100%; BACKGROUND: =
url(http://www.eenews.net/images/sr_tool_box_header_bg_rev.png) #024165 =
no-repeat left bottom; PADDING-BOTTOM: 0.25em; MARGIN: 0px; COLOR: =
#ffffff; BORDER-TOP-STYLE: none; TEXT-INDENT: 0px; PADDING-TOP: 0.3em; =
BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none; TEXT-ALIGN: right; =
BORDER-BOTTOM-STYLE: none
}
P.sr_advert A {
	COLOR: #ffffff
}
H3.gw_headlines {
	DISPLAY: none
}
H4.gw_headlines {
	PADDING-RIGHT: 10px; FONT-WEIGHT: normal; FONT-SIZE: 90%; BACKGROUND: =
url(http://www.eenews.net/images/gw_headline_head.png) #000 no-repeat =
left top; MARGIN: 1em 0px 0px; TEXT-TRANSFORM: uppercase; COLOR: =
#ffffff; PADDING-TOP: 17px; HEIGHT: 15px; TEXT-ALIGN: right
}
DIV.gw_headlines {
	BORDER-RIGHT: #006633 2px solid; PADDING-RIGHT: 0.5em; BORDER-TOP: =
#006633 2px solid; PADDING-LEFT: 0.5em; PADDING-BOTTOM: 0.5em; =
BORDER-LEFT: #006633 2px solid; PADDING-TOP: 0.5em; BORDER-BOTTOM: =
#006633 2px solid
}
DIV.gw_headlines P.more_link {
	MARGIN: 0px; TEXT-ALIGN: right
}
DIV.gw_headlines P.more_link A {
	COLOR: #990000; TEXT-DECORATION: underline
}
DIV.gw_headlines P.more_link A:hover {
	COLOR: #ff0000; TEXT-DECORATION: underline
}
DIV.gw_headlines P {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-WEIGHT: normal; FONT-SIZE: =
100%; PADDING-BOTTOM: 0.5em; MARGIN: 0.5em 0px; COLOR: #000000; =
PADDING-TOP: 0px; BORDER-BOTTOM: #cccccc 1px solid
}
DIV.gw_headlines P A {
	COLOR: #000000; TEXT-DECORATION: none
}
DIV.gw_headlines P A:hover {
	COLOR: #990000
}
DIV.gw_headlines P SPAN {
	FONT-WEIGHT: bold; TEXT-TRANSFORM: uppercase; COLOR: #006633
}
DIV.gw_headlines P A SPAN {
	COLOR: #006633; TEXT-DECORATION: underline
}
DIV.gw_headlines P A:hover SPAN {
	COLOR: #990000
}
H3.daily_headlines {
	DISPLAY: none
}
H4.daily_headlines {
	PADDING-RIGHT: 10px; FONT-WEIGHT: normal; FONT-SIZE: 90%; BACKGROUND: =
url(http://www.eenews.net/images/daily_headline_head.png) #326497 =
no-repeat left top; MARGIN: 1em 0px 0px; TEXT-TRANSFORM: uppercase; =
COLOR: #ffffff; PADDING-TOP: 17px; HEIGHT: 15px; TEXT-ALIGN: right
}
DIV.daily_headlines {
	BORDER-RIGHT: #326497 2px solid; PADDING-RIGHT: 0.5em; BORDER-TOP: =
#326497 2px solid; PADDING-LEFT: 0.5em; PADDING-BOTTOM: 0.5em; =
BORDER-LEFT: #326497 2px solid; PADDING-TOP: 0.5em; BORDER-BOTTOM: =
#326497 2px solid
}
DIV.daily_headlines P.more_link {
	MARGIN: 0px; TEXT-ALIGN: right
}
DIV.daily_headlines P.more_link A {
	COLOR: #990000; TEXT-DECORATION: underline
}
DIV.daily_headlines P.more_link A:hover {
	COLOR: #ff0000; TEXT-DECORATION: underline
}
DIV.daily_headlines P {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-WEIGHT: normal; FONT-SIZE: =
100%; PADDING-BOTTOM: 0.5em; MARGIN: 0.5em 0px; COLOR: #000000; =
PADDING-TOP: 0px; BORDER-BOTTOM: #cccccc 1px solid
}
DIV.daily_headlines P A {
	COLOR: #000000; TEXT-DECORATION: none
}
DIV.daily_headlines P A:hover {
	COLOR: #990000
}
DIV.daily_headlines P SPAN {
	FONT-WEIGHT: bold; TEXT-TRANSFORM: uppercase; COLOR: #326497
}
DIV.daily_headlines P A SPAN {
	COLOR: #326497; TEXT-DECORATION: underline
}
DIV.daily_headlines P A:hover SPAN {
	COLOR: #990000
}
H3.pm_headlines {
	DISPLAY: none
}
H4.pm_headlines {
	PADDING-RIGHT: 10px; FONT-WEIGHT: normal; FONT-SIZE: 90%; BACKGROUND: =
url(http://www.eenews.net/images/eenewspm_headlines_head.png) #336666 =
no-repeat left top; MARGIN: 1em 0px 0px; TEXT-TRANSFORM: uppercase; =
COLOR: #ffffff; PADDING-TOP: 17px; HEIGHT: 15px; TEXT-ALIGN: right
}
DIV.pm_headlines {
	BORDER-RIGHT: #336666 2px solid; PADDING-RIGHT: 0.5em; BORDER-TOP: =
#336666 2px solid; PADDING-LEFT: 0.5em; PADDING-BOTTOM: 0.5em; =
BORDER-LEFT: #336666 2px solid; PADDING-TOP: 0.5em; BORDER-BOTTOM: =
#336666 2px solid
}
DIV.pm_headlines P.more_link {
	MARGIN: 0px; TEXT-ALIGN: right
}
DIV.pm_headlines P.more_link A {
	COLOR: #990000; TEXT-DECORATION: underline
}
DIV.pm_headlines P.more_link A:hover {
	COLOR: #ff0000; TEXT-DECORATION: underline
}
DIV.pm_headlines P {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-WEIGHT: normal; FONT-SIZE: =
100%; PADDING-BOTTOM: 0.5em; MARGIN: 0.5em 0px; COLOR: #000000; =
PADDING-TOP: 0px; BORDER-BOTTOM: #cccccc 1px solid
}
DIV.pm_headlines P A {
	COLOR: #000000; TEXT-DECORATION: none
}
DIV.pm_headlines P A:hover {
	COLOR: #990000
}
DIV.pm_headlines P SPAN {
	FONT-WEIGHT: bold; TEXT-TRANSFORM: uppercase; COLOR: #336666
}
DIV.pm_headlines P A SPAN {
	COLOR: #336666; TEXT-DECORATION: underline
}
DIV.pm_headlines P A:hover SPAN {
	COLOR: #990000
}
.recent_editions {
	MARGIN-TOP: 0.5em
}
.recent_editions UL {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0em; MARGIN: 0px =
auto; PADDING-TOP: 0em; HEIGHT: 2.17em; TEXT-ALIGN: center
}
.recent_editions LI {
	BORDER-RIGHT: #cccccc 1px solid; PADDING-RIGHT: 0.6em; DISPLAY: block; =
PADDING-LEFT: 0.6em; FONT-SIZE: 90%; FLOAT: left; PADDING-BOTTOM: 0.5em; =
MARGIN: 0px; COLOR: #990000; PADDING-TOP: 0.5em; BORDER-BOTTOM: #cccccc =
1px solid; LIST-STYLE-TYPE: none
}
.recent_editions LI.first_item {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; COLOR: #ffffff
}
.recent_editions LI A {
	FONT-WEIGHT: normal; COLOR: #666666; TEXT-DECORATION: none
}
.recent_editions LI A:hover {
	COLOR: #990000; TEXT-DECORATION: underline
}
.recent_editions LI.schedule_btn {
	FONT-WEIGHT: bold; TEXT-TRANSFORM: uppercase; BORDER-TOP-STYLE: none; =
BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none; TEXT-DECORATION: =
none; BORDER-BOTTOM-STYLE: none
}
.recent_editions LI.schedule_btn A {
	FONT-WEIGHT: bold; TEXT-TRANSFORM: uppercase; BORDER-TOP-STYLE: none; =
BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none; TEXT-DECORATION: =
none; BORDER-BOTTOM-STYLE: none
}
.recent_editions LI.schedule_btn A:hover {
	FONT-WEIGHT: bold; TEXT-TRANSFORM: uppercase; BORDER-TOP-STYLE: none; =
BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none; TEXT-DECORATION: =
none; BORDER-BOTTOM-STYLE: none
}
.recent_editions LI.schedule_btn IMG {
	PADDING-RIGHT: 0.5em; VERTICAL-ALIGN: middle
}
#content H3.QOD_quote {
	PADDING-LEFT: 0px; FONT-WEIGHT: bold; FONT-SIZE: 105%; MARGIN: 0.75em =
2.75em 0.5em 3.5em; COLOR: #000000; TEXT-INDENT: -4.25em; LINE-HEIGHT: =
1.25em; FONT-STYLE: italic; TEXT-DECORATION: none
}
#content H3.QOD_quote A {
	PADDING-LEFT: 0px; FONT-WEIGHT: bold; FONT-SIZE: 105%; MARGIN: 0.75em =
2.75em 0.5em 3.5em; COLOR: #000000; TEXT-INDENT: -4.25em; LINE-HEIGHT: =
1.25em; FONT-STYLE: italic; TEXT-DECORATION: none
}
#content H3.QOD_quote A:hover {
	PADDING-LEFT: 0px; FONT-WEIGHT: bold; FONT-SIZE: 105%; MARGIN: 0.75em =
2.75em 0.5em 3.5em; COLOR: #000000; TEXT-INDENT: -4.25em; LINE-HEIGHT: =
1.25em; FONT-STYLE: italic; TEXT-DECORATION: none
}
#content P.QOD_source {
	PADDING-RIGHT: 0px; DISPLAY: block; PADDING-LEFT: 5em; FONT-SIZE: 100%; =
MARGIN: 0.25em 1.5em 0px 0px; COLOR: #333333; TEXT-ALIGN: right; =
TEXT-DECORATION: none
}
#content P.QOD_source A {
	PADDING-RIGHT: 0px; DISPLAY: block; PADDING-LEFT: 5em; FONT-SIZE: 100%; =
MARGIN: 0.25em 1.5em 0px 0px; COLOR: #333333; TEXT-ALIGN: right; =
TEXT-DECORATION: none
}
#content P.QOD_source A:hover {
	PADDING-RIGHT: 0px; DISPLAY: block; PADDING-LEFT: 5em; FONT-SIZE: 100%; =
MARGIN: 0.25em 1.5em 0px 0px; COLOR: #333333; TEXT-ALIGN: right; =
TEXT-DECORATION: none
}
P.QOD_link {
	FONT-SIZE: 100%; MARGIN: 0.25em 3em 0px 0px; TEXT-ALIGN: right
}
.story_well P.QOD_source {
	PADDING-RIGHT: 0px; DISPLAY: block; PADDING-LEFT: 5em; FONT-SIZE: 100%; =
MARGIN: 0.25em 0.5em 0px 0px; COLOR: #333333; TEXT-ALIGN: right; =
TEXT-DECORATION: none
}
.story_well P.QOD_source A {
	PADDING-RIGHT: 0px; DISPLAY: block; PADDING-LEFT: 5em; FONT-SIZE: 100%; =
MARGIN: 0.25em 0.5em 0px 0px; COLOR: #333333; TEXT-ALIGN: right; =
TEXT-DECORATION: none
}
.story_well P.QOD_source A:hover {
	PADDING-RIGHT: 0px; DISPLAY: block; PADDING-LEFT: 5em; FONT-SIZE: 100%; =
MARGIN: 0.25em 0.5em 0px 0px; COLOR: #333333; TEXT-ALIGN: right; =
TEXT-DECORATION: none
}
.story_well H3.QOD_quote {
	PADDING-LEFT: 0px; FONT-WEIGHT: bold; FONT-SIZE: 110%; MARGIN: 2em 1em =
0.5em 2.5em; COLOR: #000000; TEXT-INDENT: -3.25em; LINE-HEIGHT: 1.25em; =
FONT-STYLE: italic; TEXT-DECORATION: none
}
.story_well H3.QOD_quote A {
	PADDING-LEFT: 0px; FONT-WEIGHT: bold; FONT-SIZE: 110%; MARGIN: 2em 1em =
0.5em 2.5em; COLOR: #000000; TEXT-INDENT: -3.25em; LINE-HEIGHT: 1.25em; =
FONT-STYLE: italic; TEXT-DECORATION: none
}
.story_well H3.QOD_quote A:hover {
	PADDING-LEFT: 0px; FONT-WEIGHT: bold; FONT-SIZE: 110%; MARGIN: 2em 1em =
0.5em 2.5em; COLOR: #000000; TEXT-INDENT: -3.25em; LINE-HEIGHT: 1.25em; =
FONT-STYLE: italic; TEXT-DECORATION: none
}
.story_well P.QOD_link {
	FONT-SIZE: 100%; MARGIN: 0.25em 1em 0px 0px; TEXT-ALIGN: right
}
.sr_active_toc {
	WIDTH: 100%
}
.sr_active_toc TD {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; PADDING-BOTTOM: 1em; =
VERTICAL-ALIGN: top; PADDING-TOP: 1em; BORDER-BOTTOM: #cccccc 1px solid
}
.sr_active_toc TD P {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: =
0px; PADDING-TOP: 0px
}
.sr_active_toc TD IMG {
	BORDER-RIGHT: #000000 2px solid; BORDER-TOP: #000000 2px solid; =
BORDER-LEFT: #000000 2px solid; BORDER-BOTTOM: #000000 2px solid
}
.sr_active_toc TD A {
	FONT-WEIGHT: bold; TEXT-DECORATION: none
}
.sr_active_toc TD A:hover {
	TEXT-DECORATION: underline
}
.sr_archive_toc {
	WIDTH: 100%
}
.sr_archive_toc TD {
	PADDING-RIGHT: 3em; PADDING-LEFT: 0.25em; PADDING-BOTTOM: 1em; =
VERTICAL-ALIGN: top; PADDING-TOP: 1em; BORDER-BOTTOM: #cccccc 1px solid
}
.sr_archive_toc TD P {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: =
0px; PADDING-TOP: 0px
}
.sr_archive_toc TD IMG {
	BORDER-RIGHT: #000000 1px solid; BORDER-TOP: #000000 1px solid; FLOAT: =
left; MARGIN: 0px 0.75em 0.25em 0px; BORDER-LEFT: #000000 1px solid; =
BORDER-BOTTOM: #000000 1px solid
}
.sr_archive_toc TD A {
	FONT-WEIGHT: bold; TEXT-DECORATION: none
}
.sr_archive_toc TD A:hover {
	TEXT-DECORATION: underline
}
#archive_links H2 {
	PADDING-RIGHT: 0.25em; PADDING-LEFT: 0.25em; FONT-SIZE: 1.25em; =
PADDING-BOTTOM: 0.25em; MARGIN: 0px 0px 0.5em; PADDING-TOP: 0.25em
}
#archive_links TD {
	PADDING-RIGHT: 0.25em; PADDING-LEFT: 0.25em; PADDING-BOTTOM: 0.5em; =
MARGIN: auto; WIDTH: 10em; PADDING-TOP: 0.5em; TEXT-ALIGN: center
}
#archive_links TD.header {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; WIDTH: =
100%; PADDING-TOP: 0px
}
#archive_links {
	BORDER-RIGHT: #006633 1px solid; PADDING-RIGHT: 0px; PADDING-LEFT: 0px; =
PADDING-BOTTOM: 0px; MARGIN: 1em 0px; BORDER-LEFT: #006633 1px solid; =
PADDING-TOP: 0px; BORDER-BOTTOM: #006633 1px solid
}
#archive_links TD SELECT {
	WIDTH: 10em
}
H1.list_topic_header {
	PADDING-RIGHT: 0.5em; BORDER-TOP: #98b1cb 2px solid; PADDING-LEFT: =
0.5em; FONT-SIZE: 115%; BACKGROUND: =
url(../images/blue_btn_rev_bg_09.png) #e0e8f0 repeat-x center bottom; =
PADDING-BOTTOM: 0.35em; MARGIN: 1em 0px 0px; VERTICAL-ALIGN: middle; =
TEXT-TRANSFORM: uppercase; BORDER-LEFT: #98b1cb 2px solid; COLOR: =
#024165; PADDING-TOP: 0.35em; BORDER-BOTTOM-STYLE: none
}
.document SPAN {
	FONT-WEIGHT: bold; COLOR: #3d5896
}
.document SPAN A {
	COLOR: #3d5896
}
#key_docs .list_odd {
	PADDING-RIGHT: 0.5em; BORDER-TOP: #cccccc 1px dotted; PADDING-LEFT: =
0.5em; BACKGROUND: #ffffff; PADDING-BOTTOM: 1.25em; MARGIN: 0px 1em; =
PADDING-TOP: 1.25em; BORDER-BOTTOM: #cccccc 1px dotted
}
#key_docs TD P {
	FONT-SIZE: 100%
}
#key_docs .list_even {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; BACKGROUND: #efefef; =
PADDING-BOTTOM: 1.25em; MARGIN: 0px 1em; PADDING-TOP: 1.25em
}
#key_docs H3 SPAN.pdf {
	FONT-WEIGHT: normal; FONT-SIZE: 75%; TEXT-TRANSFORM: none; COLOR: =
#000000
}
#key_docs H3 SPAN {
	FONT-WEIGHT: bold; TEXT-TRANSFORM: uppercase
}
#key_docs H3 IMG {
	MARGIN: 0px 1em; VERTICAL-ALIGN: middle
}
#key_docs H3 A:hover SPAN {
	COLOR: #990000
}
#key_docs H3 A SPAN {
	TEXT-DECORATION: underline
}
#key_docs H3 {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-WEIGHT: normal; FONT-SIZE: =
115%; PADDING-BOTTOM: 0px; MARGIN: 0px 0.5em; PADDING-TOP: 0px
}
#key_docs H3 A {
	COLOR: #000000; TEXT-DECORATION: none
}
#key_docs H3 A:hover {
	COLOR: #990000
}
#key_docs H4 {
	FONT-WEIGHT: bold; FONT-SIZE: 100%; MARGIN: 1.25em 0px 0.25em 0.62em
}
#key_docs P {
	FONT-SIZE: 100%; MARGIN: 0.25em 0.62em 0px
}
#key_docs P.publication {
	FONT-WEIGHT: normal; FONT-SIZE: 100%; MARGIN: 0.25em 0.62em 0px; COLOR: =
#666666; FONT-STYLE: italic
}
#key_docs P.results_description {
	PADDING-RIGHT: 1em; PADDING-LEFT: 1em; FLOAT: left; PADDING-BOTTOM: =
1em; MARGIN: 0px; PADDING-TOP: 1em
}
#key_docs P.results_page_btn {
	PADDING-RIGHT: 1em; PADDING-LEFT: 1em; FONT-WEIGHT: bold; FLOAT: right; =
PADDING-BOTTOM: 1em; MARGIN: 0px; PADDING-TOP: 1em; TEXT-ALIGN: right
}
#form_errors {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-WEIGHT: bold; FONT-SIZE: =
14px; PADDING-BOTTOM: 20px; TEXT-TRANSFORM: uppercase; COLOR: red; =
PADDING-TOP: 20px; TEXT-ALIGN: center
}
INPUT#save_login {
	DISPLAY: inline
}
#submit_success {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-WEIGHT: bold; FONT-SIZE: =
14px; PADDING-BOTTOM: 20px; TEXT-TRANSFORM: uppercase; COLOR: green; =
PADDING-TOP: 20px; TEXT-ALIGN: center
}

------=_NextPart_000_0000_01CAB168.786EE890
Content-Type: application/octet-stream
Content-Transfer-Encoding: quoted-printable
Content-Location: http://www.eenews.net/rcss/2/new_dyn_pub_styles.css?1265230466

#TOC H1 {
	BORDER-TOP: #92ab7f 2px solid; BACKGROUND: #eff3e9; BORDER-LEFT: =
#92ab7f 2px solid; COLOR: #5c832f
}
#customize_TOC H1 {
	BORDER-TOP: #92ab7f 2px solid; BACKGROUND: #eff3e9; BORDER-LEFT: =
#92ab7f 2px solid; COLOR: #5c832f
}
#single_story_TOC H1 {
	BORDER-TOP: #92ab7f 2px solid; BACKGROUND: #eff3e9; BORDER-LEFT: =
#92ab7f 2px solid; COLOR: #5c832f
}
#spotlight H1 {
	BORDER-TOP: #92ab7f 2px solid; BACKGROUND: #eff3e9; BORDER-LEFT: =
#92ab7f 2px solid; COLOR: #5c832f
}
#TOC H3 A SPAN {
	COLOR: #5c832f
}
#customize_TOC H3 A SPAN #single_story_TOC H3 A SPAN {
	COLOR: #5c832f
}
#spotlight A SPAN {
	COLOR: #5c832f
}
#header_container {
	BORDER-RIGHT: #666 2px solid; BORDER-TOP: #666 2px; BACKGROUND: =
url(/images/header_ad_bg.png) #5c832f repeat-x 5px 5px; MARGIN: auto; =
BORDER-LEFT: #666 2px solid; WIDTH: 900px; BORDER-BOTTOM: #666 2px
}
#header_for_email {
	BACKGROUND: url(http://www.eenews.net/images/eepubs_bg.png) repeat-x =
left top
}
.story_well H1 {
	BACKGROUND: url(/images/spotlight_gradient.png) #eff3e9 repeat-x left =
top; COLOR: #5c832f; BORDER-TOP-STYLE: none; BORDER-BOTTOM: #92ab7f 2px =
solid; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none
}
.story_well H2 SPAN {
	COLOR: #5c832f
}
#leaderboard_ad_728x90 {
	BORDER-TOP: #92ab7f 2px solid; BACKGROUND: #eff3e9; BORDER-BOTTOM: =
#92ab7f 2px solid
}
.header_leaderboard {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; BACKGROUND: =
url(http://www.eenews.net/images/advert_text.png) #fff no-repeat left =
center; PADDING-BOTTOM: 0px; MARGIN: 0px auto 5px; WIDTH: 742px; =
PADDING-TOP: 0px; HEIGHT: 90px; TEXT-ALIGN: right
}
#flash_promo_area {
	BACKGROUND: url(http://www.eenews.net/images/marketing_bg4.jpg) =
no-repeat left top; MARGIN: 0px auto 1.5em; COLOR: #000000; HEIGHT: =
210px; TEXT-ALIGN: center
}
.pub_promo {
	PADDING-RIGHT: 0.5em; MARGIN-BOTTOM: 3.5em
}
.pub_promo P {
	PADDING-LEFT: 0.75em; PADDING-TOP: 0px
}
.pub_promo UL {
	BORDER-RIGHT: #cccccc 1px solid; PADDING-RIGHT: 0px; PADDING-LEFT: 0px; =
BACKGROUND: url(http://www.eenews.net/images/blue_btn_bg_09.png) =
repeat-x center bottom; PADDING-BOTTOM: 0em; MARGIN: 1.5em auto 0px; =
BORDER-LEFT: #cccccc 1px solid; PADDING-TOP: 0em; BORDER-BOTTOM: #cccccc =
1px solid; HEIGHT: 2.17em; TEXT-ALIGN: center
}
.pub_promo LI {
	BORDER-RIGHT: #cccccc 1px solid; PADDING-RIGHT: 1em; DISPLAY: block; =
PADDING-LEFT: 2.5em; FONT-SIZE: 100%; FLOAT: left; PADDING-BOTTOM: =
0.5em; MARGIN: 0px; COLOR: #000000; PADDING-TOP: 0.5em; LIST-STYLE-TYPE: =
none
}
.pub_promo LI.about_btn {
	BACKGROUND: url(http://www.eenews.net/images/about_icon_03.png) =
no-repeat 1em 0em
}
.pub_promo LI.sample_btn {
	BACKGROUND: url(http://www.eenews.net/images/sample_icon_05.png) =
no-repeat 0.75em 0em
}
.pub_promo LI.sample_episode_btn {
	BACKGROUND: url(http://www.eenews.net/images/watch_icon_11.png) =
no-repeat 0.5em 0em
}
.pub_promo LI.gw_link_btn {
	PADDING-LEFT: 2.5em; BACKGROUND: =
url(http://www.eenews.net/images/greenwire_bug.gif) no-repeat 0.5em =
0.3em
}
.pub_promo LI.op_link_btn {
	PADDING-LEFT: 2.5em; BACKGROUND: =
url(http://www.eenews.net/images/eetv_bug.gif) no-repeat 0.5em 0.3em
}
.pub_promo LI.pmtv_link_btn {
	PADDING-LEFT: 2.5em; BACKGROUND: =
url(http://www.eenews.net/images/eetv_bug.gif) no-repeat 0.5em 0.3em
}
.pub_promo LI.daily_link_btn {
	PADDING-LEFT: 2.5em; BACKGROUND: =
url(http://www.eenews.net/images/eedaily_bug.gif) no-repeat 0.5em 0.3em
}
.pub_promo LI.pm_link_btn {
	PADDING-LEFT: 2.5em; BACKGROUND: =
url(http://www.eenews.net/images/eenewspm_bug.gif) no-repeat 0.5em 0.3em
}
.pub_promo LI.landletter_link_btn {
	PADDING-LEFT: 2.5em; BACKGROUND: =
url(http://www.eenews.net/images/landletter_bug.gif) no-repeat 0.5em =
0.3em
}
.pub_promo LI.about_btn:hover {
	BACKGROUND: url(http://www.eenews.net/images/about_icon_03.png) #98b3cc =
no-repeat 1em 0em
}
.pub_promo LI.sample_btn:hover {
	BACKGROUND: url(http://www.eenews.net/images/sample_icon_05.png) =
#98b3cc no-repeat 0.75em 0em
}
.pub_promo LI.sample_episode_btn:hover {
	BACKGROUND: url(http://www.eenews.net/images/watch_icon_11.png) #98b3cc =
no-repeat 0.5em 0em
}
.pub_promo LI.gw_link_btn:hover {
	BACKGROUND: url(http://www.eenews.net/images/greenwire_bug.gif) #98b3cc =
no-repeat 0.5em 0.3em
}
.pub_promo LI.op_link_btn:hover {
	BACKGROUND: url(http://www.eenews.net/images/eetv_bug.gif) #98b3cc =
no-repeat 0.5em 0.3em
}
.pub_promo LI.pmtv_link_btn:hover {
	BACKGROUND: url(http://www.eenews.net/images/eetv_bug.gif) #98b3cc =
no-repeat 0.5em 0.3em
}
.pub_promo LI.daily_link_btn:hover {
	BACKGROUND: url(http://www.eenews.net/images/eedaily_bug.gif) #98b3cc =
no-repeat 0.5em 0.3em
}
.pub_promo LI.pm_link_btn:hover {
	BACKGROUND: url(http://www.eenews.net/images/eenewspm_bug.gif) #98b3cc =
no-repeat 0.5em 0.3em
}
.pub_promo LI.landletter_link_btn:hover {
	BACKGROUND: url(http://www.eenews.net/images/landletter_bug.gif) =
#98b3cc no-repeat 0.5em 0.3em
}
.pub_promo LI A {
	COLOR: #5c832f; TEXT-DECORATION: none
}
.pub_promo LI A:hover {
	BACKGROUND: #98b3cc
}
.pub_promo H2 {
	PADDING-RIGHT: 0.5em; BORDER-TOP: #92ab7f 2px solid; PADDING-LEFT: =
0.5em; FONT-SIZE: 1.25em; BACKGROUND: =
url(http://www.eenews.net/images/blue_btn_rev_bg_09.png) repeat-x center =
top; PADDING-BOTTOM: 0.5em; MARGIN: 0px; TEXT-TRANSFORM: uppercase; =
COLOR: #666666; PADDING-TOP: 0.5em
}
.pub_promo H2 IMG {
	VERTICAL-ALIGN: middle
}
.pub_promo H3 {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-SIZE: 1.25em; FLOAT: right; =
PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-TOP: 0px
}
.pub_promo H1 IMG {
	VERTICAL-ALIGN: middle
}
.pub_promo H1 {
	PADDING-LEFT: 0.5em; MARGIN-BOTTOM: 0.5em; PADDING-BOTTOM: 0.25em; =
BORDER-BOTTOM-STYLE: none
}
.pub_promo H2 SPAN {
	PADDING-LEFT: 2em
}
.pub_promo H2 SPAN A {
	TEXT-DECORATION: none
}
#right_column {
	PADDING-LEFT: 1em; BACKGROUND: #ffffff; FLOAT: right; WIDTH: 340px; =
PADDING-TOP: 1em; FONT-FAMILY: Arial, Helvetica, sans-serif
}
TABLE.top_promo_zone {
	MARGIN-TOP: 0em; MARGIN-BOTTOM: 0px; WIDTH: 100%; BORDER-BOTTOM: #ccc =
1px solid
}
TABLE.top_promo_zone TD {
	WIDTH: 33%; HEIGHT: 60px; TEXT-ALIGN: center
}
TABLE.top_promo_zone TD A {
	TEXT-DECORATION: none
}
TABLE.top_promo_zone TD IMG {
	VERTICAL-ALIGN: middle; BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: =
none; BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: none
}
#tpz_center {
	BORDER-RIGHT: #ccc 1px solid; BORDER-LEFT: #ccc 1px solid
}
#tpz_center DIV.login_arrow {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; BACKGROUND: =
url(/images/login_arrow.png) #5c832f no-repeat left top; PADDING-BOTTOM: =
0px; MARGIN: 10px 0px 0px; PADDING-TOP: 0px; HEIGHT: 60px; TEXT-ALIGN: =
left
}
#tpz_center DIV.login_arrow P {
	MARGIN: 0px 1em 0px 68px
}
#tpz_center DIV.login_arrow H3 {
	FONT-SIZE: 110%; MARGIN: 0px 1em 0px 68px; TEXT-TRANSFORM: uppercase; =
COLOR: #5c832f
}
.zones_container {
	BORDER-TOP: #92ab7f 3px solid; MARGIN-TOP: -1px; MARGIN-BOTTOM: 1em
}
.zones_inner_container {
	BORDER-TOP: #ccc 1px solid; MARGIN-TOP: 0px; MARGIN-BOTTOM: 1px; =
PADDING-BOTTOM: 1em
}
.zone_1_container {
	MARGIN: 0px 0.25em; PADDING-TOP: 0.5em
}
.zone_2_container H3.headline {
	MARGIN-TOP: 0px; FONT-SIZE: 1.5em; MARGIN-BOTTOM: 0.75em; COLOR: =
#5c832f
}
.zone_1_container H3.headline {
	MARGIN-TOP: 0px; FONT-SIZE: 1.5em; MARGIN-BOTTOM: 0.75em; COLOR: =
#5c832f
}
.zone_3_container {
	MARGIN-TOP: 1.5em
}
.zone_4_container {
	MARGIN-TOP: 1.5em
}
.zone_3_container {
	MARGIN-LEFT: 0.25em
}
.zone_4_container {
	MARGIN-RIGHT: 0.25em
}
.zone_2_container {
	MARGIN-BOTTOM: 1.5em; MARGIN-LEFT: 0.25em; MARGIN-RIGHT: 0.25em
}
.zone_3_container H3.headline {
	MARGIN-TOP: 0px; FONT-SIZE: 125%; MARGIN-BOTTOM: 0.25em; COLOR: #5c832f
}
.zone_4_container H3.headline {
	MARGIN-TOP: 0px; FONT-SIZE: 125%; MARGIN-BOTTOM: 0.25em; COLOR: #5c832f
}
.zone_3_container H3.headline SPAN {
	DISPLAY: block; FONT-SIZE: 80%; TEXT-TRANSFORM: uppercase; COLOR: #000; =
TEXT-DECORATION: none
}
.zone_3_container H3.headline A SPAN {
	DISPLAY: block; FONT-SIZE: 80%; TEXT-TRANSFORM: uppercase; COLOR: #000; =
TEXT-DECORATION: none
}
.zone_4_container H3.headline SPAN {
	DISPLAY: block; FONT-SIZE: 80%; TEXT-TRANSFORM: uppercase; COLOR: #000; =
TEXT-DECORATION: none
}
.zone_4_container H3.headline A SPAN {
	DISPLAY: block; FONT-SIZE: 80%; TEXT-TRANSFORM: uppercase; COLOR: #000; =
TEXT-DECORATION: none
}
.zone_2_container H3.headline SPAN {
	DISPLAY: block; FONT-SIZE: 80%; TEXT-TRANSFORM: uppercase; COLOR: #000; =
TEXT-DECORATION: none
}
.zone_2_container H3.headline A SPAN {
	DISPLAY: block; FONT-SIZE: 80%; TEXT-TRANSFORM: uppercase; COLOR: #000; =
TEXT-DECORATION: none
}
.zone_1_container H3.headline SPAN {
	DISPLAY: block; FONT-SIZE: 80%; TEXT-TRANSFORM: uppercase; COLOR: #000; =
TEXT-DECORATION: none
}
.zone_1_container H3.headline A SPAN {
	DISPLAY: block; FONT-SIZE: 80%; TEXT-TRANSFORM: uppercase; COLOR: #000; =
TEXT-DECORATION: none
}
.zone_3_container H3.headline SPAN.origin {
	DISPLAY: inline; FONT-WEIGHT: normal; FONT-SIZE: 85%; TEXT-TRANSFORM: =
none; COLOR: #666; FONT-STYLE: italic; TEXT-DECORATION: none
}
.zone_3_container H3.headline A SPAN.origin {
	DISPLAY: inline; FONT-WEIGHT: normal; FONT-SIZE: 85%; TEXT-TRANSFORM: =
none; COLOR: #666; FONT-STYLE: italic; TEXT-DECORATION: none
}
.zone_4_container H3.headline SPAN.origin {
	DISPLAY: inline; FONT-WEIGHT: normal; FONT-SIZE: 85%; TEXT-TRANSFORM: =
none; COLOR: #666; FONT-STYLE: italic; TEXT-DECORATION: none
}
.zone_4_container H3.headline A SPAN.origin {
	DISPLAY: inline; FONT-WEIGHT: normal; FONT-SIZE: 85%; TEXT-TRANSFORM: =
none; COLOR: #666; FONT-STYLE: italic; TEXT-DECORATION: none
}
.zone_2_container H3.headline SPAN.origin {
	DISPLAY: inline; FONT-WEIGHT: normal; FONT-SIZE: 85%; TEXT-TRANSFORM: =
none; COLOR: #666; FONT-STYLE: italic; TEXT-DECORATION: none
}
.zone_2_container H3.headline A SPAN.origin {
	DISPLAY: inline; FONT-WEIGHT: normal; FONT-SIZE: 85%; TEXT-TRANSFORM: =
none; COLOR: #666; FONT-STYLE: italic; TEXT-DECORATION: none
}
.zone_1_container H3.headline SPAN.origin {
	DISPLAY: inline; FONT-WEIGHT: normal; FONT-SIZE: 85%; TEXT-TRANSFORM: =
none; COLOR: #666; FONT-STYLE: italic; TEXT-DECORATION: none
}
.zone_1_container H3.headline A SPAN.origin {
	DISPLAY: inline; FONT-WEIGHT: normal; FONT-SIZE: 85%; TEXT-TRANSFORM: =
none; COLOR: #666; FONT-STYLE: italic; TEXT-DECORATION: none
}
.guide H3.headline A SPAN.origin {
	DISPLAY: inline; FONT-WEIGHT: normal; FONT-SIZE: 85%; TEXT-TRANSFORM: =
none; COLOR: #666; FONT-STYLE: italic; TEXT-DECORATION: none
}
.story_well H2 SPAN.origin {
	DISPLAY: inline; FONT-WEIGHT: normal; FONT-SIZE: 85%; TEXT-TRANSFORM: =
none; COLOR: #666; FONT-STYLE: italic; TEXT-DECORATION: none
}
.zone_3_container H3.headline A {
	COLOR: #5c832f; TEXT-DECORATION: none
}
.zone_4_container H3.headline A {
	COLOR: #5c832f; TEXT-DECORATION: none
}
.zone_2_container H3.headline A {
	COLOR: #5c832f; TEXT-DECORATION: none
}
.zone_1_container H3.headline A {
	COLOR: #5c832f; TEXT-DECORATION: none
}
.guide H3.headline A {
	COLOR: #5c832f; TEXT-DECORATION: none
}
.zone_3_container H3.headline A:hover {
	COLOR: #990000; TEXT-DECORATION: underline
}
.zone_4_container H3.headline A:hover {
	COLOR: #990000; TEXT-DECORATION: underline
}
.zone_2_container H3.headline A:hover {
	COLOR: #990000; TEXT-DECORATION: underline
}
.zone_1_container H3.headline A:hover {
	COLOR: #990000; TEXT-DECORATION: underline
}
.guide H3.headline A:hover {
	COLOR: #990000; TEXT-DECORATION: underline
}
.zone_3_container DIV.excerpt P {
	MARGIN-TOP: 0.5em; FONT-SIZE: 100%; MARGIN-BOTTOM: 0.25em; COLOR: #666; =
TEXT-ALIGN: justify
}
.zone_3_container DIV.summary P {
	MARGIN-TOP: 0.5em; FONT-SIZE: 100%; MARGIN-BOTTOM: 0.25em; COLOR: #666; =
TEXT-ALIGN: justify
}
.zone_3_container DIV.about P {
	MARGIN-TOP: 0.5em; FONT-SIZE: 100%; MARGIN-BOTTOM: 0.25em; COLOR: #666; =
TEXT-ALIGN: justify
}
.zone_4_container DIV.excerpt P {
	MARGIN-TOP: 0.5em; FONT-SIZE: 100%; MARGIN-BOTTOM: 0.25em; COLOR: #666; =
TEXT-ALIGN: justify
}
.zone_4_container DIV.summary P {
	MARGIN-TOP: 0.5em; FONT-SIZE: 100%; MARGIN-BOTTOM: 0.25em; COLOR: #666; =
TEXT-ALIGN: justify
}
.zone_4_container DIV.about P {
	MARGIN-TOP: 0.5em; FONT-SIZE: 100%; MARGIN-BOTTOM: 0.25em; COLOR: #666; =
TEXT-ALIGN: justify
}
.zone_2_container DIV.excerpt P {
	MARGIN-TOP: 0px; FONT-SIZE: 120%; MARGIN-BOTTOM: 0px; COLOR: #666; =
TEXT-ALIGN: justify
}
.zone_2_container DIV.summary P {
	MARGIN-TOP: 0px; FONT-SIZE: 120%; MARGIN-BOTTOM: 0px; COLOR: #666; =
TEXT-ALIGN: justify
}
.zone_2_container DIV.about P {
	MARGIN-TOP: 0px; FONT-SIZE: 120%; MARGIN-BOTTOM: 0px; COLOR: #666; =
TEXT-ALIGN: justify
}
.zone_1_container DIV.excerpt P {
	MARGIN-TOP: 0px; FONT-SIZE: 120%; MARGIN-BOTTOM: 0px; COLOR: #666; =
TEXT-ALIGN: justify
}
.zone_1_container DIV.summary P {
	MARGIN-TOP: 0px; FONT-SIZE: 120%; MARGIN-BOTTOM: 0px; COLOR: #666; =
TEXT-ALIGN: justify
}
.zone_1_container DIV.about P {
	MARGIN-TOP: 0px; FONT-SIZE: 120%; MARGIN-BOTTOM: 0px; COLOR: #666; =
TEXT-ALIGN: justify
}
.zone_3_container DIV.summary P {
	TEXT-ALIGN: left
}
.zone_4_container DIV.summary P {
	TEXT-ALIGN: left
}
.zone_1_container DIV.summary P {
	TEXT-ALIGN: left
}
.zone_2_container DIV.summary P {
	TEXT-ALIGN: left
}
.zone_2_container IMG.image_float {
	BORDER-RIGHT: #000 1px solid; BORDER-TOP: #000 1px solid; FLOAT: left; =
MARGIN: 0px 1em 0.25em 0px; BORDER-LEFT: #000 1px solid; BORDER-BOTTOM: =
#000 1px solid
}
.zone_1_container IMG.image_float {
	BORDER-RIGHT: #000 1px solid; BORDER-TOP: #000 1px solid; FLOAT: left; =
MARGIN: 0px 1em 0.25em 0px; BORDER-LEFT: #000 1px solid; BORDER-BOTTOM: =
#000 1px solid
}
.zone_3_container IMG.image_float {
	BORDER-RIGHT: #000 1px solid; BORDER-TOP: #000 1px solid; FLOAT: left; =
MARGIN: 0px 1em 0.25em 0px; BORDER-LEFT: #000 1px solid; BORDER-BOTTOM: =
#000 1px solid
}
.zone_4_container IMG.image_float {
	BORDER-RIGHT: #000 1px solid; BORDER-TOP: #000 1px solid; FLOAT: left; =
MARGIN: 0px 1em 0.25em 0px; BORDER-LEFT: #000 1px solid; BORDER-BOTTOM: =
#000 1px solid
}
.zone_2_container IMG.image {
	BORDER-RIGHT: #000 1px solid; BORDER-TOP: #000 1px solid; MARGIN: 0px =
1em 1em 0px; BORDER-LEFT: #000 1px solid; BORDER-BOTTOM: #000 1px solid
}
.zone_1_container IMG.image {
	BORDER-RIGHT: #000 1px solid; BORDER-TOP: #000 1px solid; MARGIN: 0px =
1em 1em 0px; BORDER-LEFT: #000 1px solid; BORDER-BOTTOM: #000 1px solid
}
.zone_3_container IMG.image {
	BORDER-RIGHT: #000 1px solid; BORDER-TOP: #000 1px solid; MARGIN: 0px =
1em 0.25em 0px; BORDER-LEFT: #000 1px solid; BORDER-BOTTOM: #000 1px =
solid
}
.zone_4_container IMG.image {
	BORDER-RIGHT: #000 1px solid; BORDER-TOP: #000 1px solid; MARGIN: 0px =
1em 0.25em 0px; BORDER-LEFT: #000 1px solid; BORDER-BOTTOM: #000 1px =
solid
}
.zone_3_container H2.module_title {
	FONT-SIZE: 100%; MARGIN: 0px; TEXT-TRANSFORM: uppercase; COLOR: =
#5c832f; BORDER-BOTTOM: #92ab7f 2px solid
}
.zone_4_container H2.module_title {
	FONT-SIZE: 100%; MARGIN: 0px; TEXT-TRANSFORM: uppercase; COLOR: =
#5c832f; BORDER-BOTTOM: #92ab7f 2px solid
}
.zone_2_container H2.module_title {
	FONT-SIZE: 120%; MARGIN: 1em 0px 0px; TEXT-TRANSFORM: uppercase; COLOR: =
#5c832f; BORDER-BOTTOM: #92ab7f 2px solid
}
.zone_1_container H2.module_title {
	FONT-SIZE: 120%; MARGIN: 1em 0px 0px; TEXT-TRANSFORM: uppercase; COLOR: =
#5c832f; BORDER-BOTTOM: #92ab7f 2px solid
}
.transcript {
	MARGIN: 0px 5em
}
.guide H3 {
	FONT-SIZE: 125%; MARGIN: 0px
}
.transcript H2 {
	MARGIN-TOP: 2em; FONT-SIZE: 1.5em
}
.transcript H2 SPAN.slug {
	DISPLAY: block; FONT-SIZE: 80%; TEXT-TRANSFORM: uppercase; COLOR: =
#990000
}
.guide H3 SPAN.slug {
	DISPLAY: block; FONT-SIZE: 80%; TEXT-TRANSFORM: uppercase; COLOR: #000
}
.transcript H2 SPAN.origin {
	DISPLAY: inline; FONT-WEIGHT: normal; FONT-SIZE: 85%; TEXT-TRANSFORM: =
none; COLOR: #666; FONT-STYLE: italic; TEXT-DECORATION: none
}
.guide H3 SPAN.origin {
	DISPLAY: inline; FONT-WEIGHT: normal; FONT-SIZE: 85%; TEXT-TRANSFORM: =
none; COLOR: #666; FONT-STYLE: italic; TEXT-DECORATION: none
}
.transcript IMG.image_float {
	BORDER-RIGHT: #000 1px solid; BORDER-TOP: #000 1px solid; FLOAT: left; =
MARGIN: 0px 1em 0.25em 0px; BORDER-LEFT: #000 1px solid; BORDER-BOTTOM: =
#000 1px solid
}
.guide IMG.image_float {
	BORDER-RIGHT: #000 1px solid; BORDER-TOP: #000 1px solid; FLOAT: left; =
MARGIN: 0px 1em 0.25em 0px; BORDER-LEFT: #000 1px solid; BORDER-BOTTOM: =
#000 1px solid
}
DIV.archive_item_odd {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; BACKGROUND: #fff; =
PADDING-BOTTOM: 1em; PADDING-TOP: 1em; BORDER-BOTTOM: #ccc 1px dotted
}
DIV.archive_item_even {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; BACKGROUND: #eee; =
PADDING-BOTTOM: 1em; PADDING-TOP: 1em; BORDER-BOTTOM: #ccc 1px dotted
}
DIV.archive_item_even P {
	MARGIN: 0.25em 0px
}
DIV.archive_item_odd P {
	MARGIN: 0.25em 0px
}
H3.trans_header {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-WEIGHT: bold; FONT-SIZE: =
14px; PADDING-BOTTOM: 2px; COLOR: #666; PADDING-TOP: 2px; BORDER-BOTTOM: =
#999 1px solid
}
.player_zone TABLE {
	MARGIN-TOP: 10px; MARGIN-BOTTOM: 2px; WIDTH: 100%
}
#player {
	PADDING-RIGHT: 1em; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; WIDTH: =
448px; PADDING-TOP: 0px; TEXT-ALIGN: left
}
#advert {
	PADDING-RIGHT: 2px; PADDING-LEFT: 2px; BACKGROUND: #efefef; =
PADDING-BOTTOM: 2px; MARGIN: 0px; VERTICAL-ALIGN: middle; PADDING-TOP: =
2px; HEIGHT: 282px; TEXT-ALIGN: center
}
TD.ad_text {
	COLOR: #999; FONT-STYLE: italic; TEXT-ALIGN: center
}
.left_column {
	PADDING-RIGHT: 1em; VERTICAL-ALIGN: top; WIDTH: 50%
}
.right_column {
	PADDING-LEFT: 1em; VERTICAL-ALIGN: top; WIDTH: 50%
}
.content_link {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; PADDING-BOTTOM: 0.75em; =
MARGIN: 0.5em -0.5em 0px; PADDING-TOP: 0.75em; BORDER-BOTTOM: #ccc 1px =
solid
}
.content_link_last {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; PADDING-BOTTOM: 0.75em; =
MARGIN: 0.5em -0.5em 0px; PADDING-TOP: 0.75em; BORDER-BOTTOM: #ccc 1px =
solid
}
.content_link_last {
	BORDER-BOTTOM-STYLE: none
}
.content_link TD {
	VERTICAL-ALIGN: top
}
.content_link_last TD {
	VERTICAL-ALIGN: top
}
.site_container {
	PADDING-RIGHT: 15px; PADDING-LEFT: 15px; PADDING-BOTTOM: 10px; MARGIN: =
auto; PADDING-TOP: 0px
}
.pubs_nav_new {
	BORDER-RIGHT: #666666 2px; PADDING-RIGHT: 5px; BORDER-TOP: #666666 2px; =
PADDING-LEFT: 0px; BACKGROUND: url(/images/tab_gradient.png) #eff3e9 =
repeat-x left bottom; PADDING-BOTTOM: 5px; BORDER-LEFT: #666666 2px; =
WIDTH: 895px; PADDING-TOP: 9px; BORDER-BOTTOM: #92ab7f 3px solid; =
TEXT-ALIGN: right
}
.pubs_nav_new UL {
	PADDING-RIGHT: 0px; DISPLAY: inline; PADDING-LEFT: 0px; PADDING-BOTTOM: =
0px; MARGIN: 0px; PADDING-TOP: 0px; LIST-STYLE-TYPE: none
}
.pubs_nav_new UL LI {
	PADDING-RIGHT: 0px; DISPLAY: inline; PADDING-LEFT: 0px; PADDING-BOTTOM: =
0px; MARGIN: 0px; PADDING-TOP: 0px; LIST-STYLE-TYPE: none
}
A.secondary_top_links {
	BORDER-RIGHT: #666 1px solid; PADDING-RIGHT: 3px; PADDING-LEFT: 3px; =
FONT-SIZE: 90%; PADDING-BOTTOM: 0px; MARGIN: 0px; COLOR: #666; =
PADDING-TOP: 0px; TEXT-DECORATION: none
}
A.secondary_top_links_trial {
	BORDER-RIGHT: #666 1px solid; PADDING-RIGHT: 3px; PADDING-LEFT: 3px; =
FONT-SIZE: 90%; PADDING-BOTTOM: 0px; MARGIN: 0px; COLOR: #666; =
PADDING-TOP: 0px; TEXT-DECORATION: none
}
A.secondary_top_links_last {
	BORDER-RIGHT: #666 1px solid; PADDING-RIGHT: 3px; PADDING-LEFT: 3px; =
FONT-SIZE: 90%; PADDING-BOTTOM: 0px; MARGIN: 0px; COLOR: #666; =
PADDING-TOP: 0px; TEXT-DECORATION: none
}
A.secondary_top_links_last {
	PADDING-RIGHT: 6px; PADDING-LEFT: 3px; PADDING-BOTTOM: 0px; =
PADDING-TOP: 0px; BORDER-RIGHT-STYLE: none
}
A.secondary_top_links_trial {
	COLOR: #990000
}
A.secondary_top_links:hover {
	COLOR: #990000; TEXT-DECORATION: underline
}
A.secondary_top_links_trial:hover {
	COLOR: #990000; TEXT-DECORATION: underline
}
A.secondary_top_links_last:hover {
	COLOR: #990000; TEXT-DECORATION: underline
}
A.secondary_item_last:hover {
	COLOR: #990000; TEXT-DECORATION: underline
}
A.secondary_item:hover {
	COLOR: #990000; TEXT-DECORATION: underline
}
.secondary_nav {
	PADDING-RIGHT: 0px; BORDER-TOP: #5c832f 3px solid; PADDING-LEFT: 10px; =
BACKGROUND: url(/images/bottom_nav_gradient.png) #fff repeat-x left top; =
PADDING-BOTTOM: 6px; WIDTH: 890px; PADDING-TOP: 10px; TEXT-ALIGN: center
}
A.secondary_item {
	BORDER-RIGHT: #666 1px solid; PADDING-RIGHT: 10px; PADDING-LEFT: 10px; =
FONT-SIZE: 110%; PADDING-BOTTOM: 0px; COLOR: #666; PADDING-TOP: 0px; =
TEXT-DECORATION: none
}
A.secondary_item_last {
	BORDER-RIGHT: #666 1px solid; PADDING-RIGHT: 10px; PADDING-LEFT: 10px; =
FONT-SIZE: 110%; PADDING-BOTTOM: 0px; COLOR: #666; PADDING-TOP: 0px; =
TEXT-DECORATION: none
}
A.secondary_item_last {
	BORDER-RIGHT-STYLE: none
}
.bottom_bar {
	CLEAR: both; BORDER-TOP: #92ab7f 2px solid; FONT-SIZE: 90%; BACKGROUND: =
#5c832f; PADDING-BOTTOM: 2px; COLOR: #ffffff; PADDING-TOP: 2px; =
FONT-FAMILY: Arial, Helvetica, sans-serif
}
A.tab {
	BORDER-RIGHT: #999 1px solid; PADDING-RIGHT: 10px; BORDER-TOP: #999 1px =
solid; PADDING-LEFT: 10px; FONT-WEIGHT: normal; FONT-SIZE: 110%; =
BACKGROUND: url(/images/tab_highlight.png) #003366 repeat-x left top; =
PADDING-BOTTOM: 5px; MARGIN: 0px 0px 0px -2px; BORDER-LEFT: #999 1px =
solid; COLOR: #fff; PADDING-TOP: 5px; BORDER-BOTTOM: #999 1px; =
TEXT-ALIGN: left; TEXT-DECORATION: none
}
A.tab_gw {
	BORDER-RIGHT: #999 1px solid; PADDING-RIGHT: 10px; BORDER-TOP: #999 1px =
solid; PADDING-LEFT: 10px; FONT-WEIGHT: normal; FONT-SIZE: 110%; =
BACKGROUND: url(/images/tab_highlight.png) #003366 repeat-x left top; =
PADDING-BOTTOM: 5px; MARGIN: 0px 0px 0px -2px; BORDER-LEFT: #999 1px =
solid; COLOR: #fff; PADDING-TOP: 5px; BORDER-BOTTOM: #999 1px; =
TEXT-ALIGN: left; TEXT-DECORATION: none
}
A.tab_cw {
	BORDER-RIGHT: #999 1px solid; PADDING-RIGHT: 10px; BORDER-TOP: #999 1px =
solid; PADDING-LEFT: 10px; FONT-WEIGHT: normal; FONT-SIZE: 110%; =
BACKGROUND: url(/images/tab_highlight.png) #003366 repeat-x left top; =
PADDING-BOTTOM: 5px; MARGIN: 0px 0px 0px -2px; BORDER-LEFT: #999 1px =
solid; COLOR: #fff; PADDING-TOP: 5px; BORDER-BOTTOM: #999 1px; =
TEXT-ALIGN: left; TEXT-DECORATION: none
}
A.tab_eed {
	BORDER-RIGHT: #999 1px solid; PADDING-RIGHT: 10px; BORDER-TOP: #999 1px =
solid; PADDING-LEFT: 10px; FONT-WEIGHT: normal; FONT-SIZE: 110%; =
BACKGROUND: url(/images/tab_highlight.png) #003366 repeat-x left top; =
PADDING-BOTTOM: 5px; MARGIN: 0px 0px 0px -2px; BORDER-LEFT: #999 1px =
solid; COLOR: #fff; PADDING-TOP: 5px; BORDER-BOTTOM: #999 1px; =
TEXT-ALIGN: left; TEXT-DECORATION: none
}
A.tab_tv {
	BORDER-RIGHT: #999 1px solid; PADDING-RIGHT: 10px; BORDER-TOP: #999 1px =
solid; PADDING-LEFT: 10px; FONT-WEIGHT: normal; FONT-SIZE: 110%; =
BACKGROUND: url(/images/tab_highlight.png) #003366 repeat-x left top; =
PADDING-BOTTOM: 5px; MARGIN: 0px 0px 0px -2px; BORDER-LEFT: #999 1px =
solid; COLOR: #fff; PADDING-TOP: 5px; BORDER-BOTTOM: #999 1px; =
TEXT-ALIGN: left; TEXT-DECORATION: none
}
A.tab_ll {
	BORDER-RIGHT: #999 1px solid; PADDING-RIGHT: 10px; BORDER-TOP: #999 1px =
solid; PADDING-LEFT: 10px; FONT-WEIGHT: normal; FONT-SIZE: 110%; =
BACKGROUND: url(/images/tab_highlight.png) #003366 repeat-x left top; =
PADDING-BOTTOM: 5px; MARGIN: 0px 0px 0px -2px; BORDER-LEFT: #999 1px =
solid; COLOR: #fff; PADDING-TOP: 5px; BORDER-BOTTOM: #999 1px; =
TEXT-ALIGN: left; TEXT-DECORATION: none
}
A.tab_pm {
	BORDER-RIGHT: #999 1px solid; PADDING-RIGHT: 10px; BORDER-TOP: #999 1px =
solid; PADDING-LEFT: 10px; FONT-WEIGHT: normal; FONT-SIZE: 110%; =
BACKGROUND: url(/images/tab_highlight.png) #003366 repeat-x left top; =
PADDING-BOTTOM: 5px; MARGIN: 0px 0px 0px -2px; BORDER-LEFT: #999 1px =
solid; COLOR: #fff; PADDING-TOP: 5px; BORDER-BOTTOM: #999 1px; =
TEXT-ALIGN: left; TEXT-DECORATION: none
}
A.tab_sr {
	BORDER-RIGHT: #999 1px solid; PADDING-RIGHT: 10px; BORDER-TOP: #999 1px =
solid; PADDING-LEFT: 10px; FONT-WEIGHT: normal; FONT-SIZE: 110%; =
BACKGROUND: url(/images/tab_highlight.png) #003366 repeat-x left top; =
PADDING-BOTTOM: 5px; MARGIN: 0px 0px 0px -2px; BORDER-LEFT: #999 1px =
solid; COLOR: #fff; PADDING-TOP: 5px; BORDER-BOTTOM: #999 1px; =
TEXT-ALIGN: left; TEXT-DECORATION: none
}
A.tabcurrent {
	BORDER-RIGHT: #999 1px solid; PADDING-RIGHT: 10px; BORDER-TOP: #999 1px =
solid; PADDING-LEFT: 10px; FONT-WEIGHT: normal; FONT-SIZE: 110%; =
BACKGROUND: url(/images/tab_highlight.png) #003366 repeat-x left top; =
PADDING-BOTTOM: 5px; MARGIN: 0px 0px 0px -2px; BORDER-LEFT: #999 1px =
solid; COLOR: #fff; PADDING-TOP: 5px; BORDER-BOTTOM: #999 1px; =
TEXT-ALIGN: left; TEXT-DECORATION: none
}
A.tab IMG {
	BORDER-RIGHT: #ddd 1px solid; BORDER-TOP: #ddd 1px solid; =
VERTICAL-ALIGN: middle; BORDER-LEFT: #ddd 1px solid; BORDER-BOTTOM: #ddd =
1px solid
}
A.tabcurrent IMG {
	BORDER-RIGHT: #ddd 1px solid; BORDER-TOP: #ddd 1px solid; =
VERTICAL-ALIGN: middle; BORDER-LEFT: #ddd 1px solid; BORDER-BOTTOM: #ddd =
1px solid
}
A.tab_eed {
	BACKGROUND: url(/images/tab_highlight.png) #326497 repeat-x left top
}
A.tab_gw {
	BACKGROUND: url(/images/tab_highlight.png) #5c832f repeat-x left top
}
A.tab_ll {
	BACKGROUND: url(/images/tab_highlight.png) #666633 repeat-x left top
}
A.tab_pm {
	BACKGROUND: url(/images/tab_highlight.png) #336666 repeat-x left top
}
A.tab_cw {
	BACKGROUND: url(/images/tab_highlight.png) #333399 repeat-x left top
}
A.tab_tv {
	BACKGROUND: url(/images/tab_highlight.png) #990000 repeat-x left top
}
A.tab_sr {
	BACKGROUND: url(/images/tab_highlight.png) #555 repeat-x left top
}
A.tab_eed:hover {
	BACKGROUND: url(/images/tab_highlight.png) #98b1cb repeat-x left top
}
A.tab_gw:hover {
	BACKGROUND: url(/images/tab_highlight.png) #92ab7f repeat-x left top
}
A.tab_ll:hover {
	BACKGROUND: url(/images/tab_highlight.png) #b2b299 repeat-x left top
}
A.tab_pm:hover {
	BACKGROUND: url(/images/tab_highlight.png) #99b2b2 repeat-x left top
}
A.tab_tv:hover {
	BACKGROUND: url(/images/tab_highlight.png) #ff0000 repeat-x left top
}
A.tab_cw:hover {
	BACKGROUND: url(/images/tab_highlight.png) #8581ba repeat-x left top
}
A.tab:hover {
	BACKGROUND: url(/images/tab_highlight.png) #326497 repeat-x left top
}
A.tab_sr:hover {
	BACKGROUND: url(/images/tab_highlight.png) #999 repeat-x left top
}
A.tabcurrent {
	BORDER-RIGHT: #92ab7f 2px solid; BORDER-TOP: #92ab7f 2px solid; =
FONT-WEIGHT: bold; Z-INDEX: 10; BACKGROUND: #5c832f; PADDING-BOTTOM: =
8px; BORDER-LEFT: #92ab7f 2px solid; COLOR: #fff; BORDER-BOTTOM: #92ab7f =
2px
}
A.tabcurrent:hover {
	COLOR: #fff
}
A.tab:hover {
	BORDER-RIGHT: #666 1px solid; BORDER-TOP: #666 1px solid; BORDER-LEFT: =
#666 1px solid; COLOR: #fff; BORDER-BOTTOM: #666 1px
}
A.tab_gw:hover {
	BORDER-RIGHT: #666 1px solid; BORDER-TOP: #666 1px solid; BORDER-LEFT: =
#666 1px solid; COLOR: #fff; BORDER-BOTTOM: #666 1px
}
A.tab_cw:hover {
	BORDER-RIGHT: #666 1px solid; BORDER-TOP: #666 1px solid; BORDER-LEFT: =
#666 1px solid; COLOR: #fff; BORDER-BOTTOM: #666 1px
}
A.tab_eed:hover {
	BORDER-RIGHT: #666 1px solid; BORDER-TOP: #666 1px solid; BORDER-LEFT: =
#666 1px solid; COLOR: #fff; BORDER-BOTTOM: #666 1px
}
A.tab_tv:hover {
	BORDER-RIGHT: #666 1px solid; BORDER-TOP: #666 1px solid; BORDER-LEFT: =
#666 1px solid; COLOR: #fff; BORDER-BOTTOM: #666 1px
}
A.tab_ll:hover {
	BORDER-RIGHT: #666 1px solid; BORDER-TOP: #666 1px solid; BORDER-LEFT: =
#666 1px solid; COLOR: #fff; BORDER-BOTTOM: #666 1px
}
A.tab_pm:hover {
	BORDER-RIGHT: #666 1px solid; BORDER-TOP: #666 1px solid; BORDER-LEFT: =
#666 1px solid; COLOR: #fff; BORDER-BOTTOM: #666 1px
}
A.player_links {
	FONT-WEIGHT: bold; FONT-SIZE: 110%; VERTICAL-ALIGN: middle; =
TEXT-TRANSFORM: uppercase; COLOR: #990000; MARGIN-RIGHT: 1.75em; =
TEXT-DECORATION: none
}
A.player_links:hover {
	COLOR: #ffcc00
}
.player_link_container {
	TEXT-ALIGN: left
}
A.player_links IMG {
	MARGIN: 0.5em 0.25em; VERTICAL-ALIGN: middle; BORDER-TOP-STYLE: none; =
BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: =
none
}
DIV.guide_search {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; BACKGROUND: #2b4382; =
PADDING-BOTTOM: 0.5em; COLOR: #fff; PADDING-TOP: 0.5em; TEXT-ALIGN: left
}
.guide_header {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0.25em; PADDING-BOTTOM: 0px; MARGIN: =
1em 0px 0.5em; PADDING-TOP: 0px; BORDER-BOTTOM: #ccc 2px solid
}
DIV.guide_search A {
	MARGIN: 0px 1em; COLOR: #fff
}
DIV.guide_search A:hover {
	COLOR: #ffcc00
}
DIV.guide_search FORM {
	DISPLAY: inline
}
DIV.guide_search LABEL {
	MARGIN: 0px 0.25em 0px 1em; VERTICAL-ALIGN: middle
}
P.action_buttons {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; =
PADDING-TOP: 0.5em
}
DIV.content_link P.action_buttons {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: =
0.5em 0px 0px; PADDING-TOP: 0px
}
.content_link_last P.action_buttons {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: =
0.5em 0px 0px; PADDING-TOP: 0px
}
P.action_buttons A IMG {
	MARGIN: 0px 0.25em 0px 0px; VERTICAL-ALIGN: bottom; BORDER-TOP-STYLE: =
none; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none; =
TEXT-DECORATION: none; BORDER-BOTTOM-STYLE: none
}
P.action_buttons A {
	FONT-WEIGHT: bold; FONT-SIZE: 90%; TEXT-TRANSFORM: uppercase; =
MARGIN-RIGHT: 1em; TEXT-DECORATION: none
}
P.action_buttons SPAN.origin {
	FONT-WEIGHT: bold; MARGIN-RIGHT: 1em; FONT-STYLE: italic
}
DIV.guide_search LABEL.radio {
	MARGIN: 0px 1em 0px 0.5em; VERTICAL-ALIGN: middle
}
DIV.guide_search INPUT {
	MARGIN: 0px; VERTICAL-ALIGN: middle
}
DIV.page_buttons_bottom {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; BACKGROUND: #666; =
PADDING-BOTTOM: 0px; PADDING-TOP: 0px
}
DIV.page_buttons_top {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; BACKGROUND: #666; =
PADDING-BOTTOM: 0px; PADDING-TOP: 0px
}
DIV.page_buttons_bottom {
	MARGIN-BOTTOM: 2em
}
DIV.page_buttons_bottom TD {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 5px; =
VERTICAL-ALIGN: middle; PADDING-TOP: 5px
}
DIV.page_buttons_top TD {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 5px; =
VERTICAL-ALIGN: middle; PADDING-TOP: 5px
}
TD.page_button_right {
	WIDTH: 25%; TEXT-ALIGN: right
}
TD.page_button_right A {
	PADDING-RIGHT: 1em; PADDING-LEFT: 1em; PADDING-BOTTOM: 0px; COLOR: =
#fff; PADDING-TOP: 0px; TEXT-DECORATION: none
}
TD.page_button_left A {
	PADDING-RIGHT: 1em; PADDING-LEFT: 1em; PADDING-BOTTOM: 0px; COLOR: =
#fff; PADDING-TOP: 0px; TEXT-DECORATION: none
}
TD.page_button_right A:hover {
	BACKGROUND: #666
}
TD.page_button_left A:hover {
	BACKGROUND: #666
}
TD.page_button_left {
	WIDTH: 25%; TEXT-ALIGN: left
}
TD.page_numbers {
	COLOR: #fff; TEXT-ALIGN: center
}
TD.page_numbers SPAN.highlighted {
	FONT-WEIGHT: bold; COLOR: #ccc
}
TD.page_numbers A {
	COLOR: #fff; TEXT-DECORATION: none
}
TD.page_numbers A:hover {
	COLOR: #ccc; TEXT-DECORATION: underline
}
TABLE.latest_videos {
	BORDER-TOP: #ccc 1px solid; WIDTH: 100%
}
TABLE.latest_videos TD {
	BORDER-RIGHT: #ccc 1px solid; PADDING-RIGHT: 5px; PADDING-LEFT: 5px; =
PADDING-BOTTOM: 5px; VERTICAL-ALIGN: top; WIDTH: 33.3%; PADDING-TOP: 5px
}
TABLE.latest_videos TD.last_cell {
	PADDING-RIGHT: 0px; BORDER-RIGHT-STYLE: none
}
TABLE.latest_videos TD.first_cell {
	PADDING-LEFT: 0px
}
TABLE.latest_videos TD H3.headline {
	FONT-SIZE: 145%; MARGIN: 0.25em 0px 1em; LINE-HEIGHT: 120%
}
TABLE.latest_videos TD H3.headline A {
	COLOR: #000; TEXT-DECORATION: none
}
TABLE.latest_videos TD H3.headline A:hover {
	COLOR: #990000
}
TABLE.latest_videos TD H3.headline A SPAN.slug {
	DISPLAY: block; FONT-SIZE: 90%; TEXT-TRANSFORM: uppercase; COLOR: =
#326698
}
TABLE.latest_videos TD H3.headline A SPAN.origin {
	DISPLAY: inline; FONT-WEIGHT: normal; FONT-SIZE: 80%; TEXT-TRANSFORM: =
none; COLOR: #666; FONT-STYLE: italic; TEXT-DECORATION: none
}
H2.latest_header {
	FONT-SIZE: 140%; MARGIN: 1em 0px 0.25em; TEXT-TRANSFORM: uppercase; =
COLOR: #990000
}
H2.latest_header SPAN {
	FONT-SIZE: 80%; FLOAT: right; VERTICAL-ALIGN: middle
}
H2.latest_header SPAN A {
	TEXT-DECORATION: none
}
H2.latest_header IMG {
	VERTICAL-ALIGN: middle; BORDER-TOP-STYLE: none; MARGIN-RIGHT: 0.5em; =
BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: =
none
}
.now_playing H3 {
	MARGIN-TOP: 1em; FONT-SIZE: 100%; TEXT-TRANSFORM: uppercase; COLOR: =
#326698; BORDER-BOTTOM: #cccccc 2px solid
}
.now_playing {
	MARGIN: 0.35em
}
.now_playing H2 {
	FONT-SIZE: 150%; MARGIN: 0.25em 0px 0px
}
.now_playing H2 SPAN.slug {
	DISPLAY: block; FONT-SIZE: 90%; TEXT-TRANSFORM: uppercase; COLOR: =
#326698
}
.now_playing P {
	MARGIN: 0.5em 0px
}
DIV#content IMG.image_float {
	BORDER-RIGHT: #000 1px solid; BORDER-TOP: #000 1px solid; FLOAT: left; =
BORDER-LEFT: #000 1px solid; MARGIN-RIGHT: 1em; BORDER-BOTTOM: #000 1px =
solid
}
DIV#content H2.headline {
	FONT-SIZE: 145%; LINE-HEIGHT: 120%
}
DIV#content H2.headline SPAN.slug {
	DISPLAY: block; FONT-SIZE: 80%; TEXT-TRANSFORM: uppercase; COLOR: =
#326698
}
DIV#content INPUT.colorized {
	DISPLAY: block; BACKGROUND: #ffffea; MARGIN: 0.5em 0px
}
DIV#content TEXTAREA.colorized {
	DISPLAY: block; BACKGROUND: #ffffea; MARGIN: 0.5em 0px
}
DIV#content LABEL {
	DISPLAY: block
}
DIV#content H2.headline SPAN.origin {
	DISPLAY: block; FONT-WEIGHT: normal; FONT-SIZE: 80%; FONT-STYLE: italic
}
.recent_editions_tabs P {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 5px; =
PADDING-TOP: 5px
}
.recent_editions_tabs {
	MARGIN-TOP: 3px
}
A.edition_tab {
	BORDER-RIGHT: #cccccc 1px; PADDING-RIGHT: 0.6em; BORDER-TOP: #cccccc =
1px solid; PADDING-LEFT: 0.6em; FONT-WEIGHT: normal; FONT-SIZE: 90%; =
BACKGROUND: url(/images/tab_gradient.png) #fff repeat-x left bottom; =
PADDING-BOTTOM: 0.5em; MARGIN: 0px; BORDER-LEFT: #cccccc 1px solid; =
COLOR: #666666; PADDING-TOP: 0.5em; BORDER-BOTTOM: #cccccc 1px; =
TEXT-ALIGN: center; TEXT-DECORATION: none
}
A.edition_tabcurrent {
	BORDER-RIGHT: #cccccc 1px; PADDING-RIGHT: 0.6em; BORDER-TOP: #cccccc =
1px solid; PADDING-LEFT: 0.6em; FONT-WEIGHT: normal; FONT-SIZE: 90%; =
BACKGROUND: url(/images/tab_gradient.png) #fff repeat-x left bottom; =
PADDING-BOTTOM: 0.5em; MARGIN: 0px; BORDER-LEFT: #cccccc 1px solid; =
COLOR: #666666; PADDING-TOP: 0.5em; BORDER-BOTTOM: #cccccc 1px; =
TEXT-ALIGN: center; TEXT-DECORATION: none
}
A.edition_tab_last {
	BORDER-RIGHT: #cccccc 1px; PADDING-RIGHT: 0.6em; BORDER-TOP: #cccccc =
1px solid; PADDING-LEFT: 0.6em; FONT-WEIGHT: normal; FONT-SIZE: 90%; =
BACKGROUND: url(/images/tab_gradient.png) #fff repeat-x left bottom; =
PADDING-BOTTOM: 0.5em; MARGIN: 0px; BORDER-LEFT: #cccccc 1px solid; =
COLOR: #666666; PADDING-TOP: 0.5em; BORDER-BOTTOM: #cccccc 1px; =
TEXT-ALIGN: center; TEXT-DECORATION: none
}
A.breadcrumb_link {
	BORDER-RIGHT: #cccccc 1px; PADDING-RIGHT: 0.6em; BORDER-TOP: #cccccc =
1px solid; PADDING-LEFT: 0.6em; FONT-WEIGHT: normal; FONT-SIZE: 90%; =
BACKGROUND: url(/images/tab_gradient.png) #fff repeat-x left bottom; =
PADDING-BOTTOM: 0.5em; MARGIN: 0px; BORDER-LEFT: #cccccc 1px solid; =
COLOR: #666666; PADDING-TOP: 0.5em; BORDER-BOTTOM: #cccccc 1px; =
TEXT-ALIGN: center; TEXT-DECORATION: none
}
A.breadcrumb_link {
	BACKGROUND: none transparent scroll repeat 0% 0%; COLOR: #5c832f; =
BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: =
none; BORDER-BOTTOM-STYLE: none
}
A.breadcrumb_link:hover {
	COLOR: #990000; TEXT-DECORATION: underline
}
A.edition_tab_last {
	BORDER-RIGHT: #cccccc 1px solid
}
A.edition_tabcurrent {
	BORDER-RIGHT: #92ab7f 2px solid; BORDER-TOP: #92ab7f 2px solid; =
FONT-WEIGHT: bold; BACKGROUND: #fff; PADDING-BOTTOM: 9px; BORDER-LEFT: =
#92ab7f 2px solid; COLOR: #5c832f; BORDER-BOTTOM: #92ab7f 2px
}
A.edition_tab:hover {
	BACKGROUND: url(/images/tab_gradient.png) #eff3e9 repeat-x left bottom; =
COLOR: #5c832f
}
A.edition_tab_last:hover {
	BACKGROUND: url(/images/tab_gradient.png) #eff3e9 repeat-x left bottom; =
COLOR: #5c832f
}
.edition_date {
	FONT-WEIGHT: bold; FONT-SIZE: 120%; WIDTH: 100%; COLOR: #990000
}
TABLE.edition_date {
	MARGIN-BOTTOM: 0px; PADDING-TOP: 1em
}
TABLE.edition_date TD#ed_right {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 4px; MARGIN: =
auto; VERTICAL-ALIGN: bottom; WIDTH: 40%; PADDING-TOP: 0px; TEXT-ALIGN: =
right
}
TABLE.edition_date TD#ed_left {
	VERTICAL-ALIGN: bottom
}
TABLE.edition_date TD#ed_left P {
	MARGIN: 0px
}
TABLE.edition_date TD#ed_left P.latest_editions {
	FONT-SIZE: 80%; MARGIN: 0px; TEXT-TRANSFORM: uppercase
}
FORM.search_box LABEL {
	FONT-WEIGHT: bold; FONT-SIZE: 90%; TEXT-TRANSFORM: uppercase; COLOR: =
#990000
}
FORM.search_box LABEL A {
	TEXT-DECORATION: none
}
FORM.search_box {
	PADDING-RIGHT: 0px; DISPLAY: block; PADDING-LEFT: 0px; PADDING-BOTTOM: =
0px; MARGIN: 0px; PADDING-TOP: 0px
}
FORM.search_box INPUT.search {
	BACKGROUND: #ffffea; COLOR: #999; MARGIN-RIGHT: 0.5em
}
FORM.login INPUT {
	DISPLAY: block; BACKGROUND: #ffffea; MARGIN: 0px 0px 1em; COLOR: #333
}
FORM.login LABEL {
	FONT-WEIGHT: bold; TEXT-TRANSFORM: uppercase; COLOR: #990000
}
FORM.login INPUT.submit {
	BACKGROUND: #ccc; COLOR: #000
}
FORM.small_login INPUT.text {
	PADDING-RIGHT: 0px; DISPLAY: inline; PADDING-LEFT: 0px; BACKGROUND: =
#ffffea; PADDING-BOTTOM: 0px; MARGIN: 0px; COLOR: #333; PADDING-TOP: 0px
}
FORM.small_login LABEL {
	DISPLAY: block; FONT-WEIGHT: bold; FONT-SIZE: 80%; TEXT-TRANSFORM: =
uppercase; COLOR: #990000; TEXT-ALIGN: left
}
FORM.small_login TABLE {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: 0px =
0px 0px 1em; PADDING-TOP: 0px
}
FORM.small_login TABLE TR TD {
	PADDING-RIGHT: 0.25em; VERTICAL-ALIGN: bottom; HEIGHT: 30px; =
TEXT-ALIGN: left
}
FORM.small_login {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: =
0px; PADDING-TOP: 0px
}
#TOC H1 {
	BACKGROUND: none transparent scroll repeat 0% 0%; COLOR: #5c832f; =
BORDER-TOP-STYLE: none; BORDER-BOTTOM: #92ab7f 2px solid; =
BORDER-LEFT-STYLE: none
}
#customize_TOC H1 {
	BACKGROUND: none transparent scroll repeat 0% 0%; COLOR: #5c832f; =
BORDER-TOP-STYLE: none; BORDER-BOTTOM: #92ab7f 2px solid; =
BORDER-LEFT-STYLE: none
}
#single_story_TOC H1 {
	BACKGROUND: none transparent scroll repeat 0% 0%; COLOR: #5c832f; =
BORDER-TOP-STYLE: none; BORDER-BOTTOM: #92ab7f 2px solid; =
BORDER-LEFT-STYLE: none
}
#spotlight H1 {
	BORDER-TOP: #92ab7f 2px solid; BACKGROUND: #eff3e9; BORDER-LEFT: =
#92ab7f 2px solid; COLOR: #5c832f
}
#TOC H3 A {
	COLOR: #333
}
DIV.section H3 A {
	COLOR: #333
}
#customize_TOC H3 A {
	COLOR: #333
}
DIV.section H3 A {
	COLOR: #333
}
#single_story_TOC H3 A {
	COLOR: #333
}
DIV.section H3 A {
	COLOR: #333
}
#TOC H3 A SPAN {
	COLOR: #5c832f
}
#TOC H3 SPAN {
	COLOR: #5c832f
}
#TOC DIV.section H3 SPAN A {
	COLOR: #5c832f
}
#customize_TOC H3 A SPAN {
	COLOR: #5c832f
}
#customize_TOC H3 SPAN {
	COLOR: #5c832f
}
#customize_TOC DIV.section H3 SPAN A {
	COLOR: #5c832f
}
#single_story_TOC H3 A SPAN {
	COLOR: #5c832f
}
#single_story_TOC H3 SPAN {
	COLOR: #5c832f
}
#single_story_TOC DIV.section H3 SPAN A {
	COLOR: #5c832f
}
#spotlight A SPAN {
	COLOR: #5c832f
}
#spotlight SPAN {
	COLOR: #5c832f
}
.story_well H1.QOD_header {
	PADDING-LEFT: 0.5em; BACKGROUND: url(/images/spotlight_gradient.png) =
#eff3e9 repeat-x left bottom; MARGIN: 2em -4em 0px -1.75em; =
TEXT-TRANSFORM: uppercase; COLOR: #5c832f; BORDER-TOP-STYLE: none; =
BORDER-BOTTOM: #92ab7f 2px solid; BORDER-RIGHT-STYLE: none; =
BORDER-LEFT-STYLE: none
}
H1.QOD_header {
	PADDING-LEFT: 0.5em; BACKGROUND: url(/images/spotlight_gradient.png) =
#eff3e9 repeat-x left bottom; MARGIN: 2em -4em 0px -1.75em; =
TEXT-TRANSFORM: uppercase; COLOR: #5c832f; BORDER-TOP-STYLE: none; =
BORDER-BOTTOM: #92ab7f 2px solid; BORDER-RIGHT-STYLE: none; =
BORDER-LEFT-STYLE: none
}
#header {
	BACKGROUND: url(/images/gw_bg.png) #5c832f repeat-x left bottom; =
HEIGHT: 60px
}
#header IMG.logo {
=09
}
#header IMG.tagline {
	FLOAT: right; POSITION: relative; TOP: 30px
}
.toolbox {
	BORDER-RIGHT: #5c832f 2px solid; BACKGROUND: #eff3e9; BORDER-LEFT: =
#5c832f 2px solid; BORDER-BOTTOM: #5c832f 2px solid
}
.story_well .toolbox {
	BORDER-RIGHT: #5c832f 2px solid; BACKGROUND: #eff3e9; BORDER-LEFT: =
#5c832f 2px solid; BORDER-BOTTOM: #5c832f 2px solid
}
H1.toolbox {
	BACKGROUND: url(/images/tool_box_corner.png) #5c832f no-repeat left =
top; COLOR: #ffffff
}
.story_well H1.toolbox {
	BACKGROUND: url(/images/tool_box_corner.png) #5c832f no-repeat left =
top; COLOR: #ffffff
}
.toolbox H2 {
	COLOR: #5c832f; BORDER-BOTTOM: #5c832f 1px solid
}
.story_well .toolbox H2 {
	COLOR: #5c832f; BORDER-BOTTOM: #5c832f 1px solid
}
.toolbox LABEL {
	COLOR: #5c832f
}
.story_well .toolbox LABEL {
	COLOR: #5c832f
}
.toolbox H2 A {
	COLOR: #5c832f
}
.story_well .toolbox H2 A {
	COLOR: #5c832f
}
#leaderboard_ad_728x90 {
	BORDER-TOP: #92ab7f 2px solid; BACKGROUND: #eff3e9; BORDER-BOTTOM: =
#92ab7f 2px solid
}
.search_box_header {
	COLOR: #5c832f
}
.recent_editions LI.first_item {
	BACKGROUND: #5c832f; BORDER-LEFT: #5c832f 1px solid; BORDER-BOTTOM: =
#5c832f 1px solid
}
#archive_links H2 {
	BACKGROUND: #5c832f; COLOR: #ffffff
}
.breaking_news_box {
	BORDER-RIGHT: #ccc 1px solid; PADDING-RIGHT: 10px; BORDER-TOP: #ccc 1px =
solid; MARGIN-TOP: 0px; PADDING-LEFT: 10px; BACKGROUND: =
url(/images/box_gradient.png) #eff3e9 repeat-x left top; PADDING-BOTTOM: =
10px; BORDER-LEFT: #ccc 1px solid; PADDING-TOP: 10px; BORDER-BOTTOM: =
#ccc 1px solid
}
.breaking_news_box H2 A {
	COLOR: #000000; TEXT-DECORATION: none
}
.breaking_news_box H2 {
	FONT-SIZE: 150%; COLOR: #000000; TEXT-DECORATION: none
}
.breaking_news_box H2 A:hover {
	COLOR: #990000; TEXT-DECORATION: underline
}
.breaking_news_box H2 A SPAN {
	DISPLAY: block; FONT-SIZE: 80%; TEXT-TRANSFORM: uppercase; COLOR: =
#5c832f
}
.breaking_news_box H2 SPAN {
	DISPLAY: block; FONT-SIZE: 80%; TEXT-TRANSFORM: uppercase; COLOR: =
#5c832f
}
H1.breaking_news_box {
	PADDING-RIGHT: 0.75em; PADDING-LEFT: 0.75em; FONT-WEIGHT: normal; =
FONT-SIZE: 100%; BACKGROUND: #5c832f; PADDING-BOTTOM: 0.45em; MARGIN: =
1em 0px 0px; COLOR: #ffffff; TEXT-INDENT: 0px; PADDING-TOP: 0.45em; =
TEXT-DECORATION: none; BORDER-BOTTOM-STYLE: none
}
H1.breaking_news_box A {
	PADDING-RIGHT: 0.75em; PADDING-LEFT: 0.75em; FONT-WEIGHT: normal; =
FONT-SIZE: 100%; BACKGROUND: #5c832f; PADDING-BOTTOM: 0.45em; MARGIN: =
1em 0px 0px; COLOR: #ffffff; TEXT-INDENT: 0px; PADDING-TOP: 0.45em; =
TEXT-DECORATION: none; BORDER-BOTTOM-STYLE: none
}
H1.breaking_news_box SPAN {
	FONT-WEIGHT: bold; FONT-SIZE: 110%
}
H1.breaking_news_box A SPAN {
	FONT-WEIGHT: bold; FONT-SIZE: 110%
}
H1.breaking_news_box A:hover {
	TEXT-DECORATION: underline
}
H1.breaking_news_box A IMG {
	VERTICAL-ALIGN: middle; BORDER-TOP-STYLE: none; MARGIN-RIGHT: 10px; =
BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: =
none
}
.zones_container {
	BORDER-TOP: #92ab7f 3px solid
}
#LL_story_image {
	BORDER-RIGHT: #b2b299 1px solid; PADDING-RIGHT: 0.5em; BORDER-TOP: =
#b2b299 1px solid; PADDING-LEFT: 0.5em; BACKGROUND: #edede9; FLOAT: =
left; PADDING-BOTTOM: 0.5em; MARGIN: 0em 1em 1em 0px; BORDER-LEFT: =
#b2b299 1px solid; PADDING-TOP: 0.5em; BORDER-BOTTOM: #b2b299 1px solid
}
#LL_story_image IMG {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: =
0px; PADDING-TOP: 0px
}
#LL_story_image P {
	MARGIN-TOP: 0px; PADDING-LEFT: 0px; FONT-SIZE: 95%; MARGIN-BOTTOM: 0px; =
PADDING-BOTTOM: 0px; MARGIN-LEFT: 0px; COLOR: #534640; PADDING-TOP: =
0.25em
}
H2.edition_link A {
	TEXT-DECORATION: none
}
H2.edition_link {
	FONT-SIZE: 120%; MARGIN: 1em 0px 0px; VERTICAL-ALIGN: middle; COLOR: =
#000; TEXT-ALIGN: center
}
H2.edition_link A IMG {
	VERTICAL-ALIGN: middle; BORDER-TOP-STYLE: none; MARGIN-RIGHT: 0.5em; =
BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: =
none
}
H2.toc_header {
	PADDING-RIGHT: 0.5em; BORDER-TOP: #92ab7f 2px solid; PADDING-LEFT: =
0.5em; FONT-SIZE: 120%; BACKGROUND: url(/images/tool_box_gradient.png) =
#eff3e9 repeat-x left top; PADDING-BOTTOM: 0.75em; MARGIN: 2em 0px 0px; =
VERTICAL-ALIGN: middle; COLOR: #000; TEXT-INDENT: 0px; PADDING-TOP: =
0.75em; BORDER-BOTTOM: #ccc 1px solid; TEXT-ALIGN: left
}
H2.toc_header SPAN {
	COLOR: #5c832f
}
.promo_nav H3 {
	FONT-SIZE: 110%; MARGIN-BOTTOM: 0.25em; TEXT-TRANSFORM: uppercase; =
COLOR: #5c832f; BORDER-BOTTOM: #5c832f 1px solid
}
.promo_nav {
	MARGIN-BOTTOM: 2em
}
.promo_nav P A {
	COLOR: #000; TEXT-DECORATION: none
}
.promo_nav P A:hover {
	COLOR: #990000; TEXT-DECORATION: underline
}
.promo_nav P {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0.25em; MARGIN: =
0px; PADDING-TOP: 0.25em; BORDER-BOTTOM: #eee 1px solid
}
.promo_nav TD P {
	PADDING-RIGHT: 0.5em
}
.latest_gw SPAN {
	DISPLAY: block; FONT-WEIGHT: bold; FONT-SIZE: 80%; TEXT-TRANSFORM: =
uppercase
}
.latest_ll SPAN {
	DISPLAY: block; FONT-WEIGHT: bold; FONT-SIZE: 80%; TEXT-TRANSFORM: =
uppercase
}
.latest_pm SPAN {
	DISPLAY: block; FONT-WEIGHT: bold; FONT-SIZE: 80%; TEXT-TRANSFORM: =
uppercase
}
.latest_eed SPAN {
	DISPLAY: block; FONT-WEIGHT: bold; FONT-SIZE: 80%; TEXT-TRANSFORM: =
uppercase
}
.latest_gw SPAN {
	COLOR: #5c832f
}
.latest_ll SPAN {
	COLOR: #666633
}
.latest_pm SPAN {
	COLOR: #336666
}
.latest_eed SPAN {
	COLOR: #326497
}
.latest_gw {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-WEIGHT: normal; FONT-SIZE: =
120%; PADDING-BOTTOM: 0.25em; MARGIN: 0px; PADDING-TOP: 0.25em; =
BORDER-BOTTOM: #eee 1px solid
}
.latest_ll {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-WEIGHT: normal; FONT-SIZE: =
120%; PADDING-BOTTOM: 0.25em; MARGIN: 0px; PADDING-TOP: 0.25em; =
BORDER-BOTTOM: #eee 1px solid
}
.latest_eed {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-WEIGHT: normal; FONT-SIZE: =
120%; PADDING-BOTTOM: 0.25em; MARGIN: 0px; PADDING-TOP: 0.25em; =
BORDER-BOTTOM: #eee 1px solid
}
.latest_pm {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-WEIGHT: normal; FONT-SIZE: =
120%; PADDING-BOTTOM: 0.25em; MARGIN: 0px; PADDING-TOP: 0.25em; =
BORDER-BOTTOM: #eee 1px solid
}
.latest_pm A {
	COLOR: #000; TEXT-DECORATION: none
}
.latest_gw A {
	COLOR: #000; TEXT-DECORATION: none
}
.latest_eed A {
	COLOR: #000; TEXT-DECORATION: none
}
.latest_ll A {
	COLOR: #000; TEXT-DECORATION: none
}
.latest_pm A:hover {
	COLOR: #990000; TEXT-DECORATION: underline
}
.latest_gw A:hover {
	COLOR: #990000; TEXT-DECORATION: underline
}
.latest_eed A:hover {
	COLOR: #990000; TEXT-DECORATION: underline
}
.latest_ll A:hover {
	COLOR: #990000; TEXT-DECORATION: underline
}
.latest_date {
	BORDER-TOP: #ccc 1px solid; FONT-WEIGHT: bold; COLOR: #666; =
PADDING-TOP: 0.5em
}
.table_graphic_gw {
	FONT-SIZE: 11px; MARGIN: 0px 10px 20px 0px; FONT-FAMILY: Arial, =
Helvetica, sans-serif
}
.table_graphic_gw TR.title TD {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-WEIGHT: bold; FONT-SIZE: =
1.25em; BACKGROUND: #5c832f; PADDING-BOTTOM: 0.25em; COLOR: #ffffff; =
BORDER-TOP-STYLE: none; PADDING-TOP: 0.25em; BORDER-RIGHT-STYLE: none; =
BORDER-LEFT-STYLE: none; TEXT-ALIGN: center; BORDER-BOTTOM-STYLE: none
}
.table_graphic_gw TR TD.title {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-WEIGHT: bold; FONT-SIZE: =
1.25em; BACKGROUND: #5c832f; PADDING-BOTTOM: 0.25em; COLOR: #ffffff; =
BORDER-TOP-STYLE: none; PADDING-TOP: 0.25em; BORDER-RIGHT-STYLE: none; =
BORDER-LEFT-STYLE: none; TEXT-ALIGN: center; BORDER-BOTTOM-STYLE: none
}
.table_graphic_gw TD {
	BORDER-RIGHT: #999999 1px solid; PADDING-RIGHT: 10px; BORDER-TOP: =
#999999 1px solid; PADDING-LEFT: 10px; BACKGROUND: #ffffff; =
PADDING-BOTTOM: 2px; BORDER-LEFT: #999999 1px solid; PADDING-TOP: 2px; =
BORDER-BOTTOM: #999999 1px solid
}
.table_graphic_gw TD.table_cutline {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; FONT-SIZE: 85%; =
PADDING-BOTTOM: 1em; BORDER-TOP-STYLE: none; PADDING-TOP: 0.25em; =
FONT-STYLE: normal; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none; =
BORDER-BOTTOM-STYLE: none
}
.table_graphic_gw .column_name {
	FONT-WEIGHT: bold; BACKGROUND: #eff3e9; COLOR: #5c832f
}
.table_graphic_gw TR.row_total {
	FONT-WEIGHT: bold
}
.table_graphic_gw .sub_header {
	FONT-WEIGHT: bold; BACKGROUND: #efefef; COLOR: #5c832f; TEXT-ALIGN: =
center
}
.ed_note_box {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0.5em; MARGIN: =
1em 0px; COLOR: #666; PADDING-TOP: 0.5em; BORDER-BOTTOM: #ccc 1px solid
}
.ed_note_box H2 {
	FONT-SIZE: 115%; MARGIN: 0px 0.5em 0.25em 0.25em
}
.ed_note_box H3 {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.28em; FONT-WEIGHT: normal; =
FONT-SIZE: 100%; BACKGROUND: #ffffff; PADDING-BOTTOM: 0.15em; MARGIN: =
0px 0px 1em; TEXT-TRANSFORM: none; COLOR: #5c832f; PADDING-TOP: 0.25em; =
BORDER-BOTTOM: #5c832f 2px solid
}
.ed_note_box H3 SPAN {
	FONT-WEIGHT: bold; TEXT-TRANSFORM: uppercase
}
.ed_note_box P {
	MARGIN: 0.25em 0.75em 0.5em 0.28em
}
.committee_calendar TABLE TD.senate {
	BORDER-LEFT: #ccc 1px solid
}
.committee_calendar TABLE TH.senate {
=09
}
.committee_calendar TABLE TD {
	PADDING-RIGHT: 1em; PADDING-LEFT: 1em; PADDING-BOTTOM: 0.25em; =
VERTICAL-ALIGN: top; PADDING-TOP: 0.25em
}
.committee_calendar {
	BACKGROUND: url(/images/box_gradient.png) #eff3e9 repeat-x left top; =
MARGIN-BOTTOM: 1em
}
.committee_calendar TABLE TH {
	PADDING-RIGHT: 1em; PADDING-LEFT: 1em; FONT-WEIGHT: normal; BACKGROUND: =
url(/images/tab_gradient.png) #5c832f repeat-x left bottom; =
PADDING-BOTTOM: 0.25em; VERTICAL-ALIGN: top; COLOR: #fff; PADDING-TOP: =
0.25em; TEXT-ALIGN: left
}
SPAN.cal_item_status {
	FONT-WEIGHT: bold; COLOR: #ff0000
}
.committee_calendar H2 {
	PADDING-RIGHT: 0px; MARGIN-TOP: 2em; PADDING-LEFT: 0px; FONT-SIZE: =
100%; BACKGROUND: #fff; PADDING-BOTTOM: 0.05em; TEXT-TRANSFORM: =
uppercase; COLOR: #5c832f; BORDER-TOP-STYLE: none; TEXT-INDENT: 0px; =
PADDING-TOP: 0.05em; BORDER-BOTTOM: #92ab7f 2px solid; =
BORDER-LEFT-STYLE: none
}
.committee_calendar H1 {
	MARGIN: 1em 0px 0.5em
}
.calendar_item {
	BORDER-BOTTOM: #ccc 1px solid
}
.calendar_item_last {
=09
}
.story_tools {
	PADDING-RIGHT: 0px; BORDER-TOP: #92ab7f 2px solid; PADDING-LEFT: 0px; =
BACKGROUND: url(/images/tool_box_gradient.png) #eff3e9 repeat-x left =
top; FLOAT: right; PADDING-BOTTOM: 0px; MARGIN: 2.5em -4.4em 0em 1em; =
WIDTH: 304px; PADDING-TOP: 0px; BORDER-BOTTOM: #92ab7f 2px solid
}
.latest_popular_tools {
	PADDING-BOTTOM: 0.2em; MARGIN: 1px 0px 0px; TEXT-ALIGN: left
}
.latest_popular_tools A.pop_tab {
	BORDER-RIGHT: #cccccc 1px; PADDING-RIGHT: 0.6em; BORDER-TOP: #cccccc =
1px solid; PADDING-LEFT: 0.6em; FONT-WEIGHT: normal; FONT-SIZE: 80%; =
BACKGROUND: url(/images/tab_gradient.png) #fff repeat-x left bottom; =
PADDING-BOTTOM: 0.25em; MARGIN: 0px; TEXT-TRANSFORM: uppercase; =
BORDER-LEFT: #cccccc 1px solid; COLOR: #666666; PADDING-TOP: 0.25em; =
BORDER-BOTTOM: #cccccc 1px; TEXT-ALIGN: center; TEXT-DECORATION: none
}
.latest_popular_tools A.pop_tab_last {
	BORDER-RIGHT: #cccccc 1px; PADDING-RIGHT: 0.6em; BORDER-TOP: #cccccc =
1px solid; PADDING-LEFT: 0.6em; FONT-WEIGHT: normal; FONT-SIZE: 80%; =
BACKGROUND: url(/images/tab_gradient.png) #fff repeat-x left bottom; =
PADDING-BOTTOM: 0.25em; MARGIN: 0px; TEXT-TRANSFORM: uppercase; =
BORDER-LEFT: #cccccc 1px solid; COLOR: #666666; PADDING-TOP: 0.25em; =
BORDER-BOTTOM: #cccccc 1px; TEXT-ALIGN: center; TEXT-DECORATION: none
}
.latest_popular_tools A.pop_tabcurrent {
	BORDER-RIGHT: #cccccc 1px; PADDING-RIGHT: 0.6em; BORDER-TOP: #cccccc =
1px solid; PADDING-LEFT: 0.6em; FONT-WEIGHT: normal; FONT-SIZE: 80%; =
BACKGROUND: url(/images/tab_gradient.png) #fff repeat-x left bottom; =
PADDING-BOTTOM: 0.25em; MARGIN: 0px; TEXT-TRANSFORM: uppercase; =
BORDER-LEFT: #cccccc 1px solid; COLOR: #666666; PADDING-TOP: 0.25em; =
BORDER-BOTTOM: #cccccc 1px; TEXT-ALIGN: center; TEXT-DECORATION: none
}
.latest_popular_tools A.pop_tabcurrent {
	BORDER-RIGHT: #92ab7f 1px solid; BORDER-TOP: #92ab7f 1px solid; =
BACKGROUND: #ffffff; PADDING-BOTTOM: 5px; BORDER-LEFT: #92ab7f 1px =
solid; COLOR: #5c832f; BORDER-BOTTOM: #92ab7f 1px
}
.latest_popular_tools A.pop_tab_last {
	BORDER-RIGHT: #cccccc 1px solid
}
.latest_popular_tools A.pop_tab:hover {
	BACKGROUND: url(/images/tab_gradient.png) #eff3e9 repeat-x left bottom; =
COLOR: #5c832f
}
.latest_popular_tools A.pop_tab_last:hover {
	BACKGROUND: url(/images/tab_gradient.png) #eff3e9 repeat-x left bottom; =
COLOR: #5c832f
}
#latest_popular {
	MARGIN-TOP: 0.25em; MARGIN-BOTTOM: 1em; WIDTH: 332px
}
#latest_popular_content {
	BORDER-RIGHT: #92ab7f 1px solid; BORDER-TOP: #92ab7f 1px solid; =
MIN-HEIGHT: 290px; BACKGROUND: url(/images/box_gradient_extended.png) =
#eff3e9 repeat-x left top; PADDING-BOTTOM: 0.5em; BORDER-LEFT: #92ab7f =
1px solid; PADDING-TOP: 0.5em; BORDER-BOTTOM: #92ab7f 1px solid
}
#latest_popular_content H3.headline {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-WEIGHT: normal; FONT-SIZE: =
100%; PADDING-BOTTOM: 0.25em; MARGIN: 0px 0.5em 0px 1.75em; TEXT-INDENT: =
-0.85em; PADDING-TOP: 0.25em; BORDER-BOTTOM: #ddd 1px solid
}
#latest_popular_content H3.headline {
	COLOR: #000; TEXT-DECORATION: none
}
#latest_popular_content H3.headline A {
	COLOR: #000; TEXT-DECORATION: none
}
#latest_popular_content H3.headline A:hover {
	COLOR: #990000; TEXT-DECORATION: underline
}
#latest_popular_content H3.headline SPAN {
	DISPLAY: inline; FONT-WEIGHT: bold; FONT-SIZE: 90%; TEXT-TRANSFORM: =
uppercase; COLOR: #5c832f; TEXT-DECORATION: none
}
#latest_popular_content H3.headline A SPAN {
	DISPLAY: inline; FONT-WEIGHT: bold; FONT-SIZE: 90%; TEXT-TRANSFORM: =
uppercase; COLOR: #5c832f; TEXT-DECORATION: none
}
#latest_popular_content H3.headline SPAN.origin {
	DISPLAY: inline; FONT-WEIGHT: normal; TEXT-TRANSFORM: none; COLOR: =
#666; FONT-STYLE: italic
}
#latest_popular_content H3.headline A SPAN.origin {
	DISPLAY: inline; FONT-WEIGHT: normal; TEXT-TRANSFORM: none; COLOR: =
#666; FONT-STYLE: italic
}
#latest_popular_content P.digest_item {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-WEIGHT: normal; FONT-SIZE: =
100%; PADDING-BOTTOM: 0.5em; MARGIN: 0px; TEXT-INDENT: 1em; PADDING-TOP: =
0.5em; TEXT-ALIGN: left
}
#latest_popular_content P.digest_item_with_image {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-WEIGHT: normal; FONT-SIZE: =
100%; PADDING-BOTTOM: 0.5em; MARGIN: 0px; TEXT-INDENT: 1em; PADDING-TOP: =
0.5em; TEXT-ALIGN: left
}
#latest_popular_content P.digest_item_with_image {
	TEXT-INDENT: 0px
}
#latest_popular_content DIV.digest_title {
	MARGIN-BOTTOM: 0.5em; COLOR: #5c832f; TEXT-ALIGN: center
}
#latest_popular_content P.digest_item {
	COLOR: #000; TEXT-DECORATION: none
}
#latest_popular_content P.digest_item_with_image {
	COLOR: #000; TEXT-DECORATION: none
}
#latest_popular_content P.digest_item A {
	COLOR: #000; TEXT-DECORATION: none
}
#latest_popular_content P.digest_item_with_image A {
	COLOR: #000; TEXT-DECORATION: none
}
#latest_popular_content P.digest_item IMG {
	BORDER-RIGHT: #5c832f 1px solid; BORDER-TOP: #5c832f 1px solid; =
MARGIN-BOTTOM: 0.25em; BORDER-LEFT: #5c832f 1px solid; BORDER-BOTTOM: =
#5c832f 1px solid; TEXT-DECORATION: none
}
#latest_popular_content P.digest_item_with_image IMG {
	BORDER-RIGHT: #5c832f 1px solid; BORDER-TOP: #5c832f 1px solid; =
MARGIN-BOTTOM: 0.25em; BORDER-LEFT: #5c832f 1px solid; BORDER-BOTTOM: =
#5c832f 1px solid; TEXT-DECORATION: none
}
#latest_popular_content P.digest_item A IMG {
	BORDER-RIGHT: #5c832f 1px solid; BORDER-TOP: #5c832f 1px solid; =
MARGIN-BOTTOM: 0.25em; BORDER-LEFT: #5c832f 1px solid; BORDER-BOTTOM: =
#5c832f 1px solid; TEXT-DECORATION: none
}
#latest_popular_content P.digest_item_with_image A IMG {
	BORDER-RIGHT: #5c832f 1px solid; BORDER-TOP: #5c832f 1px solid; =
MARGIN-BOTTOM: 0.25em; BORDER-LEFT: #5c832f 1px solid; BORDER-BOTTOM: =
#5c832f 1px solid; TEXT-DECORATION: none
}
#latest_popular_content P.digest_item A:hover {
	COLOR: #990000; TEXT-DECORATION: underline
}
#latest_popular_content P.digest_item_with_image A:hover {
	COLOR: #990000; TEXT-DECORATION: underline
}
#latest_popular_content P.digest_item SPAN {
	DISPLAY: inline; FONT-WEIGHT: bold; FONT-SIZE: 100%; COLOR: #000; =
TEXT-DECORATION: none
}
#latest_popular_content P.digest_item A SPAN {
	DISPLAY: inline; FONT-WEIGHT: bold; FONT-SIZE: 100%; COLOR: #000; =
TEXT-DECORATION: none
}
#latest_popular_content P.digest_item_with_image SPAN {
	DISPLAY: inline; FONT-WEIGHT: bold; FONT-SIZE: 100%; COLOR: #000; =
TEXT-DECORATION: none
}
#latest_popular_content P.digest_item_with_image A SPAN {
	DISPLAY: inline; FONT-WEIGHT: bold; FONT-SIZE: 100%; COLOR: #000; =
TEXT-DECORATION: none
}
#latest_popular_content TABLE TR TD {
	VERTICAL-ALIGN: top; WIDTH: 138px
}
#latest_popular_content TABLE TR TD.right_column {
	PADDING-RIGHT: 14px; PADDING-LEFT: 7px; PADDING-BOTTOM: 0px; =
PADDING-TOP: 0px
}
#latest_popular_content TABLE TR TD.left_column {
	PADDING-RIGHT: 7px; PADDING-LEFT: 14px; PADDING-BOTTOM: 0px; =
PADDING-TOP: 0px
}
#latest_popular_content TABLE {
	VERTICAL-ALIGN: top; WIDTH: 332px
}
DIV#latest_popular_content P.digest_item SPAN.item_origin {
	FONT-WEIGHT: bold; FONT-SIZE: 90%; COLOR: #990000; FONT-STYLE: italic
}
DIV#latest_popular_content P.digest_item A SPAN.item_origin {
	FONT-WEIGHT: bold; FONT-SIZE: 90%; COLOR: #990000; FONT-STYLE: italic
}
DIV#latest_popular_content P.digest_item_with_image SPAN.item_origin {
	FONT-WEIGHT: bold; FONT-SIZE: 90%; COLOR: #990000; FONT-STYLE: italic
}
DIV#latest_popular_content P.digest_item_with_image A SPAN.item_origin {
	FONT-WEIGHT: bold; FONT-SIZE: 90%; COLOR: #990000; FONT-STYLE: italic
}
TABLE.promo_nav_columns {
	CLEAR: both; BORDER-TOP: #ccc 1px solid; WIDTH: 100%; BORDER-BOTTOM: =
#ccc 1px solid
}
TABLE.promo_nav_columns TD {
	BORDER-RIGHT: #ccc 1px solid; PADDING-RIGHT: 10px; PADDING-LEFT: 10px; =
PADDING-BOTTOM: 0px; VERTICAL-ALIGN: top; WIDTH: 31%; PADDING-TOP: 0px
}
TABLE.promo_nav_columns TD TABLE TD {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; =
BORDER-TOP-STYLE: none; PADDING-TOP: 0px; BORDER-RIGHT-STYLE: none; =
BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: none
}
TABLE.promo_nav_columns TD.last_cell {
	PADDING-RIGHT: 0px; WIDTH: 38%; BORDER-RIGHT-STYLE: none
}
TABLE.promo_nav_columns TD.first_cell {
	PADDING-LEFT: 0px
}
TABLE.promo_nav_columns TD H3.headline {
	FONT-SIZE: 145%; MARGIN: 0.25em 0px 1em; LINE-HEIGHT: 120%
}
TABLE.promo_nav_columns TD H3.headline A {
	COLOR: #000; TEXT-DECORATION: none
}
TABLE.promo_nav_columns TD H3.headline A:hover {
	COLOR: #990000
}
TABLE.promo_nav_columns TD H3.headline A SPAN.slug {
	DISPLAY: block; FONT-SIZE: 90%; TEXT-TRANSFORM: uppercase; COLOR: =
#326698
}
TABLE.promo_nav_columns TD H3.headline A SPAN.origin {
	DISPLAY: inline; FONT-WEIGHT: normal; FONT-SIZE: 80%; TEXT-TRANSFORM: =
none; COLOR: #666; FONT-STYLE: italic; TEXT-DECORATION: none
}

------=_NextPart_000_0000_01CAB168.786EE890
Content-Type: application/octet-stream
Content-Transfer-Encoding: quoted-printable
Content-Location: http://www.eenews.net/stylesheets/printer_styles.css?1265230393

BODY {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-SIZE: 75%! important; =
PADDING-BOTTOM: 0px; MARGIN: 0px auto; PADDING-TOP: 0px; FONT-FAMILY: =
Arial, Helvetica, sans-serif
}
A {
	COLOR: #990000
}
A:hover {
	COLOR: #ff0000
}
#content_container {
	MARGIN-TOP: 0px; BACKGROUND: #ffffff; MARGIN-LEFT: auto; WIDTH: 100%! =
important; MARGIN-RIGHT: auto; PADDING-TOP: 1em; FONT-FAMILY: Arial, =
Helvetica, sans-serif; TOP: 0px
}
#content {
	WIDTH: 100%! important
}
#right_column {
	DISPLAY: none
}
.secondary_nav {
	DISPLAY: none
}
H1.date {
	FONT-SIZE: 1.5em; PADDING-BOTTOM: 0.5em; COLOR: #666666; BORDER-BOTTOM: =
#cccccc 1px solid; FONT-FAMILY: Arial, Helvetica, sans-serif; =
TEXT-ALIGN: left
}
SPAN.full_edition_link {
	PADDING-RIGHT: 0px; PADDING-LEFT: 1em; FONT-WEIGHT: normal; FONT-SIZE: =
65%; PADDING-BOTTOM: 0px; MARGIN: 0px; COLOR: #990000; PADDING-TOP: 0px
}
#TOC {
	MARGIN-TOP: 1em; PADDING-BOTTOM: 2em
}
#TOC H1 {
	PADDING-RIGHT: 0.25em; MARGIN-TOP: 2em; PADDING-LEFT: 0.25em; =
FONT-SIZE: 115%; PADDING-BOTTOM: 0.25em; VERTICAL-ALIGN: middle; =
TEXT-TRANSFORM: uppercase; PADDING-TOP: 0.25em; FONT-FAMILY: Arial, =
Helvetica, sans-serif
}
DIV.section H1 {
	PADDING-RIGHT: 0.25em; MARGIN-TOP: 2em; PADDING-LEFT: 0.25em; =
FONT-SIZE: 115%; PADDING-BOTTOM: 0.25em; VERTICAL-ALIGN: middle; =
TEXT-TRANSFORM: uppercase; PADDING-TOP: 0.25em; FONT-FAMILY: Arial, =
Helvetica, sans-serif
}
#spotlight H1 {
	PADDING-RIGHT: 0.25em; PADDING-LEFT: 0.25em; FONT-SIZE: 115%; =
PADDING-BOTTOM: 0.25em; VERTICAL-ALIGN: middle; TEXT-TRANSFORM: =
uppercase; PADDING-TOP: 0.25em; FONT-FAMILY: Arial, Helvetica, =
sans-serif
}
#spotlight H1 SPAN {
	DISPLAY: block; FONT-WEIGHT: normal; FLOAT: right; TEXT-TRANSFORM: =
none; TEXT-ALIGN: right
}
#TOC H3 {
	PADDING-LEFT: 4em; FONT-WEIGHT: normal; FONT-SIZE: 115%; MARGIN: 0.75em =
2.75em 0.75em 0.5em; TEXT-INDENT: -2.75em; FONT-FAMILY: Arial, =
Helvetica, sans-serif
}
DIV.section H3 {
	PADDING-LEFT: 4em; FONT-WEIGHT: normal; FONT-SIZE: 115%; MARGIN: 0.75em =
2.75em 0.75em 0.5em; TEXT-INDENT: -2.75em; FONT-FAMILY: Arial, =
Helvetica, sans-serif
}
#TOC H3 A {
	COLOR: #000000; TEXT-DECORATION: none
}
DIV.section H3 A {
	COLOR: #000000; TEXT-DECORATION: none
}
#TOC H3 A SPAN {
	FONT-WEIGHT: bold; TEXT-TRANSFORM: uppercase; TEXT-DECORATION: =
underline
}
DIV.section H3 A SPAN {
	FONT-WEIGHT: bold; TEXT-TRANSFORM: uppercase; TEXT-DECORATION: =
underline
}
#TOC H3 A:hover {
	COLOR: #990000
}
#TOC H3 A:hover SPAN {
	COLOR: #990000
}
DIV.section H3 A:hover {
	COLOR: #990000
}
DIV.section A:hover SPAN {
	COLOR: #990000
}
#TOC P {
	PADDING-LEFT: 1.5em; FONT-SIZE: 100%; MARGIN: 0.75em 2.75em 0.75em =
0.5em
}
#TOC DIV.section P {
	PADDING-LEFT: 4.6em; FONT-SIZE: 100%; MARGIN: 0px 2.75em 1.25em 0.5em
}
#spotlight H2 {
	PADDING-RIGHT: 1em; PADDING-LEFT: 2.8em; FONT-SIZE: 1.5em; =
MARGIN-BOTTOM: 0px; PADDING-BOTTOM: 0px; TEXT-INDENT: -2.4em; =
FONT-FAMILY: Arial, Helvetica, sans-serif
}
#spotlight H2 A:hover {
	COLOR: #990000
}
#spotlight H2 A:hover SPAN {
	COLOR: #990000
}
#spotlight H2 A {
	COLOR: #000000; TEXT-DECORATION: none
}
#spotlight A SPAN {
	TEXT-TRANSFORM: uppercase; TEXT-DECORATION: underline
}
#spotlight P {
	PADDING-RIGHT: 2em; PADDING-LEFT: 4.25em; PADDING-BOTTOM: 0px; MARGIN: =
1em 0px; PADDING-TOP: 0px
}
.sr_advert {
	DISPLAY: none
}
.link_btns {
	DISPLAY: none
}
.pm_headlines {
	DISPLAY: none
}
.gw_headlines {
	DISPLAY: none
}
.daily_headlines {
	DISPLAY: none
}
.more_link {
	DISPLAY: none
}
#tv_player {
	DISPLAY: none
}
#spotlight H2 {
	PADDING-LEFT: 1.5em; FONT-SIZE: 1.5em; MARGIN-BOTTOM: 0px; =
PADDING-BOTTOM: 0px; TEXT-INDENT: -1em; FONT-FAMILY: Arial, Helvetica, =
sans-serif
}
#spotlight H2 A:hover {
	COLOR: #990000
}
#spotlight H2 A:hover SPAN {
	COLOR: #990000
}
#spotlight H2 A {
	COLOR: #000000; TEXT-DECORATION: none
}
#spotlight A SPAN {
	TEXT-TRANSFORM: uppercase; TEXT-DECORATION: underline
}
#spotlight P {
	PADDING-LEFT: 2.25em
}
#header_container {
	MARGIN-TOP: 0px; Z-INDEX: 10; WIDTH: 100%! important; TOP: 0px
}
#header {
	MARGIN: auto; WIDTH: 100%! important
}
.pubs_nav {
	DISPLAY: none
}
.pubs_nav_new {
	DISPLAY: none
}
.edition_date {
	DISPLAY: none
}
.search_nav {
	DISPLAY: none
}
#banner_ad {
	DISPLAY: none
}
.header_leaderboard {
	DISPLAY: none
}
#header_container {
	BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: =
none; BORDER-BOTTOM-STYLE: none
}
.zones_container {
	BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: =
none; BORDER-BOTTOM-STYLE: none
}
#header IMG.tagline {
	DISPLAY: none
}
.zones_inner_container {
	BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: =
none; BORDER-BOTTOM-STYLE: none
}
#box_ad_336x280 {
	DISPLAY: none
}
#box_ad_336x280 P {
	FONT-SIZE: 90%; PADDING-BOTTOM: 0.25em; MARGIN: 0px; COLOR: #336633; =
PADDING-TOP: 0px; TEXT-ALIGN: center
}
#leaderboard_ad_728x90 {
	CLEAR: both; PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: =
1em; MARGIN: 0.5em 1em 0px; PADDING-TOP: 0px; TEXT-ALIGN: center
}
#leaderboard_ad_728x90 P {
	FONT-SIZE: 90%; PADDING-BOTTOM: 0.25em; MARGIN: 0px; PADDING-TOP: =
0.25em
}
.toolbox {
	DISPLAY: none
}
.story_well .toolbox {
	DISPLAY: none
}
H1.toolbox {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; FONT-SIZE: 115%; =
PADDING-BOTTOM: 0.25em; MARGIN: 1em 0px 0px; TEXT-TRANSFORM: uppercase; =
BORDER-TOP-STYLE: none; TEXT-INDENT: 0px; PADDING-TOP: 0.3em; =
FONT-FAMILY: Arial, Helvetica, sans-serif; BORDER-RIGHT-STYLE: none; =
BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: none
}
.story_well H1.toolbox {
	PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; FONT-SIZE: 115%; =
PADDING-BOTTOM: 0.25em; MARGIN: 1em 0px 0px; TEXT-TRANSFORM: uppercase; =
BORDER-TOP-STYLE: none; TEXT-INDENT: 0px; PADDING-TOP: 0.3em; =
FONT-FAMILY: Arial, Helvetica, sans-serif; BORDER-RIGHT-STYLE: none; =
BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: none
}
.toolbox H2 {
	FONT-SIZE: 100%; MARGIN: 1em 0px 0px; TEXT-TRANSFORM: uppercase; =
TEXT-INDENT: 0px; FONT-FAMILY: Arial, Helvetica, sans-serif
}
.story_well .toolbox H2 {
	FONT-SIZE: 100%; MARGIN: 1em 0px 0px; TEXT-TRANSFORM: uppercase; =
TEXT-INDENT: 0px; FONT-FAMILY: Arial, Helvetica, sans-serif
}
.toolbox P {
	MARGIN-TOP: 0.5em; FONT-SIZE: 95%; MARGIN-BOTTOM: 0.5em
}
.toolbox FORM {
	MARGIN: 0.5em 0px 0px; TEXT-ALIGN: left
}
.toolbox SELECT {
	MARGIN: 0.25em 0px; VERTICAL-ALIGN: middle
}
.toolbox LABEL {
	MARGIN: 0.25em 0px; VERTICAL-ALIGN: middle
}
.toolbox INPUT {
	MARGIN: 0.25em 0px; VERTICAL-ALIGN: middle
}
.toolbox_container {
	PADDING-RIGHT: 0.5em; MARGIN-TOP: 1em; PADDING-LEFT: 1em; BACKGROUND: =
#ffffff; FLOAT: right; MARGIN-BOTTOM: 1em; WIDTH: 340px; MARGIN-RIGHT: =
-5em; FONT-FAMILY: Arial, Helvetica, sans-serif
}
#special_report_guide {
	DISPLAY: none
}
#srg_header {
	DISPLAY: none
}
#more_content_container {
	DISPLAY: none
}
#more_content_header {
	DISPLAY: none
}
.story_well {
	PADDING-RIGHT: 1em; PADDING-LEFT: 1em; MARGIN-LEFT: 1em; MARGIN-RIGHT: =
1em; FONT-FAMILY: Arial, Helvetica, sans-serif
}
.story_well H1 {
	PADDING-RIGHT: 0.5em; MARGIN-TOP: 2em; PADDING-LEFT: 0.5em; FONT-SIZE: =
1.25em; PADDING-BOTTOM: 0.25em; MARGIN-LEFT: -1.7em; VERTICAL-ALIGN: =
middle; TEXT-TRANSFORM: uppercase; MARGIN-RIGHT: -4em; PADDING-TOP: =
0.25em; FONT-FAMILY: Arial, Helvetica, sans-serif
}
.story_well H2 {
	MARGIN-TOP: 2em; FONT-SIZE: 1.5em; MARGIN-BOTTOM: 0px; PADDING-BOTTOM: =
0px; TEXT-INDENT: -1.2em; FONT-FAMILY: Arial, Helvetica, sans-serif
}
.story_well H2 SPAN {
	TEXT-TRANSFORM: uppercase
}
.story_well H3 {
	FONT-SIZE: 1.25em; MARGIN-BOTTOM: 0px; PADDING-BOTTOM: 0px; =
FONT-FAMILY: Arial, Helvetica, sans-serif
}
.story_well H5.reporter {
	FONT-SIZE: 100%; MARGIN-BOTTOM: 0px; PADDING-BOTTOM: 0px; FONT-FAMILY: =
Arial, Helvetica, sans-serif
}
.top_link {
	DISPLAY: none
}
.top_link_index {
	DISPLAY: none
}
.footer_container {
	CLEAR: both; BACKGROUND: #ffffff; MARGIN: 10px auto 0px; PADDING-TOP: =
10px
}
.footer {
	BACKGROUND: #ffffff; MARGIN: 5px auto 0px; WIDTH: 100%! important; =
TEXT-ALIGN: left
}
.bottom_nav {
	CLEAR: both; DISPLAY: none
}
.bottom_nav A {
	FONT-WEIGHT: normal; COLOR: #ffffff; TEXT-DECORATION: none
}
.bottom_nav A:hover {
	FONT-WEIGHT: normal; COLOR: #bbcad5; TEXT-DECORATION: underline
}
.footer_right {
	FLOAT: right; WIDTH: 700px
}
.footer_left {
	FLOAT: left
}
.bottom_nav UL {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: =
0px; WIDTH: 100%! important; PADDING-TOP: 0px; LIST-STYLE-TYPE: none
}
.bottom_nav LI {
	BORDER-RIGHT: #43759b 1px solid; PADDING-RIGHT: 6px; DISPLAY: inline; =
PADDING-LEFT: 6px; PADDING-BOTTOM: 2px; LINE-HEIGHT: 2.5em; PADDING-TOP: =
0px
}
.bottom_nav LI.lastItem {
	BORDER-RIGHT-STYLE: none
}
.copyright {
	CLEAR: both; PADDING-LEFT: 7px; FONT-SIZE: 80%; PADDING-BOTTOM: 0px; =
COLOR: #999999; PADDING-TOP: 0px; FONT-FAMILY: Arial, Helvetica, =
sans-serif; TEXT-ALIGN: left
}
.tagLine {
	PADDING-LEFT: 7px; FONT-SIZE: 100%; PADDING-BOTTOM: 10px; COLOR: =
#999999; PADDING-TOP: 8px; FONT-STYLE: italic; FONT-FAMILY: Arial, =
Helvetica, sans-serif
}
.clear_both {
	CLEAR: both
}
.anchor {
	PADDING-TOP: 10em
}
.search_box {
	DISPLAY: none
}
.search_box_header {
	FONT-SIZE: 1.5em; MARGIN-LEFT: -1em
}
.search_description {
	MARGIN-RIGHT: 376px
}
#right_column_search {
	PADDING-RIGHT: 0.5em; FLOAT: right; MARGIN-BOTTOM: 1em; WIDTH: 340px; =
PADDING-TOP: 1em; FONT-FAMILY: Arial, Helvetica, sans-serif
}
#search_form FIELDSET {
	BORDER-RIGHT: #ffffff 0px solid; PADDING-RIGHT: 0px; BORDER-TOP: =
#ffffff 0px solid; DISPLAY: block; PADDING-LEFT: 100px; PADDING-BOTTOM: =
0px; MARGIN: 0.75em 0px; VERTICAL-ALIGN: middle; BORDER-LEFT: #ffffff =
0px solid; PADDING-TOP: 0px; BORDER-BOTTOM: #ffffff 0px solid
}
#search_form FIELDSET H3 {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-SIZE: 100%; FLOAT: left; =
PADDING-BOTTOM: 0px; MARGIN: 0px 0.5em 0px -100px; VERTICAL-ALIGN: =
middle; WIDTH: 90px; PADDING-TOP: 0px; TEXT-ALIGN: right
}
#search_form FIELDSET LABEL {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: =
0px; VERTICAL-ALIGN: middle; PADDING-TOP: 0px; TEXT-ALIGN: right
}
#search_form FIELDSET LABEL SELECT.first {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: =
0px; VERTICAL-ALIGN: middle; PADDING-TOP: 0px
}
#search_form FIELDSET LABEL INPUT.first {
	PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: =
0px; VERTICAL-ALIGN: middle; PADDING-TOP: 0px
}
#search_results_well {
	MARGIN: 2em 0px
}
DIV.story_tools {
	DISPLAY: none
}
UL.story_tool_btns {
	DISPLAY: none
}
.toolbox_container {
	DISPLAY: none
}
UL.edition_tool_btns {
	DISPLAY: none
}

------=_NextPart_000_0000_01CAB168.786EE890
Content-Type: application/octet-stream
Content-Transfer-Encoding: quoted-printable
Content-Location: http://www.eenews.net/javascripts/prototype.js?1218125236

/*  Prototype JavaScript framework, version 1.6.0.1=0A=
 *  (c) 2005-2007 Sam Stephenson=0A=
 *=0A=
 *  Prototype is freely distributable under the terms of an MIT-style =
license.=0A=
 *  For details, see the Prototype web site: http://www.prototypejs.org/=0A=
 *=0A=
 =
*------------------------------------------------------------------------=
--*/=0A=
=0A=
var Prototype =3D {=0A=
  Version: '1.6.0.1',=0A=
=0A=
  Browser: {=0A=
    IE:     !!(window.attachEvent && !window.opera),=0A=
    Opera:  !!window.opera,=0A=
    WebKit: navigator.userAgent.indexOf('AppleWebKit/') > -1,=0A=
    Gecko:  navigator.userAgent.indexOf('Gecko') > -1 && =
navigator.userAgent.indexOf('KHTML') =3D=3D -1,=0A=
    MobileSafari: !!navigator.userAgent.match(/Apple.*Mobile.*Safari/)=0A=
  },=0A=
=0A=
  BrowserFeatures: {=0A=
    XPath: !!document.evaluate,=0A=
    ElementExtensions: !!window.HTMLElement,=0A=
    SpecificElementExtensions:=0A=
      document.createElement('div').__proto__ &&=0A=
      document.createElement('div').__proto__ !=3D=3D=0A=
        document.createElement('form').__proto__=0A=
  },=0A=
=0A=
  ScriptFragment: '<script[^>]*>([\\S\\s]*?)<\/script>',=0A=
  JSONFilter: /^\/\*-secure-([\s\S]*)\*\/\s*$/,=0A=
=0A=
  emptyFunction: function() { },=0A=
  K: function(x) { return x }=0A=
};=0A=
=0A=
if (Prototype.Browser.MobileSafari)=0A=
  Prototype.BrowserFeatures.SpecificElementExtensions =3D false;=0A=
=0A=
=0A=
/* Based on Alex Arnell's inheritance implementation. */=0A=
var Class =3D {=0A=
  create: function() {=0A=
    var parent =3D null, properties =3D $A(arguments);=0A=
    if (Object.isFunction(properties[0]))=0A=
      parent =3D properties.shift();=0A=
=0A=
    function klass() {=0A=
      this.initialize.apply(this, arguments);=0A=
    }=0A=
=0A=
    Object.extend(klass, Class.Methods);=0A=
    klass.superclass =3D parent;=0A=
    klass.subclasses =3D [];=0A=
=0A=
    if (parent) {=0A=
      var subclass =3D function() { };=0A=
      subclass.prototype =3D parent.prototype;=0A=
      klass.prototype =3D new subclass;=0A=
      parent.subclasses.push(klass);=0A=
    }=0A=
=0A=
    for (var i =3D 0; i < properties.length; i++)=0A=
      klass.addMethods(properties[i]);=0A=
=0A=
    if (!klass.prototype.initialize)=0A=
      klass.prototype.initialize =3D Prototype.emptyFunction;=0A=
=0A=
    klass.prototype.constructor =3D klass;=0A=
=0A=
    return klass;=0A=
  }=0A=
};=0A=
=0A=
Class.Methods =3D {=0A=
  addMethods: function(source) {=0A=
    var ancestor   =3D this.superclass && this.superclass.prototype;=0A=
    var properties =3D Object.keys(source);=0A=
=0A=
    if (!Object.keys({ toString: true }).length)=0A=
      properties.push("toString", "valueOf");=0A=
=0A=
    for (var i =3D 0, length =3D properties.length; i < length; i++) {=0A=
      var property =3D properties[i], value =3D source[property];=0A=
      if (ancestor && Object.isFunction(value) &&=0A=
          value.argumentNames().first() =3D=3D "$super") {=0A=
        var method =3D value, value =3D Object.extend((function(m) {=0A=
          return function() { return ancestor[m].apply(this, arguments) =
};=0A=
        })(property).wrap(method), {=0A=
          valueOf:  function() { return method },=0A=
          toString: function() { return method.toString() }=0A=
        });=0A=
      }=0A=
      this.prototype[property] =3D value;=0A=
    }=0A=
=0A=
    return this;=0A=
  }=0A=
};=0A=
=0A=
var Abstract =3D { };=0A=
=0A=
Object.extend =3D function(destination, source) {=0A=
  for (var property in source)=0A=
    destination[property] =3D source[property];=0A=
  return destination;=0A=
};=0A=
=0A=
Object.extend(Object, {=0A=
  inspect: function(object) {=0A=
    try {=0A=
      if (Object.isUndefined(object)) return 'undefined';=0A=
      if (object =3D=3D=3D null) return 'null';=0A=
      return object.inspect ? object.inspect() : object.toString();=0A=
    } catch (e) {=0A=
      if (e instanceof RangeError) return '...';=0A=
      throw e;=0A=
    }=0A=
  },=0A=
=0A=
  toJSON: function(object) {=0A=
    var type =3D typeof object;=0A=
    switch (type) {=0A=
      case 'undefined':=0A=
      case 'function':=0A=
      case 'unknown': return;=0A=
      case 'boolean': return object.toString();=0A=
    }=0A=
=0A=
    if (object =3D=3D=3D null) return 'null';=0A=
    if (object.toJSON) return object.toJSON();=0A=
    if (Object.isElement(object)) return;=0A=
=0A=
    var results =3D [];=0A=
    for (var property in object) {=0A=
      var value =3D Object.toJSON(object[property]);=0A=
      if (!Object.isUndefined(value))=0A=
        results.push(property.toJSON() + ': ' + value);=0A=
    }=0A=
=0A=
    return '{' + results.join(', ') + '}';=0A=
  },=0A=
=0A=
  toQueryString: function(object) {=0A=
    return $H(object).toQueryString();=0A=
  },=0A=
=0A=
  toHTML: function(object) {=0A=
    return object && object.toHTML ? object.toHTML() : =
String.interpret(object);=0A=
  },=0A=
=0A=
  keys: function(object) {=0A=
    var keys =3D [];=0A=
    for (var property in object)=0A=
      keys.push(property);=0A=
    return keys;=0A=
  },=0A=
=0A=
  values: function(object) {=0A=
    var values =3D [];=0A=
    for (var property in object)=0A=
      values.push(object[property]);=0A=
    return values;=0A=
  },=0A=
=0A=
  clone: function(object) {=0A=
    return Object.extend({ }, object);=0A=
  },=0A=
=0A=
  isElement: function(object) {=0A=
    return object && object.nodeType =3D=3D 1;=0A=
  },=0A=
=0A=
  isArray: function(object) {=0A=
    return object && object.constructor =3D=3D=3D Array;=0A=
  },=0A=
=0A=
  isHash: function(object) {=0A=
    return object instanceof Hash;=0A=
  },=0A=
=0A=
  isFunction: function(object) {=0A=
    return typeof object =3D=3D "function";=0A=
  },=0A=
=0A=
  isString: function(object) {=0A=
    return typeof object =3D=3D "string";=0A=
  },=0A=
=0A=
  isNumber: function(object) {=0A=
    return typeof object =3D=3D "number";=0A=
  },=0A=
=0A=
  isUndefined: function(object) {=0A=
    return typeof object =3D=3D "undefined";=0A=
  }=0A=
});=0A=
=0A=
Object.extend(Function.prototype, {=0A=
  argumentNames: function() {=0A=
    var names =3D =
this.toString().match(/^[\s\(]*function[^(]*\((.*?)\)/)[1].split(",").inv=
oke("strip");=0A=
    return names.length =3D=3D 1 && !names[0] ? [] : names;=0A=
  },=0A=
=0A=
  bind: function() {=0A=
    if (arguments.length < 2 && Object.isUndefined(arguments[0])) return =
this;=0A=
    var __method =3D this, args =3D $A(arguments), object =3D =
args.shift();=0A=
    return function() {=0A=
      return __method.apply(object, args.concat($A(arguments)));=0A=
    }=0A=
  },=0A=
=0A=
  bindAsEventListener: function() {=0A=
    var __method =3D this, args =3D $A(arguments), object =3D =
args.shift();=0A=
    return function(event) {=0A=
      return __method.apply(object, [event || =
window.event].concat(args));=0A=
    }=0A=
  },=0A=
=0A=
  curry: function() {=0A=
    if (!arguments.length) return this;=0A=
    var __method =3D this, args =3D $A(arguments);=0A=
    return function() {=0A=
      return __method.apply(this, args.concat($A(arguments)));=0A=
    }=0A=
  },=0A=
=0A=
  delay: function() {=0A=
    var __method =3D this, args =3D $A(arguments), timeout =3D =
args.shift() * 1000;=0A=
    return window.setTimeout(function() {=0A=
      return __method.apply(__method, args);=0A=
    }, timeout);=0A=
  },=0A=
=0A=
  wrap: function(wrapper) {=0A=
    var __method =3D this;=0A=
    return function() {=0A=
      return wrapper.apply(this, =
[__method.bind(this)].concat($A(arguments)));=0A=
    }=0A=
  },=0A=
=0A=
  methodize: function() {=0A=
    if (this._methodized) return this._methodized;=0A=
    var __method =3D this;=0A=
    return this._methodized =3D function() {=0A=
      return __method.apply(null, [this].concat($A(arguments)));=0A=
    };=0A=
  }=0A=
});=0A=
=0A=
Function.prototype.defer =3D Function.prototype.delay.curry(0.01);=0A=
=0A=
Date.prototype.toJSON =3D function() {=0A=
  return '"' + this.getUTCFullYear() + '-' +=0A=
    (this.getUTCMonth() + 1).toPaddedString(2) + '-' +=0A=
    this.getUTCDate().toPaddedString(2) + 'T' +=0A=
    this.getUTCHours().toPaddedString(2) + ':' +=0A=
    this.getUTCMinutes().toPaddedString(2) + ':' +=0A=
    this.getUTCSeconds().toPaddedString(2) + 'Z"';=0A=
};=0A=
=0A=
var Try =3D {=0A=
  these: function() {=0A=
    var returnValue;=0A=
=0A=
    for (var i =3D 0, length =3D arguments.length; i < length; i++) {=0A=
      var lambda =3D arguments[i];=0A=
      try {=0A=
        returnValue =3D lambda();=0A=
        break;=0A=
      } catch (e) { }=0A=
    }=0A=
=0A=
    return returnValue;=0A=
  }=0A=
};=0A=
=0A=
RegExp.prototype.match =3D RegExp.prototype.test;=0A=
=0A=
RegExp.escape =3D function(str) {=0A=
  return String(str).replace(/([.*+?^=3D!:${}()|[\]\/\\])/g, '\\$1');=0A=
};=0A=
=0A=
/*-----------------------------------------------------------------------=
---*/=0A=
=0A=
var PeriodicalExecuter =3D Class.create({=0A=
  initialize: function(callback, frequency) {=0A=
    this.callback =3D callback;=0A=
    this.frequency =3D frequency;=0A=
    this.currentlyExecuting =3D false;=0A=
=0A=
    this.registerCallback();=0A=
  },=0A=
=0A=
  registerCallback: function() {=0A=
    this.timer =3D setInterval(this.onTimerEvent.bind(this), =
this.frequency * 1000);=0A=
  },=0A=
=0A=
  execute: function() {=0A=
    this.callback(this);=0A=
  },=0A=
=0A=
  stop: function() {=0A=
    if (!this.timer) return;=0A=
    clearInterval(this.timer);=0A=
    this.timer =3D null;=0A=
  },=0A=
=0A=
  onTimerEvent: function() {=0A=
    if (!this.currentlyExecuting) {=0A=
      try {=0A=
        this.currentlyExecuting =3D true;=0A=
        this.execute();=0A=
      } finally {=0A=
        this.currentlyExecuting =3D false;=0A=
      }=0A=
    }=0A=
  }=0A=
});=0A=
Object.extend(String, {=0A=
  interpret: function(value) {=0A=
    return value =3D=3D null ? '' : String(value);=0A=
  },=0A=
  specialChar: {=0A=
    '\b': '\\b',=0A=
    '\t': '\\t',=0A=
    '\n': '\\n',=0A=
    '\f': '\\f',=0A=
    '\r': '\\r',=0A=
    '\\': '\\\\'=0A=
  }=0A=
});=0A=
=0A=
Object.extend(String.prototype, {=0A=
  gsub: function(pattern, replacement) {=0A=
    var result =3D '', source =3D this, match;=0A=
    replacement =3D arguments.callee.prepareReplacement(replacement);=0A=
=0A=
    while (source.length > 0) {=0A=
      if (match =3D source.match(pattern)) {=0A=
        result +=3D source.slice(0, match.index);=0A=
        result +=3D String.interpret(replacement(match));=0A=
        source  =3D source.slice(match.index + match[0].length);=0A=
      } else {=0A=
        result +=3D source, source =3D '';=0A=
      }=0A=
    }=0A=
    return result;=0A=
  },=0A=
=0A=
  sub: function(pattern, replacement, count) {=0A=
    replacement =3D this.gsub.prepareReplacement(replacement);=0A=
    count =3D Object.isUndefined(count) ? 1 : count;=0A=
=0A=
    return this.gsub(pattern, function(match) {=0A=
      if (--count < 0) return match[0];=0A=
      return replacement(match);=0A=
    });=0A=
  },=0A=
=0A=
  scan: function(pattern, iterator) {=0A=
    this.gsub(pattern, iterator);=0A=
    return String(this);=0A=
  },=0A=
=0A=
  truncate: function(length, truncation) {=0A=
    length =3D length || 30;=0A=
    truncation =3D Object.isUndefined(truncation) ? '...' : truncation;=0A=
    return this.length > length ?=0A=
      this.slice(0, length - truncation.length) + truncation : =
String(this);=0A=
  },=0A=
=0A=
  strip: function() {=0A=
    return this.replace(/^\s+/, '').replace(/\s+$/, '');=0A=
  },=0A=
=0A=
  stripTags: function() {=0A=
    return this.replace(/<\/?[^>]+>/gi, '');=0A=
  },=0A=
=0A=
  stripScripts: function() {=0A=
    return this.replace(new RegExp(Prototype.ScriptFragment, 'img'), '');=0A=
  },=0A=
=0A=
  extractScripts: function() {=0A=
    var matchAll =3D new RegExp(Prototype.ScriptFragment, 'img');=0A=
    var matchOne =3D new RegExp(Prototype.ScriptFragment, 'im');=0A=
    return (this.match(matchAll) || []).map(function(scriptTag) {=0A=
      return (scriptTag.match(matchOne) || ['', ''])[1];=0A=
    });=0A=
  },=0A=
=0A=
  evalScripts: function() {=0A=
    return this.extractScripts().map(function(script) { return =
eval(script) });=0A=
  },=0A=
=0A=
  escapeHTML: function() {=0A=
    var self =3D arguments.callee;=0A=
    self.text.data =3D this;=0A=
    return self.div.innerHTML;=0A=
  },=0A=
=0A=
  unescapeHTML: function() {=0A=
    var div =3D new Element('div');=0A=
    div.innerHTML =3D this.stripTags();=0A=
    return div.childNodes[0] ? (div.childNodes.length > 1 ?=0A=
      $A(div.childNodes).inject('', function(memo, node) { return =
memo+node.nodeValue }) :=0A=
      div.childNodes[0].nodeValue) : '';=0A=
  },=0A=
=0A=
  toQueryParams: function(separator) {=0A=
    var match =3D this.strip().match(/([^?#]*)(#.*)?$/);=0A=
    if (!match) return { };=0A=
=0A=
    return match[1].split(separator || '&').inject({ }, function(hash, =
pair) {=0A=
      if ((pair =3D pair.split('=3D'))[0]) {=0A=
        var key =3D decodeURIComponent(pair.shift());=0A=
        var value =3D pair.length > 1 ? pair.join('=3D') : pair[0];=0A=
        if (value !=3D undefined) value =3D decodeURIComponent(value);=0A=
=0A=
        if (key in hash) {=0A=
          if (!Object.isArray(hash[key])) hash[key] =3D [hash[key]];=0A=
          hash[key].push(value);=0A=
        }=0A=
        else hash[key] =3D value;=0A=
      }=0A=
      return hash;=0A=
    });=0A=
  },=0A=
=0A=
  toArray: function() {=0A=
    return this.split('');=0A=
  },=0A=
=0A=
  succ: function() {=0A=
    return this.slice(0, this.length - 1) +=0A=
      String.fromCharCode(this.charCodeAt(this.length - 1) + 1);=0A=
  },=0A=
=0A=
  times: function(count) {=0A=
    return count < 1 ? '' : new Array(count + 1).join(this);=0A=
  },=0A=
=0A=
  camelize: function() {=0A=
    var parts =3D this.split('-'), len =3D parts.length;=0A=
    if (len =3D=3D 1) return parts[0];=0A=
=0A=
    var camelized =3D this.charAt(0) =3D=3D '-'=0A=
      ? parts[0].charAt(0).toUpperCase() + parts[0].substring(1)=0A=
      : parts[0];=0A=
=0A=
    for (var i =3D 1; i < len; i++)=0A=
      camelized +=3D parts[i].charAt(0).toUpperCase() + =
parts[i].substring(1);=0A=
=0A=
    return camelized;=0A=
  },=0A=
=0A=
  capitalize: function() {=0A=
    return this.charAt(0).toUpperCase() + =
this.substring(1).toLowerCase();=0A=
  },=0A=
=0A=
  underscore: function() {=0A=
    return this.gsub(/::/, =
'/').gsub(/([A-Z]+)([A-Z][a-z])/,'#{1}_#{2}').gsub(/([a-z\d])([A-Z])/,'#{=
1}_#{2}').gsub(/-/,'_').toLowerCase();=0A=
  },=0A=
=0A=
  dasherize: function() {=0A=
    return this.gsub(/_/,'-');=0A=
  },=0A=
=0A=
  inspect: function(useDoubleQuotes) {=0A=
    var escapedString =3D this.gsub(/[\x00-\x1f\\]/, function(match) {=0A=
      var character =3D String.specialChar[match[0]];=0A=
      return character ? character : '\\u00' + =
match[0].charCodeAt().toPaddedString(2, 16);=0A=
    });=0A=
    if (useDoubleQuotes) return '"' + escapedString.replace(/"/g, '\\"') =
+ '"';=0A=
    return "'" + escapedString.replace(/'/g, '\\\'') + "'";=0A=
  },=0A=
=0A=
  toJSON: function() {=0A=
    return this.inspect(true);=0A=
  },=0A=
=0A=
  unfilterJSON: function(filter) {=0A=
    return this.sub(filter || Prototype.JSONFilter, '#{1}');=0A=
  },=0A=
=0A=
  isJSON: function() {=0A=
    var str =3D this;=0A=
    if (str.blank()) return false;=0A=
    str =3D this.replace(/\\./g, '@').replace(/"[^"\\\n\r]*"/g, '');=0A=
    return (/^[,:{}\[\]0-9.\-+Eaeflnr-u \n\r\t]*$/).test(str);=0A=
  },=0A=
=0A=
  evalJSON: function(sanitize) {=0A=
    var json =3D this.unfilterJSON();=0A=
    try {=0A=
      if (!sanitize || json.isJSON()) return eval('(' + json + ')');=0A=
    } catch (e) { }=0A=
    throw new SyntaxError('Badly formed JSON string: ' + this.inspect());=0A=
  },=0A=
=0A=
  include: function(pattern) {=0A=
    return this.indexOf(pattern) > -1;=0A=
  },=0A=
=0A=
  startsWith: function(pattern) {=0A=
    return this.indexOf(pattern) =3D=3D=3D 0;=0A=
  },=0A=
=0A=
  endsWith: function(pattern) {=0A=
    var d =3D this.length - pattern.length;=0A=
    return d >=3D 0 && this.lastIndexOf(pattern) =3D=3D=3D d;=0A=
  },=0A=
=0A=
  empty: function() {=0A=
    return this =3D=3D '';=0A=
  },=0A=
=0A=
  blank: function() {=0A=
    return /^\s*$/.test(this);=0A=
  },=0A=
=0A=
  interpolate: function(object, pattern) {=0A=
    return new Template(this, pattern).evaluate(object);=0A=
  }=0A=
});=0A=
=0A=
if (Prototype.Browser.WebKit || Prototype.Browser.IE) =
Object.extend(String.prototype, {=0A=
  escapeHTML: function() {=0A=
    return =
this.replace(/&/g,'&amp;').replace(/</g,'&lt;').replace(/>/g,'&gt;');=0A=
  },=0A=
  unescapeHTML: function() {=0A=
    return =
this.replace(/&amp;/g,'&').replace(/&lt;/g,'<').replace(/&gt;/g,'>');=0A=
  }=0A=
});=0A=
=0A=
String.prototype.gsub.prepareReplacement =3D function(replacement) {=0A=
  if (Object.isFunction(replacement)) return replacement;=0A=
  var template =3D new Template(replacement);=0A=
  return function(match) { return template.evaluate(match) };=0A=
};=0A=
=0A=
String.prototype.parseQuery =3D String.prototype.toQueryParams;=0A=
=0A=
Object.extend(String.prototype.escapeHTML, {=0A=
  div:  document.createElement('div'),=0A=
  text: document.createTextNode('')=0A=
});=0A=
=0A=
with (String.prototype.escapeHTML) div.appendChild(text);=0A=
=0A=
var Template =3D Class.create({=0A=
  initialize: function(template, pattern) {=0A=
    this.template =3D template.toString();=0A=
    this.pattern =3D pattern || Template.Pattern;=0A=
  },=0A=
=0A=
  evaluate: function(object) {=0A=
    if (Object.isFunction(object.toTemplateReplacements))=0A=
      object =3D object.toTemplateReplacements();=0A=
=0A=
    return this.template.gsub(this.pattern, function(match) {=0A=
      if (object =3D=3D null) return '';=0A=
=0A=
      var before =3D match[1] || '';=0A=
      if (before =3D=3D '\\') return match[2];=0A=
=0A=
      var ctx =3D object, expr =3D match[3];=0A=
      var pattern =3D /^([^.[]+|\[((?:.*?[^\\])?)\])(\.|\[|$)/;=0A=
      match =3D pattern.exec(expr);=0A=
      if (match =3D=3D null) return before;=0A=
=0A=
      while (match !=3D null) {=0A=
        var comp =3D match[1].startsWith('[') ? match[2].gsub('\\\\]', =
']') : match[1];=0A=
        ctx =3D ctx[comp];=0A=
        if (null =3D=3D ctx || '' =3D=3D match[3]) break;=0A=
        expr =3D expr.substring('[' =3D=3D match[3] ? match[1].length : =
match[0].length);=0A=
        match =3D pattern.exec(expr);=0A=
      }=0A=
=0A=
      return before + String.interpret(ctx);=0A=
    }.bind(this));=0A=
  }=0A=
});=0A=
Template.Pattern =3D /(^|.|\r|\n)(#\{(.*?)\})/;=0A=
=0A=
var $break =3D { };=0A=
=0A=
var Enumerable =3D {=0A=
  each: function(iterator, context) {=0A=
    var index =3D 0;=0A=
    iterator =3D iterator.bind(context);=0A=
    try {=0A=
      this._each(function(value) {=0A=
        iterator(value, index++);=0A=
      });=0A=
    } catch (e) {=0A=
      if (e !=3D $break) throw e;=0A=
    }=0A=
    return this;=0A=
  },=0A=
=0A=
  eachSlice: function(number, iterator, context) {=0A=
    iterator =3D iterator ? iterator.bind(context) : Prototype.K;=0A=
    var index =3D -number, slices =3D [], array =3D this.toArray();=0A=
    while ((index +=3D number) < array.length)=0A=
      slices.push(array.slice(index, index+number));=0A=
    return slices.collect(iterator, context);=0A=
  },=0A=
=0A=
  all: function(iterator, context) {=0A=
    iterator =3D iterator ? iterator.bind(context) : Prototype.K;=0A=
    var result =3D true;=0A=
    this.each(function(value, index) {=0A=
      result =3D result && !!iterator(value, index);=0A=
      if (!result) throw $break;=0A=
    });=0A=
    return result;=0A=
  },=0A=
=0A=
  any: function(iterator, context) {=0A=
    iterator =3D iterator ? iterator.bind(context) : Prototype.K;=0A=
    var result =3D false;=0A=
    this.each(function(value, index) {=0A=
      if (result =3D !!iterator(value, index))=0A=
        throw $break;=0A=
    });=0A=
    return result;=0A=
  },=0A=
=0A=
  collect: function(iterator, context) {=0A=
    iterator =3D iterator ? iterator.bind(context) : Prototype.K;=0A=
    var results =3D [];=0A=
    this.each(function(value, index) {=0A=
      results.push(iterator(value, index));=0A=
    });=0A=
    return results;=0A=
  },=0A=
=0A=
  detect: function(iterator, context) {=0A=
    iterator =3D iterator.bind(context);=0A=
    var result;=0A=
    this.each(function(value, index) {=0A=
      if (iterator(value, index)) {=0A=
        result =3D value;=0A=
        throw $break;=0A=
      }=0A=
    });=0A=
    return result;=0A=
  },=0A=
=0A=
  findAll: function(iterator, context) {=0A=
    iterator =3D iterator.bind(context);=0A=
    var results =3D [];=0A=
    this.each(function(value, index) {=0A=
      if (iterator(value, index))=0A=
        results.push(value);=0A=
    });=0A=
    return results;=0A=
  },=0A=
=0A=
  grep: function(filter, iterator, context) {=0A=
    iterator =3D iterator ? iterator.bind(context) : Prototype.K;=0A=
    var results =3D [];=0A=
=0A=
    if (Object.isString(filter))=0A=
      filter =3D new RegExp(filter);=0A=
=0A=
    this.each(function(value, index) {=0A=
      if (filter.match(value))=0A=
        results.push(iterator(value, index));=0A=
    });=0A=
    return results;=0A=
  },=0A=
=0A=
  include: function(object) {=0A=
    if (Object.isFunction(this.indexOf))=0A=
      if (this.indexOf(object) !=3D -1) return true;=0A=
=0A=
    var found =3D false;=0A=
    this.each(function(value) {=0A=
      if (value =3D=3D object) {=0A=
        found =3D true;=0A=
        throw $break;=0A=
      }=0A=
    });=0A=
    return found;=0A=
  },=0A=
=0A=
  inGroupsOf: function(number, fillWith) {=0A=
    fillWith =3D Object.isUndefined(fillWith) ? null : fillWith;=0A=
    return this.eachSlice(number, function(slice) {=0A=
      while(slice.length < number) slice.push(fillWith);=0A=
      return slice;=0A=
    });=0A=
  },=0A=
=0A=
  inject: function(memo, iterator, context) {=0A=
    iterator =3D iterator.bind(context);=0A=
    this.each(function(value, index) {=0A=
      memo =3D iterator(memo, value, index);=0A=
    });=0A=
    return memo;=0A=
  },=0A=
=0A=
  invoke: function(method) {=0A=
    var args =3D $A(arguments).slice(1);=0A=
    return this.map(function(value) {=0A=
      return value[method].apply(value, args);=0A=
    });=0A=
  },=0A=
=0A=
  max: function(iterator, context) {=0A=
    iterator =3D iterator ? iterator.bind(context) : Prototype.K;=0A=
    var result;=0A=
    this.each(function(value, index) {=0A=
      value =3D iterator(value, index);=0A=
      if (result =3D=3D null || value >=3D result)=0A=
        result =3D value;=0A=
    });=0A=
    return result;=0A=
  },=0A=
=0A=
  min: function(iterator, context) {=0A=
    iterator =3D iterator ? iterator.bind(context) : Prototype.K;=0A=
    var result;=0A=
    this.each(function(value, index) {=0A=
      value =3D iterator(value, index);=0A=
      if (result =3D=3D null || value < result)=0A=
        result =3D value;=0A=
    });=0A=
    return result;=0A=
  },=0A=
=0A=
  partition: function(iterator, context) {=0A=
    iterator =3D iterator ? iterator.bind(context) : Prototype.K;=0A=
    var trues =3D [], falses =3D [];=0A=
    this.each(function(value, index) {=0A=
      (iterator(value, index) ?=0A=
        trues : falses).push(value);=0A=
    });=0A=
    return [trues, falses];=0A=
  },=0A=
=0A=
  pluck: function(property) {=0A=
    var results =3D [];=0A=
    this.each(function(value) {=0A=
      results.push(value[property]);=0A=
    });=0A=
    return results;=0A=
  },=0A=
=0A=
  reject: function(iterator, context) {=0A=
    iterator =3D iterator.bind(context);=0A=
    var results =3D [];=0A=
    this.each(function(value, index) {=0A=
      if (!iterator(value, index))=0A=
        results.push(value);=0A=
    });=0A=
    return results;=0A=
  },=0A=
=0A=
  sortBy: function(iterator, context) {=0A=
    iterator =3D iterator.bind(context);=0A=
    return this.map(function(value, index) {=0A=
      return {value: value, criteria: iterator(value, index)};=0A=
    }).sort(function(left, right) {=0A=
      var a =3D left.criteria, b =3D right.criteria;=0A=
      return a < b ? -1 : a > b ? 1 : 0;=0A=
    }).pluck('value');=0A=
  },=0A=
=0A=
  toArray: function() {=0A=
    return this.map();=0A=
  },=0A=
=0A=
  zip: function() {=0A=
    var iterator =3D Prototype.K, args =3D $A(arguments);=0A=
    if (Object.isFunction(args.last()))=0A=
      iterator =3D args.pop();=0A=
=0A=
    var collections =3D [this].concat(args).map($A);=0A=
    return this.map(function(value, index) {=0A=
      return iterator(collections.pluck(index));=0A=
    });=0A=
  },=0A=
=0A=
  size: function() {=0A=
    return this.toArray().length;=0A=
  },=0A=
=0A=
  inspect: function() {=0A=
    return '#<Enumerable:' + this.toArray().inspect() + '>';=0A=
  }=0A=
};=0A=
=0A=
Object.extend(Enumerable, {=0A=
  map:     Enumerable.collect,=0A=
  find:    Enumerable.detect,=0A=
  select:  Enumerable.findAll,=0A=
  filter:  Enumerable.findAll,=0A=
  member:  Enumerable.include,=0A=
  entries: Enumerable.toArray,=0A=
  every:   Enumerable.all,=0A=
  some:    Enumerable.any=0A=
});=0A=
function $A(iterable) {=0A=
  if (!iterable) return [];=0A=
  if (iterable.toArray) return iterable.toArray();=0A=
  var length =3D iterable.length, results =3D new Array(length);=0A=
  while (length--) results[length] =3D iterable[length];=0A=
  return results;=0A=
}=0A=
=0A=
if (Prototype.Browser.WebKit) {=0A=
  function $A(iterable) {=0A=
    if (!iterable) return [];=0A=
    if (!(Object.isFunction(iterable) && iterable =3D=3D '[object =
NodeList]') &&=0A=
        iterable.toArray) return iterable.toArray();=0A=
    var length =3D iterable.length, results =3D new Array(length);=0A=
    while (length--) results[length] =3D iterable[length];=0A=
    return results;=0A=
  }=0A=
}=0A=
=0A=
Array.from =3D $A;=0A=
=0A=
Object.extend(Array.prototype, Enumerable);=0A=
=0A=
if (!Array.prototype._reverse) Array.prototype._reverse =3D =
Array.prototype.reverse;=0A=
=0A=
Object.extend(Array.prototype, {=0A=
  _each: function(iterator) {=0A=
    for (var i =3D 0, length =3D this.length; i < length; i++)=0A=
      iterator(this[i]);=0A=
  },=0A=
=0A=
  clear: function() {=0A=
    this.length =3D 0;=0A=
    return this;=0A=
  },=0A=
=0A=
  first: function() {=0A=
    return this[0];=0A=
  },=0A=
=0A=
  last: function() {=0A=
    return this[this.length - 1];=0A=
  },=0A=
=0A=
  compact: function() {=0A=
    return this.select(function(value) {=0A=
      return value !=3D null;=0A=
    });=0A=
  },=0A=
=0A=
  flatten: function() {=0A=
    return this.inject([], function(array, value) {=0A=
      return array.concat(Object.isArray(value) ?=0A=
        value.flatten() : [value]);=0A=
    });=0A=
  },=0A=
=0A=
  without: function() {=0A=
    var values =3D $A(arguments);=0A=
    return this.select(function(value) {=0A=
      return !values.include(value);=0A=
    });=0A=
  },=0A=
=0A=
  reverse: function(inline) {=0A=
    return (inline !=3D=3D false ? this : this.toArray())._reverse();=0A=
  },=0A=
=0A=
  reduce: function() {=0A=
    return this.length > 1 ? this : this[0];=0A=
  },=0A=
=0A=
  uniq: function(sorted) {=0A=
    return this.inject([], function(array, value, index) {=0A=
      if (0 =3D=3D index || (sorted ? array.last() !=3D value : =
!array.include(value)))=0A=
        array.push(value);=0A=
      return array;=0A=
    });=0A=
  },=0A=
=0A=
  intersect: function(array) {=0A=
    return this.uniq().findAll(function(item) {=0A=
      return array.detect(function(value) { return item =3D=3D=3D value =
});=0A=
    });=0A=
  },=0A=
=0A=
  clone: function() {=0A=
    return [].concat(this);=0A=
  },=0A=
=0A=
  size: function() {=0A=
    return this.length;=0A=
  },=0A=
=0A=
  inspect: function() {=0A=
    return '[' + this.map(Object.inspect).join(', ') + ']';=0A=
  },=0A=
=0A=
  toJSON: function() {=0A=
    var results =3D [];=0A=
    this.each(function(object) {=0A=
      var value =3D Object.toJSON(object);=0A=
      if (!Object.isUndefined(value)) results.push(value);=0A=
    });=0A=
    return '[' + results.join(', ') + ']';=0A=
  }=0A=
});=0A=
=0A=
// use native browser JS 1.6 implementation if available=0A=
if (Object.isFunction(Array.prototype.forEach))=0A=
  Array.prototype._each =3D Array.prototype.forEach;=0A=
=0A=
if (!Array.prototype.indexOf) Array.prototype.indexOf =3D function(item, =
i) {=0A=
  i || (i =3D 0);=0A=
  var length =3D this.length;=0A=
  if (i < 0) i =3D length + i;=0A=
  for (; i < length; i++)=0A=
    if (this[i] =3D=3D=3D item) return i;=0A=
  return -1;=0A=
};=0A=
=0A=
if (!Array.prototype.lastIndexOf) Array.prototype.lastIndexOf =3D =
function(item, i) {=0A=
  i =3D isNaN(i) ? this.length : (i < 0 ? this.length + i : i) + 1;=0A=
  var n =3D this.slice(0, i).reverse().indexOf(item);=0A=
  return (n < 0) ? n : i - n - 1;=0A=
};=0A=
=0A=
Array.prototype.toArray =3D Array.prototype.clone;=0A=
=0A=
function $w(string) {=0A=
  if (!Object.isString(string)) return [];=0A=
  string =3D string.strip();=0A=
  return string ? string.split(/\s+/) : [];=0A=
}=0A=
=0A=
if (Prototype.Browser.Opera){=0A=
  Array.prototype.concat =3D function() {=0A=
    var array =3D [];=0A=
    for (var i =3D 0, length =3D this.length; i < length; i++) =
array.push(this[i]);=0A=
    for (var i =3D 0, length =3D arguments.length; i < length; i++) {=0A=
      if (Object.isArray(arguments[i])) {=0A=
        for (var j =3D 0, arrayLength =3D arguments[i].length; j < =
arrayLength; j++)=0A=
          array.push(arguments[i][j]);=0A=
      } else {=0A=
        array.push(arguments[i]);=0A=
      }=0A=
    }=0A=
    return array;=0A=
  };=0A=
}=0A=
Object.extend(Number.prototype, {=0A=
  toColorPart: function() {=0A=
    return this.toPaddedString(2, 16);=0A=
  },=0A=
=0A=
  succ: function() {=0A=
    return this + 1;=0A=
  },=0A=
=0A=
  times: function(iterator) {=0A=
    $R(0, this, true).each(iterator);=0A=
    return this;=0A=
  },=0A=
=0A=
  toPaddedString: function(length, radix) {=0A=
    var string =3D this.toString(radix || 10);=0A=
    return '0'.times(length - string.length) + string;=0A=
  },=0A=
=0A=
  toJSON: function() {=0A=
    return isFinite(this) ? this.toString() : 'null';=0A=
  }=0A=
});=0A=
=0A=
$w('abs round ceil floor').each(function(method){=0A=
  Number.prototype[method] =3D Math[method].methodize();=0A=
});=0A=
function $H(object) {=0A=
  return new Hash(object);=0A=
};=0A=
=0A=
var Hash =3D Class.create(Enumerable, (function() {=0A=
=0A=
  function toQueryPair(key, value) {=0A=
    if (Object.isUndefined(value)) return key;=0A=
    return key + '=3D' + encodeURIComponent(String.interpret(value));=0A=
  }=0A=
=0A=
  return {=0A=
    initialize: function(object) {=0A=
      this._object =3D Object.isHash(object) ? object.toObject() : =
Object.clone(object);=0A=
    },=0A=
=0A=
    _each: function(iterator) {=0A=
      for (var key in this._object) {=0A=
        var value =3D this._object[key], pair =3D [key, value];=0A=
        pair.key =3D key;=0A=
        pair.value =3D value;=0A=
        iterator(pair);=0A=
      }=0A=
    },=0A=
=0A=
    set: function(key, value) {=0A=
      return this._object[key] =3D value;=0A=
    },=0A=
=0A=
    get: function(key) {=0A=
      return this._object[key];=0A=
    },=0A=
=0A=
    unset: function(key) {=0A=
      var value =3D this._object[key];=0A=
      delete this._object[key];=0A=
      return value;=0A=
    },=0A=
=0A=
    toObject: function() {=0A=
      return Object.clone(this._object);=0A=
    },=0A=
=0A=
    keys: function() {=0A=
      return this.pluck('key');=0A=
    },=0A=
=0A=
    values: function() {=0A=
      return this.pluck('value');=0A=
    },=0A=
=0A=
    index: function(value) {=0A=
      var match =3D this.detect(function(pair) {=0A=
        return pair.value =3D=3D=3D value;=0A=
      });=0A=
      return match && match.key;=0A=
    },=0A=
=0A=
    merge: function(object) {=0A=
      return this.clone().update(object);=0A=
    },=0A=
=0A=
    update: function(object) {=0A=
      return new Hash(object).inject(this, function(result, pair) {=0A=
        result.set(pair.key, pair.value);=0A=
        return result;=0A=
      });=0A=
    },=0A=
=0A=
    toQueryString: function() {=0A=
      return this.map(function(pair) {=0A=
        var key =3D encodeURIComponent(pair.key), values =3D pair.value;=0A=
=0A=
        if (values && typeof values =3D=3D 'object') {=0A=
          if (Object.isArray(values))=0A=
            return values.map(toQueryPair.curry(key)).join('&');=0A=
        }=0A=
        return toQueryPair(key, values);=0A=
      }).join('&');=0A=
    },=0A=
=0A=
    inspect: function() {=0A=
      return '#<Hash:{' + this.map(function(pair) {=0A=
        return pair.map(Object.inspect).join(': ');=0A=
      }).join(', ') + '}>';=0A=
    },=0A=
=0A=
    toJSON: function() {=0A=
      return Object.toJSON(this.toObject());=0A=
    },=0A=
=0A=
    clone: function() {=0A=
      return new Hash(this);=0A=
    }=0A=
  }=0A=
})());=0A=
=0A=
Hash.prototype.toTemplateReplacements =3D Hash.prototype.toObject;=0A=
Hash.from =3D $H;=0A=
var ObjectRange =3D Class.create(Enumerable, {=0A=
  initialize: function(start, end, exclusive) {=0A=
    this.start =3D start;=0A=
    this.end =3D end;=0A=
    this.exclusive =3D exclusive;=0A=
  },=0A=
=0A=
  _each: function(iterator) {=0A=
    var value =3D this.start;=0A=
    while (this.include(value)) {=0A=
      iterator(value);=0A=
      value =3D value.succ();=0A=
    }=0A=
  },=0A=
=0A=
  include: function(value) {=0A=
    if (value < this.start)=0A=
      return false;=0A=
    if (this.exclusive)=0A=
      return value < this.end;=0A=
    return value <=3D this.end;=0A=
  }=0A=
});=0A=
=0A=
var $R =3D function(start, end, exclusive) {=0A=
  return new ObjectRange(start, end, exclusive);=0A=
};=0A=
=0A=
var Ajax =3D {=0A=
  getTransport: function() {=0A=
    return Try.these(=0A=
      function() {return new XMLHttpRequest()},=0A=
      function() {return new ActiveXObject('Msxml2.XMLHTTP')},=0A=
      function() {return new ActiveXObject('Microsoft.XMLHTTP')}=0A=
    ) || false;=0A=
  },=0A=
=0A=
  activeRequestCount: 0=0A=
};=0A=
=0A=
Ajax.Responders =3D {=0A=
  responders: [],=0A=
=0A=
  _each: function(iterator) {=0A=
    this.responders._each(iterator);=0A=
  },=0A=
=0A=
  register: function(responder) {=0A=
    if (!this.include(responder))=0A=
      this.responders.push(responder);=0A=
  },=0A=
=0A=
  unregister: function(responder) {=0A=
    this.responders =3D this.responders.without(responder);=0A=
  },=0A=
=0A=
  dispatch: function(callback, request, transport, json) {=0A=
    this.each(function(responder) {=0A=
      if (Object.isFunction(responder[callback])) {=0A=
        try {=0A=
          responder[callback].apply(responder, [request, transport, =
json]);=0A=
        } catch (e) { }=0A=
      }=0A=
    });=0A=
  }=0A=
};=0A=
=0A=
Object.extend(Ajax.Responders, Enumerable);=0A=
=0A=
Ajax.Responders.register({=0A=
  onCreate:   function() { Ajax.activeRequestCount++ },=0A=
  onComplete: function() { Ajax.activeRequestCount-- }=0A=
});=0A=
=0A=
Ajax.Base =3D Class.create({=0A=
  initialize: function(options) {=0A=
    this.options =3D {=0A=
      method:       'post',=0A=
      asynchronous: true,=0A=
      contentType:  'application/x-www-form-urlencoded',=0A=
      encoding:     'UTF-8',=0A=
      parameters:   '',=0A=
      evalJSON:     true,=0A=
      evalJS:       true=0A=
    };=0A=
    Object.extend(this.options, options || { });=0A=
=0A=
    this.options.method =3D this.options.method.toLowerCase();=0A=
=0A=
    if (Object.isString(this.options.parameters))=0A=
      this.options.parameters =3D =
this.options.parameters.toQueryParams();=0A=
    else if (Object.isHash(this.options.parameters))=0A=
      this.options.parameters =3D this.options.parameters.toObject();=0A=
  }=0A=
});=0A=
=0A=
Ajax.Request =3D Class.create(Ajax.Base, {=0A=
  _complete: false,=0A=
=0A=
  initialize: function($super, url, options) {=0A=
    $super(options);=0A=
    this.transport =3D Ajax.getTransport();=0A=
    this.request(url);=0A=
  },=0A=
=0A=
  request: function(url) {=0A=
    this.url =3D url;=0A=
    this.method =3D this.options.method;=0A=
    var params =3D Object.clone(this.options.parameters);=0A=
=0A=
    if (!['get', 'post'].include(this.method)) {=0A=
      // simulate other verbs over post=0A=
      params['_method'] =3D this.method;=0A=
      this.method =3D 'post';=0A=
    }=0A=
=0A=
    this.parameters =3D params;=0A=
=0A=
    if (params =3D Object.toQueryString(params)) {=0A=
      // when GET, append parameters to URL=0A=
      if (this.method =3D=3D 'get')=0A=
        this.url +=3D (this.url.include('?') ? '&' : '?') + params;=0A=
      else if (/Konqueror|Safari|KHTML/.test(navigator.userAgent))=0A=
        params +=3D '&_=3D';=0A=
    }=0A=
=0A=
    try {=0A=
      var response =3D new Ajax.Response(this);=0A=
      if (this.options.onCreate) this.options.onCreate(response);=0A=
      Ajax.Responders.dispatch('onCreate', this, response);=0A=
=0A=
      this.transport.open(this.method.toUpperCase(), this.url,=0A=
        this.options.asynchronous);=0A=
=0A=
      if (this.options.asynchronous) =
this.respondToReadyState.bind(this).defer(1);=0A=
=0A=
      this.transport.onreadystatechange =3D =
this.onStateChange.bind(this);=0A=
      this.setRequestHeaders();=0A=
=0A=
      this.body =3D this.method =3D=3D 'post' ? (this.options.postBody =
|| params) : null;=0A=
      this.transport.send(this.body);=0A=
=0A=
      /* Force Firefox to handle ready state 4 for synchronous requests =
*/=0A=
      if (!this.options.asynchronous && this.transport.overrideMimeType)=0A=
        this.onStateChange();=0A=
=0A=
    }=0A=
    catch (e) {=0A=
      this.dispatchException(e);=0A=
    }=0A=
  },=0A=
=0A=
  onStateChange: function() {=0A=
    var readyState =3D this.transport.readyState;=0A=
    if (readyState > 1 && !((readyState =3D=3D 4) && this._complete))=0A=
      this.respondToReadyState(this.transport.readyState);=0A=
  },=0A=
=0A=
  setRequestHeaders: function() {=0A=
    var headers =3D {=0A=
      'X-Requested-With': 'XMLHttpRequest',=0A=
      'X-Prototype-Version': Prototype.Version,=0A=
      'Accept': 'text/javascript, text/html, application/xml, text/xml, =
*/*'=0A=
    };=0A=
=0A=
    if (this.method =3D=3D 'post') {=0A=
      headers['Content-type'] =3D this.options.contentType +=0A=
        (this.options.encoding ? '; charset=3D' + this.options.encoding =
: '');=0A=
=0A=
      /* Force "Connection: close" for older Mozilla browsers to work=0A=
       * around a bug where XMLHttpRequest sends an incorrect=0A=
       * Content-length header. See Mozilla Bugzilla #246651.=0A=
       */=0A=
      if (this.transport.overrideMimeType &&=0A=
          (navigator.userAgent.match(/Gecko\/(\d{4})/) || [0,2005])[1] < =
2005)=0A=
            headers['Connection'] =3D 'close';=0A=
    }=0A=
=0A=
    // user-defined headers=0A=
    if (typeof this.options.requestHeaders =3D=3D 'object') {=0A=
      var extras =3D this.options.requestHeaders;=0A=
=0A=
      if (Object.isFunction(extras.push))=0A=
        for (var i =3D 0, length =3D extras.length; i < length; i +=3D 2)=0A=
          headers[extras[i]] =3D extras[i+1];=0A=
      else=0A=
        $H(extras).each(function(pair) { headers[pair.key] =3D =
pair.value });=0A=
    }=0A=
=0A=
    for (var name in headers)=0A=
      this.transport.setRequestHeader(name, headers[name]);=0A=
  },=0A=
=0A=
  success: function() {=0A=
    var status =3D this.getStatus();=0A=
    return !status || (status >=3D 200 && status < 300);=0A=
  },=0A=
=0A=
  getStatus: function() {=0A=
    try {=0A=
      return this.transport.status || 0;=0A=
    } catch (e) { return 0 }=0A=
  },=0A=
=0A=
  respondToReadyState: function(readyState) {=0A=
    var state =3D Ajax.Request.Events[readyState], response =3D new =
Ajax.Response(this);=0A=
=0A=
    if (state =3D=3D 'Complete') {=0A=
      try {=0A=
        this._complete =3D true;=0A=
        (this.options['on' + response.status]=0A=
         || this.options['on' + (this.success() ? 'Success' : 'Failure')]=0A=
         || Prototype.emptyFunction)(response, response.headerJSON);=0A=
      } catch (e) {=0A=
        this.dispatchException(e);=0A=
      }=0A=
=0A=
      var contentType =3D response.getHeader('Content-type');=0A=
      if (this.options.evalJS =3D=3D 'force'=0A=
          || (this.options.evalJS && contentType=0A=
          && =
contentType.match(/^\s*(text|application)\/(x-)?(java|ecma)script(;.*)?\s=
*$/i)))=0A=
        this.evalResponse();=0A=
    }=0A=
=0A=
    try {=0A=
      (this.options['on' + state] || Prototype.emptyFunction)(response, =
response.headerJSON);=0A=
      Ajax.Responders.dispatch('on' + state, this, response, =
response.headerJSON);=0A=
    } catch (e) {=0A=
      this.dispatchException(e);=0A=
    }=0A=
=0A=
    if (state =3D=3D 'Complete') {=0A=
      // avoid memory leak in MSIE: clean up=0A=
      this.transport.onreadystatechange =3D Prototype.emptyFunction;=0A=
    }=0A=
  },=0A=
=0A=
  getHeader: function(name) {=0A=
    try {=0A=
      return this.transport.getResponseHeader(name);=0A=
    } catch (e) { return null }=0A=
  },=0A=
=0A=
  evalResponse: function() {=0A=
    try {=0A=
      return eval((this.transport.responseText || '').unfilterJSON());=0A=
    } catch (e) {=0A=
      this.dispatchException(e);=0A=
    }=0A=
  },=0A=
=0A=
  dispatchException: function(exception) {=0A=
    (this.options.onException || Prototype.emptyFunction)(this, =
exception);=0A=
    Ajax.Responders.dispatch('onException', this, exception);=0A=
  }=0A=
});=0A=
=0A=
Ajax.Request.Events =3D=0A=
  ['Uninitialized', 'Loading', 'Loaded', 'Interactive', 'Complete'];=0A=
=0A=
Ajax.Response =3D Class.create({=0A=
  initialize: function(request){=0A=
    this.request =3D request;=0A=
    var transport  =3D this.transport  =3D request.transport,=0A=
        readyState =3D this.readyState =3D transport.readyState;=0A=
=0A=
    if((readyState > 2 && !Prototype.Browser.IE) || readyState =3D=3D 4) =
{=0A=
      this.status       =3D this.getStatus();=0A=
      this.statusText   =3D this.getStatusText();=0A=
      this.responseText =3D String.interpret(transport.responseText);=0A=
      this.headerJSON   =3D this._getHeaderJSON();=0A=
    }=0A=
=0A=
    if(readyState =3D=3D 4) {=0A=
      var xml =3D transport.responseXML;=0A=
      this.responseXML  =3D Object.isUndefined(xml) ? null : xml;=0A=
      this.responseJSON =3D this._getResponseJSON();=0A=
    }=0A=
  },=0A=
=0A=
  status:      0,=0A=
  statusText: '',=0A=
=0A=
  getStatus: Ajax.Request.prototype.getStatus,=0A=
=0A=
  getStatusText: function() {=0A=
    try {=0A=
      return this.transport.statusText || '';=0A=
    } catch (e) { return '' }=0A=
  },=0A=
=0A=
  getHeader: Ajax.Request.prototype.getHeader,=0A=
=0A=
  getAllHeaders: function() {=0A=
    try {=0A=
      return this.getAllResponseHeaders();=0A=
    } catch (e) { return null }=0A=
  },=0A=
=0A=
  getResponseHeader: function(name) {=0A=
    return this.transport.getResponseHeader(name);=0A=
  },=0A=
=0A=
  getAllResponseHeaders: function() {=0A=
    return this.transport.getAllResponseHeaders();=0A=
  },=0A=
=0A=
  _getHeaderJSON: function() {=0A=
    var json =3D this.getHeader('X-JSON');=0A=
    if (!json) return null;=0A=
    json =3D decodeURIComponent(escape(json));=0A=
    try {=0A=
      return json.evalJSON(this.request.options.sanitizeJSON);=0A=
    } catch (e) {=0A=
      this.request.dispatchException(e);=0A=
    }=0A=
  },=0A=
=0A=
  _getResponseJSON: function() {=0A=
    var options =3D this.request.options;=0A=
    if (!options.evalJSON || (options.evalJSON !=3D 'force' &&=0A=
      !(this.getHeader('Content-type') || =
'').include('application/json')) ||=0A=
        this.responseText.blank())=0A=
          return null;=0A=
    try {=0A=
      return this.responseText.evalJSON(options.sanitizeJSON);=0A=
    } catch (e) {=0A=
      this.request.dispatchException(e);=0A=
    }=0A=
  }=0A=
});=0A=
=0A=
Ajax.Updater =3D Class.create(Ajax.Request, {=0A=
  initialize: function($super, container, url, options) {=0A=
    this.container =3D {=0A=
      success: (container.success || container),=0A=
      failure: (container.failure || (container.success ? null : =
container))=0A=
    };=0A=
=0A=
    options =3D Object.clone(options);=0A=
    var onComplete =3D options.onComplete;=0A=
    options.onComplete =3D (function(response, json) {=0A=
      this.updateContent(response.responseText);=0A=
      if (Object.isFunction(onComplete)) onComplete(response, json);=0A=
    }).bind(this);=0A=
=0A=
    $super(url, options);=0A=
  },=0A=
=0A=
  updateContent: function(responseText) {=0A=
    var receiver =3D this.container[this.success() ? 'success' : =
'failure'],=0A=
        options =3D this.options;=0A=
=0A=
    if (!options.evalScripts) responseText =3D =
responseText.stripScripts();=0A=
=0A=
    if (receiver =3D $(receiver)) {=0A=
      if (options.insertion) {=0A=
        if (Object.isString(options.insertion)) {=0A=
          var insertion =3D { }; insertion[options.insertion] =3D =
responseText;=0A=
          receiver.insert(insertion);=0A=
        }=0A=
        else options.insertion(receiver, responseText);=0A=
      }=0A=
      else receiver.update(responseText);=0A=
    }=0A=
  }=0A=
});=0A=
=0A=
Ajax.PeriodicalUpdater =3D Class.create(Ajax.Base, {=0A=
  initialize: function($super, container, url, options) {=0A=
    $super(options);=0A=
    this.onComplete =3D this.options.onComplete;=0A=
=0A=
    this.frequency =3D (this.options.frequency || 2);=0A=
    this.decay =3D (this.options.decay || 1);=0A=
=0A=
    this.updater =3D { };=0A=
    this.container =3D container;=0A=
    this.url =3D url;=0A=
=0A=
    this.start();=0A=
  },=0A=
=0A=
  start: function() {=0A=
    this.options.onComplete =3D this.updateComplete.bind(this);=0A=
    this.onTimerEvent();=0A=
  },=0A=
=0A=
  stop: function() {=0A=
    this.updater.options.onComplete =3D undefined;=0A=
    clearTimeout(this.timer);=0A=
    (this.onComplete || Prototype.emptyFunction).apply(this, arguments);=0A=
  },=0A=
=0A=
  updateComplete: function(response) {=0A=
    if (this.options.decay) {=0A=
      this.decay =3D (response.responseText =3D=3D this.lastText ?=0A=
        this.decay * this.options.decay : 1);=0A=
=0A=
      this.lastText =3D response.responseText;=0A=
    }=0A=
    this.timer =3D this.onTimerEvent.bind(this).delay(this.decay * =
this.frequency);=0A=
  },=0A=
=0A=
  onTimerEvent: function() {=0A=
    this.updater =3D new Ajax.Updater(this.container, this.url, =
this.options);=0A=
  }=0A=
});=0A=
function $(element) {=0A=
  if (arguments.length > 1) {=0A=
    for (var i =3D 0, elements =3D [], length =3D arguments.length; i < =
length; i++)=0A=
      elements.push($(arguments[i]));=0A=
    return elements;=0A=
  }=0A=
  if (Object.isString(element))=0A=
    element =3D document.getElementById(element);=0A=
  return Element.extend(element);=0A=
}=0A=
=0A=
if (Prototype.BrowserFeatures.XPath) {=0A=
  document._getElementsByXPath =3D function(expression, parentElement) {=0A=
    var results =3D [];=0A=
    var query =3D document.evaluate(expression, $(parentElement) || =
document,=0A=
      null, XPathResult.ORDERED_NODE_SNAPSHOT_TYPE, null);=0A=
    for (var i =3D 0, length =3D query.snapshotLength; i < length; i++)=0A=
      results.push(Element.extend(query.snapshotItem(i)));=0A=
    return results;=0A=
  };=0A=
}=0A=
=0A=
/*-----------------------------------------------------------------------=
---*/=0A=
=0A=
if (!window.Node) var Node =3D { };=0A=
=0A=
if (!Node.ELEMENT_NODE) {=0A=
  // DOM level 2 ECMAScript Language Binding=0A=
  Object.extend(Node, {=0A=
    ELEMENT_NODE: 1,=0A=
    ATTRIBUTE_NODE: 2,=0A=
    TEXT_NODE: 3,=0A=
    CDATA_SECTION_NODE: 4,=0A=
    ENTITY_REFERENCE_NODE: 5,=0A=
    ENTITY_NODE: 6,=0A=
    PROCESSING_INSTRUCTION_NODE: 7,=0A=
    COMMENT_NODE: 8,=0A=
    DOCUMENT_NODE: 9,=0A=
    DOCUMENT_TYPE_NODE: 10,=0A=
    DOCUMENT_FRAGMENT_NODE: 11,=0A=
    NOTATION_NODE: 12=0A=
  });=0A=
}=0A=
=0A=
(function() {=0A=
  var element =3D this.Element;=0A=
  this.Element =3D function(tagName, attributes) {=0A=
    attributes =3D attributes || { };=0A=
    tagName =3D tagName.toLowerCase();=0A=
    var cache =3D Element.cache;=0A=
    if (Prototype.Browser.IE && attributes.name) {=0A=
      tagName =3D '<' + tagName + ' name=3D"' + attributes.name + '">';=0A=
      delete attributes.name;=0A=
      return Element.writeAttribute(document.createElement(tagName), =
attributes);=0A=
    }=0A=
    if (!cache[tagName]) cache[tagName] =3D =
Element.extend(document.createElement(tagName));=0A=
    return Element.writeAttribute(cache[tagName].cloneNode(false), =
attributes);=0A=
  };=0A=
  Object.extend(this.Element, element || { });=0A=
}).call(window);=0A=
=0A=
Element.cache =3D { };=0A=
=0A=
Element.Methods =3D {=0A=
  visible: function(element) {=0A=
    return $(element).style.display !=3D 'none';=0A=
  },=0A=
=0A=
  toggle: function(element) {=0A=
    element =3D $(element);=0A=
    Element[Element.visible(element) ? 'hide' : 'show'](element);=0A=
    return element;=0A=
  },=0A=
=0A=
  hide: function(element) {=0A=
    $(element).style.display =3D 'none';=0A=
    return element;=0A=
  },=0A=
=0A=
  show: function(element) {=0A=
    $(element).style.display =3D '';=0A=
    return element;=0A=
  },=0A=
=0A=
  remove: function(element) {=0A=
    element =3D $(element);=0A=
    element.parentNode.removeChild(element);=0A=
    return element;=0A=
  },=0A=
=0A=
  update: function(element, content) {=0A=
    element =3D $(element);=0A=
    if (content && content.toElement) content =3D content.toElement();=0A=
    if (Object.isElement(content)) return =
element.update().insert(content);=0A=
    content =3D Object.toHTML(content);=0A=
    element.innerHTML =3D content.stripScripts();=0A=
    content.evalScripts.bind(content).defer();=0A=
    return element;=0A=
  },=0A=
=0A=
  replace: function(element, content) {=0A=
    element =3D $(element);=0A=
    if (content && content.toElement) content =3D content.toElement();=0A=
    else if (!Object.isElement(content)) {=0A=
      content =3D Object.toHTML(content);=0A=
      var range =3D element.ownerDocument.createRange();=0A=
      range.selectNode(element);=0A=
      content.evalScripts.bind(content).defer();=0A=
      content =3D range.createContextualFragment(content.stripScripts());=0A=
    }=0A=
    element.parentNode.replaceChild(content, element);=0A=
    return element;=0A=
  },=0A=
=0A=
  insert: function(element, insertions) {=0A=
    element =3D $(element);=0A=
=0A=
    if (Object.isString(insertions) || Object.isNumber(insertions) ||=0A=
        Object.isElement(insertions) || (insertions && =
(insertions.toElement || insertions.toHTML)))=0A=
          insertions =3D {bottom:insertions};=0A=
=0A=
    var content, t, range;=0A=
=0A=
    for (position in insertions) {=0A=
      content  =3D insertions[position];=0A=
      position =3D position.toLowerCase();=0A=
      t =3D Element._insertionTranslations[position];=0A=
=0A=
      if (content && content.toElement) content =3D content.toElement();=0A=
      if (Object.isElement(content)) {=0A=
        t.insert(element, content);=0A=
        continue;=0A=
      }=0A=
=0A=
      content =3D Object.toHTML(content);=0A=
=0A=
      range =3D element.ownerDocument.createRange();=0A=
      t.initializeRange(element, range);=0A=
      t.insert(element, =
range.createContextualFragment(content.stripScripts()));=0A=
=0A=
      content.evalScripts.bind(content).defer();=0A=
    }=0A=
=0A=
    return element;=0A=
  },=0A=
=0A=
  wrap: function(element, wrapper, attributes) {=0A=
    element =3D $(element);=0A=
    if (Object.isElement(wrapper))=0A=
      $(wrapper).writeAttribute(attributes || { });=0A=
    else if (Object.isString(wrapper)) wrapper =3D new Element(wrapper, =
attributes);=0A=
    else wrapper =3D new Element('div', wrapper);=0A=
    if (element.parentNode)=0A=
      element.parentNode.replaceChild(wrapper, element);=0A=
    wrapper.appendChild(element);=0A=
    return wrapper;=0A=
  },=0A=
=0A=
  inspect: function(element) {=0A=
    element =3D $(element);=0A=
    var result =3D '<' + element.tagName.toLowerCase();=0A=
    $H({'id': 'id', 'className': 'class'}).each(function(pair) {=0A=
      var property =3D pair.first(), attribute =3D pair.last();=0A=
      var value =3D (element[property] || '').toString();=0A=
      if (value) result +=3D ' ' + attribute + '=3D' + =
value.inspect(true);=0A=
    });=0A=
    return result + '>';=0A=
  },=0A=
=0A=
  recursivelyCollect: function(element, property) {=0A=
    element =3D $(element);=0A=
    var elements =3D [];=0A=
    while (element =3D element[property])=0A=
      if (element.nodeType =3D=3D 1)=0A=
        elements.push(Element.extend(element));=0A=
    return elements;=0A=
  },=0A=
=0A=
  ancestors: function(element) {=0A=
    return $(element).recursivelyCollect('parentNode');=0A=
  },=0A=
=0A=
  descendants: function(element) {=0A=
    return $(element).getElementsBySelector("*");=0A=
  },=0A=
=0A=
  firstDescendant: function(element) {=0A=
    element =3D $(element).firstChild;=0A=
    while (element && element.nodeType !=3D 1) element =3D =
element.nextSibling;=0A=
    return $(element);=0A=
  },=0A=
=0A=
  immediateDescendants: function(element) {=0A=
    if (!(element =3D $(element).firstChild)) return [];=0A=
    while (element && element.nodeType !=3D 1) element =3D =
element.nextSibling;=0A=
    if (element) return [element].concat($(element).nextSiblings());=0A=
    return [];=0A=
  },=0A=
=0A=
  previousSiblings: function(element) {=0A=
    return $(element).recursivelyCollect('previousSibling');=0A=
  },=0A=
=0A=
  nextSiblings: function(element) {=0A=
    return $(element).recursivelyCollect('nextSibling');=0A=
  },=0A=
=0A=
  siblings: function(element) {=0A=
    element =3D $(element);=0A=
    return =
element.previousSiblings().reverse().concat(element.nextSiblings());=0A=
  },=0A=
=0A=
  match: function(element, selector) {=0A=
    if (Object.isString(selector))=0A=
      selector =3D new Selector(selector);=0A=
    return selector.match($(element));=0A=
  },=0A=
=0A=
  up: function(element, expression, index) {=0A=
    element =3D $(element);=0A=
    if (arguments.length =3D=3D 1) return $(element.parentNode);=0A=
    var ancestors =3D element.ancestors();=0A=
    return expression ? Selector.findElement(ancestors, expression, =
index) :=0A=
      ancestors[index || 0];=0A=
  },=0A=
=0A=
  down: function(element, expression, index) {=0A=
    element =3D $(element);=0A=
    if (arguments.length =3D=3D 1) return element.firstDescendant();=0A=
    var descendants =3D element.descendants();=0A=
    return expression ? Selector.findElement(descendants, expression, =
index) :=0A=
      descendants[index || 0];=0A=
  },=0A=
=0A=
  previous: function(element, expression, index) {=0A=
    element =3D $(element);=0A=
    if (arguments.length =3D=3D 1) return =
$(Selector.handlers.previousElementSibling(element));=0A=
    var previousSiblings =3D element.previousSiblings();=0A=
    return expression ? Selector.findElement(previousSiblings, =
expression, index) :=0A=
      previousSiblings[index || 0];=0A=
  },=0A=
=0A=
  next: function(element, expression, index) {=0A=
    element =3D $(element);=0A=
    if (arguments.length =3D=3D 1) return =
$(Selector.handlers.nextElementSibling(element));=0A=
    var nextSiblings =3D element.nextSiblings();=0A=
    return expression ? Selector.findElement(nextSiblings, expression, =
index) :=0A=
      nextSiblings[index || 0];=0A=
  },=0A=
=0A=
  select: function() {=0A=
    var args =3D $A(arguments), element =3D $(args.shift());=0A=
    return Selector.findChildElements(element, args);=0A=
  },=0A=
=0A=
  adjacent: function() {=0A=
    var args =3D $A(arguments), element =3D $(args.shift());=0A=
    return Selector.findChildElements(element.parentNode, =
args).without(element);=0A=
  },=0A=
=0A=
  identify: function(element) {=0A=
    element =3D $(element);=0A=
    var id =3D element.readAttribute('id'), self =3D arguments.callee;=0A=
    if (id) return id;=0A=
    do { id =3D 'anonymous_element_' + self.counter++ } while ($(id));=0A=
    element.writeAttribute('id', id);=0A=
    return id;=0A=
  },=0A=
=0A=
  readAttribute: function(element, name) {=0A=
    element =3D $(element);=0A=
    if (Prototype.Browser.IE) {=0A=
      var t =3D Element._attributeTranslations.read;=0A=
      if (t.values[name]) return t.values[name](element, name);=0A=
      if (t.names[name]) name =3D t.names[name];=0A=
      if (name.include(':')) {=0A=
        return (!element.attributes || !element.attributes[name]) ? null =
:=0A=
         element.attributes[name].value;=0A=
      }=0A=
    }=0A=
    return element.getAttribute(name);=0A=
  },=0A=
=0A=
  writeAttribute: function(element, name, value) {=0A=
    element =3D $(element);=0A=
    var attributes =3D { }, t =3D Element._attributeTranslations.write;=0A=
=0A=
    if (typeof name =3D=3D 'object') attributes =3D name;=0A=
    else attributes[name] =3D Object.isUndefined(value) ? true : value;=0A=
=0A=
    for (var attr in attributes) {=0A=
      name =3D t.names[attr] || attr;=0A=
      value =3D attributes[attr];=0A=
      if (t.values[attr]) name =3D t.values[attr](element, value);=0A=
      if (value =3D=3D=3D false || value =3D=3D=3D null)=0A=
        element.removeAttribute(name);=0A=
      else if (value =3D=3D=3D true)=0A=
        element.setAttribute(name, name);=0A=
      else element.setAttribute(name, value);=0A=
    }=0A=
    return element;=0A=
  },=0A=
=0A=
  getHeight: function(element) {=0A=
    return $(element).getDimensions().height;=0A=
  },=0A=
=0A=
  getWidth: function(element) {=0A=
    return $(element).getDimensions().width;=0A=
  },=0A=
=0A=
  classNames: function(element) {=0A=
    return new Element.ClassNames(element);=0A=
  },=0A=
=0A=
  hasClassName: function(element, className) {=0A=
    if (!(element =3D $(element))) return;=0A=
    var elementClassName =3D element.className;=0A=
    return (elementClassName.length > 0 && (elementClassName =3D=3D =
className ||=0A=
      new RegExp("(^|\\s)" + className + =
"(\\s|$)").test(elementClassName)));=0A=
  },=0A=
=0A=
  addClassName: function(element, className) {=0A=
    if (!(element =3D $(element))) return;=0A=
    if (!element.hasClassName(className))=0A=
      element.className +=3D (element.className ? ' ' : '') + className;=0A=
    return element;=0A=
  },=0A=
=0A=
  removeClassName: function(element, className) {=0A=
    if (!(element =3D $(element))) return;=0A=
    element.className =3D element.className.replace(=0A=
      new RegExp("(^|\\s+)" + className + "(\\s+|$)"), ' ').strip();=0A=
    return element;=0A=
  },=0A=
=0A=
  toggleClassName: function(element, className) {=0A=
    if (!(element =3D $(element))) return;=0A=
    return element[element.hasClassName(className) ?=0A=
      'removeClassName' : 'addClassName'](className);=0A=
  },=0A=
=0A=
  // removes whitespace-only text node children=0A=
  cleanWhitespace: function(element) {=0A=
    element =3D $(element);=0A=
    var node =3D element.firstChild;=0A=
    while (node) {=0A=
      var nextNode =3D node.nextSibling;=0A=
      if (node.nodeType =3D=3D 3 && !/\S/.test(node.nodeValue))=0A=
        element.removeChild(node);=0A=
      node =3D nextNode;=0A=
    }=0A=
    return element;=0A=
  },=0A=
=0A=
  empty: function(element) {=0A=
    return $(element).innerHTML.blank();=0A=
  },=0A=
=0A=
  descendantOf: function(element, ancestor) {=0A=
    element =3D $(element), ancestor =3D $(ancestor);=0A=
    var originalAncestor =3D ancestor;=0A=
=0A=
    if (element.compareDocumentPosition)=0A=
      return (element.compareDocumentPosition(ancestor) & 8) =3D=3D=3D 8;=0A=
=0A=
    if (element.sourceIndex && !Prototype.Browser.Opera) {=0A=
      var e =3D element.sourceIndex, a =3D ancestor.sourceIndex,=0A=
       nextAncestor =3D ancestor.nextSibling;=0A=
      if (!nextAncestor) {=0A=
        do { ancestor =3D ancestor.parentNode; }=0A=
        while (!(nextAncestor =3D ancestor.nextSibling) && =
ancestor.parentNode);=0A=
      }=0A=
      if (nextAncestor) return (e > a && e < nextAncestor.sourceIndex);=0A=
    }=0A=
=0A=
    while (element =3D element.parentNode)=0A=
      if (element =3D=3D originalAncestor) return true;=0A=
    return false;=0A=
  },=0A=
=0A=
  scrollTo: function(element) {=0A=
    element =3D $(element);=0A=
    var pos =3D element.cumulativeOffset();=0A=
    window.scrollTo(pos[0], pos[1]);=0A=
    return element;=0A=
  },=0A=
=0A=
  getStyle: function(element, style) {=0A=
    element =3D $(element);=0A=
    style =3D style =3D=3D 'float' ? 'cssFloat' : style.camelize();=0A=
    var value =3D element.style[style];=0A=
    if (!value) {=0A=
      var css =3D document.defaultView.getComputedStyle(element, null);=0A=
      value =3D css ? css[style] : null;=0A=
    }=0A=
    if (style =3D=3D 'opacity') return value ? parseFloat(value) : 1.0;=0A=
    return value =3D=3D 'auto' ? null : value;=0A=
  },=0A=
=0A=
  getOpacity: function(element) {=0A=
    return $(element).getStyle('opacity');=0A=
  },=0A=
=0A=
  setStyle: function(element, styles) {=0A=
    element =3D $(element);=0A=
    var elementStyle =3D element.style, match;=0A=
    if (Object.isString(styles)) {=0A=
      element.style.cssText +=3D ';' + styles;=0A=
      return styles.include('opacity') ?=0A=
        element.setOpacity(styles.match(/opacity:\s*(\d?\.?\d*)/)[1]) : =
element;=0A=
    }=0A=
    for (var property in styles)=0A=
      if (property =3D=3D 'opacity') =
element.setOpacity(styles[property]);=0A=
      else=0A=
        elementStyle[(property =3D=3D 'float' || property =3D=3D =
'cssFloat') ?=0A=
          (Object.isUndefined(elementStyle.styleFloat) ? 'cssFloat' : =
'styleFloat') :=0A=
            property] =3D styles[property];=0A=
=0A=
    return element;=0A=
  },=0A=
=0A=
  setOpacity: function(element, value) {=0A=
    element =3D $(element);=0A=
    element.style.opacity =3D (value =3D=3D 1 || value =3D=3D=3D '') ? =
'' :=0A=
      (value < 0.00001) ? 0 : value;=0A=
    return element;=0A=
  },=0A=
=0A=
  getDimensions: function(element) {=0A=
    element =3D $(element);=0A=
    var display =3D $(element).getStyle('display');=0A=
    if (display !=3D 'none' && display !=3D null) // Safari bug=0A=
      return {width: element.offsetWidth, height: element.offsetHeight};=0A=
=0A=
    // All *Width and *Height properties give 0 on elements with display =
none,=0A=
    // so enable the element temporarily=0A=
    var els =3D element.style;=0A=
    var originalVisibility =3D els.visibility;=0A=
    var originalPosition =3D els.position;=0A=
    var originalDisplay =3D els.display;=0A=
    els.visibility =3D 'hidden';=0A=
    els.position =3D 'absolute';=0A=
    els.display =3D 'block';=0A=
    var originalWidth =3D element.clientWidth;=0A=
    var originalHeight =3D element.clientHeight;=0A=
    els.display =3D originalDisplay;=0A=
    els.position =3D originalPosition;=0A=
    els.visibility =3D originalVisibility;=0A=
    return {width: originalWidth, height: originalHeight};=0A=
  },=0A=
=0A=
  makePositioned: function(element) {=0A=
    element =3D $(element);=0A=
    var pos =3D Element.getStyle(element, 'position');=0A=
    if (pos =3D=3D 'static' || !pos) {=0A=
      element._madePositioned =3D true;=0A=
      element.style.position =3D 'relative';=0A=
      // Opera returns the offset relative to the positioning context, =
when an=0A=
      // element is position relative but top and left have not been =
defined=0A=
      if (window.opera) {=0A=
        element.style.top =3D 0;=0A=
        element.style.left =3D 0;=0A=
      }=0A=
    }=0A=
    return element;=0A=
  },=0A=
=0A=
  undoPositioned: function(element) {=0A=
    element =3D $(element);=0A=
    if (element._madePositioned) {=0A=
      element._madePositioned =3D undefined;=0A=
      element.style.position =3D=0A=
        element.style.top =3D=0A=
        element.style.left =3D=0A=
        element.style.bottom =3D=0A=
        element.style.right =3D '';=0A=
    }=0A=
    return element;=0A=
  },=0A=
=0A=
  makeClipping: function(element) {=0A=
    element =3D $(element);=0A=
    if (element._overflow) return element;=0A=
    element._overflow =3D Element.getStyle(element, 'overflow') || =
'auto';=0A=
    if (element._overflow !=3D=3D 'hidden')=0A=
      element.style.overflow =3D 'hidden';=0A=
    return element;=0A=
  },=0A=
=0A=
  undoClipping: function(element) {=0A=
    element =3D $(element);=0A=
    if (!element._overflow) return element;=0A=
    element.style.overflow =3D element._overflow =3D=3D 'auto' ? '' : =
element._overflow;=0A=
    element._overflow =3D null;=0A=
    return element;=0A=
  },=0A=
=0A=
  cumulativeOffset: function(element) {=0A=
    var valueT =3D 0, valueL =3D 0;=0A=
    do {=0A=
      valueT +=3D element.offsetTop  || 0;=0A=
      valueL +=3D element.offsetLeft || 0;=0A=
      element =3D element.offsetParent;=0A=
    } while (element);=0A=
    return Element._returnOffset(valueL, valueT);=0A=
  },=0A=
=0A=
  positionedOffset: function(element) {=0A=
    var valueT =3D 0, valueL =3D 0;=0A=
    do {=0A=
      valueT +=3D element.offsetTop  || 0;=0A=
      valueL +=3D element.offsetLeft || 0;=0A=
      element =3D element.offsetParent;=0A=
      if (element) {=0A=
        if (element.tagName =3D=3D 'BODY') break;=0A=
        var p =3D Element.getStyle(element, 'position');=0A=
        if (p =3D=3D 'relative' || p =3D=3D 'absolute') break;=0A=
      }=0A=
    } while (element);=0A=
    return Element._returnOffset(valueL, valueT);=0A=
  },=0A=
=0A=
  absolutize: function(element) {=0A=
    element =3D $(element);=0A=
    if (element.getStyle('position') =3D=3D 'absolute') return;=0A=
    // Position.prepare(); // To be done manually by Scripty when it =
needs it.=0A=
=0A=
    var offsets =3D element.positionedOffset();=0A=
    var top     =3D offsets[1];=0A=
    var left    =3D offsets[0];=0A=
    var width   =3D element.clientWidth;=0A=
    var height  =3D element.clientHeight;=0A=
=0A=
    element._originalLeft   =3D left - parseFloat(element.style.left  || =
0);=0A=
    element._originalTop    =3D top  - parseFloat(element.style.top || =
0);=0A=
    element._originalWidth  =3D element.style.width;=0A=
    element._originalHeight =3D element.style.height;=0A=
=0A=
    element.style.position =3D 'absolute';=0A=
    element.style.top    =3D top + 'px';=0A=
    element.style.left   =3D left + 'px';=0A=
    element.style.width  =3D width + 'px';=0A=
    element.style.height =3D height + 'px';=0A=
    return element;=0A=
  },=0A=
=0A=
  relativize: function(element) {=0A=
    element =3D $(element);=0A=
    if (element.getStyle('position') =3D=3D 'relative') return;=0A=
    // Position.prepare(); // To be done manually by Scripty when it =
needs it.=0A=
=0A=
    element.style.position =3D 'relative';=0A=
    var top  =3D parseFloat(element.style.top  || 0) - =
(element._originalTop || 0);=0A=
    var left =3D parseFloat(element.style.left || 0) - =
(element._originalLeft || 0);=0A=
=0A=
    element.style.top    =3D top + 'px';=0A=
    element.style.left   =3D left + 'px';=0A=
    element.style.height =3D element._originalHeight;=0A=
    element.style.width  =3D element._originalWidth;=0A=
    return element;=0A=
  },=0A=
=0A=
  cumulativeScrollOffset: function(element) {=0A=
    var valueT =3D 0, valueL =3D 0;=0A=
    do {=0A=
      valueT +=3D element.scrollTop  || 0;=0A=
      valueL +=3D element.scrollLeft || 0;=0A=
      element =3D element.parentNode;=0A=
    } while (element);=0A=
    return Element._returnOffset(valueL, valueT);=0A=
  },=0A=
=0A=
  getOffsetParent: function(element) {=0A=
    if (element.offsetParent) return $(element.offsetParent);=0A=
    if (element =3D=3D document.body) return $(element);=0A=
=0A=
    while ((element =3D element.parentNode) && element !=3D =
document.body)=0A=
      if (Element.getStyle(element, 'position') !=3D 'static')=0A=
        return $(element);=0A=
=0A=
    return $(document.body);=0A=
  },=0A=
=0A=
  viewportOffset: function(forElement) {=0A=
    var valueT =3D 0, valueL =3D 0;=0A=
=0A=
    var element =3D forElement;=0A=
    do {=0A=
      valueT +=3D element.offsetTop  || 0;=0A=
      valueL +=3D element.offsetLeft || 0;=0A=
=0A=
      // Safari fix=0A=
      if (element.offsetParent =3D=3D document.body &&=0A=
        Element.getStyle(element, 'position') =3D=3D 'absolute') break;=0A=
=0A=
    } while (element =3D element.offsetParent);=0A=
=0A=
    element =3D forElement;=0A=
    do {=0A=
      if (!Prototype.Browser.Opera || element.tagName =3D=3D 'BODY') {=0A=
        valueT -=3D element.scrollTop  || 0;=0A=
        valueL -=3D element.scrollLeft || 0;=0A=
      }=0A=
    } while (element =3D element.parentNode);=0A=
=0A=
    return Element._returnOffset(valueL, valueT);=0A=
  },=0A=
=0A=
  clonePosition: function(element, source) {=0A=
    var options =3D Object.extend({=0A=
      setLeft:    true,=0A=
      setTop:     true,=0A=
      setWidth:   true,=0A=
      setHeight:  true,=0A=
      offsetTop:  0,=0A=
      offsetLeft: 0=0A=
    }, arguments[2] || { });=0A=
=0A=
    // find page position of source=0A=
    source =3D $(source);=0A=
    var p =3D source.viewportOffset();=0A=
=0A=
    // find coordinate system to use=0A=
    element =3D $(element);=0A=
    var delta =3D [0, 0];=0A=
    var parent =3D null;=0A=
    // delta [0,0] will do fine with position: fixed elements,=0A=
    // position:absolute needs offsetParent deltas=0A=
    if (Element.getStyle(element, 'position') =3D=3D 'absolute') {=0A=
      parent =3D element.getOffsetParent();=0A=
      delta =3D parent.viewportOffset();=0A=
    }=0A=
=0A=
    // correct by body offsets (fixes Safari)=0A=
    if (parent =3D=3D document.body) {=0A=
      delta[0] -=3D document.body.offsetLeft;=0A=
      delta[1] -=3D document.body.offsetTop;=0A=
    }=0A=
=0A=
    // set position=0A=
    if (options.setLeft)   element.style.left  =3D (p[0] - delta[0] + =
options.offsetLeft) + 'px';=0A=
    if (options.setTop)    element.style.top   =3D (p[1] - delta[1] + =
options.offsetTop) + 'px';=0A=
    if (options.setWidth)  element.style.width =3D source.offsetWidth + =
'px';=0A=
    if (options.setHeight) element.style.height =3D source.offsetHeight =
+ 'px';=0A=
    return element;=0A=
  }=0A=
};=0A=
=0A=
Element.Methods.identify.counter =3D 1;=0A=
=0A=
Object.extend(Element.Methods, {=0A=
  getElementsBySelector: Element.Methods.select,=0A=
  childElements: Element.Methods.immediateDescendants=0A=
});=0A=
=0A=
Element._attributeTranslations =3D {=0A=
  write: {=0A=
    names: {=0A=
      className: 'class',=0A=
      htmlFor:   'for'=0A=
    },=0A=
    values: { }=0A=
  }=0A=
};=0A=
=0A=
=0A=
if (!document.createRange || Prototype.Browser.Opera) {=0A=
  Element.Methods.insert =3D function(element, insertions) {=0A=
    element =3D $(element);=0A=
=0A=
    if (Object.isString(insertions) || Object.isNumber(insertions) ||=0A=
        Object.isElement(insertions) || (insertions && =
(insertions.toElement || insertions.toHTML)))=0A=
          insertions =3D { bottom: insertions };=0A=
=0A=
    var t =3D Element._insertionTranslations, content, position, pos, =
tagName;=0A=
=0A=
    for (position in insertions) {=0A=
      content  =3D insertions[position];=0A=
      position =3D position.toLowerCase();=0A=
      pos      =3D t[position];=0A=
=0A=
      if (content && content.toElement) content =3D content.toElement();=0A=
      if (Object.isElement(content)) {=0A=
        pos.insert(element, content);=0A=
        continue;=0A=
      }=0A=
=0A=
      content =3D Object.toHTML(content);=0A=
      tagName =3D ((position =3D=3D 'before' || position =3D=3D 'after')=0A=
        ? element.parentNode : element).tagName.toUpperCase();=0A=
=0A=
      if (t.tags[tagName]) {=0A=
        var fragments =3D =
Element._getContentFromAnonymousElement(tagName, content.stripScripts());=0A=
        if (position =3D=3D 'top' || position =3D=3D 'after') =
fragments.reverse();=0A=
        fragments.each(pos.insert.curry(element));=0A=
      }=0A=
      else element.insertAdjacentHTML(pos.adjacency, =
content.stripScripts());=0A=
=0A=
      content.evalScripts.bind(content).defer();=0A=
    }=0A=
=0A=
    return element;=0A=
  };=0A=
}=0A=
=0A=
if (Prototype.Browser.Opera) {=0A=
  Element.Methods.getStyle =3D Element.Methods.getStyle.wrap(=0A=
    function(proceed, element, style) {=0A=
      switch (style) {=0A=
        case 'left': case 'top': case 'right': case 'bottom':=0A=
          if (proceed(element, 'position') =3D=3D=3D 'static') return =
null;=0A=
        case 'height': case 'width':=0A=
          // returns '0px' for hidden elements; we want it to return null=0A=
          if (!Element.visible(element)) return null;=0A=
=0A=
          // returns the border-box dimensions rather than the =
content-box=0A=
          // dimensions, so we subtract padding and borders from the =
value=0A=
          var dim =3D parseInt(proceed(element, style), 10);=0A=
=0A=
          if (dim !=3D=3D element['offset' + style.capitalize()])=0A=
            return dim + 'px';=0A=
=0A=
          var properties;=0A=
          if (style =3D=3D=3D 'height') {=0A=
            properties =3D ['border-top-width', 'padding-top',=0A=
             'padding-bottom', 'border-bottom-width'];=0A=
          }=0A=
          else {=0A=
            properties =3D ['border-left-width', 'padding-left',=0A=
             'padding-right', 'border-right-width'];=0A=
          }=0A=
          return properties.inject(dim, function(memo, property) {=0A=
            var val =3D proceed(element, property);=0A=
            return val =3D=3D=3D null ? memo : memo - parseInt(val, 10);=0A=
          }) + 'px';=0A=
        default: return proceed(element, style);=0A=
      }=0A=
    }=0A=
  );=0A=
=0A=
  Element.Methods.readAttribute =3D Element.Methods.readAttribute.wrap(=0A=
    function(proceed, element, attribute) {=0A=
      if (attribute =3D=3D=3D 'title') return element.title;=0A=
      return proceed(element, attribute);=0A=
    }=0A=
  );=0A=
}=0A=
=0A=
else if (Prototype.Browser.IE) {=0A=
  $w('positionedOffset getOffsetParent =
viewportOffset').each(function(method) {=0A=
    Element.Methods[method] =3D Element.Methods[method].wrap(=0A=
      function(proceed, element) {=0A=
        element =3D $(element);=0A=
        var position =3D element.getStyle('position');=0A=
        if (position !=3D 'static') return proceed(element);=0A=
        element.setStyle({ position: 'relative' });=0A=
        var value =3D proceed(element);=0A=
        element.setStyle({ position: position });=0A=
        return value;=0A=
      }=0A=
    );=0A=
  });=0A=
=0A=
  Element.Methods.getStyle =3D function(element, style) {=0A=
    element =3D $(element);=0A=
    style =3D (style =3D=3D 'float' || style =3D=3D 'cssFloat') ? =
'styleFloat' : style.camelize();=0A=
    var value =3D element.style[style];=0A=
    if (!value && element.currentStyle) value =3D =
element.currentStyle[style];=0A=
=0A=
    if (style =3D=3D 'opacity') {=0A=
      if (value =3D (element.getStyle('filter') || =
'').match(/alpha\(opacity=3D(.*)\)/))=0A=
        if (value[1]) return parseFloat(value[1]) / 100;=0A=
      return 1.0;=0A=
    }=0A=
=0A=
    if (value =3D=3D 'auto') {=0A=
      if ((style =3D=3D 'width' || style =3D=3D 'height') && =
(element.getStyle('display') !=3D 'none'))=0A=
        return element['offset' + style.capitalize()] + 'px';=0A=
      return null;=0A=
    }=0A=
    return value;=0A=
  };=0A=
=0A=
  Element.Methods.setOpacity =3D function(element, value) {=0A=
    function stripAlpha(filter){=0A=
      return filter.replace(/alpha\([^\)]*\)/gi,'');=0A=
    }=0A=
    element =3D $(element);=0A=
    var currentStyle =3D element.currentStyle;=0A=
    if ((currentStyle && !currentStyle.hasLayout) ||=0A=
      (!currentStyle && element.style.zoom =3D=3D 'normal'))=0A=
        element.style.zoom =3D 1;=0A=
=0A=
    var filter =3D element.getStyle('filter'), style =3D element.style;=0A=
    if (value =3D=3D 1 || value =3D=3D=3D '') {=0A=
      (filter =3D stripAlpha(filter)) ?=0A=
        style.filter =3D filter : style.removeAttribute('filter');=0A=
      return element;=0A=
    } else if (value < 0.00001) value =3D 0;=0A=
    style.filter =3D stripAlpha(filter) +=0A=
      'alpha(opacity=3D' + (value * 100) + ')';=0A=
    return element;=0A=
  };=0A=
=0A=
  Element._attributeTranslations =3D {=0A=
    read: {=0A=
      names: {=0A=
        'class': 'className',=0A=
        'for':   'htmlFor'=0A=
      },=0A=
      values: {=0A=
        _getAttr: function(element, attribute) {=0A=
          return element.getAttribute(attribute, 2);=0A=
        },=0A=
        _getAttrNode: function(element, attribute) {=0A=
          var node =3D element.getAttributeNode(attribute);=0A=
          return node ? node.value : "";=0A=
        },=0A=
        _getEv: function(element, attribute) {=0A=
          attribute =3D element.getAttribute(attribute);=0A=
          return attribute ? attribute.toString().slice(23, -2) : null;=0A=
        },=0A=
        _flag: function(element, attribute) {=0A=
          return $(element).hasAttribute(attribute) ? attribute : null;=0A=
        },=0A=
        style: function(element) {=0A=
          return element.style.cssText.toLowerCase();=0A=
        },=0A=
        title: function(element) {=0A=
          return element.title;=0A=
        }=0A=
      }=0A=
    }=0A=
  };=0A=
=0A=
  Element._attributeTranslations.write =3D {=0A=
    names: Object.clone(Element._attributeTranslations.read.names),=0A=
    values: {=0A=
      checked: function(element, value) {=0A=
        element.checked =3D !!value;=0A=
      },=0A=
=0A=
      style: function(element, value) {=0A=
        element.style.cssText =3D value ? value : '';=0A=
      }=0A=
    }=0A=
  };=0A=
=0A=
  Element._attributeTranslations.has =3D {};=0A=
=0A=
  $w('colSpan rowSpan vAlign dateTime accessKey tabIndex ' +=0A=
      'encType maxLength readOnly longDesc').each(function(attr) {=0A=
    Element._attributeTranslations.write.names[attr.toLowerCase()] =3D =
attr;=0A=
    Element._attributeTranslations.has[attr.toLowerCase()] =3D attr;=0A=
  });=0A=
=0A=
  (function(v) {=0A=
    Object.extend(v, {=0A=
      href:        v._getAttr,=0A=
      src:         v._getAttr,=0A=
      type:        v._getAttr,=0A=
      action:      v._getAttrNode,=0A=
      disabled:    v._flag,=0A=
      checked:     v._flag,=0A=
      readonly:    v._flag,=0A=
      multiple:    v._flag,=0A=
      onload:      v._getEv,=0A=
      onunload:    v._getEv,=0A=
      onclick:     v._getEv,=0A=
      ondblclick:  v._getEv,=0A=
      onmousedown: v._getEv,=0A=
      onmouseup:   v._getEv,=0A=
      onmouseover: v._getEv,=0A=
      onmousemove: v._getEv,=0A=
      onmouseout:  v._getEv,=0A=
      onfocus:     v._getEv,=0A=
      onblur:      v._getEv,=0A=
      onkeypress:  v._getEv,=0A=
      onkeydown:   v._getEv,=0A=
      onkeyup:     v._getEv,=0A=
      onsubmit:    v._getEv,=0A=
      onreset:     v._getEv,=0A=
      onselect:    v._getEv,=0A=
      onchange:    v._getEv=0A=
    });=0A=
  })(Element._attributeTranslations.read.values);=0A=
}=0A=
=0A=
else if (Prototype.Browser.Gecko && =
/rv:1\.8\.0/.test(navigator.userAgent)) {=0A=
  Element.Methods.setOpacity =3D function(element, value) {=0A=
    element =3D $(element);=0A=
    element.style.opacity =3D (value =3D=3D 1) ? 0.999999 :=0A=
      (value =3D=3D=3D '') ? '' : (value < 0.00001) ? 0 : value;=0A=
    return element;=0A=
  };=0A=
}=0A=
=0A=
else if (Prototype.Browser.WebKit) {=0A=
  Element.Methods.setOpacity =3D function(element, value) {=0A=
    element =3D $(element);=0A=
    element.style.opacity =3D (value =3D=3D 1 || value =3D=3D=3D '') ? =
'' :=0A=
      (value < 0.00001) ? 0 : value;=0A=
=0A=
    if (value =3D=3D 1)=0A=
      if(element.tagName =3D=3D 'IMG' && element.width) {=0A=
        element.width++; element.width--;=0A=
      } else try {=0A=
        var n =3D document.createTextNode(' ');=0A=
        element.appendChild(n);=0A=
        element.removeChild(n);=0A=
      } catch (e) { }=0A=
=0A=
    return element;=0A=
  };=0A=
=0A=
  // Safari returns margins on body which is incorrect if the child is =
absolutely=0A=
  // positioned.  For performance reasons, redefine =
Element#cumulativeOffset for=0A=
  // KHTML/WebKit only.=0A=
  Element.Methods.cumulativeOffset =3D function(element) {=0A=
    var valueT =3D 0, valueL =3D 0;=0A=
    do {=0A=
      valueT +=3D element.offsetTop  || 0;=0A=
      valueL +=3D element.offsetLeft || 0;=0A=
      if (element.offsetParent =3D=3D document.body)=0A=
        if (Element.getStyle(element, 'position') =3D=3D 'absolute') =
break;=0A=
=0A=
      element =3D element.offsetParent;=0A=
    } while (element);=0A=
=0A=
    return Element._returnOffset(valueL, valueT);=0A=
  };=0A=
}=0A=
=0A=
if (Prototype.Browser.IE || Prototype.Browser.Opera) {=0A=
  // IE and Opera are missing .innerHTML support for TABLE-related and =
SELECT elements=0A=
  Element.Methods.update =3D function(element, content) {=0A=
    element =3D $(element);=0A=
=0A=
    if (content && content.toElement) content =3D content.toElement();=0A=
    if (Object.isElement(content)) return =
element.update().insert(content);=0A=
=0A=
    content =3D Object.toHTML(content);=0A=
    var tagName =3D element.tagName.toUpperCase();=0A=
=0A=
    if (tagName in Element._insertionTranslations.tags) {=0A=
      $A(element.childNodes).each(function(node) { =
element.removeChild(node) });=0A=
      Element._getContentFromAnonymousElement(tagName, =
content.stripScripts())=0A=
        .each(function(node) { element.appendChild(node) });=0A=
    }=0A=
    else element.innerHTML =3D content.stripScripts();=0A=
=0A=
    content.evalScripts.bind(content).defer();=0A=
    return element;=0A=
  };=0A=
}=0A=
=0A=
if (document.createElement('div').outerHTML) {=0A=
  Element.Methods.replace =3D function(element, content) {=0A=
    element =3D $(element);=0A=
=0A=
    if (content && content.toElement) content =3D content.toElement();=0A=
    if (Object.isElement(content)) {=0A=
      element.parentNode.replaceChild(content, element);=0A=
      return element;=0A=
    }=0A=
=0A=
    content =3D Object.toHTML(content);=0A=
    var parent =3D element.parentNode, tagName =3D =
parent.tagName.toUpperCase();=0A=
=0A=
    if (Element._insertionTranslations.tags[tagName]) {=0A=
      var nextSibling =3D element.next();=0A=
      var fragments =3D Element._getContentFromAnonymousElement(tagName, =
content.stripScripts());=0A=
      parent.removeChild(element);=0A=
      if (nextSibling)=0A=
        fragments.each(function(node) { parent.insertBefore(node, =
nextSibling) });=0A=
      else=0A=
        fragments.each(function(node) { parent.appendChild(node) });=0A=
    }=0A=
    else element.outerHTML =3D content.stripScripts();=0A=
=0A=
    content.evalScripts.bind(content).defer();=0A=
    return element;=0A=
  };=0A=
}=0A=
=0A=
Element._returnOffset =3D function(l, t) {=0A=
  var result =3D [l, t];=0A=
  result.left =3D l;=0A=
  result.top =3D t;=0A=
  return result;=0A=
};=0A=
=0A=
Element._getContentFromAnonymousElement =3D function(tagName, html) {=0A=
  var div =3D new Element('div'), t =3D =
Element._insertionTranslations.tags[tagName];=0A=
  div.innerHTML =3D t[0] + html + t[1];=0A=
  t[2].times(function() { div =3D div.firstChild });=0A=
  return $A(div.childNodes);=0A=
};=0A=
=0A=
Element._insertionTranslations =3D {=0A=
  before: {=0A=
    adjacency: 'beforeBegin',=0A=
    insert: function(element, node) {=0A=
      element.parentNode.insertBefore(node, element);=0A=
    },=0A=
    initializeRange: function(element, range) {=0A=
      range.setStartBefore(element);=0A=
    }=0A=
  },=0A=
  top: {=0A=
    adjacency: 'afterBegin',=0A=
    insert: function(element, node) {=0A=
      element.insertBefore(node, element.firstChild);=0A=
    },=0A=
    initializeRange: function(element, range) {=0A=
      range.selectNodeContents(element);=0A=
      range.collapse(true);=0A=
    }=0A=
  },=0A=
  bottom: {=0A=
    adjacency: 'beforeEnd',=0A=
    insert: function(element, node) {=0A=
      element.appendChild(node);=0A=
    }=0A=
  },=0A=
  after: {=0A=
    adjacency: 'afterEnd',=0A=
    insert: function(element, node) {=0A=
      element.parentNode.insertBefore(node, element.nextSibling);=0A=
    },=0A=
    initializeRange: function(element, range) {=0A=
      range.setStartAfter(element);=0A=
    }=0A=
  },=0A=
  tags: {=0A=
    TABLE:  ['<table>',                '</table>',                   1],=0A=
    TBODY:  ['<table><tbody>',         '</tbody></table>',           2],=0A=
    TR:     ['<table><tbody><tr>',     '</tr></tbody></table>',      3],=0A=
    TD:     ['<table><tbody><tr><td>', '</td></tr></tbody></table>', 4],=0A=
    SELECT: ['<select>',               '</select>',                  1]=0A=
  }=0A=
};=0A=
=0A=
(function() {=0A=
  this.bottom.initializeRange =3D this.top.initializeRange;=0A=
  Object.extend(this.tags, {=0A=
    THEAD: this.tags.TBODY,=0A=
    TFOOT: this.tags.TBODY,=0A=
    TH:    this.tags.TD=0A=
  });=0A=
}).call(Element._insertionTranslations);=0A=
=0A=
Element.Methods.Simulated =3D {=0A=
  hasAttribute: function(element, attribute) {=0A=
    attribute =3D Element._attributeTranslations.has[attribute] || =
attribute;=0A=
    var node =3D $(element).getAttributeNode(attribute);=0A=
    return node && node.specified;=0A=
  }=0A=
};=0A=
=0A=
Element.Methods.ByTag =3D { };=0A=
=0A=
Object.extend(Element, Element.Methods);=0A=
=0A=
if (!Prototype.BrowserFeatures.ElementExtensions &&=0A=
    document.createElement('div').__proto__) {=0A=
  window.HTMLElement =3D { };=0A=
  window.HTMLElement.prototype =3D =
document.createElement('div').__proto__;=0A=
  Prototype.BrowserFeatures.ElementExtensions =3D true;=0A=
}=0A=
=0A=
Element.extend =3D (function() {=0A=
  if (Prototype.BrowserFeatures.SpecificElementExtensions)=0A=
    return Prototype.K;=0A=
=0A=
  var Methods =3D { }, ByTag =3D Element.Methods.ByTag;=0A=
=0A=
  var extend =3D Object.extend(function(element) {=0A=
    if (!element || element._extendedByPrototype ||=0A=
        element.nodeType !=3D 1 || element =3D=3D window) return element;=0A=
=0A=
    var methods =3D Object.clone(Methods),=0A=
      tagName =3D element.tagName, property, value;=0A=
=0A=
    // extend methods for specific tags=0A=
    if (ByTag[tagName]) Object.extend(methods, ByTag[tagName]);=0A=
=0A=
    for (property in methods) {=0A=
      value =3D methods[property];=0A=
      if (Object.isFunction(value) && !(property in element))=0A=
        element[property] =3D value.methodize();=0A=
    }=0A=
=0A=
    element._extendedByPrototype =3D Prototype.emptyFunction;=0A=
    return element;=0A=
=0A=
  }, {=0A=
    refresh: function() {=0A=
      // extend methods for all tags (Safari doesn't need this)=0A=
      if (!Prototype.BrowserFeatures.ElementExtensions) {=0A=
        Object.extend(Methods, Element.Methods);=0A=
        Object.extend(Methods, Element.Methods.Simulated);=0A=
      }=0A=
    }=0A=
  });=0A=
=0A=
  extend.refresh();=0A=
  return extend;=0A=
})();=0A=
=0A=
Element.hasAttribute =3D function(element, attribute) {=0A=
  if (element.hasAttribute) return element.hasAttribute(attribute);=0A=
  return Element.Methods.Simulated.hasAttribute(element, attribute);=0A=
};=0A=
=0A=
Element.addMethods =3D function(methods) {=0A=
  var F =3D Prototype.BrowserFeatures, T =3D Element.Methods.ByTag;=0A=
=0A=
  if (!methods) {=0A=
    Object.extend(Form, Form.Methods);=0A=
    Object.extend(Form.Element, Form.Element.Methods);=0A=
    Object.extend(Element.Methods.ByTag, {=0A=
      "FORM":     Object.clone(Form.Methods),=0A=
      "INPUT":    Object.clone(Form.Element.Methods),=0A=
      "SELECT":   Object.clone(Form.Element.Methods),=0A=
      "TEXTAREA": Object.clone(Form.Element.Methods)=0A=
    });=0A=
  }=0A=
=0A=
  if (arguments.length =3D=3D 2) {=0A=
    var tagName =3D methods;=0A=
    methods =3D arguments[1];=0A=
  }=0A=
=0A=
  if (!tagName) Object.extend(Element.Methods, methods || { });=0A=
  else {=0A=
    if (Object.isArray(tagName)) tagName.each(extend);=0A=
    else extend(tagName);=0A=
  }=0A=
=0A=
  function extend(tagName) {=0A=
    tagName =3D tagName.toUpperCase();=0A=
    if (!Element.Methods.ByTag[tagName])=0A=
      Element.Methods.ByTag[tagName] =3D { };=0A=
    Object.extend(Element.Methods.ByTag[tagName], methods);=0A=
  }=0A=
=0A=
  function copy(methods, destination, onlyIfAbsent) {=0A=
    onlyIfAbsent =3D onlyIfAbsent || false;=0A=
    for (var property in methods) {=0A=
      var value =3D methods[property];=0A=
      if (!Object.isFunction(value)) continue;=0A=
      if (!onlyIfAbsent || !(property in destination))=0A=
        destination[property] =3D value.methodize();=0A=
    }=0A=
  }=0A=
=0A=
  function findDOMClass(tagName) {=0A=
    var klass;=0A=
    var trans =3D {=0A=
      "OPTGROUP": "OptGroup", "TEXTAREA": "TextArea", "P": "Paragraph",=0A=
      "FIELDSET": "FieldSet", "UL": "UList", "OL": "OList", "DL": =
"DList",=0A=
      "DIR": "Directory", "H1": "Heading", "H2": "Heading", "H3": =
"Heading",=0A=
      "H4": "Heading", "H5": "Heading", "H6": "Heading", "Q": "Quote",=0A=
      "INS": "Mod", "DEL": "Mod", "A": "Anchor", "IMG": "Image", =
"CAPTION":=0A=
      "TableCaption", "COL": "TableCol", "COLGROUP": "TableCol", "THEAD":=0A=
      "TableSection", "TFOOT": "TableSection", "TBODY": "TableSection", =
"TR":=0A=
      "TableRow", "TH": "TableCell", "TD": "TableCell", "FRAMESET":=0A=
      "FrameSet", "IFRAME": "IFrame"=0A=
    };=0A=
    if (trans[tagName]) klass =3D 'HTML' + trans[tagName] + 'Element';=0A=
    if (window[klass]) return window[klass];=0A=
    klass =3D 'HTML' + tagName + 'Element';=0A=
    if (window[klass]) return window[klass];=0A=
    klass =3D 'HTML' + tagName.capitalize() + 'Element';=0A=
    if (window[klass]) return window[klass];=0A=
=0A=
    window[klass] =3D { };=0A=
    window[klass].prototype =3D =
document.createElement(tagName).__proto__;=0A=
    return window[klass];=0A=
  }=0A=
=0A=
  if (F.ElementExtensions) {=0A=
    copy(Element.Methods, HTMLElement.prototype);=0A=
    copy(Element.Methods.Simulated, HTMLElement.prototype, true);=0A=
  }=0A=
=0A=
  if (F.SpecificElementExtensions) {=0A=
    for (var tag in Element.Methods.ByTag) {=0A=
      var klass =3D findDOMClass(tag);=0A=
      if (Object.isUndefined(klass)) continue;=0A=
      copy(T[tag], klass.prototype);=0A=
    }=0A=
  }=0A=
=0A=
  Object.extend(Element, Element.Methods);=0A=
  delete Element.ByTag;=0A=
=0A=
  if (Element.extend.refresh) Element.extend.refresh();=0A=
  Element.cache =3D { };=0A=
};=0A=
=0A=
document.viewport =3D {=0A=
  getDimensions: function() {=0A=
    var dimensions =3D { };=0A=
    var B =3D Prototype.Browser;=0A=
    $w('width height').each(function(d) {=0A=
      var D =3D d.capitalize();=0A=
      dimensions[d] =3D (B.WebKit && !document.evaluate) ? self['inner' =
+ D] :=0A=
        (B.Opera) ? document.body['client' + D] : =
document.documentElement['client' + D];=0A=
    });=0A=
    return dimensions;=0A=
  },=0A=
=0A=
  getWidth: function() {=0A=
    return this.getDimensions().width;=0A=
  },=0A=
=0A=
  getHeight: function() {=0A=
    return this.getDimensions().height;=0A=
  },=0A=
=0A=
  getScrollOffsets: function() {=0A=
    return Element._returnOffset(=0A=
      window.pageXOffset || document.documentElement.scrollLeft || =
document.body.scrollLeft,=0A=
      window.pageYOffset || document.documentElement.scrollTop || =
document.body.scrollTop);=0A=
  }=0A=
};=0A=
/* Portions of the Selector class are derived from Jack Slocum=E2=80=99s =
DomQuery,=0A=
 * part of YUI-Ext version 0.40, distributed under the terms of an =
MIT-style=0A=
 * license.  Please see http://www.yui-ext.com/ for more information. */=0A=
=0A=
var Selector =3D Class.create({=0A=
  initialize: function(expression) {=0A=
    this.expression =3D expression.strip();=0A=
    this.compileMatcher();=0A=
  },=0A=
=0A=
  shouldUseXPath: function() {=0A=
    if (!Prototype.BrowserFeatures.XPath) return false;=0A=
=0A=
    var e =3D this.expression;=0A=
=0A=
    // Safari 3 chokes on :*-of-type and :empty=0A=
    if (Prototype.Browser.WebKit &&=0A=
     (e.include("-of-type") || e.include(":empty")))=0A=
      return false;=0A=
=0A=
    // XPath can't do namespaced attributes, nor can it read=0A=
    // the "checked" property from DOM nodes=0A=
    if ((/(\[[\w-]*?:|:checked)/).test(this.expression))=0A=
      return false;=0A=
=0A=
    return true;=0A=
  },=0A=
=0A=
  compileMatcher: function() {=0A=
    if (this.shouldUseXPath())=0A=
      return this.compileXPathMatcher();=0A=
=0A=
    var e =3D this.expression, ps =3D Selector.patterns, h =3D =
Selector.handlers,=0A=
        c =3D Selector.criteria, le, p, m;=0A=
=0A=
    if (Selector._cache[e]) {=0A=
      this.matcher =3D Selector._cache[e];=0A=
      return;=0A=
    }=0A=
=0A=
    this.matcher =3D ["this.matcher =3D function(root) {",=0A=
                    "var r =3D root, h =3D Selector.handlers, c =3D =
false, n;"];=0A=
=0A=
    while (e && le !=3D e && (/\S/).test(e)) {=0A=
      le =3D e;=0A=
      for (var i in ps) {=0A=
        p =3D ps[i];=0A=
        if (m =3D e.match(p)) {=0A=
          this.matcher.push(Object.isFunction(c[i]) ? c[i](m) :=0A=
    	      new Template(c[i]).evaluate(m));=0A=
          e =3D e.replace(m[0], '');=0A=
          break;=0A=
        }=0A=
      }=0A=
    }=0A=
=0A=
    this.matcher.push("return h.unique(n);\n}");=0A=
    eval(this.matcher.join('\n'));=0A=
    Selector._cache[this.expression] =3D this.matcher;=0A=
  },=0A=
=0A=
  compileXPathMatcher: function() {=0A=
    var e =3D this.expression, ps =3D Selector.patterns,=0A=
        x =3D Selector.xpath, le, m;=0A=
=0A=
    if (Selector._cache[e]) {=0A=
      this.xpath =3D Selector._cache[e]; return;=0A=
    }=0A=
=0A=
    this.matcher =3D ['.//*'];=0A=
    while (e && le !=3D e && (/\S/).test(e)) {=0A=
      le =3D e;=0A=
      for (var i in ps) {=0A=
        if (m =3D e.match(ps[i])) {=0A=
          this.matcher.push(Object.isFunction(x[i]) ? x[i](m) :=0A=
            new Template(x[i]).evaluate(m));=0A=
          e =3D e.replace(m[0], '');=0A=
          break;=0A=
        }=0A=
      }=0A=
    }=0A=
=0A=
    this.xpath =3D this.matcher.join('');=0A=
    Selector._cache[this.expression] =3D this.xpath;=0A=
  },=0A=
=0A=
  findElements: function(root) {=0A=
    root =3D root || document;=0A=
    if (this.xpath) return document._getElementsByXPath(this.xpath, =
root);=0A=
    return this.matcher(root);=0A=
  },=0A=
=0A=
  match: function(element) {=0A=
    this.tokens =3D [];=0A=
=0A=
    var e =3D this.expression, ps =3D Selector.patterns, as =3D =
Selector.assertions;=0A=
    var le, p, m;=0A=
=0A=
    while (e && le !=3D=3D e && (/\S/).test(e)) {=0A=
      le =3D e;=0A=
      for (var i in ps) {=0A=
        p =3D ps[i];=0A=
        if (m =3D e.match(p)) {=0A=
          // use the Selector.assertions methods unless the selector=0A=
          // is too complex.=0A=
          if (as[i]) {=0A=
            this.tokens.push([i, Object.clone(m)]);=0A=
            e =3D e.replace(m[0], '');=0A=
          } else {=0A=
            // reluctantly do a document-wide search=0A=
            // and look for a match in the array=0A=
            return this.findElements(document).include(element);=0A=
          }=0A=
        }=0A=
      }=0A=
    }=0A=
=0A=
    var match =3D true, name, matches;=0A=
    for (var i =3D 0, token; token =3D this.tokens[i]; i++) {=0A=
      name =3D token[0], matches =3D token[1];=0A=
      if (!Selector.assertions[name](element, matches)) {=0A=
        match =3D false; break;=0A=
      }=0A=
    }=0A=
=0A=
    return match;=0A=
  },=0A=
=0A=
  toString: function() {=0A=
    return this.expression;=0A=
  },=0A=
=0A=
  inspect: function() {=0A=
    return "#<Selector:" + this.expression.inspect() + ">";=0A=
  }=0A=
});=0A=
=0A=
Object.extend(Selector, {=0A=
  _cache: { },=0A=
=0A=
  xpath: {=0A=
    descendant:   "//*",=0A=
    child:        "/*",=0A=
    adjacent:     "/following-sibling::*[1]",=0A=
    laterSibling: '/following-sibling::*',=0A=
    tagName:      function(m) {=0A=
      if (m[1] =3D=3D '*') return '';=0A=
      return "[local-name()=3D'" + m[1].toLowerCase() +=0A=
             "' or local-name()=3D'" + m[1].toUpperCase() + "']";=0A=
    },=0A=
    className:    "[contains(concat(' ', @class, ' '), ' #{1} ')]",=0A=
    id:           "[@id=3D'#{1}']",=0A=
    attrPresence: function(m) {=0A=
      m[1] =3D m[1].toLowerCase();=0A=
      return new Template("[@#{1}]").evaluate(m);=0A=
    },=0A=
    attr: function(m) {=0A=
      m[1] =3D m[1].toLowerCase();=0A=
      m[3] =3D m[5] || m[6];=0A=
      return new Template(Selector.xpath.operators[m[2]]).evaluate(m);=0A=
    },=0A=
    pseudo: function(m) {=0A=
      var h =3D Selector.xpath.pseudos[m[1]];=0A=
      if (!h) return '';=0A=
      if (Object.isFunction(h)) return h(m);=0A=
      return new Template(Selector.xpath.pseudos[m[1]]).evaluate(m);=0A=
    },=0A=
    operators: {=0A=
      '=3D':  "[@#{1}=3D'#{3}']",=0A=
      '!=3D': "[@#{1}!=3D'#{3}']",=0A=
      '^=3D': "[starts-with(@#{1}, '#{3}')]",=0A=
      '$=3D': "[substring(@#{1}, (string-length(@#{1}) - =
string-length('#{3}') + 1))=3D'#{3}']",=0A=
      '*=3D': "[contains(@#{1}, '#{3}')]",=0A=
      '~=3D': "[contains(concat(' ', @#{1}, ' '), ' #{3} ')]",=0A=
      '|=3D': "[contains(concat('-', @#{1}, '-'), '-#{3}-')]"=0A=
    },=0A=
    pseudos: {=0A=
      'first-child': '[not(preceding-sibling::*)]',=0A=
      'last-child':  '[not(following-sibling::*)]',=0A=
      'only-child':  '[not(preceding-sibling::* or =
following-sibling::*)]',=0A=
      'empty':       "[count(*) =3D 0 and (count(text()) =3D 0 or =
translate(text(), ' \t\r\n', '') =3D '')]",=0A=
      'checked':     "[@checked]",=0A=
      'disabled':    "[@disabled]",=0A=
      'enabled':     "[not(@disabled)]",=0A=
      'not': function(m) {=0A=
        var e =3D m[6], p =3D Selector.patterns,=0A=
            x =3D Selector.xpath, le, v;=0A=
=0A=
        var exclusion =3D [];=0A=
        while (e && le !=3D e && (/\S/).test(e)) {=0A=
          le =3D e;=0A=
          for (var i in p) {=0A=
            if (m =3D e.match(p[i])) {=0A=
              v =3D Object.isFunction(x[i]) ? x[i](m) : new =
Template(x[i]).evaluate(m);=0A=
              exclusion.push("(" + v.substring(1, v.length - 1) + ")");=0A=
              e =3D e.replace(m[0], '');=0A=
              break;=0A=
            }=0A=
          }=0A=
        }=0A=
        return "[not(" + exclusion.join(" and ") + ")]";=0A=
      },=0A=
      'nth-child':      function(m) {=0A=
        return =
Selector.xpath.pseudos.nth("(count(./preceding-sibling::*) + 1) ", m);=0A=
      },=0A=
      'nth-last-child': function(m) {=0A=
        return =
Selector.xpath.pseudos.nth("(count(./following-sibling::*) + 1) ", m);=0A=
      },=0A=
      'nth-of-type':    function(m) {=0A=
        return Selector.xpath.pseudos.nth("position() ", m);=0A=
      },=0A=
      'nth-last-of-type': function(m) {=0A=
        return Selector.xpath.pseudos.nth("(last() + 1 - position()) ", =
m);=0A=
      },=0A=
      'first-of-type':  function(m) {=0A=
        m[6] =3D "1"; return Selector.xpath.pseudos['nth-of-type'](m);=0A=
      },=0A=
      'last-of-type':   function(m) {=0A=
        m[6] =3D "1"; return =
Selector.xpath.pseudos['nth-last-of-type'](m);=0A=
      },=0A=
      'only-of-type':   function(m) {=0A=
        var p =3D Selector.xpath.pseudos; return p['first-of-type'](m) + =
p['last-of-type'](m);=0A=
      },=0A=
      nth: function(fragment, m) {=0A=
        var mm, formula =3D m[6], predicate;=0A=
        if (formula =3D=3D 'even') formula =3D '2n+0';=0A=
        if (formula =3D=3D 'odd')  formula =3D '2n+1';=0A=
        if (mm =3D formula.match(/^(\d+)$/)) // digit only=0A=
          return '[' + fragment + "=3D " + mm[1] + ']';=0A=
        if (mm =3D formula.match(/^(-?\d*)?n(([+-])(\d+))?/)) { // an+b=0A=
          if (mm[1] =3D=3D "-") mm[1] =3D -1;=0A=
          var a =3D mm[1] ? Number(mm[1]) : 1;=0A=
          var b =3D mm[2] ? Number(mm[2]) : 0;=0A=
          predicate =3D "[((#{fragment} - #{b}) mod #{a} =3D 0) and " +=0A=
          "((#{fragment} - #{b}) div #{a} >=3D 0)]";=0A=
          return new Template(predicate).evaluate({=0A=
            fragment: fragment, a: a, b: b });=0A=
        }=0A=
      }=0A=
    }=0A=
  },=0A=
=0A=
  criteria: {=0A=
    tagName:      'n =3D h.tagName(n, r, "#{1}", c);   c =3D false;',=0A=
    className:    'n =3D h.className(n, r, "#{1}", c); c =3D false;',=0A=
    id:           'n =3D h.id(n, r, "#{1}", c);        c =3D false;',=0A=
    attrPresence: 'n =3D h.attrPresence(n, r, "#{1}"); c =3D false;',=0A=
    attr: function(m) {=0A=
      m[3] =3D (m[5] || m[6]);=0A=
      return new Template('n =3D h.attr(n, r, "#{1}", "#{3}", "#{2}"); c =
=3D false;').evaluate(m);=0A=
    },=0A=
    pseudo: function(m) {=0A=
      if (m[6]) m[6] =3D m[6].replace(/"/g, '\\"');=0A=
      return new Template('n =3D h.pseudo(n, "#{1}", "#{6}", r, c); c =
=3D false;').evaluate(m);=0A=
    },=0A=
    descendant:   'c =3D "descendant";',=0A=
    child:        'c =3D "child";',=0A=
    adjacent:     'c =3D "adjacent";',=0A=
    laterSibling: 'c =3D "laterSibling";'=0A=
  },=0A=
=0A=
  patterns: {=0A=
    // combinators must be listed first=0A=
    // (and descendant needs to be last combinator)=0A=
    laterSibling: /^\s*~\s*/,=0A=
    child:        /^\s*>\s*/,=0A=
    adjacent:     /^\s*\+\s*/,=0A=
    descendant:   /^\s/,=0A=
=0A=
    // selectors follow=0A=
    tagName:      /^\s*(\*|[\w\-]+)(\b|$)?/,=0A=
    id:           /^#([\w\-\*]+)(\b|$)/,=0A=
    className:    /^\.([\w\-\*]+)(\b|$)/,=0A=
    pseudo:       =
/^:((first|last|nth|nth-last|only)(-child|-of-type)|empty|checked|(en|dis=
)abled|not)(\((.*?)\))?(\b|$|(?=3D\s)|(?=3D:))/,=0A=
    attrPresence: /^\[([\w]+)\]/,=0A=
    attr:         =
/\[((?:[\w-]*:)?[\w-]+)\s*(?:([!^$*~|]?=3D)\s*((['"])([^\4]*?)\4|([^'"][^=
\]]*?)))?\]/=0A=
  },=0A=
=0A=
  // for Selector.match and Element#match=0A=
  assertions: {=0A=
    tagName: function(element, matches) {=0A=
      return matches[1].toUpperCase() =3D=3D =
element.tagName.toUpperCase();=0A=
    },=0A=
=0A=
    className: function(element, matches) {=0A=
      return Element.hasClassName(element, matches[1]);=0A=
    },=0A=
=0A=
    id: function(element, matches) {=0A=
      return element.id =3D=3D=3D matches[1];=0A=
    },=0A=
=0A=
    attrPresence: function(element, matches) {=0A=
      return Element.hasAttribute(element, matches[1]);=0A=
    },=0A=
=0A=
    attr: function(element, matches) {=0A=
      var nodeValue =3D Element.readAttribute(element, matches[1]);=0A=
      return Selector.operators[matches[2]](nodeValue, matches[3]);=0A=
    }=0A=
  },=0A=
=0A=
  handlers: {=0A=
    // UTILITY FUNCTIONS=0A=
    // joins two collections=0A=
    concat: function(a, b) {=0A=
      for (var i =3D 0, node; node =3D b[i]; i++)=0A=
        a.push(node);=0A=
      return a;=0A=
    },=0A=
=0A=
    // marks an array of nodes for counting=0A=
    mark: function(nodes) {=0A=
      for (var i =3D 0, node; node =3D nodes[i]; i++)=0A=
        node._counted =3D true;=0A=
      return nodes;=0A=
    },=0A=
=0A=
    unmark: function(nodes) {=0A=
      for (var i =3D 0, node; node =3D nodes[i]; i++)=0A=
        node._counted =3D undefined;=0A=
      return nodes;=0A=
    },=0A=
=0A=
    // mark each child node with its position (for nth calls)=0A=
    // "ofType" flag indicates whether we're indexing for nth-of-type=0A=
    // rather than nth-child=0A=
    index: function(parentNode, reverse, ofType) {=0A=
      parentNode._counted =3D true;=0A=
      if (reverse) {=0A=
        for (var nodes =3D parentNode.childNodes, i =3D nodes.length - =
1, j =3D 1; i >=3D 0; i--) {=0A=
          var node =3D nodes[i];=0A=
          if (node.nodeType =3D=3D 1 && (!ofType || node._counted)) =
node.nodeIndex =3D j++;=0A=
        }=0A=
      } else {=0A=
        for (var i =3D 0, j =3D 1, nodes =3D parentNode.childNodes; node =
=3D nodes[i]; i++)=0A=
          if (node.nodeType =3D=3D 1 && (!ofType || node._counted)) =
node.nodeIndex =3D j++;=0A=
      }=0A=
    },=0A=
=0A=
    // filters out duplicates and extends all nodes=0A=
    unique: function(nodes) {=0A=
      if (nodes.length =3D=3D 0) return nodes;=0A=
      var results =3D [], n;=0A=
      for (var i =3D 0, l =3D nodes.length; i < l; i++)=0A=
        if (!(n =3D nodes[i])._counted) {=0A=
          n._counted =3D true;=0A=
          results.push(Element.extend(n));=0A=
        }=0A=
      return Selector.handlers.unmark(results);=0A=
    },=0A=
=0A=
    // COMBINATOR FUNCTIONS=0A=
    descendant: function(nodes) {=0A=
      var h =3D Selector.handlers;=0A=
      for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++)=0A=
        h.concat(results, node.getElementsByTagName('*'));=0A=
      return results;=0A=
    },=0A=
=0A=
    child: function(nodes) {=0A=
      var h =3D Selector.handlers;=0A=
      for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++) {=0A=
        for (var j =3D 0, child; child =3D node.childNodes[j]; j++)=0A=
          if (child.nodeType =3D=3D 1 && child.tagName !=3D '!') =
results.push(child);=0A=
      }=0A=
      return results;=0A=
    },=0A=
=0A=
    adjacent: function(nodes) {=0A=
      for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++) {=0A=
        var next =3D this.nextElementSibling(node);=0A=
        if (next) results.push(next);=0A=
      }=0A=
      return results;=0A=
    },=0A=
=0A=
    laterSibling: function(nodes) {=0A=
      var h =3D Selector.handlers;=0A=
      for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++)=0A=
        h.concat(results, Element.nextSiblings(node));=0A=
      return results;=0A=
    },=0A=
=0A=
    nextElementSibling: function(node) {=0A=
      while (node =3D node.nextSibling)=0A=
	      if (node.nodeType =3D=3D 1) return node;=0A=
      return null;=0A=
    },=0A=
=0A=
    previousElementSibling: function(node) {=0A=
      while (node =3D node.previousSibling)=0A=
        if (node.nodeType =3D=3D 1) return node;=0A=
      return null;=0A=
    },=0A=
=0A=
    // TOKEN FUNCTIONS=0A=
    tagName: function(nodes, root, tagName, combinator) {=0A=
      tagName =3D tagName.toUpperCase();=0A=
      var results =3D [], h =3D Selector.handlers;=0A=
      if (nodes) {=0A=
        if (combinator) {=0A=
          // fastlane for ordinary descendant combinators=0A=
          if (combinator =3D=3D "descendant") {=0A=
            for (var i =3D 0, node; node =3D nodes[i]; i++)=0A=
              h.concat(results, node.getElementsByTagName(tagName));=0A=
            return results;=0A=
          } else nodes =3D this[combinator](nodes);=0A=
          if (tagName =3D=3D "*") return nodes;=0A=
        }=0A=
        for (var i =3D 0, node; node =3D nodes[i]; i++)=0A=
          if (node.tagName.toUpperCase() =3D=3D tagName) =
results.push(node);=0A=
        return results;=0A=
      } else return root.getElementsByTagName(tagName);=0A=
    },=0A=
=0A=
    id: function(nodes, root, id, combinator) {=0A=
      var targetNode =3D $(id), h =3D Selector.handlers;=0A=
      if (!targetNode) return [];=0A=
      if (!nodes && root =3D=3D document) return [targetNode];=0A=
      if (nodes) {=0A=
        if (combinator) {=0A=
          if (combinator =3D=3D 'child') {=0A=
            for (var i =3D 0, node; node =3D nodes[i]; i++)=0A=
              if (targetNode.parentNode =3D=3D node) return [targetNode];=0A=
          } else if (combinator =3D=3D 'descendant') {=0A=
            for (var i =3D 0, node; node =3D nodes[i]; i++)=0A=
              if (Element.descendantOf(targetNode, node)) return =
[targetNode];=0A=
          } else if (combinator =3D=3D 'adjacent') {=0A=
            for (var i =3D 0, node; node =3D nodes[i]; i++)=0A=
              if (Selector.handlers.previousElementSibling(targetNode) =
=3D=3D node)=0A=
                return [targetNode];=0A=
          } else nodes =3D h[combinator](nodes);=0A=
        }=0A=
        for (var i =3D 0, node; node =3D nodes[i]; i++)=0A=
          if (node =3D=3D targetNode) return [targetNode];=0A=
        return [];=0A=
      }=0A=
      return (targetNode && Element.descendantOf(targetNode, root)) ? =
[targetNode] : [];=0A=
    },=0A=
=0A=
    className: function(nodes, root, className, combinator) {=0A=
      if (nodes && combinator) nodes =3D this[combinator](nodes);=0A=
      return Selector.handlers.byClassName(nodes, root, className);=0A=
    },=0A=
=0A=
    byClassName: function(nodes, root, className) {=0A=
      if (!nodes) nodes =3D Selector.handlers.descendant([root]);=0A=
      var needle =3D ' ' + className + ' ';=0A=
      for (var i =3D 0, results =3D [], node, nodeClassName; node =3D =
nodes[i]; i++) {=0A=
        nodeClassName =3D node.className;=0A=
        if (nodeClassName.length =3D=3D 0) continue;=0A=
        if (nodeClassName =3D=3D className || (' ' + nodeClassName + ' =
').include(needle))=0A=
          results.push(node);=0A=
      }=0A=
      return results;=0A=
    },=0A=
=0A=
    attrPresence: function(nodes, root, attr) {=0A=
      if (!nodes) nodes =3D root.getElementsByTagName("*");=0A=
      var results =3D [];=0A=
      for (var i =3D 0, node; node =3D nodes[i]; i++)=0A=
        if (Element.hasAttribute(node, attr)) results.push(node);=0A=
      return results;=0A=
    },=0A=
=0A=
    attr: function(nodes, root, attr, value, operator) {=0A=
      if (!nodes) nodes =3D root.getElementsByTagName("*");=0A=
      var handler =3D Selector.operators[operator], results =3D [];=0A=
      for (var i =3D 0, node; node =3D nodes[i]; i++) {=0A=
        var nodeValue =3D Element.readAttribute(node, attr);=0A=
        if (nodeValue =3D=3D=3D null) continue;=0A=
        if (handler(nodeValue, value)) results.push(node);=0A=
      }=0A=
      return results;=0A=
    },=0A=
=0A=
    pseudo: function(nodes, name, value, root, combinator) {=0A=
      if (nodes && combinator) nodes =3D this[combinator](nodes);=0A=
      if (!nodes) nodes =3D root.getElementsByTagName("*");=0A=
      return Selector.pseudos[name](nodes, value, root);=0A=
    }=0A=
  },=0A=
=0A=
  pseudos: {=0A=
    'first-child': function(nodes, value, root) {=0A=
      for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++) {=0A=
        if (Selector.handlers.previousElementSibling(node)) continue;=0A=
          results.push(node);=0A=
      }=0A=
      return results;=0A=
    },=0A=
    'last-child': function(nodes, value, root) {=0A=
      for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++) {=0A=
        if (Selector.handlers.nextElementSibling(node)) continue;=0A=
          results.push(node);=0A=
      }=0A=
      return results;=0A=
    },=0A=
    'only-child': function(nodes, value, root) {=0A=
      var h =3D Selector.handlers;=0A=
      for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++)=0A=
        if (!h.previousElementSibling(node) && =
!h.nextElementSibling(node))=0A=
          results.push(node);=0A=
      return results;=0A=
    },=0A=
    'nth-child':        function(nodes, formula, root) {=0A=
      return Selector.pseudos.nth(nodes, formula, root);=0A=
    },=0A=
    'nth-last-child':   function(nodes, formula, root) {=0A=
      return Selector.pseudos.nth(nodes, formula, root, true);=0A=
    },=0A=
    'nth-of-type':      function(nodes, formula, root) {=0A=
      return Selector.pseudos.nth(nodes, formula, root, false, true);=0A=
    },=0A=
    'nth-last-of-type': function(nodes, formula, root) {=0A=
      return Selector.pseudos.nth(nodes, formula, root, true, true);=0A=
    },=0A=
    'first-of-type':    function(nodes, formula, root) {=0A=
      return Selector.pseudos.nth(nodes, "1", root, false, true);=0A=
    },=0A=
    'last-of-type':     function(nodes, formula, root) {=0A=
      return Selector.pseudos.nth(nodes, "1", root, true, true);=0A=
    },=0A=
    'only-of-type':     function(nodes, formula, root) {=0A=
      var p =3D Selector.pseudos;=0A=
      return p['last-of-type'](p['first-of-type'](nodes, formula, root), =
formula, root);=0A=
    },=0A=
=0A=
    // handles the an+b logic=0A=
    getIndices: function(a, b, total) {=0A=
      if (a =3D=3D 0) return b > 0 ? [b] : [];=0A=
      return $R(1, total).inject([], function(memo, i) {=0A=
        if (0 =3D=3D (i - b) % a && (i - b) / a >=3D 0) memo.push(i);=0A=
        return memo;=0A=
      });=0A=
    },=0A=
=0A=
    // handles nth(-last)-child, nth(-last)-of-type, and =
(first|last)-of-type=0A=
    nth: function(nodes, formula, root, reverse, ofType) {=0A=
      if (nodes.length =3D=3D 0) return [];=0A=
      if (formula =3D=3D 'even') formula =3D '2n+0';=0A=
      if (formula =3D=3D 'odd')  formula =3D '2n+1';=0A=
      var h =3D Selector.handlers, results =3D [], indexed =3D [], m;=0A=
      h.mark(nodes);=0A=
      for (var i =3D 0, node; node =3D nodes[i]; i++) {=0A=
        if (!node.parentNode._counted) {=0A=
          h.index(node.parentNode, reverse, ofType);=0A=
          indexed.push(node.parentNode);=0A=
        }=0A=
      }=0A=
      if (formula.match(/^\d+$/)) { // just a number=0A=
        formula =3D Number(formula);=0A=
        for (var i =3D 0, node; node =3D nodes[i]; i++)=0A=
          if (node.nodeIndex =3D=3D formula) results.push(node);=0A=
      } else if (m =3D formula.match(/^(-?\d*)?n(([+-])(\d+))?/)) { // =
an+b=0A=
        if (m[1] =3D=3D "-") m[1] =3D -1;=0A=
        var a =3D m[1] ? Number(m[1]) : 1;=0A=
        var b =3D m[2] ? Number(m[2]) : 0;=0A=
        var indices =3D Selector.pseudos.getIndices(a, b, nodes.length);=0A=
        for (var i =3D 0, node, l =3D indices.length; node =3D nodes[i]; =
i++) {=0A=
          for (var j =3D 0; j < l; j++)=0A=
            if (node.nodeIndex =3D=3D indices[j]) results.push(node);=0A=
        }=0A=
      }=0A=
      h.unmark(nodes);=0A=
      h.unmark(indexed);=0A=
      return results;=0A=
    },=0A=
=0A=
    'empty': function(nodes, value, root) {=0A=
      for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++) {=0A=
        // IE treats comments as element nodes=0A=
        if (node.tagName =3D=3D '!' || (node.firstChild && =
!node.innerHTML.match(/^\s*$/))) continue;=0A=
        results.push(node);=0A=
      }=0A=
      return results;=0A=
    },=0A=
=0A=
    'not': function(nodes, selector, root) {=0A=
      var h =3D Selector.handlers, selectorType, m;=0A=
      var exclusions =3D new Selector(selector).findElements(root);=0A=
      h.mark(exclusions);=0A=
      for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++)=0A=
        if (!node._counted) results.push(node);=0A=
      h.unmark(exclusions);=0A=
      return results;=0A=
    },=0A=
=0A=
    'enabled': function(nodes, value, root) {=0A=
      for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++)=0A=
        if (!node.disabled) results.push(node);=0A=
      return results;=0A=
    },=0A=
=0A=
    'disabled': function(nodes, value, root) {=0A=
      for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++)=0A=
        if (node.disabled) results.push(node);=0A=
      return results;=0A=
    },=0A=
=0A=
    'checked': function(nodes, value, root) {=0A=
      for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++)=0A=
        if (node.checked) results.push(node);=0A=
      return results;=0A=
    }=0A=
  },=0A=
=0A=
  operators: {=0A=
    '=3D':  function(nv, v) { return nv =3D=3D v; },=0A=
    '!=3D': function(nv, v) { return nv !=3D v; },=0A=
    '^=3D': function(nv, v) { return nv.startsWith(v); },=0A=
    '$=3D': function(nv, v) { return nv.endsWith(v); },=0A=
    '*=3D': function(nv, v) { return nv.include(v); },=0A=
    '~=3D': function(nv, v) { return (' ' + nv + ' ').include(' ' + v + =
' '); },=0A=
    '|=3D': function(nv, v) { return ('-' + nv.toUpperCase() + =
'-').include('-' + v.toUpperCase() + '-'); }=0A=
  },=0A=
=0A=
  matchElements: function(elements, expression) {=0A=
    var matches =3D new Selector(expression).findElements(), h =3D =
Selector.handlers;=0A=
    h.mark(matches);=0A=
    for (var i =3D 0, results =3D [], element; element =3D elements[i]; =
i++)=0A=
      if (element._counted) results.push(element);=0A=
    h.unmark(matches);=0A=
    return results;=0A=
  },=0A=
=0A=
  findElement: function(elements, expression, index) {=0A=
    if (Object.isNumber(expression)) {=0A=
      index =3D expression; expression =3D false;=0A=
    }=0A=
    return Selector.matchElements(elements, expression || '*')[index || =
0];=0A=
  },=0A=
=0A=
  findChildElements: function(element, expressions) {=0A=
    var exprs =3D expressions.join(',');=0A=
    expressions =3D [];=0A=
    exprs.scan(/(([\w#:.~>+()\s-]+|\*|\[.*?\])+)\s*(,|$)/, function(m) {=0A=
      expressions.push(m[1].strip());=0A=
    });=0A=
    var results =3D [], h =3D Selector.handlers;=0A=
    for (var i =3D 0, l =3D expressions.length, selector; i < l; i++) {=0A=
      selector =3D new Selector(expressions[i].strip());=0A=
      h.concat(results, selector.findElements(element));=0A=
    }=0A=
    return (l > 1) ? h.unique(results) : results;=0A=
  }=0A=
});=0A=
=0A=
if (Prototype.Browser.IE) {=0A=
  // IE returns comment nodes on getElementsByTagName("*").=0A=
  // Filter them out.=0A=
  Selector.handlers.concat =3D function(a, b) {=0A=
    for (var i =3D 0, node; node =3D b[i]; i++)=0A=
      if (node.tagName !=3D=3D "!") a.push(node);=0A=
    return a;=0A=
  };=0A=
}=0A=
=0A=
function $$() {=0A=
  return Selector.findChildElements(document, $A(arguments));=0A=
}=0A=
var Form =3D {=0A=
  reset: function(form) {=0A=
    $(form).reset();=0A=
    return form;=0A=
  },=0A=
=0A=
  serializeElements: function(elements, options) {=0A=
    if (typeof options !=3D 'object') options =3D { hash: !!options };=0A=
    else if (Object.isUndefined(options.hash)) options.hash =3D true;=0A=
    var key, value, submitted =3D false, submit =3D options.submit;=0A=
=0A=
    var data =3D elements.inject({ }, function(result, element) {=0A=
      if (!element.disabled && element.name) {=0A=
        key =3D element.name; value =3D $(element).getValue();=0A=
        if (value !=3D null && (element.type !=3D 'submit' || =
(!submitted &&=0A=
            submit !=3D=3D false && (!submit || key =3D=3D submit) && =
(submitted =3D true)))) {=0A=
          if (key in result) {=0A=
            // a key is already present; construct an array of values=0A=
            if (!Object.isArray(result[key])) result[key] =3D =
[result[key]];=0A=
            result[key].push(value);=0A=
          }=0A=
          else result[key] =3D value;=0A=
        }=0A=
      }=0A=
      return result;=0A=
    });=0A=
=0A=
    return options.hash ? data : Object.toQueryString(data);=0A=
  }=0A=
};=0A=
=0A=
Form.Methods =3D {=0A=
  serialize: function(form, options) {=0A=
    return Form.serializeElements(Form.getElements(form), options);=0A=
  },=0A=
=0A=
  getElements: function(form) {=0A=
    return $A($(form).getElementsByTagName('*')).inject([],=0A=
      function(elements, child) {=0A=
        if (Form.Element.Serializers[child.tagName.toLowerCase()])=0A=
          elements.push(Element.extend(child));=0A=
        return elements;=0A=
      }=0A=
    );=0A=
  },=0A=
=0A=
  getInputs: function(form, typeName, name) {=0A=
    form =3D $(form);=0A=
    var inputs =3D form.getElementsByTagName('input');=0A=
=0A=
    if (!typeName && !name) return $A(inputs).map(Element.extend);=0A=
=0A=
    for (var i =3D 0, matchingInputs =3D [], length =3D inputs.length; i =
< length; i++) {=0A=
      var input =3D inputs[i];=0A=
      if ((typeName && input.type !=3D typeName) || (name && input.name =
!=3D name))=0A=
        continue;=0A=
      matchingInputs.push(Element.extend(input));=0A=
    }=0A=
=0A=
    return matchingInputs;=0A=
  },=0A=
=0A=
  disable: function(form) {=0A=
    form =3D $(form);=0A=
    Form.getElements(form).invoke('disable');=0A=
    return form;=0A=
  },=0A=
=0A=
  enable: function(form) {=0A=
    form =3D $(form);=0A=
    Form.getElements(form).invoke('enable');=0A=
    return form;=0A=
  },=0A=
=0A=
  findFirstElement: function(form) {=0A=
    var elements =3D $(form).getElements().findAll(function(element) {=0A=
      return 'hidden' !=3D element.type && !element.disabled;=0A=
    });=0A=
    var firstByIndex =3D elements.findAll(function(element) {=0A=
      return element.hasAttribute('tabIndex') && element.tabIndex >=3D 0;=0A=
    }).sortBy(function(element) { return element.tabIndex }).first();=0A=
=0A=
    return firstByIndex ? firstByIndex : elements.find(function(element) =
{=0A=
      return ['input', 'select', =
'textarea'].include(element.tagName.toLowerCase());=0A=
    });=0A=
  },=0A=
=0A=
  focusFirstElement: function(form) {=0A=
    form =3D $(form);=0A=
    form.findFirstElement().activate();=0A=
    return form;=0A=
  },=0A=
=0A=
  request: function(form, options) {=0A=
    form =3D $(form), options =3D Object.clone(options || { });=0A=
=0A=
    var params =3D options.parameters, action =3D =
form.readAttribute('action') || '';=0A=
    if (action.blank()) action =3D window.location.href;=0A=
    options.parameters =3D form.serialize(true);=0A=
=0A=
    if (params) {=0A=
      if (Object.isString(params)) params =3D params.toQueryParams();=0A=
      Object.extend(options.parameters, params);=0A=
    }=0A=
=0A=
    if (form.hasAttribute('method') && !options.method)=0A=
      options.method =3D form.method;=0A=
=0A=
    return new Ajax.Request(action, options);=0A=
  }=0A=
};=0A=
=0A=
/*-----------------------------------------------------------------------=
---*/=0A=
=0A=
Form.Element =3D {=0A=
  focus: function(element) {=0A=
    $(element).focus();=0A=
    return element;=0A=
  },=0A=
=0A=
  select: function(element) {=0A=
    $(element).select();=0A=
    return element;=0A=
  }=0A=
};=0A=
=0A=
Form.Element.Methods =3D {=0A=
  serialize: function(element) {=0A=
    element =3D $(element);=0A=
    if (!element.disabled && element.name) {=0A=
      var value =3D element.getValue();=0A=
      if (value !=3D undefined) {=0A=
        var pair =3D { };=0A=
        pair[element.name] =3D value;=0A=
        return Object.toQueryString(pair);=0A=
      }=0A=
    }=0A=
    return '';=0A=
  },=0A=
=0A=
  getValue: function(element) {=0A=
    element =3D $(element);=0A=
    var method =3D element.tagName.toLowerCase();=0A=
    return Form.Element.Serializers[method](element);=0A=
  },=0A=
=0A=
  setValue: function(element, value) {=0A=
    element =3D $(element);=0A=
    var method =3D element.tagName.toLowerCase();=0A=
    Form.Element.Serializers[method](element, value);=0A=
    return element;=0A=
  },=0A=
=0A=
  clear: function(element) {=0A=
    $(element).value =3D '';=0A=
    return element;=0A=
  },=0A=
=0A=
  present: function(element) {=0A=
    return $(element).value !=3D '';=0A=
  },=0A=
=0A=
  activate: function(element) {=0A=
    element =3D $(element);=0A=
    try {=0A=
      element.focus();=0A=
      if (element.select && (element.tagName.toLowerCase() !=3D 'input' =
||=0A=
          !['button', 'reset', 'submit'].include(element.type)))=0A=
        element.select();=0A=
    } catch (e) { }=0A=
    return element;=0A=
  },=0A=
=0A=
  disable: function(element) {=0A=
    element =3D $(element);=0A=
    element.blur();=0A=
    element.disabled =3D true;=0A=
    return element;=0A=
  },=0A=
=0A=
  enable: function(element) {=0A=
    element =3D $(element);=0A=
    element.disabled =3D false;=0A=
    return element;=0A=
  }=0A=
};=0A=
=0A=
/*-----------------------------------------------------------------------=
---*/=0A=
=0A=
var Field =3D Form.Element;=0A=
var $F =3D Form.Element.Methods.getValue;=0A=
=0A=
/*-----------------------------------------------------------------------=
---*/=0A=
=0A=
Form.Element.Serializers =3D {=0A=
  input: function(element, value) {=0A=
    switch (element.type.toLowerCase()) {=0A=
      case 'checkbox':=0A=
      case 'radio':=0A=
        return Form.Element.Serializers.inputSelector(element, value);=0A=
      default:=0A=
        return Form.Element.Serializers.textarea(element, value);=0A=
    }=0A=
  },=0A=
=0A=
  inputSelector: function(element, value) {=0A=
    if (Object.isUndefined(value)) return element.checked ? =
element.value : null;=0A=
    else element.checked =3D !!value;=0A=
  },=0A=
=0A=
  textarea: function(element, value) {=0A=
    if (Object.isUndefined(value)) return element.value;=0A=
    else element.value =3D value;=0A=
  },=0A=
=0A=
  select: function(element, index) {=0A=
    if (Object.isUndefined(index))=0A=
      return this[element.type =3D=3D 'select-one' ?=0A=
        'selectOne' : 'selectMany'](element);=0A=
    else {=0A=
      var opt, value, single =3D !Object.isArray(index);=0A=
      for (var i =3D 0, length =3D element.length; i < length; i++) {=0A=
        opt =3D element.options[i];=0A=
        value =3D this.optionValue(opt);=0A=
        if (single) {=0A=
          if (value =3D=3D index) {=0A=
            opt.selected =3D true;=0A=
            return;=0A=
          }=0A=
        }=0A=
        else opt.selected =3D index.include(value);=0A=
      }=0A=
    }=0A=
  },=0A=
=0A=
  selectOne: function(element) {=0A=
    var index =3D element.selectedIndex;=0A=
    return index >=3D 0 ? this.optionValue(element.options[index]) : =
null;=0A=
  },=0A=
=0A=
  selectMany: function(element) {=0A=
    var values, length =3D element.length;=0A=
    if (!length) return null;=0A=
=0A=
    for (var i =3D 0, values =3D []; i < length; i++) {=0A=
      var opt =3D element.options[i];=0A=
      if (opt.selected) values.push(this.optionValue(opt));=0A=
    }=0A=
    return values;=0A=
  },=0A=
=0A=
  optionValue: function(opt) {=0A=
    // extend element because hasAttribute may not be native=0A=
    return Element.extend(opt).hasAttribute('value') ? opt.value : =
opt.text;=0A=
  }=0A=
};=0A=
=0A=
/*-----------------------------------------------------------------------=
---*/=0A=
=0A=
Abstract.TimedObserver =3D Class.create(PeriodicalExecuter, {=0A=
  initialize: function($super, element, frequency, callback) {=0A=
    $super(callback, frequency);=0A=
    this.element   =3D $(element);=0A=
    this.lastValue =3D this.getValue();=0A=
  },=0A=
=0A=
  execute: function() {=0A=
    var value =3D this.getValue();=0A=
    if (Object.isString(this.lastValue) && Object.isString(value) ?=0A=
        this.lastValue !=3D value : String(this.lastValue) !=3D =
String(value)) {=0A=
      this.callback(this.element, value);=0A=
      this.lastValue =3D value;=0A=
    }=0A=
  }=0A=
});=0A=
=0A=
Form.Element.Observer =3D Class.create(Abstract.TimedObserver, {=0A=
  getValue: function() {=0A=
    return Form.Element.getValue(this.element);=0A=
  }=0A=
});=0A=
=0A=
Form.Observer =3D Class.create(Abstract.TimedObserver, {=0A=
  getValue: function() {=0A=
    return Form.serialize(this.element);=0A=
  }=0A=
});=0A=
=0A=
/*-----------------------------------------------------------------------=
---*/=0A=
=0A=
Abstract.EventObserver =3D Class.create({=0A=
  initialize: function(element, callback) {=0A=
    this.element  =3D $(element);=0A=
    this.callback =3D callback;=0A=
=0A=
    this.lastValue =3D this.getValue();=0A=
    if (this.element.tagName.toLowerCase() =3D=3D 'form')=0A=
      this.registerFormCallbacks();=0A=
    else=0A=
      this.registerCallback(this.element);=0A=
  },=0A=
=0A=
  onElementEvent: function() {=0A=
    var value =3D this.getValue();=0A=
    if (this.lastValue !=3D value) {=0A=
      this.callback(this.element, value);=0A=
      this.lastValue =3D value;=0A=
    }=0A=
  },=0A=
=0A=
  registerFormCallbacks: function() {=0A=
    Form.getElements(this.element).each(this.registerCallback, this);=0A=
  },=0A=
=0A=
  registerCallback: function(element) {=0A=
    if (element.type) {=0A=
      switch (element.type.toLowerCase()) {=0A=
        case 'checkbox':=0A=
        case 'radio':=0A=
          Event.observe(element, 'click', =
this.onElementEvent.bind(this));=0A=
          break;=0A=
        default:=0A=
          Event.observe(element, 'change', =
this.onElementEvent.bind(this));=0A=
          break;=0A=
      }=0A=
    }=0A=
  }=0A=
});=0A=
=0A=
Form.Element.EventObserver =3D Class.create(Abstract.EventObserver, {=0A=
  getValue: function() {=0A=
    return Form.Element.getValue(this.element);=0A=
  }=0A=
});=0A=
=0A=
Form.EventObserver =3D Class.create(Abstract.EventObserver, {=0A=
  getValue: function() {=0A=
    return Form.serialize(this.element);=0A=
  }=0A=
});=0A=
if (!window.Event) var Event =3D { };=0A=
=0A=
Object.extend(Event, {=0A=
  KEY_BACKSPACE: 8,=0A=
  KEY_TAB:       9,=0A=
  KEY_RETURN:   13,=0A=
  KEY_ESC:      27,=0A=
  KEY_LEFT:     37,=0A=
  KEY_UP:       38,=0A=
  KEY_RIGHT:    39,=0A=
  KEY_DOWN:     40,=0A=
  KEY_DELETE:   46,=0A=
  KEY_HOME:     36,=0A=
  KEY_END:      35,=0A=
  KEY_PAGEUP:   33,=0A=
  KEY_PAGEDOWN: 34,=0A=
  KEY_INSERT:   45,=0A=
=0A=
  cache: { },=0A=
=0A=
  relatedTarget: function(event) {=0A=
    var element;=0A=
    switch(event.type) {=0A=
      case 'mouseover': element =3D event.fromElement; break;=0A=
      case 'mouseout':  element =3D event.toElement;   break;=0A=
      default: return null;=0A=
    }=0A=
    return Element.extend(element);=0A=
  }=0A=
});=0A=
=0A=
Event.Methods =3D (function() {=0A=
  var isButton;=0A=
=0A=
  if (Prototype.Browser.IE) {=0A=
    var buttonMap =3D { 0: 1, 1: 4, 2: 2 };=0A=
    isButton =3D function(event, code) {=0A=
      return event.button =3D=3D buttonMap[code];=0A=
    };=0A=
=0A=
  } else if (Prototype.Browser.WebKit) {=0A=
    isButton =3D function(event, code) {=0A=
      switch (code) {=0A=
        case 0: return event.which =3D=3D 1 && !event.metaKey;=0A=
        case 1: return event.which =3D=3D 1 && event.metaKey;=0A=
        default: return false;=0A=
      }=0A=
    };=0A=
=0A=
  } else {=0A=
    isButton =3D function(event, code) {=0A=
      return event.which ? (event.which =3D=3D=3D code + 1) : =
(event.button =3D=3D=3D code);=0A=
    };=0A=
  }=0A=
=0A=
  return {=0A=
    isLeftClick:   function(event) { return isButton(event, 0) },=0A=
    isMiddleClick: function(event) { return isButton(event, 1) },=0A=
    isRightClick:  function(event) { return isButton(event, 2) },=0A=
=0A=
    element: function(event) {=0A=
      var node =3D Event.extend(event).target;=0A=
      return Element.extend(node.nodeType =3D=3D Node.TEXT_NODE ? =
node.parentNode : node);=0A=
    },=0A=
=0A=
    findElement: function(event, expression) {=0A=
      var element =3D Event.element(event);=0A=
      if (!expression) return element;=0A=
      var elements =3D [element].concat(element.ancestors());=0A=
      return Selector.findElement(elements, expression, 0);=0A=
    },=0A=
=0A=
    pointer: function(event) {=0A=
      return {=0A=
        x: event.pageX || (event.clientX +=0A=
          (document.documentElement.scrollLeft || =
document.body.scrollLeft)),=0A=
        y: event.pageY || (event.clientY +=0A=
          (document.documentElement.scrollTop || =
document.body.scrollTop))=0A=
      };=0A=
    },=0A=
=0A=
    pointerX: function(event) { return Event.pointer(event).x },=0A=
    pointerY: function(event) { return Event.pointer(event).y },=0A=
=0A=
    stop: function(event) {=0A=
      Event.extend(event);=0A=
      event.preventDefault();=0A=
      event.stopPropagation();=0A=
      event.stopped =3D true;=0A=
    }=0A=
  };=0A=
})();=0A=
=0A=
Event.extend =3D (function() {=0A=
  var methods =3D Object.keys(Event.Methods).inject({ }, function(m, =
name) {=0A=
    m[name] =3D Event.Methods[name].methodize();=0A=
    return m;=0A=
  });=0A=
=0A=
  if (Prototype.Browser.IE) {=0A=
    Object.extend(methods, {=0A=
      stopPropagation: function() { this.cancelBubble =3D true },=0A=
      preventDefault:  function() { this.returnValue =3D false },=0A=
      inspect: function() { return "[object Event]" }=0A=
    });=0A=
=0A=
    return function(event) {=0A=
      if (!event) return false;=0A=
      if (event._extendedByPrototype) return event;=0A=
=0A=
      event._extendedByPrototype =3D Prototype.emptyFunction;=0A=
      var pointer =3D Event.pointer(event);=0A=
      Object.extend(event, {=0A=
        target: event.srcElement,=0A=
        relatedTarget: Event.relatedTarget(event),=0A=
        pageX:  pointer.x,=0A=
        pageY:  pointer.y=0A=
      });=0A=
      return Object.extend(event, methods);=0A=
    };=0A=
=0A=
  } else {=0A=
    Event.prototype =3D Event.prototype || =
document.createEvent("HTMLEvents").__proto__;=0A=
    Object.extend(Event.prototype, methods);=0A=
    return Prototype.K;=0A=
  }=0A=
})();=0A=
=0A=
Object.extend(Event, (function() {=0A=
  var cache =3D Event.cache;=0A=
=0A=
  function getEventID(element) {=0A=
    if (element._eventID) return element._eventID;=0A=
    arguments.callee.id =3D arguments.callee.id || 1;=0A=
    return element._eventID =3D ++arguments.callee.id;=0A=
  }=0A=
=0A=
  function getDOMEventName(eventName) {=0A=
    if (eventName && eventName.include(':')) return "dataavailable";=0A=
    return eventName;=0A=
  }=0A=
=0A=
  function getCacheForID(id) {=0A=
    return cache[id] =3D cache[id] || { };=0A=
  }=0A=
=0A=
  function getWrappersForEventName(id, eventName) {=0A=
    var c =3D getCacheForID(id);=0A=
    return c[eventName] =3D c[eventName] || [];=0A=
  }=0A=
=0A=
  function createWrapper(element, eventName, handler) {=0A=
    var id =3D getEventID(element);=0A=
    var c =3D getWrappersForEventName(id, eventName);=0A=
    if (c.pluck("handler").include(handler)) return false;=0A=
=0A=
    var wrapper =3D function(event) {=0A=
      if (!Event || !Event.extend ||=0A=
        (event.eventName && event.eventName !=3D eventName))=0A=
          return false;=0A=
=0A=
      Event.extend(event);=0A=
      handler.call(element, event)=0A=
    };=0A=
=0A=
    wrapper.handler =3D handler;=0A=
    c.push(wrapper);=0A=
    return wrapper;=0A=
  }=0A=
=0A=
  function findWrapper(id, eventName, handler) {=0A=
    var c =3D getWrappersForEventName(id, eventName);=0A=
    return c.find(function(wrapper) { return wrapper.handler =3D=3D =
handler });=0A=
  }=0A=
=0A=
  function destroyWrapper(id, eventName, handler) {=0A=
    var c =3D getCacheForID(id);=0A=
    if (!c[eventName]) return false;=0A=
    c[eventName] =3D c[eventName].without(findWrapper(id, eventName, =
handler));=0A=
  }=0A=
=0A=
  function destroyCache() {=0A=
    for (var id in cache)=0A=
      for (var eventName in cache[id])=0A=
        cache[id][eventName] =3D null;=0A=
  }=0A=
=0A=
  if (window.attachEvent) {=0A=
    window.attachEvent("onunload", destroyCache);=0A=
  }=0A=
=0A=
  return {=0A=
    observe: function(element, eventName, handler) {=0A=
      element =3D $(element);=0A=
      var name =3D getDOMEventName(eventName);=0A=
=0A=
      var wrapper =3D createWrapper(element, eventName, handler);=0A=
      if (!wrapper) return element;=0A=
=0A=
      if (element.addEventListener) {=0A=
        element.addEventListener(name, wrapper, false);=0A=
      } else {=0A=
        element.attachEvent("on" + name, wrapper);=0A=
      }=0A=
=0A=
      return element;=0A=
    },=0A=
=0A=
    stopObserving: function(element, eventName, handler) {=0A=
      element =3D $(element);=0A=
      var id =3D getEventID(element), name =3D =
getDOMEventName(eventName);=0A=
=0A=
      if (!handler && eventName) {=0A=
        getWrappersForEventName(id, eventName).each(function(wrapper) {=0A=
          element.stopObserving(eventName, wrapper.handler);=0A=
        });=0A=
        return element;=0A=
=0A=
      } else if (!eventName) {=0A=
        Object.keys(getCacheForID(id)).each(function(eventName) {=0A=
          element.stopObserving(eventName);=0A=
        });=0A=
        return element;=0A=
      }=0A=
=0A=
      var wrapper =3D findWrapper(id, eventName, handler);=0A=
      if (!wrapper) return element;=0A=
=0A=
      if (element.removeEventListener) {=0A=
        element.removeEventListener(name, wrapper, false);=0A=
      } else {=0A=
        element.detachEvent("on" + name, wrapper);=0A=
      }=0A=
=0A=
      destroyWrapper(id, eventName, handler);=0A=
=0A=
      return element;=0A=
    },=0A=
=0A=
    fire: function(element, eventName, memo) {=0A=
      element =3D $(element);=0A=
      if (element =3D=3D document && document.createEvent && =
!element.dispatchEvent)=0A=
        element =3D document.documentElement;=0A=
=0A=
      if (document.createEvent) {=0A=
        var event =3D document.createEvent("HTMLEvents");=0A=
        event.initEvent("dataavailable", true, true);=0A=
      } else {=0A=
        var event =3D document.createEventObject();=0A=
        event.eventType =3D "ondataavailable";=0A=
      }=0A=
=0A=
      event.eventName =3D eventName;=0A=
      event.memo =3D memo || { };=0A=
=0A=
      if (document.createEvent) {=0A=
        element.dispatchEvent(event);=0A=
      } else {=0A=
        element.fireEvent(event.eventType, event);=0A=
      }=0A=
=0A=
      return Event.extend(event);=0A=
    }=0A=
  };=0A=
})());=0A=
=0A=
Object.extend(Event, Event.Methods);=0A=
=0A=
Element.addMethods({=0A=
  fire:          Event.fire,=0A=
  observe:       Event.observe,=0A=
  stopObserving: Event.stopObserving=0A=
});=0A=
=0A=
Object.extend(document, {=0A=
  fire:          Element.Methods.fire.methodize(),=0A=
  observe:       Element.Methods.observe.methodize(),=0A=
  stopObserving: Element.Methods.stopObserving.methodize()=0A=
});=0A=
=0A=
(function() {=0A=
  /* Support for the DOMContentLoaded event is based on work by Dan Webb,=0A=
     Matthias Miller, Dean Edwards and John Resig. */=0A=
=0A=
  var timer, fired =3D false;=0A=
=0A=
  function fireContentLoadedEvent() {=0A=
    if (fired) return;=0A=
    if (timer) window.clearInterval(timer);=0A=
    document.fire("dom:loaded");=0A=
    fired =3D true;=0A=
  }=0A=
=0A=
  if (document.addEventListener) {=0A=
    if (Prototype.Browser.WebKit) {=0A=
      timer =3D window.setInterval(function() {=0A=
        if (/loaded|complete/.test(document.readyState))=0A=
          fireContentLoadedEvent();=0A=
      }, 0);=0A=
=0A=
      Event.observe(window, "load", fireContentLoadedEvent);=0A=
=0A=
    } else {=0A=
      document.addEventListener("DOMContentLoaded",=0A=
        fireContentLoadedEvent, false);=0A=
    }=0A=
=0A=
  } else {=0A=
    document.write("<script id=3D__onDOMContentLoaded defer =
src=3D//:><\/script>");=0A=
    $("__onDOMContentLoaded").onreadystatechange =3D function() {=0A=
      if (this.readyState =3D=3D "complete") {=0A=
        this.onreadystatechange =3D null;=0A=
        fireContentLoadedEvent();=0A=
      }=0A=
    };=0A=
  }=0A=
})();=0A=
/*------------------------------- DEPRECATED =
-------------------------------*/=0A=
=0A=
Hash.toQueryString =3D Object.toQueryString;=0A=
=0A=
var Toggle =3D { display: Element.toggle };=0A=
=0A=
Element.Methods.childOf =3D Element.Methods.descendantOf;=0A=
=0A=
var Insertion =3D {=0A=
  Before: function(element, content) {=0A=
    return Element.insert(element, {before:content});=0A=
  },=0A=
=0A=
  Top: function(element, content) {=0A=
    return Element.insert(element, {top:content});=0A=
  },=0A=
=0A=
  Bottom: function(element, content) {=0A=
    return Element.insert(element, {bottom:content});=0A=
  },=0A=
=0A=
  After: function(element, content) {=0A=
    return Element.insert(element, {after:content});=0A=
  }=0A=
};=0A=
=0A=
var $continue =3D new Error('"throw $continue" is deprecated, use =
"return" instead');=0A=
=0A=
// This should be moved to script.aculo.us; notice the deprecated methods=0A=
// further below, that map to the newer Element methods.=0A=
var Position =3D {=0A=
  // set to true if needed, warning: firefox performance problems=0A=
  // NOT neeeded for page scrolling, only if draggable contained in=0A=
  // scrollable elements=0A=
  includeScrollOffsets: false,=0A=
=0A=
  // must be called before calling withinIncludingScrolloffset, every =
time the=0A=
  // page is scrolled=0A=
  prepare: function() {=0A=
    this.deltaX =3D  window.pageXOffset=0A=
                || document.documentElement.scrollLeft=0A=
                || document.body.scrollLeft=0A=
                || 0;=0A=
    this.deltaY =3D  window.pageYOffset=0A=
                || document.documentElement.scrollTop=0A=
                || document.body.scrollTop=0A=
                || 0;=0A=
  },=0A=
=0A=
  // caches x/y coordinate pair to use with overlap=0A=
  within: function(element, x, y) {=0A=
    if (this.includeScrollOffsets)=0A=
      return this.withinIncludingScrolloffsets(element, x, y);=0A=
    this.xcomp =3D x;=0A=
    this.ycomp =3D y;=0A=
    this.offset =3D Element.cumulativeOffset(element);=0A=
=0A=
    return (y >=3D this.offset[1] &&=0A=
            y <  this.offset[1] + element.offsetHeight &&=0A=
            x >=3D this.offset[0] &&=0A=
            x <  this.offset[0] + element.offsetWidth);=0A=
  },=0A=
=0A=
  withinIncludingScrolloffsets: function(element, x, y) {=0A=
    var offsetcache =3D Element.cumulativeScrollOffset(element);=0A=
=0A=
    this.xcomp =3D x + offsetcache[0] - this.deltaX;=0A=
    this.ycomp =3D y + offsetcache[1] - this.deltaY;=0A=
    this.offset =3D Element.cumulativeOffset(element);=0A=
=0A=
    return (this.ycomp >=3D this.offset[1] &&=0A=
            this.ycomp <  this.offset[1] + element.offsetHeight &&=0A=
            this.xcomp >=3D this.offset[0] &&=0A=
            this.xcomp <  this.offset[0] + element.offsetWidth);=0A=
  },=0A=
=0A=
  // within must be called directly before=0A=
  overlap: function(mode, element) {=0A=
    if (!mode) return 0;=0A=
    if (mode =3D=3D 'vertical')=0A=
      return ((this.offset[1] + element.offsetHeight) - this.ycomp) /=0A=
        element.offsetHeight;=0A=
    if (mode =3D=3D 'horizontal')=0A=
      return ((this.offset[0] + element.offsetWidth) - this.xcomp) /=0A=
        element.offsetWidth;=0A=
  },=0A=
=0A=
  // Deprecation layer -- use newer Element methods now (1.5.2).=0A=
=0A=
  cumulativeOffset: Element.Methods.cumulativeOffset,=0A=
=0A=
  positionedOffset: Element.Methods.positionedOffset,=0A=
=0A=
  absolutize: function(element) {=0A=
    Position.prepare();=0A=
    return Element.absolutize(element);=0A=
  },=0A=
=0A=
  relativize: function(element) {=0A=
    Position.prepare();=0A=
    return Element.relativize(element);=0A=
  },=0A=
=0A=
  realOffset: Element.Methods.cumulativeScrollOffset,=0A=
=0A=
  offsetParent: Element.Methods.getOffsetParent,=0A=
=0A=
  page: Element.Methods.viewportOffset,=0A=
=0A=
  clone: function(source, target, options) {=0A=
    options =3D options || { };=0A=
    return Element.clonePosition(target, source, options);=0A=
  }=0A=
};=0A=
=0A=
/*-----------------------------------------------------------------------=
---*/=0A=
=0A=
if (!document.getElementsByClassName) document.getElementsByClassName =
=3D function(instanceMethods){=0A=
  function iter(name) {=0A=
    return name.blank() ? null : "[contains(concat(' ', @class, ' '), ' =
" + name + " ')]";=0A=
  }=0A=
=0A=
  instanceMethods.getElementsByClassName =3D =
Prototype.BrowserFeatures.XPath ?=0A=
  function(element, className) {=0A=
    className =3D className.toString().strip();=0A=
    var cond =3D /\s/.test(className) ? $w(className).map(iter).join('') =
: iter(className);=0A=
    return cond ? document._getElementsByXPath('.//*' + cond, element) : =
[];=0A=
  } : function(element, className) {=0A=
    className =3D className.toString().strip();=0A=
    var elements =3D [], classNames =3D (/\s/.test(className) ? =
$w(className) : null);=0A=
    if (!classNames && !className) return elements;=0A=
=0A=
    var nodes =3D $(element).getElementsByTagName('*');=0A=
    className =3D ' ' + className + ' ';=0A=
=0A=
    for (var i =3D 0, child, cn; child =3D nodes[i]; i++) {=0A=
      if (child.className && (cn =3D ' ' + child.className + ' ') && =
(cn.include(className) ||=0A=
          (classNames && classNames.all(function(name) {=0A=
            return !name.toString().blank() && cn.include(' ' + name + ' =
');=0A=
          }))))=0A=
        elements.push(Element.extend(child));=0A=
    }=0A=
    return elements;=0A=
  };=0A=
=0A=
  return function(className, parentElement) {=0A=
    return $(parentElement || =
document.body).getElementsByClassName(className);=0A=
  };=0A=
}(Element.Methods);=0A=
=0A=
/*-----------------------------------------------------------------------=
---*/=0A=
=0A=
Element.ClassNames =3D Class.create();=0A=
Element.ClassNames.prototype =3D {=0A=
  initialize: function(element) {=0A=
    this.element =3D $(element);=0A=
  },=0A=
=0A=
  _each: function(iterator) {=0A=
    this.element.className.split(/\s+/).select(function(name) {=0A=
      return name.length > 0;=0A=
    })._each(iterator);=0A=
  },=0A=
=0A=
  set: function(className) {=0A=
    this.element.className =3D className;=0A=
  },=0A=
=0A=
  add: function(classNameToAdd) {=0A=
    if (this.include(classNameToAdd)) return;=0A=
    this.set($A(this).concat(classNameToAdd).join(' '));=0A=
  },=0A=
=0A=
  remove: function(classNameToRemove) {=0A=
    if (!this.include(classNameToRemove)) return;=0A=
    this.set($A(this).without(classNameToRemove).join(' '));=0A=
  },=0A=
=0A=
  toString: function() {=0A=
    return $A(this).join(' ');=0A=
  }=0A=
};=0A=
=0A=
Object.extend(Element.ClassNames.prototype, Enumerable);=0A=
=0A=
/*-----------------------------------------------------------------------=
---*/=0A=
=0A=
Element.addMethods();
------=_NextPart_000_0000_01CAB168.786EE890
Content-Type: application/octet-stream
Content-Transfer-Encoding: quoted-printable
Content-Location: http://www.eenews.net/javascripts/effects.js?1218125236

// Copyright (c) 2005-2007 Thomas Fuchs (http://script.aculo.us, =
http://mir.aculo.us)=0A=
// Contributors:=0A=
//  Justin Palmer (http://encytemedia.com/)=0A=
//  Mark Pilgrim (http://diveintomark.org/)=0A=
//  Martin Bialasinki=0A=
// =0A=
// script.aculo.us is freely distributable under the terms of an =
MIT-style license.=0A=
// For details, see the script.aculo.us web site: =
http://script.aculo.us/ =0A=
=0A=
// converts rgb() and #xxx to #xxxxxx format,  =0A=
// returns self (or first argument) if not convertable  =0A=
String.prototype.parseColor =3D function() {  =0A=
  var color =3D '#';=0A=
  if (this.slice(0,4) =3D=3D 'rgb(') {  =0A=
    var cols =3D this.slice(4,this.length-1).split(',');  =0A=
    var i=3D0; do { color +=3D parseInt(cols[i]).toColorPart() } while =
(++i<3);  =0A=
  } else {  =0A=
    if (this.slice(0,1) =3D=3D '#') {  =0A=
      if (this.length=3D=3D4) for(var i=3D1;i<4;i++) color +=3D =
(this.charAt(i) + this.charAt(i)).toLowerCase();  =0A=
      if (this.length=3D=3D7) color =3D this.toLowerCase();  =0A=
    }  =0A=
  }  =0A=
  return (color.length=3D=3D7 ? color : (arguments[0] || this));  =0A=
};=0A=
=0A=
/*-----------------------------------------------------------------------=
---*/=0A=
=0A=
Element.collectTextNodes =3D function(element) {  =0A=
  return $A($(element).childNodes).collect( function(node) {=0A=
    return (node.nodeType=3D=3D3 ? node.nodeValue : =0A=
      (node.hasChildNodes() ? Element.collectTextNodes(node) : ''));=0A=
  }).flatten().join('');=0A=
};=0A=
=0A=
Element.collectTextNodesIgnoreClass =3D function(element, className) {  =0A=
  return $A($(element).childNodes).collect( function(node) {=0A=
    return (node.nodeType=3D=3D3 ? node.nodeValue : =0A=
      ((node.hasChildNodes() && !Element.hasClassName(node,className)) ? =0A=
        Element.collectTextNodesIgnoreClass(node, className) : ''));=0A=
  }).flatten().join('');=0A=
};=0A=
=0A=
Element.setContentZoom =3D function(element, percent) {=0A=
  element =3D $(element);  =0A=
  element.setStyle({fontSize: (percent/100) + 'em'});   =0A=
  if (Prototype.Browser.WebKit) window.scrollBy(0,0);=0A=
  return element;=0A=
};=0A=
=0A=
Element.getInlineOpacity =3D function(element){=0A=
  return $(element).style.opacity || '';=0A=
};=0A=
=0A=
Element.forceRerendering =3D function(element) {=0A=
  try {=0A=
    element =3D $(element);=0A=
    var n =3D document.createTextNode(' ');=0A=
    element.appendChild(n);=0A=
    element.removeChild(n);=0A=
  } catch(e) { }=0A=
};=0A=
=0A=
/*-----------------------------------------------------------------------=
---*/=0A=
=0A=
var Effect =3D {=0A=
  _elementDoesNotExistError: {=0A=
    name: 'ElementDoesNotExistError',=0A=
    message: 'The specified DOM element does not exist, but is required =
for this effect to operate'=0A=
  },=0A=
  Transitions: {=0A=
    linear: Prototype.K,=0A=
    sinoidal: function(pos) {=0A=
      return (-Math.cos(pos*Math.PI)/2) + 0.5;=0A=
    },=0A=
    reverse: function(pos) {=0A=
      return 1-pos;=0A=
    },=0A=
    flicker: function(pos) {=0A=
      var pos =3D ((-Math.cos(pos*Math.PI)/4) + 0.75) + Math.random()/4;=0A=
      return pos > 1 ? 1 : pos;=0A=
    },=0A=
    wobble: function(pos) {=0A=
      return (-Math.cos(pos*Math.PI*(9*pos))/2) + 0.5;=0A=
    },=0A=
    pulse: function(pos, pulses) { =0A=
      pulses =3D pulses || 5; =0A=
      return (=0A=
        ((pos % (1/pulses)) * pulses).round() =3D=3D 0 ? =0A=
              ((pos * pulses * 2) - (pos * pulses * 2).floor()) : =0A=
          1 - ((pos * pulses * 2) - (pos * pulses * 2).floor())=0A=
        );=0A=
    },=0A=
    spring: function(pos) { =0A=
      return 1 - (Math.cos(pos * 4.5 * Math.PI) * Math.exp(-pos * 6)); =0A=
    },=0A=
    none: function(pos) {=0A=
      return 0;=0A=
    },=0A=
    full: function(pos) {=0A=
      return 1;=0A=
    }=0A=
  },=0A=
  DefaultOptions: {=0A=
    duration:   1.0,   // seconds=0A=
    fps:        100,   // 100=3D assume 66fps max.=0A=
    sync:       false, // true for combining=0A=
    from:       0.0,=0A=
    to:         1.0,=0A=
    delay:      0.0,=0A=
    queue:      'parallel'=0A=
  },=0A=
  tagifyText: function(element) {=0A=
    var tagifyStyle =3D 'position:relative';=0A=
    if (Prototype.Browser.IE) tagifyStyle +=3D ';zoom:1';=0A=
    =0A=
    element =3D $(element);=0A=
    $A(element.childNodes).each( function(child) {=0A=
      if (child.nodeType=3D=3D3) {=0A=
        child.nodeValue.toArray().each( function(character) {=0A=
          element.insertBefore(=0A=
            new Element('span', {style: tagifyStyle}).update(=0A=
              character =3D=3D ' ' ? String.fromCharCode(160) : =
character), =0A=
              child);=0A=
        });=0A=
        Element.remove(child);=0A=
      }=0A=
    });=0A=
  },=0A=
  multiple: function(element, effect) {=0A=
    var elements;=0A=
    if (((typeof element =3D=3D 'object') || =0A=
        Object.isFunction(element)) && =0A=
       (element.length))=0A=
      elements =3D element;=0A=
    else=0A=
      elements =3D $(element).childNodes;=0A=
      =0A=
    var options =3D Object.extend({=0A=
      speed: 0.1,=0A=
      delay: 0.0=0A=
    }, arguments[2] || { });=0A=
    var masterDelay =3D options.delay;=0A=
=0A=
    $A(elements).each( function(element, index) {=0A=
      new effect(element, Object.extend(options, { delay: index * =
options.speed + masterDelay }));=0A=
    });=0A=
  },=0A=
  PAIRS: {=0A=
    'slide':  ['SlideDown','SlideUp'],=0A=
    'blind':  ['BlindDown','BlindUp'],=0A=
    'appear': ['Appear','Fade']=0A=
  },=0A=
  toggle: function(element, effect) {=0A=
    element =3D $(element);=0A=
    effect =3D (effect || 'appear').toLowerCase();=0A=
    var options =3D Object.extend({=0A=
      queue: { position:'end', scope:(element.id || 'global'), limit: 1 }=0A=
    }, arguments[2] || { });=0A=
    Effect[element.visible() ? =0A=
      Effect.PAIRS[effect][1] : Effect.PAIRS[effect][0]](element, =
options);=0A=
  }=0A=
};=0A=
=0A=
Effect.DefaultOptions.transition =3D Effect.Transitions.sinoidal;=0A=
=0A=
/* ------------- core effects ------------- */=0A=
=0A=
Effect.ScopedQueue =3D Class.create(Enumerable, {=0A=
  initialize: function() {=0A=
    this.effects  =3D [];=0A=
    this.interval =3D null;    =0A=
  },=0A=
  _each: function(iterator) {=0A=
    this.effects._each(iterator);=0A=
  },=0A=
  add: function(effect) {=0A=
    var timestamp =3D new Date().getTime();=0A=
    =0A=
    var position =3D Object.isString(effect.options.queue) ? =0A=
      effect.options.queue : effect.options.queue.position;=0A=
    =0A=
    switch(position) {=0A=
      case 'front':=0A=
        // move unstarted effects after this effect  =0A=
        this.effects.findAll(function(e){ return e.state=3D=3D'idle' =
}).each( function(e) {=0A=
            e.startOn  +=3D effect.finishOn;=0A=
            e.finishOn +=3D effect.finishOn;=0A=
          });=0A=
        break;=0A=
      case 'with-last':=0A=
        timestamp =3D this.effects.pluck('startOn').max() || timestamp;=0A=
        break;=0A=
      case 'end':=0A=
        // start effect after last queued effect has finished=0A=
        timestamp =3D this.effects.pluck('finishOn').max() || timestamp;=0A=
        break;=0A=
    }=0A=
    =0A=
    effect.startOn  +=3D timestamp;=0A=
    effect.finishOn +=3D timestamp;=0A=
=0A=
    if (!effect.options.queue.limit || (this.effects.length < =
effect.options.queue.limit))=0A=
      this.effects.push(effect);=0A=
    =0A=
    if (!this.interval)=0A=
      this.interval =3D setInterval(this.loop.bind(this), 15);=0A=
  },=0A=
  remove: function(effect) {=0A=
    this.effects =3D this.effects.reject(function(e) { return =
e=3D=3Deffect });=0A=
    if (this.effects.length =3D=3D 0) {=0A=
      clearInterval(this.interval);=0A=
      this.interval =3D null;=0A=
    }=0A=
  },=0A=
  loop: function() {=0A=
    var timePos =3D new Date().getTime();=0A=
    for(var i=3D0, len=3Dthis.effects.length;i<len;i++) =0A=
      this.effects[i] && this.effects[i].loop(timePos);=0A=
  }=0A=
});=0A=
=0A=
Effect.Queues =3D {=0A=
  instances: $H(),=0A=
  get: function(queueName) {=0A=
    if (!Object.isString(queueName)) return queueName;=0A=
    =0A=
    return this.instances.get(queueName) ||=0A=
      this.instances.set(queueName, new Effect.ScopedQueue());=0A=
  }=0A=
};=0A=
Effect.Queue =3D Effect.Queues.get('global');=0A=
=0A=
Effect.Base =3D Class.create({=0A=
  position: null,=0A=
  start: function(options) {=0A=
    function codeForEvent(options,eventName){=0A=
      return (=0A=
        (options[eventName+'Internal'] ? =
'this.options.'+eventName+'Internal(this);' : '') +=0A=
        (options[eventName] ? 'this.options.'+eventName+'(this);' : '')=0A=
      );=0A=
    }=0A=
    if (options && options.transition =3D=3D=3D false) =
options.transition =3D Effect.Transitions.linear;=0A=
    this.options      =3D Object.extend(Object.extend({ =
},Effect.DefaultOptions), options || { });=0A=
    this.currentFrame =3D 0;=0A=
    this.state        =3D 'idle';=0A=
    this.startOn      =3D this.options.delay*1000;=0A=
    this.finishOn     =3D this.startOn+(this.options.duration*1000);=0A=
    this.fromToDelta  =3D this.options.to-this.options.from;=0A=
    this.totalTime    =3D this.finishOn-this.startOn;=0A=
    this.totalFrames  =3D this.options.fps*this.options.duration;=0A=
    =0A=
    eval('this.render =3D function(pos){ '+=0A=
      'if (this.state=3D=3D"idle"){this.state=3D"running";'+=0A=
      codeForEvent(this.options,'beforeSetup')+=0A=
      (this.setup ? 'this.setup();':'')+ =0A=
      codeForEvent(this.options,'afterSetup')+=0A=
      '};if (this.state=3D=3D"running"){'+=0A=
      =
'pos=3Dthis.options.transition(pos)*'+this.fromToDelta+'+'+this.options.f=
rom+';'+=0A=
      'this.position=3Dpos;'+=0A=
      codeForEvent(this.options,'beforeUpdate')+=0A=
      (this.update ? 'this.update(pos);':'')+=0A=
      codeForEvent(this.options,'afterUpdate')+=0A=
      '}}');=0A=
    =0A=
    this.event('beforeStart');=0A=
    if (!this.options.sync)=0A=
      Effect.Queues.get(Object.isString(this.options.queue) ? =0A=
        'global' : this.options.queue.scope).add(this);=0A=
  },=0A=
  loop: function(timePos) {=0A=
    if (timePos >=3D this.startOn) {=0A=
      if (timePos >=3D this.finishOn) {=0A=
        this.render(1.0);=0A=
        this.cancel();=0A=
        this.event('beforeFinish');=0A=
        if (this.finish) this.finish(); =0A=
        this.event('afterFinish');=0A=
        return;  =0A=
      }=0A=
      var pos   =3D (timePos - this.startOn) / this.totalTime,=0A=
          frame =3D (pos * this.totalFrames).round();=0A=
      if (frame > this.currentFrame) {=0A=
        this.render(pos);=0A=
        this.currentFrame =3D frame;=0A=
      }=0A=
    }=0A=
  },=0A=
  cancel: function() {=0A=
    if (!this.options.sync)=0A=
      Effect.Queues.get(Object.isString(this.options.queue) ? =0A=
        'global' : this.options.queue.scope).remove(this);=0A=
    this.state =3D 'finished';=0A=
  },=0A=
  event: function(eventName) {=0A=
    if (this.options[eventName + 'Internal']) this.options[eventName + =
'Internal'](this);=0A=
    if (this.options[eventName]) this.options[eventName](this);=0A=
  },=0A=
  inspect: function() {=0A=
    var data =3D $H();=0A=
    for(property in this)=0A=
      if (!Object.isFunction(this[property])) data.set(property, =
this[property]);=0A=
    return '#<Effect:' + data.inspect() + ',options:' + =
$H(this.options).inspect() + '>';=0A=
  }=0A=
});=0A=
=0A=
Effect.Parallel =3D Class.create(Effect.Base, {=0A=
  initialize: function(effects) {=0A=
    this.effects =3D effects || [];=0A=
    this.start(arguments[1]);=0A=
  },=0A=
  update: function(position) {=0A=
    this.effects.invoke('render', position);=0A=
  },=0A=
  finish: function(position) {=0A=
    this.effects.each( function(effect) {=0A=
      effect.render(1.0);=0A=
      effect.cancel();=0A=
      effect.event('beforeFinish');=0A=
      if (effect.finish) effect.finish(position);=0A=
      effect.event('afterFinish');=0A=
    });=0A=
  }=0A=
});=0A=
=0A=
Effect.Tween =3D Class.create(Effect.Base, {=0A=
  initialize: function(object, from, to) {=0A=
    object =3D Object.isString(object) ? $(object) : object;=0A=
    var args =3D $A(arguments), method =3D args.last(), =0A=
      options =3D args.length =3D=3D 5 ? args[3] : null;=0A=
    this.method =3D Object.isFunction(method) ? method.bind(object) :=0A=
      Object.isFunction(object[method]) ? object[method].bind(object) : =0A=
      function(value) { object[method] =3D value };=0A=
    this.start(Object.extend({ from: from, to: to }, options || { }));=0A=
  },=0A=
  update: function(position) {=0A=
    this.method(position);=0A=
  }=0A=
});=0A=
=0A=
Effect.Event =3D Class.create(Effect.Base, {=0A=
  initialize: function() {=0A=
    this.start(Object.extend({ duration: 0 }, arguments[0] || { }));=0A=
  },=0A=
  update: Prototype.emptyFunction=0A=
});=0A=
=0A=
Effect.Opacity =3D Class.create(Effect.Base, {=0A=
  initialize: function(element) {=0A=
    this.element =3D $(element);=0A=
    if (!this.element) throw(Effect._elementDoesNotExistError);=0A=
    // make this work on IE on elements without 'layout'=0A=
    if (Prototype.Browser.IE && (!this.element.currentStyle.hasLayout))=0A=
      this.element.setStyle({zoom: 1});=0A=
    var options =3D Object.extend({=0A=
      from: this.element.getOpacity() || 0.0,=0A=
      to:   1.0=0A=
    }, arguments[1] || { });=0A=
    this.start(options);=0A=
  },=0A=
  update: function(position) {=0A=
    this.element.setOpacity(position);=0A=
  }=0A=
});=0A=
=0A=
Effect.Move =3D Class.create(Effect.Base, {=0A=
  initialize: function(element) {=0A=
    this.element =3D $(element);=0A=
    if (!this.element) throw(Effect._elementDoesNotExistError);=0A=
    var options =3D Object.extend({=0A=
      x:    0,=0A=
      y:    0,=0A=
      mode: 'relative'=0A=
    }, arguments[1] || { });=0A=
    this.start(options);=0A=
  },=0A=
  setup: function() {=0A=
    this.element.makePositioned();=0A=
    this.originalLeft =3D parseFloat(this.element.getStyle('left') || =
'0');=0A=
    this.originalTop  =3D parseFloat(this.element.getStyle('top')  || =
'0');=0A=
    if (this.options.mode =3D=3D 'absolute') {=0A=
      this.options.x =3D this.options.x - this.originalLeft;=0A=
      this.options.y =3D this.options.y - this.originalTop;=0A=
    }=0A=
  },=0A=
  update: function(position) {=0A=
    this.element.setStyle({=0A=
      left: (this.options.x  * position + this.originalLeft).round() + =
'px',=0A=
      top:  (this.options.y  * position + this.originalTop).round()  + =
'px'=0A=
    });=0A=
  }=0A=
});=0A=
=0A=
// for backwards compatibility=0A=
Effect.MoveBy =3D function(element, toTop, toLeft) {=0A=
  return new Effect.Move(element, =0A=
    Object.extend({ x: toLeft, y: toTop }, arguments[3] || { }));=0A=
};=0A=
=0A=
Effect.Scale =3D Class.create(Effect.Base, {=0A=
  initialize: function(element, percent) {=0A=
    this.element =3D $(element);=0A=
    if (!this.element) throw(Effect._elementDoesNotExistError);=0A=
    var options =3D Object.extend({=0A=
      scaleX: true,=0A=
      scaleY: true,=0A=
      scaleContent: true,=0A=
      scaleFromCenter: false,=0A=
      scaleMode: 'box',        // 'box' or 'contents' or { } with =
provided values=0A=
      scaleFrom: 100.0,=0A=
      scaleTo:   percent=0A=
    }, arguments[2] || { });=0A=
    this.start(options);=0A=
  },=0A=
  setup: function() {=0A=
    this.restoreAfterFinish =3D this.options.restoreAfterFinish || false;=0A=
    this.elementPositioning =3D this.element.getStyle('position');=0A=
    =0A=
    this.originalStyle =3D { };=0A=
    ['top','left','width','height','fontSize'].each( function(k) {=0A=
      this.originalStyle[k] =3D this.element.style[k];=0A=
    }.bind(this));=0A=
      =0A=
    this.originalTop  =3D this.element.offsetTop;=0A=
    this.originalLeft =3D this.element.offsetLeft;=0A=
    =0A=
    var fontSize =3D this.element.getStyle('font-size') || '100%';=0A=
    ['em','px','%','pt'].each( function(fontSizeType) {=0A=
      if (fontSize.indexOf(fontSizeType)>0) {=0A=
        this.fontSize     =3D parseFloat(fontSize);=0A=
        this.fontSizeType =3D fontSizeType;=0A=
      }=0A=
    }.bind(this));=0A=
    =0A=
    this.factor =3D (this.options.scaleTo - this.options.scaleFrom)/100;=0A=
    =0A=
    this.dims =3D null;=0A=
    if (this.options.scaleMode=3D=3D'box')=0A=
      this.dims =3D [this.element.offsetHeight, =
this.element.offsetWidth];=0A=
    if (/^content/.test(this.options.scaleMode))=0A=
      this.dims =3D [this.element.scrollHeight, =
this.element.scrollWidth];=0A=
    if (!this.dims)=0A=
      this.dims =3D [this.options.scaleMode.originalHeight,=0A=
                   this.options.scaleMode.originalWidth];=0A=
  },=0A=
  update: function(position) {=0A=
    var currentScale =3D (this.options.scaleFrom/100.0) + (this.factor * =
position);=0A=
    if (this.options.scaleContent && this.fontSize)=0A=
      this.element.setStyle({fontSize: this.fontSize * currentScale + =
this.fontSizeType });=0A=
    this.setDimensions(this.dims[0] * currentScale, this.dims[1] * =
currentScale);=0A=
  },=0A=
  finish: function(position) {=0A=
    if (this.restoreAfterFinish) =
this.element.setStyle(this.originalStyle);=0A=
  },=0A=
  setDimensions: function(height, width) {=0A=
    var d =3D { };=0A=
    if (this.options.scaleX) d.width =3D width.round() + 'px';=0A=
    if (this.options.scaleY) d.height =3D height.round() + 'px';=0A=
    if (this.options.scaleFromCenter) {=0A=
      var topd  =3D (height - this.dims[0])/2;=0A=
      var leftd =3D (width  - this.dims[1])/2;=0A=
      if (this.elementPositioning =3D=3D 'absolute') {=0A=
        if (this.options.scaleY) d.top =3D this.originalTop-topd + 'px';=0A=
        if (this.options.scaleX) d.left =3D this.originalLeft-leftd + =
'px';=0A=
      } else {=0A=
        if (this.options.scaleY) d.top =3D -topd + 'px';=0A=
        if (this.options.scaleX) d.left =3D -leftd + 'px';=0A=
      }=0A=
    }=0A=
    this.element.setStyle(d);=0A=
  }=0A=
});=0A=
=0A=
Effect.Highlight =3D Class.create(Effect.Base, {=0A=
  initialize: function(element) {=0A=
    this.element =3D $(element);=0A=
    if (!this.element) throw(Effect._elementDoesNotExistError);=0A=
    var options =3D Object.extend({ startcolor: '#ffff99' }, =
arguments[1] || { });=0A=
    this.start(options);=0A=
  },=0A=
  setup: function() {=0A=
    // Prevent executing on elements not in the layout flow=0A=
    if (this.element.getStyle('display')=3D=3D'none') { this.cancel(); =
return; }=0A=
    // Disable background image during the effect=0A=
    this.oldStyle =3D { };=0A=
    if (!this.options.keepBackgroundImage) {=0A=
      this.oldStyle.backgroundImage =3D =
this.element.getStyle('background-image');=0A=
      this.element.setStyle({backgroundImage: 'none'});=0A=
    }=0A=
    if (!this.options.endcolor)=0A=
      this.options.endcolor =3D =
this.element.getStyle('background-color').parseColor('#ffffff');=0A=
    if (!this.options.restorecolor)=0A=
      this.options.restorecolor =3D =
this.element.getStyle('background-color');=0A=
    // init color calculations=0A=
    this._base  =3D $R(0,2).map(function(i){ return =
parseInt(this.options.startcolor.slice(i*2+1,i*2+3),16) }.bind(this));=0A=
    this._delta =3D $R(0,2).map(function(i){ return =
parseInt(this.options.endcolor.slice(i*2+1,i*2+3),16)-this._base[i] =
}.bind(this));=0A=
  },=0A=
  update: function(position) {=0A=
    this.element.setStyle({backgroundColor: =
$R(0,2).inject('#',function(m,v,i){=0A=
      return =
m+((this._base[i]+(this._delta[i]*position)).round().toColorPart()); =
}.bind(this)) });=0A=
  },=0A=
  finish: function() {=0A=
    this.element.setStyle(Object.extend(this.oldStyle, {=0A=
      backgroundColor: this.options.restorecolor=0A=
    }));=0A=
  }=0A=
});=0A=
=0A=
Effect.ScrollTo =3D function(element) {=0A=
  var options =3D arguments[1] || { },=0A=
    scrollOffsets =3D document.viewport.getScrollOffsets(),=0A=
    elementOffsets =3D $(element).cumulativeOffset(),=0A=
    max =3D (window.height || document.body.scrollHeight) - =
document.viewport.getHeight();  =0A=
=0A=
  if (options.offset) elementOffsets[1] +=3D options.offset;=0A=
=0A=
  return new Effect.Tween(null,=0A=
    scrollOffsets.top,=0A=
    elementOffsets[1] > max ? max : elementOffsets[1],=0A=
    options,=0A=
    function(p){ scrollTo(scrollOffsets.left, p.round()) }=0A=
  );=0A=
};=0A=
=0A=
/* ------------- combination effects ------------- */=0A=
=0A=
Effect.Fade =3D function(element) {=0A=
  element =3D $(element);=0A=
  var oldOpacity =3D element.getInlineOpacity();=0A=
  var options =3D Object.extend({=0A=
    from: element.getOpacity() || 1.0,=0A=
    to:   0.0,=0A=
    afterFinishInternal: function(effect) { =0A=
      if (effect.options.to!=3D0) return;=0A=
      effect.element.hide().setStyle({opacity: oldOpacity}); =0A=
    }=0A=
  }, arguments[1] || { });=0A=
  return new Effect.Opacity(element,options);=0A=
};=0A=
=0A=
Effect.Appear =3D function(element) {=0A=
  element =3D $(element);=0A=
  var options =3D Object.extend({=0A=
  from: (element.getStyle('display') =3D=3D 'none' ? 0.0 : =
element.getOpacity() || 0.0),=0A=
  to:   1.0,=0A=
  // force Safari to render floated elements properly=0A=
  afterFinishInternal: function(effect) {=0A=
    effect.element.forceRerendering();=0A=
  },=0A=
  beforeSetup: function(effect) {=0A=
    effect.element.setOpacity(effect.options.from).show(); =0A=
  }}, arguments[1] || { });=0A=
  return new Effect.Opacity(element,options);=0A=
};=0A=
=0A=
Effect.Puff =3D function(element) {=0A=
  element =3D $(element);=0A=
  var oldStyle =3D { =0A=
    opacity: element.getInlineOpacity(), =0A=
    position: element.getStyle('position'),=0A=
    top:  element.style.top,=0A=
    left: element.style.left,=0A=
    width: element.style.width,=0A=
    height: element.style.height=0A=
  };=0A=
  return new Effect.Parallel(=0A=
   [ new Effect.Scale(element, 200, =0A=
      { sync: true, scaleFromCenter: true, scaleContent: true, =
restoreAfterFinish: true }), =0A=
     new Effect.Opacity(element, { sync: true, to: 0.0 } ) ], =0A=
     Object.extend({ duration: 1.0, =0A=
      beforeSetupInternal: function(effect) {=0A=
        Position.absolutize(effect.effects[0].element)=0A=
      },=0A=
      afterFinishInternal: function(effect) {=0A=
         effect.effects[0].element.hide().setStyle(oldStyle); }=0A=
     }, arguments[1] || { })=0A=
   );=0A=
};=0A=
=0A=
Effect.BlindUp =3D function(element) {=0A=
  element =3D $(element);=0A=
  element.makeClipping();=0A=
  return new Effect.Scale(element, 0,=0A=
    Object.extend({ scaleContent: false, =0A=
      scaleX: false, =0A=
      restoreAfterFinish: true,=0A=
      afterFinishInternal: function(effect) {=0A=
        effect.element.hide().undoClipping();=0A=
      } =0A=
    }, arguments[1] || { })=0A=
  );=0A=
};=0A=
=0A=
Effect.BlindDown =3D function(element) {=0A=
  element =3D $(element);=0A=
  var elementDimensions =3D element.getDimensions();=0A=
  return new Effect.Scale(element, 100, Object.extend({ =0A=
    scaleContent: false, =0A=
    scaleX: false,=0A=
    scaleFrom: 0,=0A=
    scaleMode: {originalHeight: elementDimensions.height, originalWidth: =
elementDimensions.width},=0A=
    restoreAfterFinish: true,=0A=
    afterSetup: function(effect) {=0A=
      effect.element.makeClipping().setStyle({height: '0px'}).show(); =0A=
    },  =0A=
    afterFinishInternal: function(effect) {=0A=
      effect.element.undoClipping();=0A=
    }=0A=
  }, arguments[1] || { }));=0A=
};=0A=
=0A=
Effect.SwitchOff =3D function(element) {=0A=
  element =3D $(element);=0A=
  var oldOpacity =3D element.getInlineOpacity();=0A=
  return new Effect.Appear(element, Object.extend({=0A=
    duration: 0.4,=0A=
    from: 0,=0A=
    transition: Effect.Transitions.flicker,=0A=
    afterFinishInternal: function(effect) {=0A=
      new Effect.Scale(effect.element, 1, { =0A=
        duration: 0.3, scaleFromCenter: true,=0A=
        scaleX: false, scaleContent: false, restoreAfterFinish: true,=0A=
        beforeSetup: function(effect) { =0A=
          effect.element.makePositioned().makeClipping();=0A=
        },=0A=
        afterFinishInternal: function(effect) {=0A=
          =
effect.element.hide().undoClipping().undoPositioned().setStyle({opacity: =
oldOpacity});=0A=
        }=0A=
      })=0A=
    }=0A=
  }, arguments[1] || { }));=0A=
};=0A=
=0A=
Effect.DropOut =3D function(element) {=0A=
  element =3D $(element);=0A=
  var oldStyle =3D {=0A=
    top: element.getStyle('top'),=0A=
    left: element.getStyle('left'),=0A=
    opacity: element.getInlineOpacity() };=0A=
  return new Effect.Parallel(=0A=
    [ new Effect.Move(element, {x: 0, y: 100, sync: true }), =0A=
      new Effect.Opacity(element, { sync: true, to: 0.0 }) ],=0A=
    Object.extend(=0A=
      { duration: 0.5,=0A=
        beforeSetup: function(effect) {=0A=
          effect.effects[0].element.makePositioned(); =0A=
        },=0A=
        afterFinishInternal: function(effect) {=0A=
          =
effect.effects[0].element.hide().undoPositioned().setStyle(oldStyle);=0A=
        } =0A=
      }, arguments[1] || { }));=0A=
};=0A=
=0A=
Effect.Shake =3D function(element) {=0A=
  element =3D $(element);=0A=
  var options =3D Object.extend({=0A=
    distance: 20,=0A=
    duration: 0.5=0A=
  }, arguments[1] || {});=0A=
  var distance =3D parseFloat(options.distance);=0A=
  var split =3D parseFloat(options.duration) / 10.0;=0A=
  var oldStyle =3D {=0A=
    top: element.getStyle('top'),=0A=
    left: element.getStyle('left') };=0A=
    return new Effect.Move(element,=0A=
      { x:  distance, y: 0, duration: split, afterFinishInternal: =
function(effect) {=0A=
    new Effect.Move(effect.element,=0A=
      { x: -distance*2, y: 0, duration: split*2,  afterFinishInternal: =
function(effect) {=0A=
    new Effect.Move(effect.element,=0A=
      { x:  distance*2, y: 0, duration: split*2,  afterFinishInternal: =
function(effect) {=0A=
    new Effect.Move(effect.element,=0A=
      { x: -distance*2, y: 0, duration: split*2,  afterFinishInternal: =
function(effect) {=0A=
    new Effect.Move(effect.element,=0A=
      { x:  distance*2, y: 0, duration: split*2,  afterFinishInternal: =
function(effect) {=0A=
    new Effect.Move(effect.element,=0A=
      { x: -distance, y: 0, duration: split, afterFinishInternal: =
function(effect) {=0A=
        effect.element.undoPositioned().setStyle(oldStyle);=0A=
  }}) }}) }}) }}) }}) }});=0A=
};=0A=
=0A=
Effect.SlideDown =3D function(element) {=0A=
  element =3D $(element).cleanWhitespace();=0A=
  // SlideDown need to have the content of the element wrapped in a =
container element with fixed height!=0A=
  var oldInnerBottom =3D element.down().getStyle('bottom');=0A=
  var elementDimensions =3D element.getDimensions();=0A=
  return new Effect.Scale(element, 100, Object.extend({ =0A=
    scaleContent: false, =0A=
    scaleX: false, =0A=
    scaleFrom: window.opera ? 0 : 1,=0A=
    scaleMode: {originalHeight: elementDimensions.height, originalWidth: =
elementDimensions.width},=0A=
    restoreAfterFinish: true,=0A=
    afterSetup: function(effect) {=0A=
      effect.element.makePositioned();=0A=
      effect.element.down().makePositioned();=0A=
      if (window.opera) effect.element.setStyle({top: ''});=0A=
      effect.element.makeClipping().setStyle({height: '0px'}).show(); =0A=
    },=0A=
    afterUpdateInternal: function(effect) {=0A=
      effect.element.down().setStyle({bottom:=0A=
        (effect.dims[0] - effect.element.clientHeight) + 'px' }); =0A=
    },=0A=
    afterFinishInternal: function(effect) {=0A=
      effect.element.undoClipping().undoPositioned();=0A=
      effect.element.down().undoPositioned().setStyle({bottom: =
oldInnerBottom}); }=0A=
    }, arguments[1] || { })=0A=
  );=0A=
};=0A=
=0A=
Effect.SlideUp =3D function(element) {=0A=
  element =3D $(element).cleanWhitespace();=0A=
  var oldInnerBottom =3D element.down().getStyle('bottom');=0A=
  var elementDimensions =3D element.getDimensions();=0A=
  return new Effect.Scale(element, window.opera ? 0 : 1,=0A=
   Object.extend({ scaleContent: false, =0A=
    scaleX: false, =0A=
    scaleMode: 'box',=0A=
    scaleFrom: 100,=0A=
    scaleMode: {originalHeight: elementDimensions.height, originalWidth: =
elementDimensions.width},=0A=
    restoreAfterFinish: true,=0A=
    afterSetup: function(effect) {=0A=
      effect.element.makePositioned();=0A=
      effect.element.down().makePositioned();=0A=
      if (window.opera) effect.element.setStyle({top: ''});=0A=
      effect.element.makeClipping().show();=0A=
    },  =0A=
    afterUpdateInternal: function(effect) {=0A=
      effect.element.down().setStyle({bottom:=0A=
        (effect.dims[0] - effect.element.clientHeight) + 'px' });=0A=
    },=0A=
    afterFinishInternal: function(effect) {=0A=
      effect.element.hide().undoClipping().undoPositioned();=0A=
      effect.element.down().undoPositioned().setStyle({bottom: =
oldInnerBottom});=0A=
    }=0A=
   }, arguments[1] || { })=0A=
  );=0A=
};=0A=
=0A=
// Bug in opera makes the TD containing this element expand for a =
instance after finish =0A=
Effect.Squish =3D function(element) {=0A=
  return new Effect.Scale(element, window.opera ? 1 : 0, { =0A=
    restoreAfterFinish: true,=0A=
    beforeSetup: function(effect) {=0A=
      effect.element.makeClipping(); =0A=
    },  =0A=
    afterFinishInternal: function(effect) {=0A=
      effect.element.hide().undoClipping(); =0A=
    }=0A=
  });=0A=
};=0A=
=0A=
Effect.Grow =3D function(element) {=0A=
  element =3D $(element);=0A=
  var options =3D Object.extend({=0A=
    direction: 'center',=0A=
    moveTransition: Effect.Transitions.sinoidal,=0A=
    scaleTransition: Effect.Transitions.sinoidal,=0A=
    opacityTransition: Effect.Transitions.full=0A=
  }, arguments[1] || { });=0A=
  var oldStyle =3D {=0A=
    top: element.style.top,=0A=
    left: element.style.left,=0A=
    height: element.style.height,=0A=
    width: element.style.width,=0A=
    opacity: element.getInlineOpacity() };=0A=
=0A=
  var dims =3D element.getDimensions();    =0A=
  var initialMoveX, initialMoveY;=0A=
  var moveX, moveY;=0A=
  =0A=
  switch (options.direction) {=0A=
    case 'top-left':=0A=
      initialMoveX =3D initialMoveY =3D moveX =3D moveY =3D 0; =0A=
      break;=0A=
    case 'top-right':=0A=
      initialMoveX =3D dims.width;=0A=
      initialMoveY =3D moveY =3D 0;=0A=
      moveX =3D -dims.width;=0A=
      break;=0A=
    case 'bottom-left':=0A=
      initialMoveX =3D moveX =3D 0;=0A=
      initialMoveY =3D dims.height;=0A=
      moveY =3D -dims.height;=0A=
      break;=0A=
    case 'bottom-right':=0A=
      initialMoveX =3D dims.width;=0A=
      initialMoveY =3D dims.height;=0A=
      moveX =3D -dims.width;=0A=
      moveY =3D -dims.height;=0A=
      break;=0A=
    case 'center':=0A=
      initialMoveX =3D dims.width / 2;=0A=
      initialMoveY =3D dims.height / 2;=0A=
      moveX =3D -dims.width / 2;=0A=
      moveY =3D -dims.height / 2;=0A=
      break;=0A=
  }=0A=
  =0A=
  return new Effect.Move(element, {=0A=
    x: initialMoveX,=0A=
    y: initialMoveY,=0A=
    duration: 0.01, =0A=
    beforeSetup: function(effect) {=0A=
      effect.element.hide().makeClipping().makePositioned();=0A=
    },=0A=
    afterFinishInternal: function(effect) {=0A=
      new Effect.Parallel(=0A=
        [ new Effect.Opacity(effect.element, { sync: true, to: 1.0, =
from: 0.0, transition: options.opacityTransition }),=0A=
          new Effect.Move(effect.element, { x: moveX, y: moveY, sync: =
true, transition: options.moveTransition }),=0A=
          new Effect.Scale(effect.element, 100, {=0A=
            scaleMode: { originalHeight: dims.height, originalWidth: =
dims.width }, =0A=
            sync: true, scaleFrom: window.opera ? 1 : 0, transition: =
options.scaleTransition, restoreAfterFinish: true})=0A=
        ], Object.extend({=0A=
             beforeSetup: function(effect) {=0A=
               effect.effects[0].element.setStyle({height: =
'0px'}).show(); =0A=
             },=0A=
             afterFinishInternal: function(effect) {=0A=
               =
effect.effects[0].element.undoClipping().undoPositioned().setStyle(oldSty=
le); =0A=
             }=0A=
           }, options)=0A=
      )=0A=
    }=0A=
  });=0A=
};=0A=
=0A=
Effect.Shrink =3D function(element) {=0A=
  element =3D $(element);=0A=
  var options =3D Object.extend({=0A=
    direction: 'center',=0A=
    moveTransition: Effect.Transitions.sinoidal,=0A=
    scaleTransition: Effect.Transitions.sinoidal,=0A=
    opacityTransition: Effect.Transitions.none=0A=
  }, arguments[1] || { });=0A=
  var oldStyle =3D {=0A=
    top: element.style.top,=0A=
    left: element.style.left,=0A=
    height: element.style.height,=0A=
    width: element.style.width,=0A=
    opacity: element.getInlineOpacity() };=0A=
=0A=
  var dims =3D element.getDimensions();=0A=
  var moveX, moveY;=0A=
  =0A=
  switch (options.direction) {=0A=
    case 'top-left':=0A=
      moveX =3D moveY =3D 0;=0A=
      break;=0A=
    case 'top-right':=0A=
      moveX =3D dims.width;=0A=
      moveY =3D 0;=0A=
      break;=0A=
    case 'bottom-left':=0A=
      moveX =3D 0;=0A=
      moveY =3D dims.height;=0A=
      break;=0A=
    case 'bottom-right':=0A=
      moveX =3D dims.width;=0A=
      moveY =3D dims.height;=0A=
      break;=0A=
    case 'center':  =0A=
      moveX =3D dims.width / 2;=0A=
      moveY =3D dims.height / 2;=0A=
      break;=0A=
  }=0A=
  =0A=
  return new Effect.Parallel(=0A=
    [ new Effect.Opacity(element, { sync: true, to: 0.0, from: 1.0, =
transition: options.opacityTransition }),=0A=
      new Effect.Scale(element, window.opera ? 1 : 0, { sync: true, =
transition: options.scaleTransition, restoreAfterFinish: true}),=0A=
      new Effect.Move(element, { x: moveX, y: moveY, sync: true, =
transition: options.moveTransition })=0A=
    ], Object.extend({            =0A=
         beforeStartInternal: function(effect) {=0A=
           effect.effects[0].element.makePositioned().makeClipping(); =0A=
         },=0A=
         afterFinishInternal: function(effect) {=0A=
           =
effect.effects[0].element.hide().undoClipping().undoPositioned().setStyle=
(oldStyle); }=0A=
       }, options)=0A=
  );=0A=
};=0A=
=0A=
Effect.Pulsate =3D function(element) {=0A=
  element =3D $(element);=0A=
  var options    =3D arguments[1] || { };=0A=
  var oldOpacity =3D element.getInlineOpacity();=0A=
  var transition =3D options.transition || Effect.Transitions.sinoidal;=0A=
  var reverser   =3D function(pos){ return =
transition(1-Effect.Transitions.pulse(pos, options.pulses)) };=0A=
  reverser.bind(transition);=0A=
  return new Effect.Opacity(element, =0A=
    Object.extend(Object.extend({  duration: 2.0, from: 0,=0A=
      afterFinishInternal: function(effect) { =
effect.element.setStyle({opacity: oldOpacity}); }=0A=
    }, options), {transition: reverser}));=0A=
};=0A=
=0A=
Effect.Fold =3D function(element) {=0A=
  element =3D $(element);=0A=
  var oldStyle =3D {=0A=
    top: element.style.top,=0A=
    left: element.style.left,=0A=
    width: element.style.width,=0A=
    height: element.style.height };=0A=
  element.makeClipping();=0A=
  return new Effect.Scale(element, 5, Object.extend({   =0A=
    scaleContent: false,=0A=
    scaleX: false,=0A=
    afterFinishInternal: function(effect) {=0A=
    new Effect.Scale(element, 1, { =0A=
      scaleContent: false, =0A=
      scaleY: false,=0A=
      afterFinishInternal: function(effect) {=0A=
        effect.element.hide().undoClipping().setStyle(oldStyle);=0A=
      } });=0A=
  }}, arguments[1] || { }));=0A=
};=0A=
=0A=
Effect.Morph =3D Class.create(Effect.Base, {=0A=
  initialize: function(element) {=0A=
    this.element =3D $(element);=0A=
    if (!this.element) throw(Effect._elementDoesNotExistError);=0A=
    var options =3D Object.extend({=0A=
      style: { }=0A=
    }, arguments[1] || { });=0A=
    =0A=
    if (!Object.isString(options.style)) this.style =3D =
$H(options.style);=0A=
    else {=0A=
      if (options.style.include(':'))=0A=
        this.style =3D options.style.parseStyle();=0A=
      else {=0A=
        this.element.addClassName(options.style);=0A=
        this.style =3D $H(this.element.getStyles());=0A=
        this.element.removeClassName(options.style);=0A=
        var css =3D this.element.getStyles();=0A=
        this.style =3D this.style.reject(function(style) {=0A=
          return style.value =3D=3D css[style.key];=0A=
        });=0A=
        options.afterFinishInternal =3D function(effect) {=0A=
          effect.element.addClassName(effect.options.style);=0A=
          effect.transforms.each(function(transform) {=0A=
            effect.element.style[transform.style] =3D '';=0A=
          });=0A=
        }=0A=
      }=0A=
    }=0A=
    this.start(options);=0A=
  },=0A=
  =0A=
  setup: function(){=0A=
    function parseColor(color){=0A=
      if (!color || ['rgba(0, 0, 0, 0)','transparent'].include(color)) =
color =3D '#ffffff';=0A=
      color =3D color.parseColor();=0A=
      return $R(0,2).map(function(i){=0A=
        return parseInt( color.slice(i*2+1,i*2+3), 16 ) =0A=
      });=0A=
    }=0A=
    this.transforms =3D this.style.map(function(pair){=0A=
      var property =3D pair[0], value =3D pair[1], unit =3D null;=0A=
=0A=
      if (value.parseColor('#zzzzzz') !=3D '#zzzzzz') {=0A=
        value =3D value.parseColor();=0A=
        unit  =3D 'color';=0A=
      } else if (property =3D=3D 'opacity') {=0A=
        value =3D parseFloat(value);=0A=
        if (Prototype.Browser.IE && =
(!this.element.currentStyle.hasLayout))=0A=
          this.element.setStyle({zoom: 1});=0A=
      } else if (Element.CSS_LENGTH.test(value)) {=0A=
          var components =3D value.match(/^([\+\-]?[0-9\.]+)(.*)$/);=0A=
          value =3D parseFloat(components[1]);=0A=
          unit =3D (components.length =3D=3D 3) ? components[2] : null;=0A=
      }=0A=
=0A=
      var originalValue =3D this.element.getStyle(property);=0A=
      return { =0A=
        style: property.camelize(), =0A=
        originalValue: unit=3D=3D'color' ? parseColor(originalValue) : =
parseFloat(originalValue || 0), =0A=
        targetValue: unit=3D=3D'color' ? parseColor(value) : value,=0A=
        unit: unit=0A=
      };=0A=
    }.bind(this)).reject(function(transform){=0A=
      return (=0A=
        (transform.originalValue =3D=3D transform.targetValue) ||=0A=
        (=0A=
          transform.unit !=3D 'color' &&=0A=
          (isNaN(transform.originalValue) || =
isNaN(transform.targetValue))=0A=
        )=0A=
      )=0A=
    });=0A=
  },=0A=
  update: function(position) {=0A=
    var style =3D { }, transform, i =3D this.transforms.length;=0A=
    while(i--)=0A=
      style[(transform =3D this.transforms[i]).style] =3D =0A=
        transform.unit=3D=3D'color' ? '#'+=0A=
          (Math.round(transform.originalValue[0]+=0A=
            =
(transform.targetValue[0]-transform.originalValue[0])*position)).toColorP=
art() +=0A=
          (Math.round(transform.originalValue[1]+=0A=
            =
(transform.targetValue[1]-transform.originalValue[1])*position)).toColorP=
art() +=0A=
          (Math.round(transform.originalValue[2]+=0A=
            =
(transform.targetValue[2]-transform.originalValue[2])*position)).toColorP=
art() :=0A=
        (transform.originalValue +=0A=
          (transform.targetValue - transform.originalValue) * =
position).toFixed(3) + =0A=
            (transform.unit =3D=3D=3D null ? '' : transform.unit);=0A=
    this.element.setStyle(style, true);=0A=
  }=0A=
});=0A=
=0A=
Effect.Transform =3D Class.create({=0A=
  initialize: function(tracks){=0A=
    this.tracks  =3D [];=0A=
    this.options =3D arguments[1] || { };=0A=
    this.addTracks(tracks);=0A=
  },=0A=
  addTracks: function(tracks){=0A=
    tracks.each(function(track){=0A=
      track =3D $H(track);=0A=
      var data =3D track.values().first();=0A=
      this.tracks.push($H({=0A=
        ids:     track.keys().first(),=0A=
        effect:  Effect.Morph,=0A=
        options: { style: data }=0A=
      }));=0A=
    }.bind(this));=0A=
    return this;=0A=
  },=0A=
  play: function(){=0A=
    return new Effect.Parallel(=0A=
      this.tracks.map(function(track){=0A=
        var ids =3D track.get('ids'), effect =3D track.get('effect'), =
options =3D track.get('options');=0A=
        var elements =3D [$(ids) || $$(ids)].flatten();=0A=
        return elements.map(function(e){ return new effect(e, =
Object.extend({ sync:true }, options)) });=0A=
      }).flatten(),=0A=
      this.options=0A=
    );=0A=
  }=0A=
});=0A=
=0A=
Element.CSS_PROPERTIES =3D $w(=0A=
  'backgroundColor backgroundPosition borderBottomColor =
borderBottomStyle ' + =0A=
  'borderBottomWidth borderLeftColor borderLeftStyle borderLeftWidth ' +=0A=
  'borderRightColor borderRightStyle borderRightWidth borderSpacing ' +=0A=
  'borderTopColor borderTopStyle borderTopWidth bottom clip color ' +=0A=
  'fontSize fontWeight height left letterSpacing lineHeight ' +=0A=
  'marginBottom marginLeft marginRight marginTop markerOffset maxHeight =
'+=0A=
  'maxWidth minHeight minWidth opacity outlineColor outlineOffset ' +=0A=
  'outlineWidth paddingBottom paddingLeft paddingRight paddingTop ' +=0A=
  'right textIndent top width wordSpacing zIndex');=0A=
  =0A=
Element.CSS_LENGTH =3D =
/^(([\+\-]?[0-9\.]+)(em|ex|px|in|cm|mm|pt|pc|\%))|0$/;=0A=
=0A=
String.__parseStyleElement =3D document.createElement('div');=0A=
String.prototype.parseStyle =3D function(){=0A=
  var style, styleRules =3D $H();=0A=
  if (Prototype.Browser.WebKit)=0A=
    style =3D new Element('div',{style:this}).style;=0A=
  else {=0A=
    String.__parseStyleElement.innerHTML =3D '<div style=3D"' + this + =
'"></div>';=0A=
    style =3D String.__parseStyleElement.childNodes[0].style;=0A=
  }=0A=
  =0A=
  Element.CSS_PROPERTIES.each(function(property){=0A=
    if (style[property]) styleRules.set(property, style[property]); =0A=
  });=0A=
  =0A=
  if (Prototype.Browser.IE && this.include('opacity'))=0A=
    styleRules.set('opacity', =
this.match(/opacity:\s*((?:0|1)?(?:\.\d*)?)/)[1]);=0A=
=0A=
  return styleRules;=0A=
};=0A=
=0A=
if (document.defaultView && document.defaultView.getComputedStyle) {=0A=
  Element.getStyles =3D function(element) {=0A=
    var css =3D document.defaultView.getComputedStyle($(element), null);=0A=
    return Element.CSS_PROPERTIES.inject({ }, function(styles, property) =
{=0A=
      styles[property] =3D css[property];=0A=
      return styles;=0A=
    });=0A=
  };=0A=
} else {=0A=
  Element.getStyles =3D function(element) {=0A=
    element =3D $(element);=0A=
    var css =3D element.currentStyle, styles;=0A=
    styles =3D Element.CSS_PROPERTIES.inject({ }, function(hash, =
property) {=0A=
      hash.set(property, css[property]);=0A=
      return hash;=0A=
    });=0A=
    if (!styles.opacity) styles.set('opacity', element.getOpacity());=0A=
    return styles;=0A=
  };=0A=
};=0A=
=0A=
Effect.Methods =3D {=0A=
  morph: function(element, style) {=0A=
    element =3D $(element);=0A=
    new Effect.Morph(element, Object.extend({ style: style }, =
arguments[2] || { }));=0A=
    return element;=0A=
  },=0A=
  visualEffect: function(element, effect, options) {=0A=
    element =3D $(element)=0A=
    var s =3D effect.dasherize().camelize(), klass =3D =
s.charAt(0).toUpperCase() + s.substring(1);=0A=
    new Effect[klass](element, options);=0A=
    return element;=0A=
  },=0A=
  highlight: function(element, options) {=0A=
    element =3D $(element);=0A=
    new Effect.Highlight(element, options);=0A=
    return element;=0A=
  }=0A=
};=0A=
=0A=
$w('fade appear grow shrink fold blindUp blindDown slideUp slideDown '+=0A=
  'pulsate shake puff squish switchOff dropOut').each(=0A=
  function(effect) { =0A=
    Effect.Methods[effect] =3D function(element, options){=0A=
      element =3D $(element);=0A=
      Effect[effect.charAt(0).toUpperCase() + =
effect.substring(1)](element, options);=0A=
      return element;=0A=
    }=0A=
  }=0A=
);=0A=
=0A=
$w('getInlineOpacity forceRerendering setContentZoom collectTextNodes =
collectTextNodesIgnoreClass getStyles').each( =0A=
  function(f) { Effect.Methods[f] =3D Element[f]; }=0A=
);=0A=
=0A=
Element.addMethods(Effect.Methods);=0A=

------=_NextPart_000_0000_01CAB168.786EE890
Content-Type: application/octet-stream
Content-Transfer-Encoding: quoted-printable
Content-Location: http://www.eenews.net/javascripts/dragdrop.js?1218125236

// Copyright (c) 2005-2007 Thomas Fuchs (http://script.aculo.us, =
http://mir.aculo.us)=0A=
//           (c) 2005-2007 Sammi Williams =
(http://www.oriontransfer.co.nz, sammi@oriontransfer.co.nz)=0A=
// =0A=
// script.aculo.us is freely distributable under the terms of an =
MIT-style license.=0A=
// For details, see the script.aculo.us web site: http://script.aculo.us/=0A=
=0A=
if(Object.isUndefined(Effect))=0A=
  throw("dragdrop.js requires including script.aculo.us' effects.js =
library");=0A=
=0A=
var Droppables =3D {=0A=
  drops: [],=0A=
=0A=
  remove: function(element) {=0A=
    this.drops =3D this.drops.reject(function(d) { return =
d.element=3D=3D$(element) });=0A=
  },=0A=
=0A=
  add: function(element) {=0A=
    element =3D $(element);=0A=
    var options =3D Object.extend({=0A=
      greedy:     true,=0A=
      hoverclass: null,=0A=
      tree:       false=0A=
    }, arguments[1] || { });=0A=
=0A=
    // cache containers=0A=
    if(options.containment) {=0A=
      options._containers =3D [];=0A=
      var containment =3D options.containment;=0A=
      if(Object.isArray(containment)) {=0A=
        containment.each( function(c) { options._containers.push($(c)) =
});=0A=
      } else {=0A=
        options._containers.push($(containment));=0A=
      }=0A=
    }=0A=
    =0A=
    if(options.accept) options.accept =3D [options.accept].flatten();=0A=
=0A=
    Element.makePositioned(element); // fix IE=0A=
    options.element =3D element;=0A=
=0A=
    this.drops.push(options);=0A=
  },=0A=
  =0A=
  findDeepestChild: function(drops) {=0A=
    deepest =3D drops[0];=0A=
      =0A=
    for (i =3D 1; i < drops.length; ++i)=0A=
      if (Element.isParent(drops[i].element, deepest.element))=0A=
        deepest =3D drops[i];=0A=
    =0A=
    return deepest;=0A=
  },=0A=
=0A=
  isContained: function(element, drop) {=0A=
    var containmentNode;=0A=
    if(drop.tree) {=0A=
      containmentNode =3D element.treeNode; =0A=
    } else {=0A=
      containmentNode =3D element.parentNode;=0A=
    }=0A=
    return drop._containers.detect(function(c) { return containmentNode =
=3D=3D c });=0A=
  },=0A=
  =0A=
  isAffected: function(point, element, drop) {=0A=
    return (=0A=
      (drop.element!=3Delement) &&=0A=
      ((!drop._containers) ||=0A=
        this.isContained(element, drop)) &&=0A=
      ((!drop.accept) ||=0A=
        (Element.classNames(element).detect( =0A=
          function(v) { return drop.accept.include(v) } ) )) &&=0A=
      Position.within(drop.element, point[0], point[1]) );=0A=
  },=0A=
=0A=
  deactivate: function(drop) {=0A=
    if(drop.hoverclass)=0A=
      Element.removeClassName(drop.element, drop.hoverclass);=0A=
    this.last_active =3D null;=0A=
  },=0A=
=0A=
  activate: function(drop) {=0A=
    if(drop.hoverclass)=0A=
      Element.addClassName(drop.element, drop.hoverclass);=0A=
    this.last_active =3D drop;=0A=
  },=0A=
=0A=
  show: function(point, element) {=0A=
    if(!this.drops.length) return;=0A=
    var drop, affected =3D [];=0A=
    =0A=
    this.drops.each( function(drop) {=0A=
      if(Droppables.isAffected(point, element, drop))=0A=
        affected.push(drop);=0A=
    });=0A=
        =0A=
    if(affected.length>0)=0A=
      drop =3D Droppables.findDeepestChild(affected);=0A=
=0A=
    if(this.last_active && this.last_active !=3D drop) =
this.deactivate(this.last_active);=0A=
    if (drop) {=0A=
      Position.within(drop.element, point[0], point[1]);=0A=
      if(drop.onHover)=0A=
        drop.onHover(element, drop.element, =
Position.overlap(drop.overlap, drop.element));=0A=
      =0A=
      if (drop !=3D this.last_active) Droppables.activate(drop);=0A=
    }=0A=
  },=0A=
=0A=
  fire: function(event, element) {=0A=
    if(!this.last_active) return;=0A=
    Position.prepare();=0A=
=0A=
    if (this.isAffected([Event.pointerX(event), Event.pointerY(event)], =
element, this.last_active))=0A=
      if (this.last_active.onDrop) {=0A=
        this.last_active.onDrop(element, this.last_active.element, =
event); =0A=
        return true; =0A=
      }=0A=
  },=0A=
=0A=
  reset: function() {=0A=
    if(this.last_active)=0A=
      this.deactivate(this.last_active);=0A=
  }=0A=
}=0A=
=0A=
var Draggables =3D {=0A=
  drags: [],=0A=
  observers: [],=0A=
  =0A=
  register: function(draggable) {=0A=
    if(this.drags.length =3D=3D 0) {=0A=
      this.eventMouseUp   =3D this.endDrag.bindAsEventListener(this);=0A=
      this.eventMouseMove =3D this.updateDrag.bindAsEventListener(this);=0A=
      this.eventKeypress  =3D this.keyPress.bindAsEventListener(this);=0A=
      =0A=
      Event.observe(document, "mouseup", this.eventMouseUp);=0A=
      Event.observe(document, "mousemove", this.eventMouseMove);=0A=
      Event.observe(document, "keypress", this.eventKeypress);=0A=
    }=0A=
    this.drags.push(draggable);=0A=
  },=0A=
  =0A=
  unregister: function(draggable) {=0A=
    this.drags =3D this.drags.reject(function(d) { return =
d=3D=3Ddraggable });=0A=
    if(this.drags.length =3D=3D 0) {=0A=
      Event.stopObserving(document, "mouseup", this.eventMouseUp);=0A=
      Event.stopObserving(document, "mousemove", this.eventMouseMove);=0A=
      Event.stopObserving(document, "keypress", this.eventKeypress);=0A=
    }=0A=
  },=0A=
  =0A=
  activate: function(draggable) {=0A=
    if(draggable.options.delay) { =0A=
      this._timeout =3D setTimeout(function() { =0A=
        Draggables._timeout =3D null; =0A=
        window.focus(); =0A=
        Draggables.activeDraggable =3D draggable; =0A=
      }.bind(this), draggable.options.delay); =0A=
    } else {=0A=
      window.focus(); // allows keypress events if window isn't =
currently focused, fails for Safari=0A=
      this.activeDraggable =3D draggable;=0A=
    }=0A=
  },=0A=
  =0A=
  deactivate: function() {=0A=
    this.activeDraggable =3D null;=0A=
  },=0A=
  =0A=
  updateDrag: function(event) {=0A=
    if(!this.activeDraggable) return;=0A=
    var pointer =3D [Event.pointerX(event), Event.pointerY(event)];=0A=
    // Mozilla-based browsers fire successive mousemove events with=0A=
    // the same coordinates, prevent needless redrawing (moz bug?)=0A=
    if(this._lastPointer && (this._lastPointer.inspect() =3D=3D =
pointer.inspect())) return;=0A=
    this._lastPointer =3D pointer;=0A=
    =0A=
    this.activeDraggable.updateDrag(event, pointer);=0A=
  },=0A=
  =0A=
  endDrag: function(event) {=0A=
    if(this._timeout) { =0A=
      clearTimeout(this._timeout); =0A=
      this._timeout =3D null; =0A=
    }=0A=
    if(!this.activeDraggable) return;=0A=
    this._lastPointer =3D null;=0A=
    this.activeDraggable.endDrag(event);=0A=
    this.activeDraggable =3D null;=0A=
  },=0A=
  =0A=
  keyPress: function(event) {=0A=
    if(this.activeDraggable)=0A=
      this.activeDraggable.keyPress(event);=0A=
  },=0A=
  =0A=
  addObserver: function(observer) {=0A=
    this.observers.push(observer);=0A=
    this._cacheObserverCallbacks();=0A=
  },=0A=
  =0A=
  removeObserver: function(element) {  // element instead of observer =
fixes mem leaks=0A=
    this.observers =3D this.observers.reject( function(o) { return =
o.element=3D=3Delement });=0A=
    this._cacheObserverCallbacks();=0A=
  },=0A=
  =0A=
  notify: function(eventName, draggable, event) {  // 'onStart', =
'onEnd', 'onDrag'=0A=
    if(this[eventName+'Count'] > 0)=0A=
      this.observers.each( function(o) {=0A=
        if(o[eventName]) o[eventName](eventName, draggable, event);=0A=
      });=0A=
    if(draggable.options[eventName]) =
draggable.options[eventName](draggable, event);=0A=
  },=0A=
  =0A=
  _cacheObserverCallbacks: function() {=0A=
    ['onStart','onEnd','onDrag'].each( function(eventName) {=0A=
      Draggables[eventName+'Count'] =3D Draggables.observers.select(=0A=
        function(o) { return o[eventName]; }=0A=
      ).length;=0A=
    });=0A=
  }=0A=
}=0A=
=0A=
/*-----------------------------------------------------------------------=
---*/=0A=
=0A=
var Draggable =3D Class.create({=0A=
  initialize: function(element) {=0A=
    var defaults =3D {=0A=
      handle: false,=0A=
      reverteffect: function(element, top_offset, left_offset) {=0A=
        var dur =3D =
Math.sqrt(Math.abs(top_offset^2)+Math.abs(left_offset^2))*0.02;=0A=
        new Effect.Move(element, { x: -left_offset, y: -top_offset, =
duration: dur,=0A=
          queue: {scope:'_draggable', position:'end'}=0A=
        });=0A=
      },=0A=
      endeffect: function(element) {=0A=
        var toOpacity =3D Object.isNumber(element._opacity) ? =
element._opacity : 1.0;=0A=
        new Effect.Opacity(element, {duration:0.2, from:0.7, =
to:toOpacity, =0A=
          queue: {scope:'_draggable', position:'end'},=0A=
          afterFinish: function(){ =0A=
            Draggable._dragging[element] =3D false =0A=
          }=0A=
        }); =0A=
      },=0A=
      zindex: 1000,=0A=
      revert: false,=0A=
      quiet: false,=0A=
      scroll: false,=0A=
      scrollSensitivity: 20,=0A=
      scrollSpeed: 15,=0A=
      snap: false,  // false, or xy or [x,y] or function(x,y){ return =
[x,y] }=0A=
      delay: 0=0A=
    };=0A=
    =0A=
    if(!arguments[1] || Object.isUndefined(arguments[1].endeffect))=0A=
      Object.extend(defaults, {=0A=
        starteffect: function(element) {=0A=
          element._opacity =3D Element.getOpacity(element);=0A=
          Draggable._dragging[element] =3D true;=0A=
          new Effect.Opacity(element, {duration:0.2, =
from:element._opacity, to:0.7}); =0A=
        }=0A=
      });=0A=
    =0A=
    var options =3D Object.extend(defaults, arguments[1] || { });=0A=
=0A=
    this.element =3D $(element);=0A=
    =0A=
    if(options.handle && Object.isString(options.handle))=0A=
      this.handle =3D this.element.down('.'+options.handle, 0);=0A=
    =0A=
    if(!this.handle) this.handle =3D $(options.handle);=0A=
    if(!this.handle) this.handle =3D this.element;=0A=
    =0A=
    if(options.scroll && !options.scroll.scrollTo && =
!options.scroll.outerHTML) {=0A=
      options.scroll =3D $(options.scroll);=0A=
      this._isScrollChild =3D Element.childOf(this.element, =
options.scroll);=0A=
    }=0A=
=0A=
    Element.makePositioned(this.element); // fix IE    =0A=
=0A=
    this.options  =3D options;=0A=
    this.dragging =3D false;   =0A=
=0A=
    this.eventMouseDown =3D this.initDrag.bindAsEventListener(this);=0A=
    Event.observe(this.handle, "mousedown", this.eventMouseDown);=0A=
    =0A=
    Draggables.register(this);=0A=
  },=0A=
  =0A=
  destroy: function() {=0A=
    Event.stopObserving(this.handle, "mousedown", this.eventMouseDown);=0A=
    Draggables.unregister(this);=0A=
  },=0A=
  =0A=
  currentDelta: function() {=0A=
    return([=0A=
      parseInt(Element.getStyle(this.element,'left') || '0'),=0A=
      parseInt(Element.getStyle(this.element,'top') || '0')]);=0A=
  },=0A=
  =0A=
  initDrag: function(event) {=0A=
    if(!Object.isUndefined(Draggable._dragging[this.element]) &&=0A=
      Draggable._dragging[this.element]) return;=0A=
    if(Event.isLeftClick(event)) {    =0A=
      // abort on form elements, fixes a Firefox issue=0A=
      var src =3D Event.element(event);=0A=
      if((tag_name =3D src.tagName.toUpperCase()) && (=0A=
        tag_name=3D=3D'INPUT' ||=0A=
        tag_name=3D=3D'SELECT' ||=0A=
        tag_name=3D=3D'OPTION' ||=0A=
        tag_name=3D=3D'BUTTON' ||=0A=
        tag_name=3D=3D'TEXTAREA')) return;=0A=
        =0A=
      var pointer =3D [Event.pointerX(event), Event.pointerY(event)];=0A=
      var pos     =3D Position.cumulativeOffset(this.element);=0A=
      this.offset =3D [0,1].map( function(i) { return (pointer[i] - =
pos[i]) });=0A=
      =0A=
      Draggables.activate(this);=0A=
      Event.stop(event);=0A=
    }=0A=
  },=0A=
  =0A=
  startDrag: function(event) {=0A=
    this.dragging =3D true;=0A=
    if(!this.delta)=0A=
      this.delta =3D this.currentDelta();=0A=
    =0A=
    if(this.options.zindex) {=0A=
      this.originalZ =3D =
parseInt(Element.getStyle(this.element,'z-index') || 0);=0A=
      this.element.style.zIndex =3D this.options.zindex;=0A=
    }=0A=
    =0A=
    if(this.options.ghosting) {=0A=
      this._clone =3D this.element.cloneNode(true);=0A=
      this.element._originallyAbsolute =3D =
(this.element.getStyle('position') =3D=3D 'absolute');=0A=
      if (!this.element._originallyAbsolute)=0A=
        Position.absolutize(this.element);=0A=
      this.element.parentNode.insertBefore(this._clone, this.element);=0A=
    }=0A=
    =0A=
    if(this.options.scroll) {=0A=
      if (this.options.scroll =3D=3D window) {=0A=
        var where =3D this._getWindowScroll(this.options.scroll);=0A=
        this.originalScrollLeft =3D where.left;=0A=
        this.originalScrollTop =3D where.top;=0A=
      } else {=0A=
        this.originalScrollLeft =3D this.options.scroll.scrollLeft;=0A=
        this.originalScrollTop =3D this.options.scroll.scrollTop;=0A=
      }=0A=
    }=0A=
    =0A=
    Draggables.notify('onStart', this, event);=0A=
        =0A=
    if(this.options.starteffect) this.options.starteffect(this.element);=0A=
  },=0A=
  =0A=
  updateDrag: function(event, pointer) {=0A=
    if(!this.dragging) this.startDrag(event);=0A=
    =0A=
    if(!this.options.quiet){=0A=
      Position.prepare();=0A=
      Droppables.show(pointer, this.element);=0A=
    }=0A=
    =0A=
    Draggables.notify('onDrag', this, event);=0A=
    =0A=
    this.draw(pointer);=0A=
    if(this.options.change) this.options.change(this);=0A=
    =0A=
    if(this.options.scroll) {=0A=
      this.stopScrolling();=0A=
      =0A=
      var p;=0A=
      if (this.options.scroll =3D=3D window) {=0A=
        with(this._getWindowScroll(this.options.scroll)) { p =3D [ left, =
top, left+width, top+height ]; }=0A=
      } else {=0A=
        p =3D Position.page(this.options.scroll);=0A=
        p[0] +=3D this.options.scroll.scrollLeft + Position.deltaX;=0A=
        p[1] +=3D this.options.scroll.scrollTop + Position.deltaY;=0A=
        p.push(p[0]+this.options.scroll.offsetWidth);=0A=
        p.push(p[1]+this.options.scroll.offsetHeight);=0A=
      }=0A=
      var speed =3D [0,0];=0A=
      if(pointer[0] < (p[0]+this.options.scrollSensitivity)) speed[0] =
=3D pointer[0]-(p[0]+this.options.scrollSensitivity);=0A=
      if(pointer[1] < (p[1]+this.options.scrollSensitivity)) speed[1] =
=3D pointer[1]-(p[1]+this.options.scrollSensitivity);=0A=
      if(pointer[0] > (p[2]-this.options.scrollSensitivity)) speed[0] =
=3D pointer[0]-(p[2]-this.options.scrollSensitivity);=0A=
      if(pointer[1] > (p[3]-this.options.scrollSensitivity)) speed[1] =
=3D pointer[1]-(p[3]-this.options.scrollSensitivity);=0A=
      this.startScrolling(speed);=0A=
    }=0A=
    =0A=
    // fix AppleWebKit rendering=0A=
    if(Prototype.Browser.WebKit) window.scrollBy(0,0);=0A=
    =0A=
    Event.stop(event);=0A=
  },=0A=
  =0A=
  finishDrag: function(event, success) {=0A=
    this.dragging =3D false;=0A=
    =0A=
    if(this.options.quiet){=0A=
      Position.prepare();=0A=
      var pointer =3D [Event.pointerX(event), Event.pointerY(event)];=0A=
      Droppables.show(pointer, this.element);=0A=
    }=0A=
=0A=
    if(this.options.ghosting) {=0A=
      if (!this.element._originallyAbsolute)=0A=
        Position.relativize(this.element);=0A=
      delete this.element._originallyAbsolute;=0A=
      Element.remove(this._clone);=0A=
      this._clone =3D null;=0A=
    }=0A=
=0A=
    var dropped =3D false; =0A=
    if(success) { =0A=
      dropped =3D Droppables.fire(event, this.element); =0A=
      if (!dropped) dropped =3D false; =0A=
    }=0A=
    if(dropped && this.options.onDropped) =
this.options.onDropped(this.element);=0A=
    Draggables.notify('onEnd', this, event);=0A=
=0A=
    var revert =3D this.options.revert;=0A=
    if(revert && Object.isFunction(revert)) revert =3D =
revert(this.element);=0A=
    =0A=
    var d =3D this.currentDelta();=0A=
    if(revert && this.options.reverteffect) {=0A=
      if (dropped =3D=3D 0 || revert !=3D 'failure')=0A=
        this.options.reverteffect(this.element,=0A=
          d[1]-this.delta[1], d[0]-this.delta[0]);=0A=
    } else {=0A=
      this.delta =3D d;=0A=
    }=0A=
=0A=
    if(this.options.zindex)=0A=
      this.element.style.zIndex =3D this.originalZ;=0A=
=0A=
    if(this.options.endeffect) =0A=
      this.options.endeffect(this.element);=0A=
      =0A=
    Draggables.deactivate(this);=0A=
    Droppables.reset();=0A=
  },=0A=
  =0A=
  keyPress: function(event) {=0A=
    if(event.keyCode!=3DEvent.KEY_ESC) return;=0A=
    this.finishDrag(event, false);=0A=
    Event.stop(event);=0A=
  },=0A=
  =0A=
  endDrag: function(event) {=0A=
    if(!this.dragging) return;=0A=
    this.stopScrolling();=0A=
    this.finishDrag(event, true);=0A=
    Event.stop(event);=0A=
  },=0A=
  =0A=
  draw: function(point) {=0A=
    var pos =3D Position.cumulativeOffset(this.element);=0A=
    if(this.options.ghosting) {=0A=
      var r   =3D Position.realOffset(this.element);=0A=
      pos[0] +=3D r[0] - Position.deltaX; pos[1] +=3D r[1] - =
Position.deltaY;=0A=
    }=0A=
    =0A=
    var d =3D this.currentDelta();=0A=
    pos[0] -=3D d[0]; pos[1] -=3D d[1];=0A=
    =0A=
    if(this.options.scroll && (this.options.scroll !=3D window && =
this._isScrollChild)) {=0A=
      pos[0] -=3D this.options.scroll.scrollLeft-this.originalScrollLeft;=0A=
      pos[1] -=3D this.options.scroll.scrollTop-this.originalScrollTop;=0A=
    }=0A=
    =0A=
    var p =3D [0,1].map(function(i){ =0A=
      return (point[i]-pos[i]-this.offset[i]) =0A=
    }.bind(this));=0A=
    =0A=
    if(this.options.snap) {=0A=
      if(Object.isFunction(this.options.snap)) {=0A=
        p =3D this.options.snap(p[0],p[1],this);=0A=
      } else {=0A=
      if(Object.isArray(this.options.snap)) {=0A=
        p =3D p.map( function(v, i) {=0A=
          return (v/this.options.snap[i]).round()*this.options.snap[i] =
}.bind(this))=0A=
      } else {=0A=
        p =3D p.map( function(v) {=0A=
          return (v/this.options.snap).round()*this.options.snap =
}.bind(this))=0A=
      }=0A=
    }}=0A=
    =0A=
    var style =3D this.element.style;=0A=
    if((!this.options.constraint) || =
(this.options.constraint=3D=3D'horizontal'))=0A=
      style.left =3D p[0] + "px";=0A=
    if((!this.options.constraint) || =
(this.options.constraint=3D=3D'vertical'))=0A=
      style.top  =3D p[1] + "px";=0A=
    =0A=
    if(style.visibility=3D=3D"hidden") style.visibility =3D ""; // fix =
gecko rendering=0A=
  },=0A=
  =0A=
  stopScrolling: function() {=0A=
    if(this.scrollInterval) {=0A=
      clearInterval(this.scrollInterval);=0A=
      this.scrollInterval =3D null;=0A=
      Draggables._lastScrollPointer =3D null;=0A=
    }=0A=
  },=0A=
  =0A=
  startScrolling: function(speed) {=0A=
    if(!(speed[0] || speed[1])) return;=0A=
    this.scrollSpeed =3D =
[speed[0]*this.options.scrollSpeed,speed[1]*this.options.scrollSpeed];=0A=
    this.lastScrolled =3D new Date();=0A=
    this.scrollInterval =3D setInterval(this.scroll.bind(this), 10);=0A=
  },=0A=
  =0A=
  scroll: function() {=0A=
    var current =3D new Date();=0A=
    var delta =3D current - this.lastScrolled;=0A=
    this.lastScrolled =3D current;=0A=
    if(this.options.scroll =3D=3D window) {=0A=
      with (this._getWindowScroll(this.options.scroll)) {=0A=
        if (this.scrollSpeed[0] || this.scrollSpeed[1]) {=0A=
          var d =3D delta / 1000;=0A=
          this.options.scroll.scrollTo( left + d*this.scrollSpeed[0], =
top + d*this.scrollSpeed[1] );=0A=
        }=0A=
      }=0A=
    } else {=0A=
      this.options.scroll.scrollLeft +=3D this.scrollSpeed[0] * delta / =
1000;=0A=
      this.options.scroll.scrollTop  +=3D this.scrollSpeed[1] * delta / =
1000;=0A=
    }=0A=
    =0A=
    Position.prepare();=0A=
    Droppables.show(Draggables._lastPointer, this.element);=0A=
    Draggables.notify('onDrag', this);=0A=
    if (this._isScrollChild) {=0A=
      Draggables._lastScrollPointer =3D Draggables._lastScrollPointer || =
$A(Draggables._lastPointer);=0A=
      Draggables._lastScrollPointer[0] +=3D this.scrollSpeed[0] * delta =
/ 1000;=0A=
      Draggables._lastScrollPointer[1] +=3D this.scrollSpeed[1] * delta =
/ 1000;=0A=
      if (Draggables._lastScrollPointer[0] < 0)=0A=
        Draggables._lastScrollPointer[0] =3D 0;=0A=
      if (Draggables._lastScrollPointer[1] < 0)=0A=
        Draggables._lastScrollPointer[1] =3D 0;=0A=
      this.draw(Draggables._lastScrollPointer);=0A=
    }=0A=
    =0A=
    if(this.options.change) this.options.change(this);=0A=
  },=0A=
  =0A=
  _getWindowScroll: function(w) {=0A=
    var T, L, W, H;=0A=
    with (w.document) {=0A=
      if (w.document.documentElement && documentElement.scrollTop) {=0A=
        T =3D documentElement.scrollTop;=0A=
        L =3D documentElement.scrollLeft;=0A=
      } else if (w.document.body) {=0A=
        T =3D body.scrollTop;=0A=
        L =3D body.scrollLeft;=0A=
      }=0A=
      if (w.innerWidth) {=0A=
        W =3D w.innerWidth;=0A=
        H =3D w.innerHeight;=0A=
      } else if (w.document.documentElement && =
documentElement.clientWidth) {=0A=
        W =3D documentElement.clientWidth;=0A=
        H =3D documentElement.clientHeight;=0A=
      } else {=0A=
        W =3D body.offsetWidth;=0A=
        H =3D body.offsetHeight=0A=
      }=0A=
    }=0A=
    return { top: T, left: L, width: W, height: H };=0A=
  }=0A=
});=0A=
=0A=
Draggable._dragging =3D { };=0A=
=0A=
/*-----------------------------------------------------------------------=
---*/=0A=
=0A=
var SortableObserver =3D Class.create({=0A=
  initialize: function(element, observer) {=0A=
    this.element   =3D $(element);=0A=
    this.observer  =3D observer;=0A=
    this.lastValue =3D Sortable.serialize(this.element);=0A=
  },=0A=
  =0A=
  onStart: function() {=0A=
    this.lastValue =3D Sortable.serialize(this.element);=0A=
  },=0A=
  =0A=
  onEnd: function() {=0A=
    Sortable.unmark();=0A=
    if(this.lastValue !=3D Sortable.serialize(this.element))=0A=
      this.observer(this.element)=0A=
  }=0A=
});=0A=
=0A=
var Sortable =3D {=0A=
  SERIALIZE_RULE: /^[^_\-](?:[A-Za-z0-9\-\_]*)[_](.*)$/,=0A=
  =0A=
  sortables: { },=0A=
  =0A=
  _findRootElement: function(element) {=0A=
    while (element.tagName.toUpperCase() !=3D "BODY") {  =0A=
      if(element.id && Sortable.sortables[element.id]) return element;=0A=
      element =3D element.parentNode;=0A=
    }=0A=
  },=0A=
=0A=
  options: function(element) {=0A=
    element =3D Sortable._findRootElement($(element));=0A=
    if(!element) return;=0A=
    return Sortable.sortables[element.id];=0A=
  },=0A=
  =0A=
  destroy: function(element){=0A=
    var s =3D Sortable.options(element);=0A=
    =0A=
    if(s) {=0A=
      Draggables.removeObserver(s.element);=0A=
      s.droppables.each(function(d){ Droppables.remove(d) });=0A=
      s.draggables.invoke('destroy');=0A=
      =0A=
      delete Sortable.sortables[s.element.id];=0A=
    }=0A=
  },=0A=
=0A=
  create: function(element) {=0A=
    element =3D $(element);=0A=
    var options =3D Object.extend({ =0A=
      element:     element,=0A=
      tag:         'li',       // assumes li children, override with =
tag: 'tagname'=0A=
      dropOnEmpty: false,=0A=
      tree:        false,=0A=
      treeTag:     'ul',=0A=
      overlap:     'vertical', // one of 'vertical', 'horizontal'=0A=
      constraint:  'vertical', // one of 'vertical', 'horizontal', false=0A=
      containment: element,    // also takes array of elements (or =
id's); or false=0A=
      handle:      false,      // or a CSS class=0A=
      only:        false,=0A=
      delay:       0,=0A=
      hoverclass:  null,=0A=
      ghosting:    false,=0A=
      quiet:       false, =0A=
      scroll:      false,=0A=
      scrollSensitivity: 20,=0A=
      scrollSpeed: 15,=0A=
      format:      this.SERIALIZE_RULE,=0A=
      =0A=
      // these take arrays of elements or ids and can be =0A=
      // used for better initialization performance=0A=
      elements:    false,=0A=
      handles:     false,=0A=
      =0A=
      onChange:    Prototype.emptyFunction,=0A=
      onUpdate:    Prototype.emptyFunction=0A=
    }, arguments[1] || { });=0A=
=0A=
    // clear any old sortable with same element=0A=
    this.destroy(element);=0A=
=0A=
    // build options for the draggables=0A=
    var options_for_draggable =3D {=0A=
      revert:      true,=0A=
      quiet:       options.quiet,=0A=
      scroll:      options.scroll,=0A=
      scrollSpeed: options.scrollSpeed,=0A=
      scrollSensitivity: options.scrollSensitivity,=0A=
      delay:       options.delay,=0A=
      ghosting:    options.ghosting,=0A=
      constraint:  options.constraint,=0A=
      handle:      options.handle };=0A=
=0A=
    if(options.starteffect)=0A=
      options_for_draggable.starteffect =3D options.starteffect;=0A=
=0A=
    if(options.reverteffect)=0A=
      options_for_draggable.reverteffect =3D options.reverteffect;=0A=
    else=0A=
      if(options.ghosting) options_for_draggable.reverteffect =3D =
function(element) {=0A=
        element.style.top  =3D 0;=0A=
        element.style.left =3D 0;=0A=
      };=0A=
=0A=
    if(options.endeffect)=0A=
      options_for_draggable.endeffect =3D options.endeffect;=0A=
=0A=
    if(options.zindex)=0A=
      options_for_draggable.zindex =3D options.zindex;=0A=
=0A=
    // build options for the droppables  =0A=
    var options_for_droppable =3D {=0A=
      overlap:     options.overlap,=0A=
      containment: options.containment,=0A=
      tree:        options.tree,=0A=
      hoverclass:  options.hoverclass,=0A=
      onHover:     Sortable.onHover=0A=
    }=0A=
    =0A=
    var options_for_tree =3D {=0A=
      onHover:      Sortable.onEmptyHover,=0A=
      overlap:      options.overlap,=0A=
      containment:  options.containment,=0A=
      hoverclass:   options.hoverclass=0A=
    }=0A=
=0A=
    // fix for gecko engine=0A=
    Element.cleanWhitespace(element); =0A=
=0A=
    options.draggables =3D [];=0A=
    options.droppables =3D [];=0A=
=0A=
    // drop on empty handling=0A=
    if(options.dropOnEmpty || options.tree) {=0A=
      Droppables.add(element, options_for_tree);=0A=
      options.droppables.push(element);=0A=
    }=0A=
=0A=
    (options.elements || this.findElements(element, options) || =
[]).each( function(e,i) {=0A=
      var handle =3D options.handles ? $(options.handles[i]) :=0A=
        (options.handle ? $(e).select('.' + options.handle)[0] : e); =0A=
      options.draggables.push(=0A=
        new Draggable(e, Object.extend(options_for_draggable, { handle: =
handle })));=0A=
      Droppables.add(e, options_for_droppable);=0A=
      if(options.tree) e.treeNode =3D element;=0A=
      options.droppables.push(e);      =0A=
    });=0A=
    =0A=
    if(options.tree) {=0A=
      (Sortable.findTreeElements(element, options) || []).each( =
function(e) {=0A=
        Droppables.add(e, options_for_tree);=0A=
        e.treeNode =3D element;=0A=
        options.droppables.push(e);=0A=
      });=0A=
    }=0A=
=0A=
    // keep reference=0A=
    this.sortables[element.id] =3D options;=0A=
=0A=
    // for onupdate=0A=
    Draggables.addObserver(new SortableObserver(element, =
options.onUpdate));=0A=
=0A=
  },=0A=
=0A=
  // return all suitable-for-sortable elements in a guaranteed order=0A=
  findElements: function(element, options) {=0A=
    return Element.findChildren(=0A=
      element, options.only, options.tree ? true : false, options.tag);=0A=
  },=0A=
  =0A=
  findTreeElements: function(element, options) {=0A=
    return Element.findChildren(=0A=
      element, options.only, options.tree ? true : false, =
options.treeTag);=0A=
  },=0A=
=0A=
  onHover: function(element, dropon, overlap) {=0A=
    if(Element.isParent(dropon, element)) return;=0A=
=0A=
    if(overlap > .33 && overlap < .66 && Sortable.options(dropon).tree) {=0A=
      return;=0A=
    } else if(overlap>0.5) {=0A=
      Sortable.mark(dropon, 'before');=0A=
      if(dropon.previousSibling !=3D element) {=0A=
        var oldParentNode =3D element.parentNode;=0A=
        element.style.visibility =3D "hidden"; // fix gecko rendering=0A=
        dropon.parentNode.insertBefore(element, dropon);=0A=
        if(dropon.parentNode!=3DoldParentNode) =0A=
          Sortable.options(oldParentNode).onChange(element);=0A=
        Sortable.options(dropon.parentNode).onChange(element);=0A=
      }=0A=
    } else {=0A=
      Sortable.mark(dropon, 'after');=0A=
      var nextElement =3D dropon.nextSibling || null;=0A=
      if(nextElement !=3D element) {=0A=
        var oldParentNode =3D element.parentNode;=0A=
        element.style.visibility =3D "hidden"; // fix gecko rendering=0A=
        dropon.parentNode.insertBefore(element, nextElement);=0A=
        if(dropon.parentNode!=3DoldParentNode) =0A=
          Sortable.options(oldParentNode).onChange(element);=0A=
        Sortable.options(dropon.parentNode).onChange(element);=0A=
      }=0A=
    }=0A=
  },=0A=
  =0A=
  onEmptyHover: function(element, dropon, overlap) {=0A=
    var oldParentNode =3D element.parentNode;=0A=
    var droponOptions =3D Sortable.options(dropon);=0A=
        =0A=
    if(!Element.isParent(dropon, element)) {=0A=
      var index;=0A=
      =0A=
      var children =3D Sortable.findElements(dropon, {tag: =
droponOptions.tag, only: droponOptions.only});=0A=
      var child =3D null;=0A=
            =0A=
      if(children) {=0A=
        var offset =3D Element.offsetSize(dropon, droponOptions.overlap) =
* (1.0 - overlap);=0A=
        =0A=
        for (index =3D 0; index < children.length; index +=3D 1) {=0A=
          if (offset - Element.offsetSize (children[index], =
droponOptions.overlap) >=3D 0) {=0A=
            offset -=3D Element.offsetSize (children[index], =
droponOptions.overlap);=0A=
          } else if (offset - (Element.offsetSize (children[index], =
droponOptions.overlap) / 2) >=3D 0) {=0A=
            child =3D index + 1 < children.length ? children[index + 1] =
: null;=0A=
            break;=0A=
          } else {=0A=
            child =3D children[index];=0A=
            break;=0A=
          }=0A=
        }=0A=
      }=0A=
      =0A=
      dropon.insertBefore(element, child);=0A=
      =0A=
      Sortable.options(oldParentNode).onChange(element);=0A=
      droponOptions.onChange(element);=0A=
    }=0A=
  },=0A=
=0A=
  unmark: function() {=0A=
    if(Sortable._marker) Sortable._marker.hide();=0A=
  },=0A=
=0A=
  mark: function(dropon, position) {=0A=
    // mark on ghosting only=0A=
    var sortable =3D Sortable.options(dropon.parentNode);=0A=
    if(sortable && !sortable.ghosting) return; =0A=
=0A=
    if(!Sortable._marker) {=0A=
      Sortable._marker =3D =0A=
        ($('dropmarker') || =
Element.extend(document.createElement('DIV'))).=0A=
          =
hide().addClassName('dropmarker').setStyle({position:'absolute'});=0A=
      =
document.getElementsByTagName("body").item(0).appendChild(Sortable._marke=
r);=0A=
    }    =0A=
    var offsets =3D Position.cumulativeOffset(dropon);=0A=
    Sortable._marker.setStyle({left: offsets[0]+'px', top: offsets[1] + =
'px'});=0A=
    =0A=
    if(position=3D=3D'after')=0A=
      if(sortable.overlap =3D=3D 'horizontal') =0A=
        Sortable._marker.setStyle({left: (offsets[0]+dropon.clientWidth) =
+ 'px'});=0A=
      else=0A=
        Sortable._marker.setStyle({top: (offsets[1]+dropon.clientHeight) =
+ 'px'});=0A=
    =0A=
    Sortable._marker.show();=0A=
  },=0A=
  =0A=
  _tree: function(element, options, parent) {=0A=
    var children =3D Sortable.findElements(element, options) || [];=0A=
  =0A=
    for (var i =3D 0; i < children.length; ++i) {=0A=
      var match =3D children[i].id.match(options.format);=0A=
=0A=
      if (!match) continue;=0A=
      =0A=
      var child =3D {=0A=
        id: encodeURIComponent(match ? match[1] : null),=0A=
        element: element,=0A=
        parent: parent,=0A=
        children: [],=0A=
        position: parent.children.length,=0A=
        container: $(children[i]).down(options.treeTag)=0A=
      }=0A=
      =0A=
      /* Get the element containing the children and recurse over it */=0A=
      if (child.container)=0A=
        this._tree(child.container, options, child)=0A=
      =0A=
      parent.children.push (child);=0A=
    }=0A=
=0A=
    return parent; =0A=
  },=0A=
=0A=
  tree: function(element) {=0A=
    element =3D $(element);=0A=
    var sortableOptions =3D this.options(element);=0A=
    var options =3D Object.extend({=0A=
      tag: sortableOptions.tag,=0A=
      treeTag: sortableOptions.treeTag,=0A=
      only: sortableOptions.only,=0A=
      name: element.id,=0A=
      format: sortableOptions.format=0A=
    }, arguments[1] || { });=0A=
    =0A=
    var root =3D {=0A=
      id: null,=0A=
      parent: null,=0A=
      children: [],=0A=
      container: element,=0A=
      position: 0=0A=
    }=0A=
    =0A=
    return Sortable._tree(element, options, root);=0A=
  },=0A=
=0A=
  /* Construct a [i] index for a particular node */=0A=
  _constructIndex: function(node) {=0A=
    var index =3D '';=0A=
    do {=0A=
      if (node.id) index =3D '[' + node.position + ']' + index;=0A=
    } while ((node =3D node.parent) !=3D null);=0A=
    return index;=0A=
  },=0A=
=0A=
  sequence: function(element) {=0A=
    element =3D $(element);=0A=
    var options =3D Object.extend(this.options(element), arguments[1] || =
{ });=0A=
    =0A=
    return $(this.findElements(element, options) || []).map( =
function(item) {=0A=
      return item.id.match(options.format) ? =
item.id.match(options.format)[1] : '';=0A=
    });=0A=
  },=0A=
=0A=
  setSequence: function(element, new_sequence) {=0A=
    element =3D $(element);=0A=
    var options =3D Object.extend(this.options(element), arguments[2] || =
{ });=0A=
    =0A=
    var nodeMap =3D { };=0A=
    this.findElements(element, options).each( function(n) {=0A=
        if (n.id.match(options.format))=0A=
            nodeMap[n.id.match(options.format)[1]] =3D [n, n.parentNode];=0A=
        n.parentNode.removeChild(n);=0A=
    });=0A=
   =0A=
    new_sequence.each(function(ident) {=0A=
      var n =3D nodeMap[ident];=0A=
      if (n) {=0A=
        n[1].appendChild(n[0]);=0A=
        delete nodeMap[ident];=0A=
      }=0A=
    });=0A=
  },=0A=
  =0A=
  serialize: function(element) {=0A=
    element =3D $(element);=0A=
    var options =3D Object.extend(Sortable.options(element), =
arguments[1] || { });=0A=
    var name =3D encodeURIComponent(=0A=
      (arguments[1] && arguments[1].name) ? arguments[1].name : =
element.id);=0A=
    =0A=
    if (options.tree) {=0A=
      return Sortable.tree(element, arguments[1]).children.map( function =
(item) {=0A=
        return [name + Sortable._constructIndex(item) + "[id]=3D" + =0A=
                =
encodeURIComponent(item.id)].concat(item.children.map(arguments.callee));=0A=
      }).flatten().join('&');=0A=
    } else {=0A=
      return Sortable.sequence(element, arguments[1]).map( =
function(item) {=0A=
        return name + "[]=3D" + encodeURIComponent(item);=0A=
      }).join('&');=0A=
    }=0A=
  }=0A=
}=0A=
=0A=
// Returns true if child is contained within element=0A=
Element.isParent =3D function(child, element) {=0A=
  if (!child.parentNode || child =3D=3D element) return false;=0A=
  if (child.parentNode =3D=3D element) return true;=0A=
  return Element.isParent(child.parentNode, element);=0A=
}=0A=
=0A=
Element.findChildren =3D function(element, only, recursive, tagName) {   =0A=
  if(!element.hasChildNodes()) return null;=0A=
  tagName =3D tagName.toUpperCase();=0A=
  if(only) only =3D [only].flatten();=0A=
  var elements =3D [];=0A=
  $A(element.childNodes).each( function(e) {=0A=
    if(e.tagName && e.tagName.toUpperCase()=3D=3DtagName &&=0A=
      (!only || (Element.classNames(e).detect(function(v) { return =
only.include(v) }))))=0A=
        elements.push(e);=0A=
    if(recursive) {=0A=
      var grandchildren =3D Element.findChildren(e, only, recursive, =
tagName);=0A=
      if(grandchildren) elements.push(grandchildren);=0A=
    }=0A=
  });=0A=
=0A=
  return (elements.length>0 ? elements.flatten() : []);=0A=
}=0A=
=0A=
Element.offsetSize =3D function (element, type) {=0A=
  return element['offset' + ((type=3D=3D'vertical' || =
type=3D=3D'height') ? 'Height' : 'Width')];=0A=
}=0A=

------=_NextPart_000_0000_01CAB168.786EE890
Content-Type: application/octet-stream
Content-Transfer-Encoding: quoted-printable
Content-Location: http://www.eenews.net/javascripts/controls.js?1218125236

// Copyright (c) 2005-2007 Thomas Fuchs (http://script.aculo.us, =
http://mir.aculo.us)=0A=
//           (c) 2005-2007 Ivan Krstic =
(http://blogs.law.harvard.edu/ivan)=0A=
//           (c) 2005-2007 Jon Tirsen (http://www.tirsen.com)=0A=
// Contributors:=0A=
//  Richard Livsey=0A=
//  Rahul Bhargava=0A=
//  Rob Wills=0A=
// =0A=
// script.aculo.us is freely distributable under the terms of an =
MIT-style license.=0A=
// For details, see the script.aculo.us web site: http://script.aculo.us/=0A=
=0A=
// Autocompleter.Base handles all the autocompletion functionality =0A=
// that's independent of the data source for autocompletion. This=0A=
// includes drawing the autocompletion menu, observing keyboard=0A=
// and mouse events, and similar.=0A=
//=0A=
// Specific autocompleters need to provide, at the very least, =0A=
// a getUpdatedChoices function that will be invoked every time=0A=
// the text inside the monitored textbox changes. This method =0A=
// should get the text for which to provide autocompletion by=0A=
// invoking this.getToken(), NOT by directly accessing=0A=
// this.element.value. This is to allow incremental tokenized=0A=
// autocompletion. Specific auto-completion logic (AJAX, etc)=0A=
// belongs in getUpdatedChoices.=0A=
//=0A=
// Tokenized incremental autocompletion is enabled automatically=0A=
// when an autocompleter is instantiated with the 'tokens' option=0A=
// in the options parameter, e.g.:=0A=
// new Ajax.Autocompleter('id','upd', '/url/', { tokens: ',' });=0A=
// will incrementally autocomplete with a comma as the token.=0A=
// Additionally, ',' in the above example can be replaced with=0A=
// a token array, e.g. { tokens: [',', '\n'] } which=0A=
// enables autocompletion on multiple tokens. This is most =0A=
// useful when one of the tokens is \n (a newline), as it =0A=
// allows smart autocompletion after linebreaks.=0A=
=0A=
if(typeof Effect =3D=3D 'undefined')=0A=
  throw("controls.js requires including script.aculo.us' effects.js =
library");=0A=
=0A=
var Autocompleter =3D { }=0A=
Autocompleter.Base =3D Class.create({=0A=
  baseInitialize: function(element, update, options) {=0A=
    element          =3D $(element)=0A=
    this.element     =3D element; =0A=
    this.update      =3D $(update);  =0A=
    this.hasFocus    =3D false; =0A=
    this.changed     =3D false; =0A=
    this.active      =3D false; =0A=
    this.index       =3D 0;     =0A=
    this.entryCount  =3D 0;=0A=
    this.oldElementValue =3D this.element.value;=0A=
=0A=
    if(this.setOptions)=0A=
      this.setOptions(options);=0A=
    else=0A=
      this.options =3D options || { };=0A=
=0A=
    this.options.paramName    =3D this.options.paramName || =
this.element.name;=0A=
    this.options.tokens       =3D this.options.tokens || [];=0A=
    this.options.frequency    =3D this.options.frequency || 0.4;=0A=
    this.options.minChars     =3D this.options.minChars || 1;=0A=
    this.options.onShow       =3D this.options.onShow || =0A=
      function(element, update){ =0A=
        if(!update.style.position || =
update.style.position=3D=3D'absolute') {=0A=
          update.style.position =3D 'absolute';=0A=
          Position.clone(element, update, {=0A=
            setHeight: false, =0A=
            offsetTop: element.offsetHeight=0A=
          });=0A=
        }=0A=
        Effect.Appear(update,{duration:0.15});=0A=
      };=0A=
    this.options.onHide =3D this.options.onHide || =0A=
      function(element, update){ new Effect.Fade(update,{duration:0.15}) =
};=0A=
=0A=
    if(typeof(this.options.tokens) =3D=3D 'string') =0A=
      this.options.tokens =3D new Array(this.options.tokens);=0A=
    // Force carriage returns as token delimiters anyway=0A=
    if (!this.options.tokens.include('\n'))=0A=
      this.options.tokens.push('\n');=0A=
=0A=
    this.observer =3D null;=0A=
    =0A=
    this.element.setAttribute('autocomplete','off');=0A=
=0A=
    Element.hide(this.update);=0A=
=0A=
    Event.observe(this.element, 'blur', =
this.onBlur.bindAsEventListener(this));=0A=
    Event.observe(this.element, 'keydown', =
this.onKeyPress.bindAsEventListener(this));=0A=
  },=0A=
=0A=
  show: function() {=0A=
    if(Element.getStyle(this.update, 'display')=3D=3D'none') =
this.options.onShow(this.element, this.update);=0A=
    if(!this.iefix && =0A=
      (Prototype.Browser.IE) &&=0A=
      (Element.getStyle(this.update, 'position')=3D=3D'absolute')) {=0A=
      new Insertion.After(this.update, =0A=
       '<iframe id=3D"' + this.update.id + '_iefix" '+=0A=
       =
'style=3D"display:none;position:absolute;filter:progid:DXImageTransform.M=
icrosoft.Alpha(opacity=3D0);" ' +=0A=
       'src=3D"javascript:false;" frameborder=3D"0" =
scrolling=3D"no"></iframe>');=0A=
      this.iefix =3D $(this.update.id+'_iefix');=0A=
    }=0A=
    if(this.iefix) setTimeout(this.fixIEOverlapping.bind(this), 50);=0A=
  },=0A=
  =0A=
  fixIEOverlapping: function() {=0A=
    Position.clone(this.update, this.iefix, =
{setTop:(!this.update.style.height)});=0A=
    this.iefix.style.zIndex =3D 1;=0A=
    this.update.style.zIndex =3D 2;=0A=
    Element.show(this.iefix);=0A=
  },=0A=
=0A=
  hide: function() {=0A=
    this.stopIndicator();=0A=
    if(Element.getStyle(this.update, 'display')!=3D'none') =
this.options.onHide(this.element, this.update);=0A=
    if(this.iefix) Element.hide(this.iefix);=0A=
  },=0A=
=0A=
  startIndicator: function() {=0A=
    if(this.options.indicator) Element.show(this.options.indicator);=0A=
  },=0A=
=0A=
  stopIndicator: function() {=0A=
    if(this.options.indicator) Element.hide(this.options.indicator);=0A=
  },=0A=
=0A=
  onKeyPress: function(event) {=0A=
    if(this.active)=0A=
      switch(event.keyCode) {=0A=
       case Event.KEY_TAB:=0A=
       case Event.KEY_RETURN:=0A=
         this.selectEntry();=0A=
         Event.stop(event);=0A=
       case Event.KEY_ESC:=0A=
         this.hide();=0A=
         this.active =3D false;=0A=
         Event.stop(event);=0A=
         return;=0A=
       case Event.KEY_LEFT:=0A=
       case Event.KEY_RIGHT:=0A=
         return;=0A=
       case Event.KEY_UP:=0A=
         this.markPrevious();=0A=
         this.render();=0A=
         Event.stop(event);=0A=
         return;=0A=
       case Event.KEY_DOWN:=0A=
         this.markNext();=0A=
         this.render();=0A=
         Event.stop(event);=0A=
         return;=0A=
      }=0A=
     else =0A=
       if(event.keyCode=3D=3DEvent.KEY_TAB || =
event.keyCode=3D=3DEvent.KEY_RETURN || =0A=
         (Prototype.Browser.WebKit > 0 && event.keyCode =3D=3D 0)) =
return;=0A=
=0A=
    this.changed =3D true;=0A=
    this.hasFocus =3D true;=0A=
=0A=
    if(this.observer) clearTimeout(this.observer);=0A=
      this.observer =3D =0A=
        setTimeout(this.onObserverEvent.bind(this), =
this.options.frequency*1000);=0A=
  },=0A=
=0A=
  activate: function() {=0A=
    this.changed =3D false;=0A=
    this.hasFocus =3D true;=0A=
    this.getUpdatedChoices();=0A=
  },=0A=
=0A=
  onHover: function(event) {=0A=
    var element =3D Event.findElement(event, 'LI');=0A=
    if(this.index !=3D element.autocompleteIndex) =0A=
    {=0A=
        this.index =3D element.autocompleteIndex;=0A=
        this.render();=0A=
    }=0A=
    Event.stop(event);=0A=
  },=0A=
  =0A=
  onClick: function(event) {=0A=
    var element =3D Event.findElement(event, 'LI');=0A=
    this.index =3D element.autocompleteIndex;=0A=
    this.selectEntry();=0A=
    this.hide();=0A=
  },=0A=
  =0A=
  onBlur: function(event) {=0A=
    // needed to make click events working=0A=
    setTimeout(this.hide.bind(this), 250);=0A=
    this.hasFocus =3D false;=0A=
    this.active =3D false;     =0A=
  }, =0A=
  =0A=
  render: function() {=0A=
    if(this.entryCount > 0) {=0A=
      for (var i =3D 0; i < this.entryCount; i++)=0A=
        this.index=3D=3Di ? =0A=
          Element.addClassName(this.getEntry(i),"selected") : =0A=
          Element.removeClassName(this.getEntry(i),"selected");=0A=
      if(this.hasFocus) { =0A=
        this.show();=0A=
        this.active =3D true;=0A=
      }=0A=
    } else {=0A=
      this.active =3D false;=0A=
      this.hide();=0A=
    }=0A=
  },=0A=
  =0A=
  markPrevious: function() {=0A=
    if(this.index > 0) this.index--=0A=
      else this.index =3D this.entryCount-1;=0A=
    this.getEntry(this.index).scrollIntoView(true);=0A=
  },=0A=
  =0A=
  markNext: function() {=0A=
    if(this.index < this.entryCount-1) this.index++=0A=
      else this.index =3D 0;=0A=
    this.getEntry(this.index).scrollIntoView(false);=0A=
  },=0A=
  =0A=
  getEntry: function(index) {=0A=
    return this.update.firstChild.childNodes[index];=0A=
  },=0A=
  =0A=
  getCurrentEntry: function() {=0A=
    return this.getEntry(this.index);=0A=
  },=0A=
  =0A=
  selectEntry: function() {=0A=
    this.active =3D false;=0A=
    this.updateElement(this.getCurrentEntry());=0A=
  },=0A=
=0A=
  updateElement: function(selectedElement) {=0A=
    if (this.options.updateElement) {=0A=
      this.options.updateElement(selectedElement);=0A=
      return;=0A=
    }=0A=
    var value =3D '';=0A=
    if (this.options.select) {=0A=
      var nodes =3D $(selectedElement).select('.' + this.options.select) =
|| [];=0A=
      if(nodes.length>0) value =3D Element.collectTextNodes(nodes[0], =
this.options.select);=0A=
    } else=0A=
      value =3D Element.collectTextNodesIgnoreClass(selectedElement, =
'informal');=0A=
    =0A=
    var bounds =3D this.getTokenBounds();=0A=
    if (bounds[0] !=3D -1) {=0A=
      var newValue =3D this.element.value.substr(0, bounds[0]);=0A=
      var whitespace =3D =
this.element.value.substr(bounds[0]).match(/^\s+/);=0A=
      if (whitespace)=0A=
        newValue +=3D whitespace[0];=0A=
      this.element.value =3D newValue + value + =
this.element.value.substr(bounds[1]);=0A=
    } else {=0A=
      this.element.value =3D value;=0A=
    }=0A=
    this.oldElementValue =3D this.element.value;=0A=
    this.element.focus();=0A=
    =0A=
    if (this.options.afterUpdateElement)=0A=
      this.options.afterUpdateElement(this.element, selectedElement);=0A=
  },=0A=
=0A=
  updateChoices: function(choices) {=0A=
    if(!this.changed && this.hasFocus) {=0A=
      this.update.innerHTML =3D choices;=0A=
      Element.cleanWhitespace(this.update);=0A=
      Element.cleanWhitespace(this.update.down());=0A=
=0A=
      if(this.update.firstChild && this.update.down().childNodes) {=0A=
        this.entryCount =3D =0A=
          this.update.down().childNodes.length;=0A=
        for (var i =3D 0; i < this.entryCount; i++) {=0A=
          var entry =3D this.getEntry(i);=0A=
          entry.autocompleteIndex =3D i;=0A=
          this.addObservers(entry);=0A=
        }=0A=
      } else { =0A=
        this.entryCount =3D 0;=0A=
      }=0A=
=0A=
      this.stopIndicator();=0A=
      this.index =3D 0;=0A=
      =0A=
      if(this.entryCount=3D=3D1 && this.options.autoSelect) {=0A=
        this.selectEntry();=0A=
        this.hide();=0A=
      } else {=0A=
        this.render();=0A=
      }=0A=
    }=0A=
  },=0A=
=0A=
  addObservers: function(element) {=0A=
    Event.observe(element, "mouseover", =
this.onHover.bindAsEventListener(this));=0A=
    Event.observe(element, "click", =
this.onClick.bindAsEventListener(this));=0A=
  },=0A=
=0A=
  onObserverEvent: function() {=0A=
    this.changed =3D false;   =0A=
    this.tokenBounds =3D null;=0A=
    if(this.getToken().length>=3Dthis.options.minChars) {=0A=
      this.getUpdatedChoices();=0A=
    } else {=0A=
      this.active =3D false;=0A=
      this.hide();=0A=
    }=0A=
    this.oldElementValue =3D this.element.value;=0A=
  },=0A=
=0A=
  getToken: function() {=0A=
    var bounds =3D this.getTokenBounds();=0A=
    return this.element.value.substring(bounds[0], bounds[1]).strip();=0A=
  },=0A=
=0A=
  getTokenBounds: function() {=0A=
    if (null !=3D this.tokenBounds) return this.tokenBounds;=0A=
    var value =3D this.element.value;=0A=
    if (value.strip().empty()) return [-1, 0];=0A=
    var diff =3D arguments.callee.getFirstDifferencePos(value, =
this.oldElementValue);=0A=
    var offset =3D (diff =3D=3D this.oldElementValue.length ? 1 : 0);=0A=
    var prevTokenPos =3D -1, nextTokenPos =3D value.length;=0A=
    var tp;=0A=
    for (var index =3D 0, l =3D this.options.tokens.length; index < l; =
++index) {=0A=
      tp =3D value.lastIndexOf(this.options.tokens[index], diff + offset =
- 1);=0A=
      if (tp > prevTokenPos) prevTokenPos =3D tp;=0A=
      tp =3D value.indexOf(this.options.tokens[index], diff + offset);=0A=
      if (-1 !=3D tp && tp < nextTokenPos) nextTokenPos =3D tp;=0A=
    }=0A=
    return (this.tokenBounds =3D [prevTokenPos + 1, nextTokenPos]);=0A=
  }=0A=
});=0A=
=0A=
Autocompleter.Base.prototype.getTokenBounds.getFirstDifferencePos =3D =
function(newS, oldS) {=0A=
  var boundary =3D Math.min(newS.length, oldS.length);=0A=
  for (var index =3D 0; index < boundary; ++index)=0A=
    if (newS[index] !=3D oldS[index])=0A=
      return index;=0A=
  return boundary;=0A=
};=0A=
=0A=
Ajax.Autocompleter =3D Class.create(Autocompleter.Base, {=0A=
  initialize: function(element, update, url, options) {=0A=
    this.baseInitialize(element, update, options);=0A=
    this.options.asynchronous  =3D true;=0A=
    this.options.onComplete    =3D this.onComplete.bind(this);=0A=
    this.options.defaultParams =3D this.options.parameters || null;=0A=
    this.url                   =3D url;=0A=
  },=0A=
=0A=
  getUpdatedChoices: function() {=0A=
    this.startIndicator();=0A=
    =0A=
    var entry =3D encodeURIComponent(this.options.paramName) + '=3D' + =0A=
      encodeURIComponent(this.getToken());=0A=
=0A=
    this.options.parameters =3D this.options.callback ?=0A=
      this.options.callback(this.element, entry) : entry;=0A=
=0A=
    if(this.options.defaultParams) =0A=
      this.options.parameters +=3D '&' + this.options.defaultParams;=0A=
    =0A=
    new Ajax.Request(this.url, this.options);=0A=
  },=0A=
=0A=
  onComplete: function(request) {=0A=
    this.updateChoices(request.responseText);=0A=
  }=0A=
});=0A=
=0A=
// The local array autocompleter. Used when you'd prefer to=0A=
// inject an array of autocompletion options into the page, rather=0A=
// than sending out Ajax queries, which can be quite slow sometimes.=0A=
//=0A=
// The constructor takes four parameters. The first two are, as usual,=0A=
// the id of the monitored textbox, and id of the autocompletion menu.=0A=
// The third is the array you want to autocomplete from, and the fourth=0A=
// is the options block.=0A=
//=0A=
// Extra local autocompletion options:=0A=
// - choices - How many autocompletion choices to offer=0A=
//=0A=
// - partialSearch - If false, the autocompleter will match entered=0A=
//                    text only at the beginning of strings in the =0A=
//                    autocomplete array. Defaults to true, which will=0A=
//                    match text at the beginning of any *word* in the=0A=
//                    strings in the autocomplete array. If you want to=0A=
//                    search anywhere in the string, additionally set=0A=
//                    the option fullSearch to true (default: off).=0A=
//=0A=
// - fullSsearch - Search anywhere in autocomplete array strings.=0A=
//=0A=
// - partialChars - How many characters to enter before triggering=0A=
//                   a partial match (unlike minChars, which defines=0A=
//                   how many characters are required to do any match=0A=
//                   at all). Defaults to 2.=0A=
//=0A=
// - ignoreCase - Whether to ignore case when autocompleting.=0A=
//                 Defaults to true.=0A=
//=0A=
// It's possible to pass in a custom function as the 'selector' =0A=
// option, if you prefer to write your own autocompletion logic.=0A=
// In that case, the other options above will not apply unless=0A=
// you support them.=0A=
=0A=
Autocompleter.Local =3D Class.create(Autocompleter.Base, {=0A=
  initialize: function(element, update, array, options) {=0A=
    this.baseInitialize(element, update, options);=0A=
    this.options.array =3D array;=0A=
  },=0A=
=0A=
  getUpdatedChoices: function() {=0A=
    this.updateChoices(this.options.selector(this));=0A=
  },=0A=
=0A=
  setOptions: function(options) {=0A=
    this.options =3D Object.extend({=0A=
      choices: 10,=0A=
      partialSearch: true,=0A=
      partialChars: 2,=0A=
      ignoreCase: true,=0A=
      fullSearch: false,=0A=
      selector: function(instance) {=0A=
        var ret       =3D []; // Beginning matches=0A=
        var partial   =3D []; // Inside matches=0A=
        var entry     =3D instance.getToken();=0A=
        var count     =3D 0;=0A=
=0A=
        for (var i =3D 0; i < instance.options.array.length &&  =0A=
          ret.length < instance.options.choices ; i++) { =0A=
=0A=
          var elem =3D instance.options.array[i];=0A=
          var foundPos =3D instance.options.ignoreCase ? =0A=
            elem.toLowerCase().indexOf(entry.toLowerCase()) : =0A=
            elem.indexOf(entry);=0A=
=0A=
          while (foundPos !=3D -1) {=0A=
            if (foundPos =3D=3D 0 && elem.length !=3D entry.length) { =0A=
              ret.push("<li><strong>" + elem.substr(0, entry.length) + =
"</strong>" + =0A=
                elem.substr(entry.length) + "</li>");=0A=
              break;=0A=
            } else if (entry.length >=3D instance.options.partialChars =
&& =0A=
              instance.options.partialSearch && foundPos !=3D -1) {=0A=
              if (instance.options.fullSearch || =
/\s/.test(elem.substr(foundPos-1,1))) {=0A=
                partial.push("<li>" + elem.substr(0, foundPos) + =
"<strong>" +=0A=
                  elem.substr(foundPos, entry.length) + "</strong>" + =
elem.substr(=0A=
                  foundPos + entry.length) + "</li>");=0A=
                break;=0A=
              }=0A=
            }=0A=
=0A=
            foundPos =3D instance.options.ignoreCase ? =0A=
              elem.toLowerCase().indexOf(entry.toLowerCase(), foundPos + =
1) : =0A=
              elem.indexOf(entry, foundPos + 1);=0A=
=0A=
          }=0A=
        }=0A=
        if (partial.length)=0A=
          ret =3D ret.concat(partial.slice(0, instance.options.choices - =
ret.length))=0A=
        return "<ul>" + ret.join('') + "</ul>";=0A=
      }=0A=
    }, options || { });=0A=
  }=0A=
});=0A=
=0A=
// AJAX in-place editor and collection editor=0A=
// Full rewrite by Christophe Porteneuve <tdd@tddsworld.com> (April =
2007).=0A=
=0A=
// Use this if you notice weird scrolling problems on some browsers,=0A=
// the DOM might be a bit confused when this gets called so do this=0A=
// waits 1 ms (with setTimeout) until it does the activation=0A=
Field.scrollFreeActivate =3D function(field) {=0A=
  setTimeout(function() {=0A=
    Field.activate(field);=0A=
  }, 1);=0A=
}=0A=
=0A=
Ajax.InPlaceEditor =3D Class.create({=0A=
  initialize: function(element, url, options) {=0A=
    this.url =3D url;=0A=
    this.element =3D element =3D $(element);=0A=
    this.prepareOptions();=0A=
    this._controls =3D { };=0A=
    arguments.callee.dealWithDeprecatedOptions(options); // DEPRECATION =
LAYER!!!=0A=
    Object.extend(this.options, options || { });=0A=
    if (!this.options.formId && this.element.id) {=0A=
      this.options.formId =3D this.element.id + '-inplaceeditor';=0A=
      if ($(this.options.formId))=0A=
        this.options.formId =3D '';=0A=
    }=0A=
    if (this.options.externalControl)=0A=
      this.options.externalControl =3D $(this.options.externalControl);=0A=
    if (!this.options.externalControl)=0A=
      this.options.externalControlOnly =3D false;=0A=
    this._originalBackground =3D =
this.element.getStyle('background-color') || 'transparent';=0A=
    this.element.title =3D this.options.clickToEditText;=0A=
    this._boundCancelHandler =3D this.handleFormCancellation.bind(this);=0A=
    this._boundComplete =3D (this.options.onComplete || =
Prototype.emptyFunction).bind(this);=0A=
    this._boundFailureHandler =3D this.handleAJAXFailure.bind(this);=0A=
    this._boundSubmitHandler =3D this.handleFormSubmission.bind(this);=0A=
    this._boundWrapperHandler =3D this.wrapUp.bind(this);=0A=
    this.registerListeners();=0A=
  },=0A=
  checkForEscapeOrReturn: function(e) {=0A=
    if (!this._editing || e.ctrlKey || e.altKey || e.shiftKey) return;=0A=
    if (Event.KEY_ESC =3D=3D e.keyCode)=0A=
      this.handleFormCancellation(e);=0A=
    else if (Event.KEY_RETURN =3D=3D e.keyCode)=0A=
      this.handleFormSubmission(e);=0A=
  },=0A=
  createControl: function(mode, handler, extraClasses) {=0A=
    var control =3D this.options[mode + 'Control'];=0A=
    var text =3D this.options[mode + 'Text'];=0A=
    if ('button' =3D=3D control) {=0A=
      var btn =3D document.createElement('input');=0A=
      btn.type =3D 'submit';=0A=
      btn.value =3D text;=0A=
      btn.className =3D 'editor_' + mode + '_button';=0A=
      if ('cancel' =3D=3D mode)=0A=
        btn.onclick =3D this._boundCancelHandler;=0A=
      this._form.appendChild(btn);=0A=
      this._controls[mode] =3D btn;=0A=
    } else if ('link' =3D=3D control) {=0A=
      var link =3D document.createElement('a');=0A=
      link.href =3D '#';=0A=
      link.appendChild(document.createTextNode(text));=0A=
      link.onclick =3D 'cancel' =3D=3D mode ? this._boundCancelHandler : =
this._boundSubmitHandler;=0A=
      link.className =3D 'editor_' + mode + '_link';=0A=
      if (extraClasses)=0A=
        link.className +=3D ' ' + extraClasses;=0A=
      this._form.appendChild(link);=0A=
      this._controls[mode] =3D link;=0A=
    }=0A=
  },=0A=
  createEditField: function() {=0A=
    var text =3D (this.options.loadTextURL ? this.options.loadingText : =
this.getText());=0A=
    var fld;=0A=
    if (1 >=3D this.options.rows && !/\r|\n/.test(this.getText())) {=0A=
      fld =3D document.createElement('input');=0A=
      fld.type =3D 'text';=0A=
      var size =3D this.options.size || this.options.cols || 0;=0A=
      if (0 < size) fld.size =3D size;=0A=
    } else {=0A=
      fld =3D document.createElement('textarea');=0A=
      fld.rows =3D (1 >=3D this.options.rows ? this.options.autoRows : =
this.options.rows);=0A=
      fld.cols =3D this.options.cols || 40;=0A=
    }=0A=
    fld.name =3D this.options.paramName;=0A=
    fld.value =3D text; // No HTML breaks conversion anymore=0A=
    fld.className =3D 'editor_field';=0A=
    if (this.options.submitOnBlur)=0A=
      fld.onblur =3D this._boundSubmitHandler;=0A=
    this._controls.editor =3D fld;=0A=
    if (this.options.loadTextURL)=0A=
      this.loadExternalText();=0A=
    this._form.appendChild(this._controls.editor);=0A=
  },=0A=
  createForm: function() {=0A=
    var ipe =3D this;=0A=
    function addText(mode, condition) {=0A=
      var text =3D ipe.options['text' + mode + 'Controls'];=0A=
      if (!text || condition =3D=3D=3D false) return;=0A=
      ipe._form.appendChild(document.createTextNode(text));=0A=
    };=0A=
    this._form =3D $(document.createElement('form'));=0A=
    this._form.id =3D this.options.formId;=0A=
    this._form.addClassName(this.options.formClassName);=0A=
    this._form.onsubmit =3D this._boundSubmitHandler;=0A=
    this.createEditField();=0A=
    if ('textarea' =3D=3D this._controls.editor.tagName.toLowerCase())=0A=
      this._form.appendChild(document.createElement('br'));=0A=
    if (this.options.onFormCustomization)=0A=
      this.options.onFormCustomization(this, this._form);=0A=
    addText('Before', this.options.okControl || =
this.options.cancelControl);=0A=
    this.createControl('ok', this._boundSubmitHandler);=0A=
    addText('Between', this.options.okControl && =
this.options.cancelControl);=0A=
    this.createControl('cancel', this._boundCancelHandler, =
'editor_cancel');=0A=
    addText('After', this.options.okControl || =
this.options.cancelControl);=0A=
  },=0A=
  destroy: function() {=0A=
    if (this._oldInnerHTML)=0A=
      this.element.innerHTML =3D this._oldInnerHTML;=0A=
    this.leaveEditMode();=0A=
    this.unregisterListeners();=0A=
  },=0A=
  enterEditMode: function(e) {=0A=
    if (this._saving || this._editing) return;=0A=
    this._editing =3D true;=0A=
    this.triggerCallback('onEnterEditMode');=0A=
    if (this.options.externalControl)=0A=
      this.options.externalControl.hide();=0A=
    this.element.hide();=0A=
    this.createForm();=0A=
    this.element.parentNode.insertBefore(this._form, this.element);=0A=
    if (!this.options.loadTextURL)=0A=
      this.postProcessEditField();=0A=
    if (e) Event.stop(e);=0A=
  },=0A=
  enterHover: function(e) {=0A=
    if (this.options.hoverClassName)=0A=
      this.element.addClassName(this.options.hoverClassName);=0A=
    if (this._saving) return;=0A=
    this.triggerCallback('onEnterHover');=0A=
  },=0A=
  getText: function() {=0A=
    return this.element.innerHTML;=0A=
  },=0A=
  handleAJAXFailure: function(transport) {=0A=
    this.triggerCallback('onFailure', transport);=0A=
    if (this._oldInnerHTML) {=0A=
      this.element.innerHTML =3D this._oldInnerHTML;=0A=
      this._oldInnerHTML =3D null;=0A=
    }=0A=
  },=0A=
  handleFormCancellation: function(e) {=0A=
    this.wrapUp();=0A=
    if (e) Event.stop(e);=0A=
  },=0A=
  handleFormSubmission: function(e) {=0A=
    var form =3D this._form;=0A=
    var value =3D $F(this._controls.editor);=0A=
    this.prepareSubmission();=0A=
    var params =3D this.options.callback(form, value) || '';=0A=
    if (Object.isString(params))=0A=
      params =3D params.toQueryParams();=0A=
    params.editorId =3D this.element.id;=0A=
    if (this.options.htmlResponse) {=0A=
      var options =3D Object.extend({ evalScripts: true }, =
this.options.ajaxOptions);=0A=
      Object.extend(options, {=0A=
        parameters: params,=0A=
        onComplete: this._boundWrapperHandler,=0A=
        onFailure: this._boundFailureHandler=0A=
      });=0A=
      new Ajax.Updater({ success: this.element }, this.url, options);=0A=
    } else {=0A=
      var options =3D Object.extend({ method: 'get' }, =
this.options.ajaxOptions);=0A=
      Object.extend(options, {=0A=
        parameters: params,=0A=
        onComplete: this._boundWrapperHandler,=0A=
        onFailure: this._boundFailureHandler=0A=
      });=0A=
      new Ajax.Request(this.url, options);=0A=
    }=0A=
    if (e) Event.stop(e);=0A=
  },=0A=
  leaveEditMode: function() {=0A=
    this.element.removeClassName(this.options.savingClassName);=0A=
    this.removeForm();=0A=
    this.leaveHover();=0A=
    this.element.style.backgroundColor =3D this._originalBackground;=0A=
    this.element.show();=0A=
    if (this.options.externalControl)=0A=
      this.options.externalControl.show();=0A=
    this._saving =3D false;=0A=
    this._editing =3D false;=0A=
    this._oldInnerHTML =3D null;=0A=
    this.triggerCallback('onLeaveEditMode');=0A=
  },=0A=
  leaveHover: function(e) {=0A=
    if (this.options.hoverClassName)=0A=
      this.element.removeClassName(this.options.hoverClassName);=0A=
    if (this._saving) return;=0A=
    this.triggerCallback('onLeaveHover');=0A=
  },=0A=
  loadExternalText: function() {=0A=
    this._form.addClassName(this.options.loadingClassName);=0A=
    this._controls.editor.disabled =3D true;=0A=
    var options =3D Object.extend({ method: 'get' }, =
this.options.ajaxOptions);=0A=
    Object.extend(options, {=0A=
      parameters: 'editorId=3D' + encodeURIComponent(this.element.id),=0A=
      onComplete: Prototype.emptyFunction,=0A=
      onSuccess: function(transport) {=0A=
        this._form.removeClassName(this.options.loadingClassName);=0A=
        var text =3D transport.responseText;=0A=
        if (this.options.stripLoadedTextTags)=0A=
          text =3D text.stripTags();=0A=
        this._controls.editor.value =3D text;=0A=
        this._controls.editor.disabled =3D false;=0A=
        this.postProcessEditField();=0A=
      }.bind(this),=0A=
      onFailure: this._boundFailureHandler=0A=
    });=0A=
    new Ajax.Request(this.options.loadTextURL, options);=0A=
  },=0A=
  postProcessEditField: function() {=0A=
    var fpc =3D this.options.fieldPostCreation;=0A=
    if (fpc)=0A=
      $(this._controls.editor)['focus' =3D=3D fpc ? 'focus' : =
'activate']();=0A=
  },=0A=
  prepareOptions: function() {=0A=
    this.options =3D Object.clone(Ajax.InPlaceEditor.DefaultOptions);=0A=
    Object.extend(this.options, Ajax.InPlaceEditor.DefaultCallbacks);=0A=
    [this._extraDefaultOptions].flatten().compact().each(function(defs) {=0A=
      Object.extend(this.options, defs);=0A=
    }.bind(this));=0A=
  },=0A=
  prepareSubmission: function() {=0A=
    this._saving =3D true;=0A=
    this.removeForm();=0A=
    this.leaveHover();=0A=
    this.showSaving();=0A=
  },=0A=
  registerListeners: function() {=0A=
    this._listeners =3D { };=0A=
    var listener;=0A=
    $H(Ajax.InPlaceEditor.Listeners).each(function(pair) {=0A=
      listener =3D this[pair.value].bind(this);=0A=
      this._listeners[pair.key] =3D listener;=0A=
      if (!this.options.externalControlOnly)=0A=
        this.element.observe(pair.key, listener);=0A=
      if (this.options.externalControl)=0A=
        this.options.externalControl.observe(pair.key, listener);=0A=
    }.bind(this));=0A=
  },=0A=
  removeForm: function() {=0A=
    if (!this._form) return;=0A=
    this._form.remove();=0A=
    this._form =3D null;=0A=
    this._controls =3D { };=0A=
  },=0A=
  showSaving: function() {=0A=
    this._oldInnerHTML =3D this.element.innerHTML;=0A=
    this.element.innerHTML =3D this.options.savingText;=0A=
    this.element.addClassName(this.options.savingClassName);=0A=
    this.element.style.backgroundColor =3D this._originalBackground;=0A=
    this.element.show();=0A=
  },=0A=
  triggerCallback: function(cbName, arg) {=0A=
    if ('function' =3D=3D typeof this.options[cbName]) {=0A=
      this.options[cbName](this, arg);=0A=
    }=0A=
  },=0A=
  unregisterListeners: function() {=0A=
    $H(this._listeners).each(function(pair) {=0A=
      if (!this.options.externalControlOnly)=0A=
        this.element.stopObserving(pair.key, pair.value);=0A=
      if (this.options.externalControl)=0A=
        this.options.externalControl.stopObserving(pair.key, pair.value);=0A=
    }.bind(this));=0A=
  },=0A=
  wrapUp: function(transport) {=0A=
    this.leaveEditMode();=0A=
    // Can't use triggerCallback due to backward compatibility: requires=0A=
    // binding + direct element=0A=
    this._boundComplete(transport, this.element);=0A=
  }=0A=
});=0A=
=0A=
Object.extend(Ajax.InPlaceEditor.prototype, {=0A=
  dispose: Ajax.InPlaceEditor.prototype.destroy=0A=
});=0A=
=0A=
Ajax.InPlaceCollectionEditor =3D Class.create(Ajax.InPlaceEditor, {=0A=
  initialize: function($super, element, url, options) {=0A=
    this._extraDefaultOptions =3D =
Ajax.InPlaceCollectionEditor.DefaultOptions;=0A=
    $super(element, url, options);=0A=
  },=0A=
=0A=
  createEditField: function() {=0A=
    var list =3D document.createElement('select');=0A=
    list.name =3D this.options.paramName;=0A=
    list.size =3D 1;=0A=
    this._controls.editor =3D list;=0A=
    this._collection =3D this.options.collection || [];=0A=
    if (this.options.loadCollectionURL)=0A=
      this.loadCollection();=0A=
    else=0A=
      this.checkForExternalText();=0A=
    this._form.appendChild(this._controls.editor);=0A=
  },=0A=
=0A=
  loadCollection: function() {=0A=
    this._form.addClassName(this.options.loadingClassName);=0A=
    this.showLoadingText(this.options.loadingCollectionText);=0A=
    var options =3D Object.extend({ method: 'get' }, =
this.options.ajaxOptions);=0A=
    Object.extend(options, {=0A=
      parameters: 'editorId=3D' + encodeURIComponent(this.element.id),=0A=
      onComplete: Prototype.emptyFunction,=0A=
      onSuccess: function(transport) {=0A=
        var js =3D transport.responseText.strip();=0A=
        if (!/^\[.*\]$/.test(js)) // TODO: improve sanity check=0A=
          throw 'Server returned an invalid collection representation.';=0A=
        this._collection =3D eval(js);=0A=
        this.checkForExternalText();=0A=
      }.bind(this),=0A=
      onFailure: this.onFailure=0A=
    });=0A=
    new Ajax.Request(this.options.loadCollectionURL, options);=0A=
  },=0A=
=0A=
  showLoadingText: function(text) {=0A=
    this._controls.editor.disabled =3D true;=0A=
    var tempOption =3D this._controls.editor.firstChild;=0A=
    if (!tempOption) {=0A=
      tempOption =3D document.createElement('option');=0A=
      tempOption.value =3D '';=0A=
      this._controls.editor.appendChild(tempOption);=0A=
      tempOption.selected =3D true;=0A=
    }=0A=
    tempOption.update((text || '').stripScripts().stripTags());=0A=
  },=0A=
=0A=
  checkForExternalText: function() {=0A=
    this._text =3D this.getText();=0A=
    if (this.options.loadTextURL)=0A=
      this.loadExternalText();=0A=
    else=0A=
      this.buildOptionList();=0A=
  },=0A=
=0A=
  loadExternalText: function() {=0A=
    this.showLoadingText(this.options.loadingText);=0A=
    var options =3D Object.extend({ method: 'get' }, =
this.options.ajaxOptions);=0A=
    Object.extend(options, {=0A=
      parameters: 'editorId=3D' + encodeURIComponent(this.element.id),=0A=
      onComplete: Prototype.emptyFunction,=0A=
      onSuccess: function(transport) {=0A=
        this._text =3D transport.responseText.strip();=0A=
        this.buildOptionList();=0A=
      }.bind(this),=0A=
      onFailure: this.onFailure=0A=
    });=0A=
    new Ajax.Request(this.options.loadTextURL, options);=0A=
  },=0A=
=0A=
  buildOptionList: function() {=0A=
    this._form.removeClassName(this.options.loadingClassName);=0A=
    this._collection =3D this._collection.map(function(entry) {=0A=
      return 2 =3D=3D=3D entry.length ? entry : [entry, entry].flatten();=0A=
    });=0A=
    var marker =3D ('value' in this.options) ? this.options.value : =
this._text;=0A=
    var textFound =3D this._collection.any(function(entry) {=0A=
      return entry[0] =3D=3D marker;=0A=
    }.bind(this));=0A=
    this._controls.editor.update('');=0A=
    var option;=0A=
    this._collection.each(function(entry, index) {=0A=
      option =3D document.createElement('option');=0A=
      option.value =3D entry[0];=0A=
      option.selected =3D textFound ? entry[0] =3D=3D marker : 0 =3D=3D =
index;=0A=
      option.appendChild(document.createTextNode(entry[1]));=0A=
      this._controls.editor.appendChild(option);=0A=
    }.bind(this));=0A=
    this._controls.editor.disabled =3D false;=0A=
    Field.scrollFreeActivate(this._controls.editor);=0A=
  }=0A=
});=0A=
=0A=
//**** DEPRECATION LAYER FOR InPlace[Collection]Editor! ****=0A=
//**** This only  exists for a while,  in order to  let ****=0A=
//**** users adapt to  the new API.  Read up on the new ****=0A=
//**** API and convert your code to it ASAP!            ****=0A=
=0A=
Ajax.InPlaceEditor.prototype.initialize.dealWithDeprecatedOptions =3D =
function(options) {=0A=
  if (!options) return;=0A=
  function fallback(name, expr) {=0A=
    if (name in options || expr =3D=3D=3D undefined) return;=0A=
    options[name] =3D expr;=0A=
  };=0A=
  fallback('cancelControl', (options.cancelLink ? 'link' : =
(options.cancelButton ? 'button' :=0A=
    options.cancelLink =3D=3D options.cancelButton =3D=3D false ? false =
: undefined)));=0A=
  fallback('okControl', (options.okLink ? 'link' : (options.okButton ? =
'button' :=0A=
    options.okLink =3D=3D options.okButton =3D=3D false ? false : =
undefined)));=0A=
  fallback('highlightColor', options.highlightcolor);=0A=
  fallback('highlightEndColor', options.highlightendcolor);=0A=
};=0A=
=0A=
Object.extend(Ajax.InPlaceEditor, {=0A=
  DefaultOptions: {=0A=
    ajaxOptions: { },=0A=
    autoRows: 3,                                // Use when multi-line =
w/ rows =3D=3D 1=0A=
    cancelControl: 'link',                      // 'link'|'button'|false=0A=
    cancelText: 'cancel',=0A=
    clickToEditText: 'Click to edit',=0A=
    externalControl: null,                      // id|elt=0A=
    externalControlOnly: false,=0A=
    fieldPostCreation: 'activate',              // =
'activate'|'focus'|false=0A=
    formClassName: 'inplaceeditor-form',=0A=
    formId: null,                               // id|elt=0A=
    highlightColor: '#ffff99',=0A=
    highlightEndColor: '#ffffff',=0A=
    hoverClassName: '',=0A=
    htmlResponse: true,=0A=
    loadingClassName: 'inplaceeditor-loading',=0A=
    loadingText: 'Loading...',=0A=
    okControl: 'button',                        // 'link'|'button'|false=0A=
    okText: 'ok',=0A=
    paramName: 'value',=0A=
    rows: 1,                                    // If 1 and multi-line, =
uses autoRows=0A=
    savingClassName: 'inplaceeditor-saving',=0A=
    savingText: 'Saving...',=0A=
    size: 0,=0A=
    stripLoadedTextTags: false,=0A=
    submitOnBlur: false,=0A=
    textAfterControls: '',=0A=
    textBeforeControls: '',=0A=
    textBetweenControls: ''=0A=
  },=0A=
  DefaultCallbacks: {=0A=
    callback: function(form) {=0A=
      return Form.serialize(form);=0A=
    },=0A=
    onComplete: function(transport, element) {=0A=
      // For backward compatibility, this one is bound to the IPE, and =
passes=0A=
      // the element directly.  It was too often customized, so we don't =
break it.=0A=
      new Effect.Highlight(element, {=0A=
        startcolor: this.options.highlightColor, keepBackgroundImage: =
true });=0A=
    },=0A=
    onEnterEditMode: null,=0A=
    onEnterHover: function(ipe) {=0A=
      ipe.element.style.backgroundColor =3D ipe.options.highlightColor;=0A=
      if (ipe._effect)=0A=
        ipe._effect.cancel();=0A=
    },=0A=
    onFailure: function(transport, ipe) {=0A=
      alert('Error communication with the server: ' + =
transport.responseText.stripTags());=0A=
    },=0A=
    onFormCustomization: null, // Takes the IPE and its generated form, =
after editor, before controls.=0A=
    onLeaveEditMode: null,=0A=
    onLeaveHover: function(ipe) {=0A=
      ipe._effect =3D new Effect.Highlight(ipe.element, {=0A=
        startcolor: ipe.options.highlightColor, endcolor: =
ipe.options.highlightEndColor,=0A=
        restorecolor: ipe._originalBackground, keepBackgroundImage: true=0A=
      });=0A=
    }=0A=
  },=0A=
  Listeners: {=0A=
    click: 'enterEditMode',=0A=
    keydown: 'checkForEscapeOrReturn',=0A=
    mouseover: 'enterHover',=0A=
    mouseout: 'leaveHover'=0A=
  }=0A=
});=0A=
=0A=
Ajax.InPlaceCollectionEditor.DefaultOptions =3D {=0A=
  loadingCollectionText: 'Loading options...'=0A=
};=0A=
=0A=
// Delayed observer, like Form.Element.Observer, =0A=
// but waits for delay after last key input=0A=
// Ideal for live-search fields=0A=
=0A=
Form.Element.DelayedObserver =3D Class.create({=0A=
  initialize: function(element, delay, callback) {=0A=
    this.delay     =3D delay || 0.5;=0A=
    this.element   =3D $(element);=0A=
    this.callback  =3D callback;=0A=
    this.timer     =3D null;=0A=
    this.lastValue =3D $F(this.element); =0A=
    =
Event.observe(this.element,'keyup',this.delayedListener.bindAsEventListen=
er(this));=0A=
  },=0A=
  delayedListener: function(event) {=0A=
    if(this.lastValue =3D=3D $F(this.element)) return;=0A=
    if(this.timer) clearTimeout(this.timer);=0A=
    this.timer =3D setTimeout(this.onTimerEvent.bind(this), this.delay * =
1000);=0A=
    this.lastValue =3D $F(this.element);=0A=
  },=0A=
  onTimerEvent: function() {=0A=
    this.timer =3D null;=0A=
    this.callback(this.element, $F(this.element));=0A=
  }=0A=
});=0A=

------=_NextPart_000_0000_01CAB168.786EE890
Content-Type: application/octet-stream
Content-Transfer-Encoding: quoted-printable
Content-Location: http://www.eenews.net/javascripts/application.js?1181426390

// Place your application-specific JavaScript functions and classes here=0A=
// This file is automatically included by javascript_include_tag =
:defaults=0A=

------=_NextPart_000_0000_01CAB168.786EE890
Content-Type: application/octet-stream
Content-Transfer-Encoding: quoted-printable
Content-Location: http://www.eenews.net/javascripts/custom_effects.js?1181426390

Effect.FadeNoHide =3D function(element, element2) {=0A=
  element =3D $(element);=0A=
  element2 =3D $(element2);=0A=
  var oldOpacity =3D element.getInlineOpacity();=0A=
  var options =3D Object.extend({=0A=
  from: element.getOpacity() || 1.0,=0A=
  to:   0.0,=0A=
  afterFinishInternal: function(effect) { =0A=
    if(effect.options.to!=3D0) return;=0A=
	effect.element.hide();=0A=
	element2.show();=0A=
	element2.setOpacity(0.0);=0A=
    return new Effect.Appear(element2);=0A=
  }}, arguments[1] || {});=0A=
  return new Effect.Opacity(element,options);=0A=
}=0A=
=0A=
Element.Methods.visualEffect =3D function(element, effect, options) {=0A=
  s =3D effect.gsub(/_/, '-').camelize();=0A=
  effect_class =3D s.charAt(0).toUpperCase() + s.substring(1);=0A=
  new Effect[effect_class](element, options);=0A=
  return $(element);=0A=
};=0A=
=0A=
Element.addMethods();=0A=
=0A=
=0A=
=0A=
function selectAll(el) {=0A=
    elements =3D el.parentNode.getElementsByTagName("input")=0A=
	for (var i =3D 0; i < elements.length; i++) {=0A=
   		if (el.checked) {=0A=
        		elements[i].checked =3D true;=0A=
		} else {=0A=
			elements[i].checked =3D false;=0A=
		}	=0A=
	}=0A=
	=0A=
}
------=_NextPart_000_0000_01CAB168.786EE890--

