From: Subject: =?Windows-1252?Q?La_Semaine_des_Pyr=E9n=E9es:_Tarbes_:_Claudine_Chaiffre_?= =?Windows-1252?Q?a_mont=E9_sa_soci=E9t=E9_de_coaching_et_relooking?= Date: Sun, 28 Dec 2008 14:39:26 +0100 MIME-Version: 1.0 Content-Type: multipart/related; type="text/html"; boundary="----=_NextPart_000_0046_01C968FA.15503320" X-MimeOLE: Produced By Microsoft MimeOLE V6.00.2900.5579 This is a multi-part message in MIME format. ------=_NextPart_000_0046_01C968FA.15503320 Content-Type: text/html; charset="iso-8859-15" Content-Transfer-Encoding: quoted-printable Content-Location: http://www.lasemainedespyrenees.fr/actualite/viewArticle.php?idDossier=30 La Semaine des = Pyr=E9n=E9es: Tarbes : Claudine Chaiffre a mont=E9 sa soci=E9t=E9 de = coaching et relooking
3D"La
Dimanche 28 D=E9cembre - = F=EAte des Saints=20 Innocents >> La Semaine des Pyr=E9n=E9es >> S'abonner = au fil=20 RSS
D=E9j=E0 inscrit ?  =20
Dans les articles Dans les Flash Info
Dossier du 09/10/2008 =E0 15:23
Tarbes : Claudine Chaiffre a mont=E9 sa soci=E9t=E9 de coaching et=20 relooking
Claudine Chaiffre en prospection dans = les rues de=20 Tarbes.
Claudine Chaiffre a r=E9alis=E9 son r=EAve en = montant sa=20 soci=E9t=E9. Depuis le mois de mai, elle occupe son temps =E0 relooker, = coacher,=20 divertir. Rencontre avec cette jeune femme dynamique.

A la=20 t=E9l=E9vision, les =E9missions consacr=E9es au coaching et au relooking = se multiplient.=20 A Tarbes, Claudine Chaiffre a mont=E9 au mois de mai dernier sa = soci=E9t=E9 : =AB=20 Instant Priv=E9s =BB. Elle propose de nombreux services : relooking, = coaching,=20 d=E9coration, cr=E9ation d'=E9v=E9nements.

La Semaine : Qu'est ce = qui vous a=20 pouss=E9e =E0 vous lancer dans le coaching ?
Claudine : = J'avais besoin=20 de montrer mon c=F4t=E9 cr=E9atif. Je veux aider les gens. C'est ma = priorit=E9. Pour=20 arriver =E0 faire ce que je fais, il faut ensuite aimer les gens. Il = faut =EAtre =E0=20 l'=E9coute. Il faut comprendre leur recherche.
Je touche finalement = des=20 domaines assez diff=E9rents mais qui se rejoignent tous en fin de=20 compte.

Quels=20 services proposez-vous ?
Je propose du relooking personnel ou=20 professionnel. Je peux intervenir =E9galement pour revoir la = d=E9coration=20 professionnelle ou personnelle. Je peux donner des id=E9es pour relooker = un=20 int=E9rieur. Je peux aussi apporter un accompagnement dans l'achat. Mais = je peux=20 aussi faire de la recherche de mobilier et de d=E9coration. Ensuite, = j'am=E8ne le=20 client afin de valider ce choix.
Je travaille aussi dans le domaine = de=20 l'=E9v=E9nementiel. A ce niveau-l=E0, c'est tr=E8s, tr=E8s vaste. Cela = va de=20 l'organisation de soir=E9es, =E0 un restaurant, d'une surprise que l'on = veut faire =E0=20 son bien-aim=E9 ou sa bien-aim=E9e. Mais cela peut =EAtre aussi de la = recherche=20 immobili=E8re.
Je suis le temps que les gens n'ont plus.

=ABEn moyenne, il faut compter entre 150 et = 350 euros=20 pour un relooking=BB

Qui fait appel =E0 vous=20 ?
Il n'y a pas de portrait type de personne. Dans le = relooking, cela=20 peut =EAtre des personnes qui sont mal dans leur peau et qui ne se = retrouvent pas.=20 Elles n'arrivent pas forc=E9ment =E0 trouver un service dans les = commerces car il=20 faut du temps pour comprendre quelqu'un. Lorsqu'elles viennent me voir, = ces=20 personnes se livrent vraiment. Cela me permet de faire un travail. Mais = cela=20 peut =EAtre n'importe qui.
De toute fa=E7on, je veux =EAtre ouverte = =E0 tout le=20 monde.

Pensez-vous=20 que ce type de m=E9tier va se d=E9velopper ?
J'y crois = profond=E9ment. Les=20 gens dans le commerce ne se retrouvent pas. Les gens attendent autre = chose. Je=20 pense qu'Instant Priv=E9s, c'est un concept moderne aux valeurs = d'autrefois. Il=20 est important d'=E9couter une personne et de savoir ce qu'elle = veut.

Depuis quand = fonctionnez-vous=20 ?
Depuis le mois de mai 2008. C'est un pari audacieux. Instant = Priv=E9s=20 est une jeune entreprise. On a bien d=E9marr=E9. Je crois =E0 fond dans = ces=20 prestations qui sont assez vastes.

Sur quel budget faut-il = compter=20 pour un relooking par exemple ?
Cela d=E9pend si une personne = souhaite=20 seulement un conseil, un accompagnement ou si elle veut que je g=E8re = tout=20 compl=E8tement. En moyenne, il faut compter entre 150 et 350 = euros.

Est-ce que les = =E9missions qui ont=20 tendance =E0 se d=E9velopper sur ces th=E8mes-l=E0 peuvent faciliter = l'=E9mergence=20 d'entreprise comme la v=F4tre ?
Oui bien s=FBr. Il y a = beaucoup de monde=20 qui regarde ces =E9missions.
Je pense que dans le d=E9partement les = gens ont les=20 m=EAmes attentes qu'=E0 Paris ou dans les grandes villes. Il n'y a donc = pas de=20 raison que cela ne marche pas.

Certaines enseignes en = r=E9gion=20 parisienne proposent un espace relooking dans leurs commerces. Qu'en = pensez-vous=20 ?
Cela peut-=EAtre une bonne chose =E0 condition que cela soit = bien fait.=20 Si on ne regarde que le porte-monnaie des gens cela ne pourra pas=20 marcher.


Article r=E9dig=E9 par :
Patrick = Sacristan
  • 1
  • 2
  • 3
  • 4
  • 5

Actualit=E9 Flash info
Tous = les=20 flashs
Qu'en pensez-vous ?
Le conseil g=E9n=E9ral et = la r=E9gion vont=20 devoir apporter 480 000 euros pour =E9quilibrer les comptes du Pic du = Midi en=20 2008. Trouvez-vous cela normal ?
Oui=20
Non
Ne se prononce pas
------=_NextPart_000_0046_01C968FA.15503320 Content-Type: image/gif Content-Transfer-Encoding: base64 Content-Location: http://www.lasemainedespyrenees.fr//img/logo.gif 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 ------=_NextPart_000_0046_01C968FA.15503320 Content-Type: image/jpeg Content-Transfer-Encoding: base64 Content-Location: http://www.lasemainedespyrenees.fr//uploads/information/710-photo1-snap.jpg /9j/4AAQSkZJRgABAQAAAQABAAD//gA+Q1JFQVRPUjogZ2QtanBlZyB2MS4wICh1c2luZyBJSkcg SlBFRyB2NjIpLCBkZWZhdWx0IHF1YWxpdHkK/9sAQwAIBgYHBgUIBwcHCQkICgwUDQwLCwwZEhMP FB0aHx4dGhwcICQuJyAiLCMcHCg3KSwwMTQ0NB8nOT04MjwuMzQy/9sAQwEJCQkMCwwYDQ0YMiEc ITIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIy/8AAEQgA ugD6AwEiAAIRAQMRAf/EAB8AAAEFAQEBAQEBAAAAAAAAAAABAgMEBQYHCAkKC//EALUQAAIBAwMC BAMFBQQEAAABfQECAwAEEQUSITFBBhNRYQcicRQygZGhCCNCscEVUtHwJDNicoIJChYXGBkaJSYn KCkqNDU2Nzg5OkNERUZHSElKU1RVVldYWVpjZGVmZ2hpanN0dXZ3eHl6g4SFhoeIiYqSk5SVlpeY mZqio6Slpqeoqaqys7S1tre4ubrCw8TFxsfIycrS09TV1tfY2drh4uPk5ebn6Onq8fLz9PX29/j5 +v/EAB8BAAMBAQEBAQEBAQEAAAAAAAABAgMEBQYHCAkKC//EALURAAIBAgQEAwQHBQQEAAECdwAB AgMRBAUhMQYSQVEHYXETIjKBCBRCkaGxwQkjM1LwFWJy0QoWJDThJfEXGBkaJicoKSo1Njc4OTpD REVGR0hJSlNUVVZXWFlaY2RlZmdoaWpzdHV2d3h5eoKDhIWGh4iJipKTlJWWl5iZmqKjpKWmp6ip qrKztLW2t7i5usLDxMXGx8jJytLT1NXW19jZ2uLj5OXm5+jp6vLz9PX29/j5+v/aAAwDAQACEQMR AD8A8tsUsY7pJphJAqnIkibjoMD2wc13ya1c3PlvGVNoRsUleoOOSfxrgdOuFhjMfkK2H+bd94D0 PqK2re5WYBAWg8oH5AMLn2FAHUWer3TC2AUq23puwdo4zj+p9q6iwvvtYidhyMruB5PoOv0rytNV vIr+e5gIPnMUwuMgDtj0rpNBvZXtVVl3OW+ds8jOePegDupY5xc5aKN9y5BbAY47E46ikF3PEZro WuYgnLqCWGD0Zc59afbPHLbRsJEk2/KCxzk+h71ftWUbxMoRm4IH3W9/r7UAC3sPkpKSQjjO4KSo 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 Rg8elWKAP//Z ------=_NextPart_000_0046_01C968FA.15503320 Content-Type: text/css; charset="iso-8859-1" Content-Transfer-Encoding: quoted-printable Content-Location: http://www.lasemainedespyrenees.fr/css/default.css BODY { MARGIN-TOP: 0px; FONT-SIZE: 12px; MARGIN-LEFT: 0px; COLOR: #666; = FONT-FAMILY: Arial, Tahoma, Verdana, Sans-serif; BACKGROUND-COLOR: = #bcbdc1; TEXT-ALIGN: left } A:link { COLOR: #666; TEXT-DECORATION: none } A:visited { COLOR: #666; TEXT-DECORATION: none } A:hover { COLOR: #666; TEXT-DECORATION: underline } A:active { COLOR: #666; TEXT-DECORATION: none } A.blueLink { COLOR: #0766ae; TEXT-DECORATION: none } A.redLink { COLOR: #d2232a; TEXT-DECORATION: none } IMG { BORDER-TOP-WIDTH: 0px; BORDER-LEFT-WIDTH: 0px; BORDER-BOTTOM-WIDTH: = 0px; BORDER-RIGHT-WIDTH: 0px } H1 { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-WEIGHT: bold; FONT-SIZE: = 2em; PADDING-BOTTOM: 0px; MARGIN: 0px 0px 4px; PADDING-TOP: 0px } H2 { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-WEIGHT: bold; FONT-SIZE: = 1.8em; PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-TOP: 0px } H3 { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-WEIGHT: bold; FONT-SIZE: = 1.5em; PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-TOP: 0px } H4 { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-WEIGHT: bold; FONT-SIZE: = 1.2em; PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-TOP: 0px } H5 { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-WEIGHT: bold; FONT-SIZE: = 2.2em; PADDING-BOTTOM: 0px; MARGIN: 0px 0px 4px; PADDING-TOP: 0px; = LETTER-SPACING: -2px } .TextInput { FONT-SIZE: 10px; WIDTH: 100%; HEIGHT: 18px } FIELDSET { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: = 0px; BORDER-TOP-STYLE: none; PADDING-TOP: 0px; BORDER-RIGHT-STYLE: none; = BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: none } FORM { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: = 0px; PADDING-TOP: 0px } #container { PADDING-RIGHT: 10px; PADDING-LEFT: 10px; MIN-HEIGHT: 600px; BACKGROUND: = #fff; PADDING-BOTTOM: 10px; MARGIN: 0px 0px 0px 25px; WIDTH: 930px; = PADDING-TOP: 10px; TEXT-ALIGN: left } * HTML #container { HEIGHT: 600px } #pub { MARGIN-BOTTOM: 5px; TEXT-ALIGN: center } #header { MARGIN-BOTTOM: 15px; WIDTH: 100% } #breadCrumbs { FONT-SIZE: 0.8em; FLOAT: left; MARGIN: 30px 0px 5px 55px } #searchBar { CLEAR: both; PADDING-RIGHT: 15px; PADDING-LEFT: 10px; BACKGROUND: = url(../img/searchbar_bg.gif) no-repeat left bottom; PADDING-BOTTOM: 8px; = WIDTH: 910px; PADDING-TOP: 10px } #BoutonRecherche { BORDER-TOP-WIDTH: 0px; BORDER-LEFT-WIDTH: 0px; BACKGROUND-IMAGE: = url(../img/ok.gif); BORDER-BOTTOM-WIDTH: 0px; MARGIN-LEFT: 20px; WIDTH: = 34px; CURSOR: pointer; COLOR: white; HEIGHT: 18px; BACKGROUND-COLOR: = #d2232a; BORDER-RIGHT-WIDTH: 0px } .menu { PADDING-RIGHT: 5px; PADDING-LEFT: 5px; FLOAT: left; PADDING-BOTTOM: = 5px; WIDTH: 550px; PADDING-TOP: 5px; TEXT-ALIGN: right } .menu UL LI A { DISPLAY: inline; FONT-WEIGHT: bold; FONT-SIZE: 13px; BACKGROUND: none = transparent scroll repeat 0% 0%; PADDING-BOTTOM: 3px; MARGIN: 5px 12px; = OVERFLOW: hidden; COLOR: #666; LINE-HEIGHT: 20px; HEIGHT: 20px; = TEXT-ALIGN: left; TEXT-DECORATION: none } .menu UL LI A:visited { DISPLAY: inline; FONT-WEIGHT: bold; FONT-SIZE: 13px; BACKGROUND: none = transparent scroll repeat 0% 0%; PADDING-BOTTOM: 3px; MARGIN: 5px 12px; = OVERFLOW: hidden; COLOR: #666; LINE-HEIGHT: 20px; HEIGHT: 20px; = TEXT-ALIGN: left; TEXT-DECORATION: none } .menu UL { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: = 0px; LINE-HEIGHT: 28px; PADDING-TOP: 0px; LIST-STYLE-TYPE: none } .menu UL LI { FLOAT: left; POSITION: relative } .menu UL LI UL { DISPLAY: none } .menu UL LI A:hover { BACKGROUND: #fff; COLOR: #666; BORDER-BOTTOM: #d6252d 3px solid } .menu UL LI A.active { BACKGROUND: #fff; COLOR: #666; BORDER-BOTTOM: #d6252d 3px solid } UL.sousmenu { BORDER-RIGHT: gray 1px solid; BORDER-TOP: gray 1px solid; FONT-WEIGHT: = normal; FONT-SIZE: 12px; BACKGROUND: #fff; FILTER: alpha(opacity=3D85); = BORDER-LEFT: gray 1px solid; LINE-HEIGHT: 18px; BORDER-BOTTOM: gray 1px = solid; TEXT-ALIGN: left; opacity: 0.85 } UL.sousmenu LI A { FONT-WEIGHT: normal; FONT-SIZE: 12px; BORDER-TOP-STYLE: none; = BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: = none } UL.sousmenu LI A:visited { FONT-WEIGHT: normal; FONT-SIZE: 12px; BORDER-TOP-STYLE: none; = BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: = none } .menu UL LI:hover UL.sousmenu LI A:hover { COLOR: #d6252d; BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: none; = BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: none } .menu UL LI:hover UL.sousmenu LI { WIDTH: 150px; BORDER-BOTTOM: #666 1px solid } .menu UL LI:hover UL.sousmenu LI.last { BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: = none; BORDER-BOTTOM-STYLE: none } .menu UL LI:hover UL.sousmenu { DISPLAY: block; LEFT: 0px; WIDTH: 150px; POSITION: absolute; TOP: 24px } * HTML .menu UL { LINE-HEIGHT: 16px } * HTML .menu UL LI A.hide { DISPLAY: none } .menu UL LI A.hide:visited { DISPLAY: none } * HTML .menu UL LI A:hover UL LI A.hide { DISPLAY: none } * HTML .menu UL LI A:hover { =09 } * HTML .menu UL LI A:hover UL.sousmenu { DISPLAY: block; LEFT: 0px; WIDTH: 120px; POSITION: absolute; TOP: 21px } * HTML .menu UL LI A:hover UL.sousmenu LI { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: = 0px; WIDTH: 150px; PADDING-TOP: 0px; BORDER-BOTTOM: #666 1px solid; = HEIGHT: 10px; TEXT-ALIGN: left } * HTML .menu UL LI A:hover UL.sousmenu LI A { DISPLAY: block; FONT-WEIGHT: normal; FONT-SIZE: 12px; BORDER-TOP-STYLE: = none; LINE-HEIGHT: 10px; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: = none; HEIGHT: 10px; BORDER-BOTTOM-STYLE: none } * HTML .menu UL LI A:hover UL.sousmenu LI A UL { VISIBILITY: hidden } * HTML .menu UL LI A:hover UL.sousmenu LI.last { BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: = none; BORDER-BOTTOM-STYLE: none } * HTML .menu UL LI A:hover UL.sousmenu LI A:hover { COLOR: #d6252d; BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: none; = BORDER-LEFT-STYLE: none; TEXT-DECORATION: none; BORDER-BOTTOM-STYLE: = none } #largeCol { FLOAT: left; WIDTH: 615px } .horizontalBlock { CLEAR: both } #footer { BORDER-TOP: #fff 10px solid; BACKGROUND: #666; MARGIN: 0px 0px 0px = 25px; WIDTH: 950px; HEIGHT: 30px } * HTML #footer { WIDTH: 955px } #footer UL { MARGIN: 0px; PADDING-TOP: 6px; LIST-STYLE-TYPE: none; TEXT-ALIGN: = center } #footer UL LI { DISPLAY: inline; MARGIN-RIGHT: 15px } #footer UL LI A { FONT-WEIGHT: bold; FONT-SIZE: 0.8em; COLOR: #fff; TEXT-DECORATION: none } .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/topleft_corner.gif); BACKGROUND-REPEAT: no-repeat } .plainroundedBox .plainheaderBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/topleft_corner.gif); BACKGROUND-REPEAT: no-repeat } .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/topright_corner.gif); PADDING-BOTTOM: 4px; COLOR: #fff; = PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .plainroundedBox .plainheaderBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/topright_corner.gif); PADDING-BOTTOM: 4px; COLOR: #fff; = PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .roundedBox .footerBox { BACKGROUND: url(../img/botleft_corner.gif) no-repeat left bottom } .plainroundedBox .plainfooterBox { BACKGROUND: url(../img/botleft_corner.gif) no-repeat left bottom } .roundedBox .footerBoxTitle { BACKGROUND: url(../img/botright_corner.gif) no-repeat right bottom; = HEIGHT: 16px } .plainroundedBox .plainfooterBoxTitle { BACKGROUND: url(../img/botright_corner.gif) no-repeat right bottom; = HEIGHT: 16px } .roundedBox .footerBoxFlat { HEIGHT: 1px } .plainroundedBox .plainfooterBoxFlat { HEIGHT: 1px } .roundedBox .footerBoxTitle A { FONT-SIZE: 0.8em; FLOAT: right; MARGIN: 1px 8px 2px 0px; COLOR: #fff; = TEXT-DECORATION: none } .roundedBox .boxContent { PADDING-RIGHT: 7px; PADDING-LEFT: 7px; PADDING-BOTTOM: 7px; MARGIN: 0px = 1px; PADDING-TOP: 7px; HEIGHT: 1%; BACKGROUND-COLOR: #fff } .plainroundedBox .plainboxContent { PADDING-RIGHT: 7px; PADDING-LEFT: 7px; PADDING-BOTTOM: 7px; MARGIN: 0px = 1px; PADDING-TOP: 7px; HEIGHT: 1%; BACKGROUND-COLOR: transparent } .roundedBox .boxContentTexte { PADDING-RIGHT: 17px; PADDING-LEFT: 17px; PADDING-BOTTOM: 17px; MARGIN: = 0px 1px; PADDING-TOP: 17px; HEIGHT: 1%; BACKGROUND-COLOR: #fff } .lightBlue .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .lightGrey .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .lightRed .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .lightYellow .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .lightBlue .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; COLOR: = #044a88; MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: = no-repeat } .lightGrey .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; COLOR: = #044a88; MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: = no-repeat } .lightRed .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; COLOR: = #044a88; MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: = no-repeat } .lightYellow .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; COLOR: = #044a88; MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: = no-repeat } .lightBlue .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .lightGrey .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .lightRed .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .lightYellow .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .lightBlue .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .lightGrey .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .lightRed .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .lightYellow .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .lightBlue .roundedBox .headerBoxTitle { COLOR: #044a88 } .lightBlue .roundedBox .footerBoxTitle A { COLOR: #044a88 } A.darkblue { COLOR: #044a88 } .lightGrey .roundedBox .headerBoxTitle { COLOR: #7e8e81 } .lightGrey .roundedBox .footerBoxTitle A { COLOR: #7e8e81 } A.grey { COLOR: #7e8e81 } .lightRed .roundedBox .headerBoxTitle { COLOR: #d2232a } .lightRed .roundedBox .footerBoxTitle A { COLOR: #d2232a } .lightYellow .roundedBox .headerBoxTitle { COLOR: #fce621 } .lightYellow .roundedBox .footerBoxTitle A { COLOR: #fce621 } A.yellow { COLOR: #fce621 } .darkBlue { BACKGROUND-COLOR: #014a7f } .blue A { COLOR: #014a7f } .darkBlue A { COLOR: #014a7f } .lightBlue A { COLOR: #014a7f } .lightYellow { BACKGROUND-COLOR: #fce621 } .yellow { BACKGROUND-COLOR: #fce621 } .lightYellow A { COLOR: #fce621 } .lightRed { BACKGROUND-COLOR: #d2232a } .red { BACKGROUND-COLOR: #d2232a } .lightBlue { BACKGROUND-COLOR: #c9d3dc } .lightGrey { BACKGROUND-COLOR: #7e8e81 } .grey { BACKGROUND-COLOR: #eceeed } .blueGrey { BACKGROUND-COLOR: #d6e1e6 } .darkGrey { BACKGROUND-COLOR: #999 } .oneThird { WIDTH: 303px } .twoThird { WIDTH: 615px } .full { WIDTH: 100% } .positionLeft { FLOAT: left } .positionRight { FLOAT: right } .blueTitle { COLOR: #014a7f } .darkGreyTitle { COLOR: #555 } .redTitle { COLOR: #d2232a } .yellowTitle { COLOR: #fce621 } .normalText { FONT-SIZE: 0.9em } .unePicture { WIDTH: 225px } .uneText { MARGIN-LEFT: 6px; WIDTH: 365px } .half { WIDTH: 48% } .smallUne { FLOAT: left; MARGIN: 0px 10px 0px 0px } .smallerUne IMG { FLOAT: left; MARGIN: 4px 5px 0px 0px; WIDTH: 60px } .uneFit { FLOAT: left; WIDTH: 150px } .actuFit { FLOAT: left; WIDTH: 200px } UL.simpleList { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: = 0px; PADDING-TOP: 0px; LIST-STYLE-TYPE: none } UL.simpleList LI { PADDING-LEFT: 10px; BACKGROUND: url(../img/double_fleche.gif) no-repeat = 0px 5px; COLOR: #0766ae } .blocTexte { COLOR: #666; LINE-HEIGHT: 18px; TEXT-ALIGN: justify } UL.pagination { PADDING-RIGHT: 0px; MARGIN-TOP: 15px; PADDING-LEFT: 0px; = PADDING-BOTTOM: 0px; PADDING-TOP: 0px; LIST-STYLE-TYPE: none; = TEXT-ALIGN: right } UL.pagination LI { PADDING-RIGHT: 3px; DISPLAY: inline; PADDING-LEFT: 3px; PADDING-BOTTOM: = 3px; PADDING-TOP: 3px } UL.pagination LI A { BORDER-RIGHT: #666 2px solid; PADDING-RIGHT: 3px; BORDER-TOP: #666 2px = solid; PADDING-LEFT: 3px; BACKGROUND: #e4e4e4; PADDING-BOTTOM: 0px; = BORDER-LEFT: #666 2px solid; COLOR: #666; PADDING-TOP: 0px; = BORDER-BOTTOM: #666 2px solid; TEXT-DECORATION: none } UL.pagination LI A:hover { BORDER-RIGHT: #7096d0 2px solid; BORDER-TOP: #7096d0 2px solid; = BACKGROUND: #e4e4e4; BORDER-LEFT: #7096d0 2px solid; COLOR: #7096d0; = BORDER-BOTTOM: #7096d0 2px solid } UL.pagination LI A.active { BORDER-RIGHT: #7096d0 2px solid; BORDER-TOP: #7096d0 2px solid; = BACKGROUND: #e4e4e4; BORDER-LEFT: #7096d0 2px solid; COLOR: #666; = BORDER-BOTTOM: #7096d0 2px solid } .diaporama { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: = 15px auto; WIDTH: 100%; PADDING-TOP: 0px } .theView { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; BACKGROUND: #000; = PADDING-BOTTOM: 0px; MARGIN: 0px auto; PADDING-TOP: 0px; TEXT-ALIGN: = center } .theDefinition { PADDING-RIGHT: 8px; PADDING-LEFT: 8px; BACKGROUND: #000; = PADDING-BOTTOM: 8px; COLOR: #fff; PADDING-TOP: 8px; TEXT-ALIGN: left } .diapoNav { PADDING-RIGHT: 4px; PADDING-LEFT: 4px; Z-INDEX: 1000; BACKGROUND: #000; = PADDING-BOTTOM: 4px; COLOR: #fff; PADDING-TOP: 4px; POSITION: relative; = TOP: 0px; HEIGHT: 43px } .diapoNav UL { PADDING-RIGHT: 0px; MARGIN-TOP: 6px; PADDING-LEFT: 0px; PADDING-BOTTOM: = 0px; MARGIN-LEFT: 6px; PADDING-TOP: 0px; LIST-STYLE-TYPE: none } .diapoNav UL LI { DISPLAY: inline; MARGIN-RIGHT: 5px } .diapoNav UL LI A IMG { BORDER-RIGHT: #fff 1px solid; PADDING-RIGHT: 0px; BORDER-TOP: #fff 1px = solid; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; BORDER-LEFT: #fff 1px = solid; WIDTH: 25px; PADDING-TOP: 0px; BORDER-BOTTOM: #fff 1px solid } .diapoNav UL LI A:hover IMG { BORDER-RIGHT: aqua 1px solid; BORDER-TOP: aqua 1px solid; BORDER-LEFT: = aqua 1px solid; BORDER-BOTTOM: aqua 1px solid } .sideNotes { PADDING-RIGHT: 4px; PADDING-LEFT: 4px; MARGIN-BOTTOM: 10px; = PADDING-BOTTOM: 4px; WIDTH: 295px; PADDING-TOP: 4px } .reactions { PADDING-RIGHT: 10px; PADDING-LEFT: 10px; PADDING-BOTTOM: 8px; = PADDING-TOP: 5px } .reactionsAlt { PADDING-RIGHT: 10px; PADDING-LEFT: 10px; BACKGROUND: #e4e4e4; = PADDING-BOTTOM: 8px; PADDING-TOP: 5px } .reactionsDate { FONT-SIZE: 0.8em; COLOR: #666 } .posting { BORDER-TOP: #7e8e81 1px dashed } UL.sideLinks { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: = 0px; PADDING-TOP: 0px; LIST-STYLE-TYPE: none } UL.sideLinks LI { PADDING-RIGHT: 0px; PADDING-LEFT: 20px; PADDING-BOTTOM: 2px; = PADDING-TOP: 2px } UL.sideLinks LI A { FONT-WEIGHT: bold; COLOR: #d2232a; TEXT-DECORATION: none } .redSidenotes A:hover { COLOR: #d2232a } .blueSidenotes A:hover { COLOR: #014a7f } .print { BACKGROUND: url(../img/print.gif) no-repeat 0px 3px } .send { BACKGROUND: url(../img/send.gif) no-repeat 0px 3px } .comment { BACKGROUND: url(../img/comment.gif) no-repeat 0px 3px } UL.articlesList { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: = 0px; PADDING-TOP: 0px; LIST-STYLE-TYPE: none } UL.articlesList LI { BACKGROUND: url(../img/bg_articles_list.gif) no-repeat right bottom; = MARGIN-BOTTOM: 10px; PADDING-BOTTOM: 4px } UL.articlesList LI A { COLOR: #666; TEXT-DECORATION: none } UL.articlesList LI A:hover { COLOR: #000; TEXT-DECORATION: none } .articlesPresentation { PADDING-RIGHT: 5px; PADDING-LEFT: 5px; FLOAT: left; PADDING-BOTTOM: = 5px; WIDTH: 440px; PADDING-TOP: 5px } .articleIllustrations { FLOAT: left; WIDTH: 124px; MARGIN-RIGHT: 10px } .articleIllustrations IMG { BORDER-RIGHT: #000 2px solid; BORDER-TOP: #000 2px solid; BORDER-LEFT: = #000 2px solid; WIDTH: 120px; MARGIN-RIGHT: 10px; BORDER-BOTTOM: #000 = 2px solid } .IllusFlashLegend { PADDING-RIGHT: 2px; MARGIN-TOP: -5px; PADDING-LEFT: 2px; FONT-SIZE: = 11px; BACKGROUND: #000; PADDING-BOTTOM: 0px; WIDTH: 120px; COLOR: #fff; = PADDING-TOP: 0px } .mediaZone { PADDING-RIGHT: 4px; PADDING-LEFT: 4px; MIN-HEIGHT: 200px; BACKGROUND: = url(../img/bg_zonemedia.gif) no-repeat left bottom; FLOAT: left; = PADDING-BOTTOM: 4px; WIDTH: 200px; MARGIN-RIGHT: 13px; PADDING-TOP: 4px } .illusArticle { FLOAT: left; WIDTH: 250px; MARGIN-RIGHT: 10px } .illusArticle IMG { BORDER-RIGHT: #000 2px solid; BORDER-TOP: #000 2px solid; BORDER-LEFT: = #000 2px solid; WIDTH: 246px; BORDER-BOTTOM: #000 2px solid } .IllusArticleLegend { PADDING-RIGHT: 2px; MARGIN-TOP: -5px; PADDING-LEFT: 2px; FONT-SIZE: = 11px; BACKGROUND: #000; PADDING-BOTTOM: 0px; WIDTH: 246px; COLOR: #fff; = PADDING-TOP: 0px } DIV.progBar { CLEAR: both; WIDTH: 100% } TABLE.sondage { FLOAT: left; WIDTH: 70% } TABLE.sondage TD.resultGreen { BACKGROUND: url(../img/bg_result_green.gif); COLOR: #fff } TABLE.sondage TD.resultBlue { BACKGROUND: url(../img/bg_result_blue.gif); COLOR: #fff } TABLE.sondage TD.resultRed { BACKGROUND: url(../img/bg_result_red.gif); COLOR: #fff } TABLE.sondage TD.resultYellow { BACKGROUND: url(../img/bg_result_yellow.gif); COLOR: #fff } TABLE.sondage TD.resultBlank { BACKGROUND: url(../img/bg_result_grey.gif); HEIGHT: 16px } DIV.resultNumber { PADDING-RIGHT: 10px; MARGIN-TOP: 1px; PADDING-LEFT: 13px; FONT-SIZE: = 0.9em; BACKGROUND: url(../img/bg_result_number.gif) no-repeat; FLOAT: = left; PADDING-BOTTOM: 1px; WIDTH: 25px; COLOR: #fff; PADDING-TOP: 1px } DIV.answer { WIDTH: 100% } UL.cinemaList { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: = 0px; PADDING-TOP: 0px; LIST-STYLE-TYPE: none } UL.cinemaList LI IMG { BORDER-RIGHT: #999 2px dotted; PADDING-RIGHT: 5px; FLOAT: left; = MARGIN-RIGHT: 10px } UL.cinemaList LI { MARGIN-TOP: 4px; PADDING-BOTTOM: 5px; BORDER-BOTTOM: #999 2px dotted } UL.cinemaList LI A { COLOR: #333 } FORM#an_search { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: = 0px; PADDING-TOP: 0px } FORM#GFGForm { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: = 0px; PADDING-TOP: 0px } FORM#an_search P { CLEAR: both; PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: = 0px; MARGIN: 6px 0px 0px; PADDING-TOP: 0px } FORM#GFGForm P { CLEAR: both; PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: = 0px; MARGIN: 6px 0px 0px; PADDING-TOP: 0px } FORM#an_search LABEL { FLOAT: left; WIDTH: 75px; PADDING-TOP: 3px } FORM#GFGForm LABEL { FLOAT: left; WIDTH: 75px; PADDING-TOP: 3px } FORM#an_search INPUT { BORDER-RIGHT: #ccc 1px solid; PADDING-RIGHT: 1px; BORDER-TOP: #ccc 1px = solid; PADDING-LEFT: 1px; PADDING-BOTTOM: 1px; BORDER-LEFT: #e4e4e4 1px = solid; PADDING-TOP: 1px; BORDER-BOTTOM: #e4e4e4 1px solid } FORM#GFGForm INPUT { BORDER-RIGHT: #ccc 1px solid; PADDING-RIGHT: 1px; BORDER-TOP: #ccc 1px = solid; PADDING-LEFT: 1px; PADDING-BOTTOM: 1px; BORDER-LEFT: #e4e4e4 1px = solid; PADDING-TOP: 1px; BORDER-BOTTOM: #e4e4e4 1px solid } FORM#an_search TEXTAREA { BORDER-RIGHT: #ccc 1px solid; PADDING-RIGHT: 1px; BORDER-TOP: #ccc 1px = solid; PADDING-LEFT: 1px; PADDING-BOTTOM: 1px; BORDER-LEFT: #e4e4e4 1px = solid; PADDING-TOP: 1px; BORDER-BOTTOM: #e4e4e4 1px solid } FORM#GFGForm TEXTAREA { BORDER-RIGHT: #ccc 1px solid; PADDING-RIGHT: 1px; BORDER-TOP: #ccc 1px = solid; PADDING-LEFT: 1px; PADDING-BOTTOM: 1px; BORDER-LEFT: #e4e4e4 1px = solid; PADDING-TOP: 1px; BORDER-BOTTOM: #e4e4e4 1px solid } FORM#an_search SELECT { BORDER-RIGHT: #ccc 1px solid; PADDING-RIGHT: 1px; BORDER-TOP: #ccc 1px = solid; PADDING-LEFT: 1px; PADDING-BOTTOM: 1px; BORDER-LEFT: #e4e4e4 1px = solid; PADDING-TOP: 1px; BORDER-BOTTOM: #e4e4e4 1px solid } FORM#GFGForm SELECT { BORDER-RIGHT: #ccc 1px solid; PADDING-RIGHT: 1px; BORDER-TOP: #ccc 1px = solid; PADDING-LEFT: 1px; PADDING-BOTTOM: 1px; BORDER-LEFT: #e4e4e4 1px = solid; PADDING-TOP: 1px; BORDER-BOTTOM: #e4e4e4 1px solid } FORM#an_search INPUT.alignField { MARGIN-LEFT: 75px } FORM#GFGForm INPUT.alignField { MARGIN-LEFT: 75px } .alignF { LEFT: 75px; POSITION: relative } FORM#GFGForm SELECT { WIDTH: 195px } FORM#GFGForm .legend { MARGIN-TOP: 2px; PADDING-LEFT: 18px; FONT-SIZE: 10px; BACKGROUND: = url(../img/bg_legendForm.gif) no-repeat; MARGIN-LEFT: 75px; COLOR: #333; = PADDING-TOP: 2px } UL.annoncesList { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: = 0px; PADDING-TOP: 0px; LIST-STYLE-TYPE: none; TEXT-ALIGN: left } UL.annoncesList LI { CLEAR: left; PADDING-RIGHT: 10px; PADDING-LEFT: 10px; BACKGROUND: = url(../img/bg_annonces.gif) no-repeat right top; FLOAT: left; = MARGIN-BOTTOM: 10px; PADDING-BOTTOM: 4px; OVERFLOW: hidden; WIDTH: 580px } UL.annoncesList LI P { PADDING-RIGHT: 0px; BORDER-TOP: #e4e4e4 1px solid; PADDING-LEFT: 0px; = PADDING-BOTTOM: 0px; MARGIN: 2px 0px 0px; PADDING-TOP: 0px } .anTitle { FONT-WEIGHT: bold; FONT-SIZE: 18px; MARGIN: 10px 0px 5px 25px } .anInfos { BORDER-RIGHT: #ccc 1px solid; PADDING-RIGHT: 4px; BORDER-TOP: #ccc 1px = solid; PADDING-LEFT: 4px; FONT-SIZE: 10px; BACKGROUND: #eaeaea; FLOAT: = right; PADDING-BOTTOM: 4px; BORDER-LEFT: #ccc 1px solid; WIDTH: 230px; = MARGIN-RIGHT: 20px; PADDING-TOP: 4px; BORDER-BOTTOM: #ccc 1px solid } .anDesc { FONT-WEIGHT: bold; FLOAT: left; WIDTH: 300px } UL.boutiqueList { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: = 0px; PADDING-TOP: 0px; LIST-STYLE-TYPE: none; TEXT-ALIGN: left } UL.boutiqueList LI { CLEAR: left; PADDING-RIGHT: 10px; PADDING-LEFT: 10px; BACKGROUND: = url(../img/bgBoutique.gif) no-repeat right bottom; FLOAT: left; = MARGIN-BOTTOM: 10px; PADDING-BOTTOM: 4px; OVERFLOW: hidden; WIDTH: 575px } UL.boutiqueList LI P { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: 2px = 0px 0px; PADDING-TOP: 0px } .btTitle { FONT-WEIGHT: bold; FONT-SIZE: 18px; MARGIN: 0px 0px 5px; WIDTH: 300px } .btInfos { PADDING-RIGHT: 4px; PADDING-LEFT: 4px; FONT-SIZE: 10px; FLOAT: right; = PADDING-BOTTOM: 4px; WIDTH: 240px; MARGIN-RIGHT: 20px; PADDING-TOP: 4px; = TEXT-ALIGN: right } .btDesc { FONT-WEIGHT: bold; FLOAT: left; WIDTH: 300px } .btPlus { CURSOR: pointer; COLOR: #014a7f } .adminSubNav { PADDING-RIGHT: 0px; PADDING-LEFT: 10px; PADDING-BOTTOM: 15px; = PADDING-TOP: 10px } .adminSubNav UL.subNav { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FLOAT: left; PADDING-BOTTOM: = 0px; MARGIN: 0px; WIDTH: 200px; PADDING-TOP: 0px } .adminSubNav UL.subNav LI { LIST-STYLE-TYPE: none } .adminSubNav UL.subNav LI.red { PADDING-RIGHT: 0px; PADDING-LEFT: 15px; BACKGROUND: = url(../img/red_arrows.gif) no-repeat 0px 3px; PADDING-BOTTOM: 0px; = PADDING-TOP: 0px } .adminSubNav UL.subNav LI.blue { PADDING-RIGHT: 0px; PADDING-LEFT: 15px; BACKGROUND: = url(../img/blue_arrows.gif) no-repeat 0px 3px; PADDING-BOTTOM: 0px; = PADDING-TOP: 0px } UL.adminTabNav { MARGIN-LEFT: 110px; TEXT-ALIGN: center } UL.adminTabNav LI { PADDING-RIGHT: 0px; DISPLAY: block; PADDING-LEFT: 0px; BACKGROUND: = url(../img/admin_tabnav.gif) no-repeat 0px 3px; FLOAT: left; = PADDING-BOTTOM: 3px; WIDTH: 160px; MARGIN-RIGHT: 4px; PADDING-TOP: 6px; = LIST-STYLE-TYPE: none } UL.adminTabNav LI.active { BACKGROUND: url(../img/admin_tabnav_active.gif) no-repeat 0px 3px } UL.adminTabNav LI A { FONT-WEIGHT: bold; FONT-SIZE: 1.2em; COLOR: #fff; TEXT-DECORATION: none } UL.adminTabNav LI A:hover { COLOR: #333 } UL.adminTabNav LI.active A { COLOR: #333 } FORM#adminForm { MARGIN-BOTTOM: 20px; WIDTH: 90% } FORM#adminForm P { CLEAR: both; LINE-HEIGHT: 30px } FORM#adminForm INPUT { BORDER-RIGHT: #ccc 1px solid; PADDING-RIGHT: 1px; BORDER-TOP: #ccc 1px = solid; PADDING-LEFT: 1px; FLOAT: left; PADDING-BOTTOM: 1px; BORDER-LEFT: = #e4e4e4 1px solid; PADDING-TOP: 1px; BORDER-BOTTOM: #e4e4e4 1px solid } FORM#adminForm TEXTAREA { BORDER-RIGHT: #ccc 1px solid; PADDING-RIGHT: 1px; BORDER-TOP: #ccc 1px = solid; PADDING-LEFT: 1px; FLOAT: left; PADDING-BOTTOM: 1px; BORDER-LEFT: = #e4e4e4 1px solid; PADDING-TOP: 1px; BORDER-BOTTOM: #e4e4e4 1px solid } FORM#adminForm SELECT { BORDER-RIGHT: #ccc 1px solid; PADDING-RIGHT: 1px; BORDER-TOP: #ccc 1px = solid; PADDING-LEFT: 1px; FLOAT: left; PADDING-BOTTOM: 1px; BORDER-LEFT: = #e4e4e4 1px solid; PADDING-TOP: 1px; BORDER-BOTTOM: #e4e4e4 1px solid } FORM#adminForm SPAN { FLOAT: left } FORM#adminForm LABEL { FLOAT: left; WIDTH: 220px; PADDING-TOP: 3px } FORM#adminForm LABEL { FLOAT: left; WIDTH: 220px; PADDING-TOP: 3px } FORM#adminForm .legend { BORDER-RIGHT: #69b2d3 1px solid; BORDER-TOP: #69b2d3 1px solid; = MARGIN-TOP: 2px; PADDING-LEFT: 18px; FONT-SIZE: 10px; BACKGROUND: = #fdf493 no-repeat; FLOAT: left; PADDING-BOTTOM: 2px; MARGIN-LEFT: 10px; = BORDER-LEFT: #69b2d3 1px solid; WIDTH: 200px; COLOR: #333; PADDING-TOP: = 2px; BORDER-BOTTOM: #69b2d3 1px solid } FORM#logAdmin { PADDING-RIGHT: 20px; PADDING-LEFT: 20px; PADDING-BOTTOM: 20px; MARGIN: = 0px auto; WIDTH: 350px; PADDING-TOP: 20px } FORM#logAdmin P { CLEAR: both; LINE-HEIGHT: 30px } FORM#logAdmin LABEL { FLOAT: left; WIDTH: 120px } FORM#logAdmin INPUT { BORDER-RIGHT: #333 1px solid; PADDING-RIGHT: 3px; BORDER-TOP: #333 1px = solid; PADDING-LEFT: 3px; FONT-SIZE: 14px; FLOAT: left; PADDING-BOTTOM: = 3px; BORDER-LEFT: #333 1px solid; WIDTH: 200px; PADDING-TOP: 3px; = BORDER-BOTTOM: #333 1px solid } FORM#logAdmin INPUT.bouton { BORDER-RIGHT: white 2px solid; PADDING-RIGHT: 1px; BORDER-TOP: white = 2px solid; PADDING-LEFT: 1px; FONT-WEIGHT: bold; BACKGROUND: #999; = FLOAT: left; PADDING-BOTTOM: 1px; BORDER-LEFT: white 2px solid; WIDTH: = 100px; COLOR: white; PADDING-TOP: 1px; BORDER-BOTTOM: white 2px solid } .clearBoth { CLEAR: both; HEIGHT: 0% } .dashedSeparator { CLEAR: both; BORDER-TOP: #7e8e81 1px dashed; PADDING-BOTTOM: 10px; = HEIGHT: 1px } .dashedSeparatorRed { CLEAR: both; BORDER-TOP: #d2232a 1px dashed; PADDING-BOTTOM: 10px; = HEIGHT: 1px } .dashedSeparatorBlue { CLEAR: both; BORDER-TOP: #014a7f 1px dashed; PADDING-BOTTOM: 10px; = HEIGHT: 1px } .marginLeft { MARGIN-LEFT: 10px } .marginBottom { MARGIN-BOTTOM: 10px } .marginTop { MARGIN-TOP: 10px } .paddingMore { PADDING-RIGHT: 8px; PADDING-LEFT: 8px; PADDING-BOTTOM: 8px; = PADDING-TOP: 8px } UL.linkList { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: = 0px; PADDING-TOP: 0px; LIST-STYLE-TYPE: none } UL.linkList LI { PADDING-LEFT: 10px } .bold { FONT-WEIGHT: bold } PRE { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; BACKGROUND: #fffaed; = PADDING-BOTTOM: 0px; BORDER-LEFT: #ebd8aa 5px solid; COLOR: #333; = TEXT-INDENT: 0px; PADDING-TOP: 0px } .tempoItem { MARGIN-TOP: 10px; MARGIN-LEFT: 10px; WIDTH: 300px } .alignCenter { TEXT-ALIGN: center } .alignRight { TEXT-ALIGN: right } .dgLine1 .dgCol { BORDER-RIGHT: #ccc 1px solid; FLOAT: left; OVERFLOW: hidden; WIDTH: = 147px; COLOR: #444444; HEIGHT: 30px; TEXT-ALIGN: center } .dgLine2 .dgCol { BORDER-RIGHT: #ccc 1px solid; FLOAT: left; OVERFLOW: hidden; WIDTH: = 147px; COLOR: #444444; HEIGHT: 30px; TEXT-ALIGN: center } .dgLineHeader { PADDING-RIGHT: 4px; MARGIN-TOP: 15px; PADDING-LEFT: 4px; FONT-WEIGHT: = bold; FONT-SIZE: 16px; BACKGROUND: url(../img/bg_dgheader.gif) #2d93c1 = repeat-x left top; PADDING-BOTTOM: 0px; PADDING-TOP: 10px; HEIGHT: 30px } .dgLineHeader .dgCol { BORDER-RIGHT: white 1px solid; BACKGROUND: none transparent scroll = repeat 0% 0%; FLOAT: left; WIDTH: 147px; COLOR: white; TEXT-ALIGN: = center } .dgLineHeader .dgCol A { FONT-WEIGHT: bold; FONT-SIZE: 16px; COLOR: white } .dgLineHeader .dgCol A:hover { PADDING-RIGHT: 15px; FONT-WEIGHT: bold; FONT-SIZE: 16px; BACKGROUND: = url(../img/bg_dgheader_order.gif) no-repeat 100% 4px; COLOR: white; = TEXT-DECORATION: none } .dgLine1 { PADDING-RIGHT: 4px; PADDING-LEFT: 4px; FONT-SIZE: 11px; PADDING-BOTTOM: = 4px; PADDING-TOP: 4px; HEIGHT: 30px; BACKGROUND-COLOR: #fafafa } .dgLine2 { PADDING-RIGHT: 4px; PADDING-LEFT: 4px; FONT-SIZE: 11px; PADDING-BOTTOM: = 4px; PADDING-TOP: 4px; HEIGHT: 30px; BACKGROUND-COLOR: #e6f7fe } .dgLine2 IMG { MARGIN-TOP: 4px } .dgLine1 IMG { MARGIN-TOP: 4px } .dgLineHeader { CLEAR: both } .dgLine1 { CLEAR: both } .dgLine2 { CLEAR: both } .roundedBox .boxContentCenter { MARGIN: 0px 1px; HEIGHT: 1%; BACKGROUND-COLOR: #fff; TEXT-ALIGN: center } .menu UL LI .activecat { BACKGROUND: #fff; COLOR: #666; BORDER-BOTTOM: #d6252d 3px solid } .centerDiv { MARGIN: 0px auto } .centerText { TEXT-ALIGN: center } .rougeCadre .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .rougeOrangeCadre .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .orangeCadre .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .orangeCadre .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .jauneOrangeCadre .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .violetFonceCadre .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .violetClairCadre .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .roseFonceCadre .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .roseClairCadre .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .bleuNuitCadre .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .bleuCielCadre .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .bleuCielClairCadre .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .bleuClairCadre .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .vertOliveCadre .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .vertFonceCadre .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .vertPrairieCadre .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .vertClairCadre .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .terreCadre .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .terreClairCadre .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .beigeFonceCadre .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .beigeCadre .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .bordeauFonceCadre .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .bordeauCadre .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .rougeFonceCadre .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .grisFonceCadre .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .grisSourisCadre .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .grisClairCadre .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .grisPlusClairCadre .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .grisTresClairCadre .roundedBox .headerBox { BACKGROUND-POSITION: left top; BACKGROUND-IMAGE: = url(../img/white_topleft_corner.gif); MARGIN-RIGHT: 6px; = BACKGROUND-REPEAT: no-repeat } .rougeCadre .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; = MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .rougeOrangeCadre .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; = MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .orangeCadre .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; = MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .orangeCadre .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; = MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .jauneOrangeCadre .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; = MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .violetFonceCadre .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; = MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .violetClairCadre .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; = MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .roseFonceCadre .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; = MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .roseClairCadre .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; = MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .bleuNuitCadre .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; = MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .bleuCielCadre .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; = MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .bleuCielClairCadre .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; = MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .bleuClairCadre .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; = MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .vertOliveCadre .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; = MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .vertFonceCadre .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; = MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .vertPrairieCadre .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; = MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .vertClairCadre .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; = MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .terreCadre .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; = MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .terreClairCadre .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; = MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .beigeFonceCadre .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; = MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .beigeCadre .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; = MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .bordeauFonceCadre .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; = MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .bordeauCadre .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; = MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .rougeFonceCadre .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; = MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .grisFonceCadre .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; = MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .grisSourisCadre .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; = MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .grisClairCadre .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; = MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .grisPlusClairCadre .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; = MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .grisTresClairCadre .roundedBox .headerBoxTitle { PADDING-RIGHT: 2px; BACKGROUND-POSITION: right top; PADDING-LEFT: 7px; = FONT-WEIGHT: bold; FONT-SIZE: 1em; BACKGROUND-IMAGE: = url(../img/white_topright_corner.gif); PADDING-BOTTOM: 4px; = MARGIN-RIGHT: -6px; PADDING-TOP: 3px; BACKGROUND-REPEAT: no-repeat } .rougeCadre .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .rougeOrangeCadre .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .orangeCadre .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .orangeCadre .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .jauneOrangeCadre .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .violetFonceCadre .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .violetClairCadre .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .roseFonceCadre .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .roseClairCadre .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .bleuNuitCadre .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .bleuCielCadre .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .bleuCielClairCadre .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .bleuClairCadre .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .vertOliveCadre .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .vertFonceCadre .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .vertPrairieCadre .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .vertClairCadre .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .terreCadre .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .terreClairCadre .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .beigeFonceCadre .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .beigeCadre .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .bordeauFonceCadre .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .bordeauCadre .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .rougeFonceCadre .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .grisFonceCadre .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .grisSourisCadre .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .grisClairCadre .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .grisPlusClairCadre .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .grisTresClairCadre .roundedBox .footerBox { BACKGROUND: url(../img/white_botleft_corner.gif) no-repeat left bottom; = MARGIN-RIGHT: 6px } .rougeCadre .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .rougeOrangeCadre .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .orangeCadre .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .orangeCadre .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .jauneOrangeCadre .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .violetFonceCadre .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .violetClairCadre .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .roseFonceCadre .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .roseClairCadre .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .bleuNuitCadre .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .bleuCielCadre .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .bleuCielClairCadre .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .bleuClairCadre .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .vertOliveCadre .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .vertFonceCadre .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .vertPrairieCadre .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .vertClairCadre .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .terreCadre .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .terreClairCadre .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .beigeFonceCadre .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .beigeCadre .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .bordeauFonceCadre .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .bordeauCadre .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .rougeFonceCadre .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .grisFonceCadre .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .grisSourisCadre .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .grisClairCadre .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .grisPlusClairCadre .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .grisTresClairCadre .roundedBox .footerBoxTitle { BACKGROUND: url(../img/white_botright_corner.gif) no-repeat right = bottom; MARGIN-RIGHT: -6px; HEIGHT: 16px } .rougeCadre .roundedBox .headerBoxTitle { COLOR: #ff0000 } .rougeOrangeCadre .roundedBox .headerBoxTitle { COLOR: #ff3300 } .orangeCadre .roundedBox .headerBoxTitle { COLOR: #ff6600 } .jauneOrangeCadre .roundedBox .headerBoxTitle { COLOR: #ff9900 } .violetFonceCadre .roundedBox .headerBoxTitle { COLOR: #96004b } .violetClairCadre .roundedBox .headerBoxTitle { COLOR: #c00060 } .roseFonceCadre .roundedBox .headerBoxTitle { COLOR: #ec0076 } .roseClairCadre .roundedBox .headerBoxTitle { COLOR: #ec50af } .bleuNuitCadre .roundedBox .headerBoxTitle { COLOR: #003366 } .bleuCielCadre .roundedBox .headerBoxTitle { COLOR: #004e9c } .bleuCielClairCadre .roundedBox .headerBoxTitle { COLOR: #0066cd } .bleuClairCadre .roundedBox .headerBoxTitle { COLOR: #349aee } .vertOliveCadre .roundedBox .headerBoxTitle { COLOR: #009a5a } .vertFonceCadre .roundedBox .headerBoxTitle { COLOR: #669900 } .vertPrairieCadre .roundedBox .headerBoxTitle { COLOR: #79b700 } .vertClairCadre .roundedBox .headerBoxTitle { COLOR: #aacd3c } .terreCadre .roundedBox .headerBoxTitle { COLOR: #584940 } .terreClairCadre .roundedBox .headerBoxTitle { COLOR: #7a6558 } .beigeFonceCadre .roundedBox .headerBoxTitle { COLOR: #957b6b } .beigeCadre .roundedBox .headerBoxTitle { COLOR: #b89884 } .bordeauFonceCadre .roundedBox .headerBoxTitle { COLOR: #660000 } .bordeauCadre .roundedBox .headerBoxTitle { COLOR: #900000 } .rougeFonceCadre .roundedBox .headerBoxTitle { COLOR: #ac0000 } .grisFonceCadre .roundedBox .headerBoxTitle { COLOR: #333333 } .grisSourisCadre .roundedBox .headerBoxTitle { COLOR: #666666 } .grisClairCadre .roundedBox .headerBoxTitle { COLOR: #999999 } .grisPlusClairCadre .roundedBox .headerBoxTitle { COLOR: #e7e7e7 } .grisTresClairCadre .roundedBox .headerBoxTitle { COLOR: #e8e8ea } .rouge { BACKGROUND-COLOR: #ff0000 } .rougeCadre { BACKGROUND-COLOR: #ff0000 } .rougeOrange { BACKGROUND-COLOR: #ff3300 } .rougeOrangeCadre { BACKGROUND-COLOR: #ff3300 } .orange { BACKGROUND-COLOR: #ff6600 } .orangeCadre { BACKGROUND-COLOR: #ff6600 } .jauneOrange { BACKGROUND-COLOR: #ff9900 } .jauneOrangeCadre { BACKGROUND-COLOR: #ff9900 } .violetFonce { BACKGROUND-COLOR: #96004b } .violetFonceCadre { BACKGROUND-COLOR: #96004b } .violetClair { BACKGROUND-COLOR: #c00060 } .violetClairCadre { BACKGROUND-COLOR: #c00060 } .roseFonce { BACKGROUND-COLOR: #ec0076 } .roseFonceCadre { BACKGROUND-COLOR: #ec0076 } .roseClair { BACKGROUND-COLOR: #ec50af } .roseClairCadre { BACKGROUND-COLOR: #ec50af } .bleuNuit { BACKGROUND-COLOR: #003366 } .bleuNuitCadre { BACKGROUND-COLOR: #003366 } .bleuCiel { BACKGROUND-COLOR: #004e9c } .bleuCielCadre { BACKGROUND-COLOR: #004e9c } .bleuCielClair { BACKGROUND-COLOR: #0066cd } .bleuCielClairCadre { BACKGROUND-COLOR: #0066cd } .bleuManche { BACKGROUND-COLOR: #000033 } .bleuClair { BACKGROUND-COLOR: #349aee } .bleuClairCadre { BACKGROUND-COLOR: #349aee } .vertOlive { BACKGROUND-COLOR: #009a5a } .vertOliveCadre { BACKGROUND-COLOR: #009a5a } .vertFonce { BACKGROUND-COLOR: #669900 } .vertFonceCadre { BACKGROUND-COLOR: #669900 } .vertPrairie { BACKGROUND-COLOR: #79b700 } .vertPrairieCadre { BACKGROUND-COLOR: #79b700 } .vertClair { BACKGROUND-COLOR: #aacd3c } .vertClairCadre { BACKGROUND-COLOR: #aacd3c } .terre { BACKGROUND-COLOR: #584940 } .terreCadre { BACKGROUND-COLOR: #584940 } .terreClair { BACKGROUND-COLOR: #7a6558 } .terreClairCadre { BACKGROUND-COLOR: #7a6558 } .beigeFonce { BACKGROUND-COLOR: #957b6b } .beigeFonceCadre { BACKGROUND-COLOR: #957b6b } .beige { BACKGROUND-COLOR: #b89884 } .beigeCadre { BACKGROUND-COLOR: #b89884 } .bordeauFonce { BACKGROUND-COLOR: #660000 } .bordeauFonceCadre { BACKGROUND-COLOR: #660000 } .bordeau { BACKGROUND-COLOR: #900000 } .bordeauCadre { BACKGROUND-COLOR: #900000 } .rougeFonce { BACKGROUND-COLOR: #ac0000 } .rougeFonceCadre { BACKGROUND-COLOR: #ac0000 } .grisFonce { BACKGROUND-COLOR: #333333 } .grisFonceCadre { BACKGROUND-COLOR: #333333 } .grisSouris { BACKGROUND-COLOR: #666666 } .grisSourisCadre { BACKGROUND-COLOR: #666666 } .grisClair { BACKGROUND-COLOR: #999999 } .grisClairCadre { BACKGROUND-COLOR: #999999 } .grisPlusClair { BACKGROUND-COLOR: #e7e7e7 } .grisPlusClairCadre { BACKGROUND-COLOR: #e7e7e7 } .grisTresClair { BACKGROUND-COLOR: #e8e8ea } .grisTresClairCadre { BACKGROUND-COLOR: #e8e8ea } .NoBackground { BACKGROUND-COLOR: transparent } .TitreVert { FONT-WEIGHT: bold; FONT-SIZE: 26px; COLOR: #497401 } .RssTexteVert { FONT-WEIGHT: bold; COLOR: #568501 } #RssTexteCadre { WIDTH: 260px } #rssFeeds { MARGIN: 0px auto; WIDTH: 150px; TEXT-ALIGN: left } .RssBlocTexte { TEXT-ALIGN: left } #SkyScraper { LEFT: 980px; POSITION: absolute; TOP: 200px } .smallerUne1 IMG { FLOAT: left; MARGIN: 4px 5px 0px 0px; WIDTH: 70px } #EntreeBoutique { BACKGROUND-POSITION: right 50%; BACKGROUND-IMAGE: = url(../img/bg-boutique.gif); MARGIN-LEFT: 20px; COLOR: #626262; = BACKGROUND-REPEAT: no-repeat; HEIGHT: 306px } .BtnValider { BACKGROUND-IMAGE: url(../img/btn-valider.gif); MARGIN-LEFT: 10px; = WIDTH: 68px; CURSOR: pointer; BORDER-TOP-STYLE: none; = BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none; HEIGHT: 27px; = BACKGROUND-COLOR: transparent; BORDER-BOTTOM-STYLE: none } .RedTexte { COLOR: #d2232a } .VeryBigTexte { FONT-WEIGHT: bold; FONT-SIZE: 40px } .BigTexte { FONT-WEIGHT: bold; FONT-SIZE: 25px } .displayNone { DISPLAY: none } .greyCom { BACKGROUND-COLOR: #bbb } #logFront #BoutonLog { BORDER-TOP-WIDTH: 0px; BORDER-LEFT-WIDTH: 0px; BACKGROUND-IMAGE: = url(../img/ok.gif); BORDER-BOTTOM-WIDTH: 0px; MARGIN-LEFT: 10px; WIDTH: = 34px; CURSOR: pointer; COLOR: white; HEIGHT: 18px; BACKGROUND-COLOR: = #d2232a; BORDER-RIGHT-WIDTH: 0px } .loginBar { FONT-WEIGHT: bold; FONT-SIZE: 11px; FLOAT: right; MARGIN-LEFT: -50px; = WIDTH: 270px; COLOR: #d2232a } #logFront .TextInput { WIDTH: 60px } .SearchBarLoginInput { FONT-SIZE: 13px; WIDTH: 65px; HEIGHT: 15px } .SearchBarSearchInput { FONT-SIZE: 13px; WIDTH: 120px; HEIGHT: 15px } .RedLink { FONT-WEIGHT: bold; COLOR: #d2232a; TEXT-DECORATION: none } .RedLink:visited { FONT-WEIGHT: bold; COLOR: #d2232a; TEXT-DECORATION: none } .RedLink:hover { FONT-WEIGHT: bold; COLOR: #d2232a; TEXT-DECORATION: underline } #listeCatPA { BACKGROUND-IMAGE: url(../img/listePabg.gif); BACKGROUND-REPEAT: = repeat-y } .paTitre { PADDING-RIGHT: 10px; PADDING-LEFT: 10px; FONT-WEIGHT: bold; FONT-SIZE: = 16px; FLOAT: left; WIDTH: 179px } .paTitre A { FONT-WEIGHT: bold; FONT-SIZE: 18px; COLOR: #85b040 } .paTitre A:hover { FONT-WEIGHT: bold; FONT-SIZE: 18px; COLOR: #85b040 } .paTitre1 { FONT-WEIGHT: bold; FONT-SIZE: 14px; FLOAT: left; WIDTH: 280px } .paTitre1 A { FONT-WEIGHT: bold; FONT-SIZE: 14px; COLOR: #666666 } .paTitre1 A:hover { FONT-WEIGHT: bold; FONT-SIZE: 14px; COLOR: #666666 } .paSsTitre { FONT-SIZE: 14px } .paSsTitre A { FONT-WEIGHT: bold; FONT-SIZE: 14px; COLOR: #6d6e71 } .paSsTitre A:hover { FONT-WEIGHT: bold; FONT-SIZE: 14px; COLOR: #6d6e71 } .paSsTitre2 { FONT-SIZE: 12px } .paSsTitre2 A { FONT-WEIGHT: normal; FONT-SIZE: 12px; COLOR: #6d6e71 } .paSsTitre2 A:hover { FONT-WEIGHT: normal; FONT-SIZE: 12px; COLOR: #6d6e71 } .handCursor { CURSOR: pointer } .imgSmall { WIDTH: 120px } #raisonRefus { DISPLAY: none } .askValidate { FONT-WEIGHT: bold; FONT-SIZE: 16px } .askValidate:hover { FONT-WEIGHT: bold; FONT-SIZE: 16px } .labelFacture { WIDTH: 400px } .valFacture { MARGIN-LEFT: 400px } .cadreFacture { BORDER-RIGHT: black 1px solid; BORDER-TOP: black 1px solid; MARGIN-TOP: = 30px; BORDER-LEFT: black 1px solid; WIDTH: 900px; BORDER-BOTTOM: black = 1px solid } .ligneFacture { MARGIN-BOTTOM: 5px } .col1Facture { BORDER-RIGHT: black 1px solid; PADDING-RIGHT: 5px; PADDING-LEFT: 5px; = FLOAT: left; PADDING-BOTTOM: 5px; WIDTH: 350px; PADDING-TOP: 5px; = HEIGHT: 30px } .col2Facture { BORDER-RIGHT: black 1px solid; PADDING-RIGHT: 5px; PADDING-LEFT: 5px; = FLOAT: left; PADDING-BOTTOM: 5px; WIDTH: 100px; PADDING-TOP: 5px; = HEIGHT: 30px } .col3Facture { BORDER-RIGHT: black 1px solid; PADDING-RIGHT: 5px; PADDING-LEFT: 5px; = FLOAT: left; PADDING-BOTTOM: 5px; WIDTH: 150px; PADDING-TOP: 5px; = HEIGHT: 30px } .col4Facture { PADDING-RIGHT: 5px; PADDING-LEFT: 5px; FLOAT: left; PADDING-BOTTOM: = 5px; WIDTH: 250px; PADDING-TOP: 5px; HEIGHT: 30px } .lineFacture { BORDER-BOTTOM: black 1px solid } .headerFacture { FONT-WEIGHT: bold; FONT-SIZE: 16px; TEXT-ALIGN: center } .sepTrait { FONT-SIZE: 1px; HEIGHT: 1px; BACKGROUND-COLOR: gray } .smallInfoRed { FONT-SIZE: 11px; COLOR: red } .titrePrincipal { FONT-WEIGHT: bold; FONT-SIZE: 18px; COLOR: #85b040 } .titrePrincipal A { FONT-WEIGHT: bold; FONT-SIZE: 18px; COLOR: #85b040 } .titrePrincipal A:visited { FONT-WEIGHT: bold; FONT-SIZE: 18px; COLOR: #85b040 } .tip { FONT-SIZE: 10px } .rechercheLabel { FONT-SIZE: 14px; FLOAT: left; WIDTH: 110px; COLOR: #6d6e71 } .rechercheInput { MARGIN-LEFT: 110px } .inputWidth { WIDTH: 185px } .inputDdlWidth { WIDTH: 190px } .rechercherBouton { FONT-WEIGHT: bold; CURSOR: pointer; COLOR: #8cb44b; BORDER-TOP-STYLE: = none; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none; = BACKGROUND-COLOR: transparent; TEXT-DECORATION: underline; = BORDER-BOTTOM-STYLE: none } .freeSearchLabel { FONT-WEIGHT: bold; FONT-SIZE: 14px; COLOR: #6d6e71 } .loginSize { WIDTH: 250px } .floatRight { FLOAT: right } #loginLinkcadre { FONT-WEIGHT: bold; FONT-SIZE: 10px; WIDTH: 180px; COLOR: #747578 } #passerAnnonce { FONT-WEIGHT: bold; FONT-SIZE: 12px; WIDTH: 60px; COLOR: #747578 } #passerAnnonce A { COLOR: #85b040 } #loginLinkcadre A { COLOR: #85b040 } .dashedSepGray { FONT-SIZE: 1px; BACKGROUND-IMAGE: url(../img/dashedBgGray.gif); HEIGHT: = 2px } .dashedSepGreen { FONT-SIZE: 1px; BACKGROUND-IMAGE: url(../img/dashedBgGreen.gif); = HEIGHT: 2px } .listPA { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; LIST-STYLE-POSITION: inside; = LIST-STYLE-IMAGE: url(../img/pucePA.gif); PADDING-BOTTOM: 0px; MARGIN: = 0px; PADDING-TOP: 0px } #paRech2 { WIDTH: 250px } #listePaCat { MARGIN-TOP: 0px; PADDING-LEFT: 0px; MARGIN-LEFT: 0px; WIDTH: 600px; = COLOR: #8a8a8c; PADDING-TOP: 0px; LIST-STYLE-TYPE: none } #listePaCat LI { MARGIN-TOP: 10px; BORDER-BOTTOM: #cccdcf 1px dashed; HEIGHT: 110px } #listePaCat LI DIV { VERTICAL-ALIGN: middle; HEIGHT: 110px } .dashedBot { PADDING-BOTTOM: 5px; BORDER-BOTTOM: #cccdcf 1px dashed } .imgPa { WIDTH: 180px } .prixPa { FONT-WEIGHT: bold; FONT-SIZE: 16px; WIDTH: 100px; LINE-HEIGHT: 100px } .datePa { FONT-SIZE: 14px; WIDTH: 130px; LINE-HEIGHT: 100px } .descPa { OVERFLOW: hidden; WIDTH: 190px; HEIGHT: 110px } .imgPaTitre { WIDTH: 180px; COLOR: white } .prixPaTitre { WIDTH: 100px } .datePaTitre { WIDTH: 130px } .descPaTitre { WIDTH: 180px } #AnnonceView A { FONT-SIZE: 14px; COLOR: #85b040 } #InfoPa { WIDTH: 252px; COLOR: #636466 } .InfoPaLine { HEIGHT: 25px } .GrayBg { BORDER-TOP: #cacacc 1px solid; BORDER-BOTTOM: #cacacc 1px solid; = BACKGROUND-COLOR: #ededef } .paMargin { MARGIN: 5px } #ImagePa IMG { MARGIN-RIGHT: 10px } .dashedBotPa { BORDER-BOTTOM: #79b700 1px dashed } #ContactVendeurBouton { HEIGHT: 31px } #ContactVendeurForm { COLOR: #636466 } .formRepondreLabel { WIDTH: 60px; PADDING-TOP: 4px } .MarginTop { MARGIN-TOP: 5px } #ValPaContact { WIDTH: 490px } .whiteLink { FONT-WEIGHT: bold; COLOR: #fffff4 } .whiteLink:hover { FONT-WEIGHT: bold; COLOR: #ce2329 } .noresult { FONT-WEIGHT: bold; FONT-SIZE: 14px; PADDING-BOTTOM: 100px; PADDING-TOP: = 100px; TEXT-ALIGN: center } .TitreArticleSpace { MARGIN-TOP: -20px; MARGIN-BOTTOM: 20px } .btstyle { BORDER-RIGHT: #ccc 1px solid; PADDING-RIGHT: 1px; BORDER-TOP: #ccc 1px = solid; MARGIN-TOP: 10px; PADDING-LEFT: 1px; PADDING-BOTTOM: 1px; = BORDER-LEFT: #e4e4e4 1px solid; PADDING-TOP: 1px; BORDER-BOTTOM: #e4e4e4 = 1px solid } .WhiteLink { COLOR: white; TEXT-DECORATION: none } .WhiteLink A { COLOR: white; TEXT-DECORATION: none } .WhiteLink:visited { COLOR: white; TEXT-DECORATION: none } .WhiteLink A:visited { COLOR: white; TEXT-DECORATION: none } .WhiteLink:hover { COLOR: white; TEXT-DECORATION: underline } .WhiteLink A:hover { COLOR: white; TEXT-DECORATION: underline } .logoPos { MIN-HEIGHT: 50px } * HTML .logoPos { HEIGHT: 50px } .aboContact { BACKGROUND-POSITION: right 50%; BACKGROUND-IMAGE: = url(../img/abo_contact.jpg); BACKGROUND-REPEAT: no-repeat } .photosContact { BACKGROUND-POSITION: right 50%; BACKGROUND-IMAGE: = url(../img/back_photo.jpg); BACKGROUND-REPEAT: no-repeat } .menuUne { BACKGROUND-IMAGE: url(../img/uneMenuBack.gif); WIDTH: 585px; HEIGHT: = 27px } .pointer { CURSOR: pointer } .subUneWidth { WIDTH: 450px } .TitreArticleSpace H5 { LETTER-SPACING: 0px } .ongletPA { TEXT-ALIGN: left } UL.ongletPA { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: 5px = 0px 0px; PADDING-TOP: 0px; TEXT-ALIGN: left } UL.ongletPA LI { PADDING-RIGHT: 0px; DISPLAY: block; PADDING-LEFT: 0px; BACKGROUND: = url(../img/grisOnglet.gif) 0px 0px; FLOAT: left; PADDING-BOTTOM: 0px; = WIDTH: 168px; MARGIN-RIGHT: 4px; PADDING-TOP: 3px; LIST-STYLE-TYPE: = none; HEIGHT: 18px; TEXT-ALIGN: center } UL.ongletPA LI.active { PADDING-RIGHT: 0px; DISPLAY: block; PADDING-LEFT: 0px; BACKGROUND: = url(../img/greenOnglet.gif) 0px 0px; FLOAT: left; PADDING-BOTTOM: 0px; = WIDTH: 168px; MARGIN-RIGHT: 4px; PADDING-TOP: 3px; LIST-STYLE-TYPE: = none; HEIGHT: 18px } UL.ongletPA LI A { FONT-WEIGHT: bold; FONT-SIZE: 1.2em; COLOR: #fff; TEXT-DECORATION: none } UL.ongletPA LI.active A { COLOR: #fff } UL.ongletPA LI A:hover { COLOR: #000 } .topPA { PADDING-RIGHT: 0px; BACKGROUND-POSITION: right 50%; PADDING-LEFT: 0px; = BACKGROUND-IMAGE: url(../img/fondPA.jpg); PADDING-BOTTOM: 0px; MARGIN: = 0px; PADDING-TOP: 0px; BACKGROUND-REPEAT: no-repeat; HEIGHT: 170px } .topBoutique { PADDING-RIGHT: 0px; BACKGROUND-POSITION: right 50%; PADDING-LEFT: 0px; = BACKGROUND-IMAGE: url(../img/fondBoutique.jpg); PADDING-BOTTOM: 0px; = MARGIN: 0px; PADDING-TOP: 0px; BACKGROUND-REPEAT: no-repeat; HEIGHT: = 170px } .titrePA { FONT-WEIGHT: bold; FONT-SIZE: 25px; COLOR: #85b040 } .topPALeft { FLOAT: left; WIDTH: 330px } #logFrontPA #BoutonLog { BORDER-TOP-WIDTH: 0px; BACKGROUND-POSITION: 50% bottom; = BORDER-LEFT-WIDTH: 0px; BACKGROUND-IMAGE: url(../img/okPA.gif); = BORDER-BOTTOM-WIDTH: 0px; MARGIN-LEFT: 10px; WIDTH: 51px; CURSOR: = pointer; COLOR: white; BACKGROUND-REPEAT: no-repeat; HEIGHT: 40px; = BACKGROUND-COLOR: #ffffff; BORDER-RIGHT-WIDTH: 0px } .sousTitrePA { FONT-WEIGHT: bold; FONT-SIZE: 18px; COLOR: #85b040 } .ssousTitrePA { FONT-SIZE: 12px; COLOR: #7a7a7a } FORM#PAForm { MARGIN-BOTTOM: 20px; MARGIN-LEFT: 100px; WIDTH: 90% } FORM#PAForm P { CLEAR: both; LINE-HEIGHT: 30px } FORM#PAForm INPUT { BORDER-RIGHT: #ccc 1px solid; PADDING-RIGHT: 1px; BORDER-TOP: #ccc 1px = solid; PADDING-LEFT: 1px; FLOAT: left; PADDING-BOTTOM: 1px; BORDER-LEFT: = #e4e4e4 1px solid; PADDING-TOP: 1px; BORDER-BOTTOM: #e4e4e4 1px solid } FORM#PAForm TEXTAREA { BORDER-RIGHT: #ccc 1px solid; PADDING-RIGHT: 1px; BORDER-TOP: #ccc 1px = solid; PADDING-LEFT: 1px; FLOAT: left; PADDING-BOTTOM: 1px; BORDER-LEFT: = #e4e4e4 1px solid; PADDING-TOP: 1px; BORDER-BOTTOM: #e4e4e4 1px solid } FORM#PAForm SELECT { BORDER-RIGHT: #ccc 1px solid; PADDING-RIGHT: 1px; BORDER-TOP: #ccc 1px = solid; PADDING-LEFT: 1px; FLOAT: left; PADDING-BOTTOM: 1px; BORDER-LEFT: = #e4e4e4 1px solid; PADDING-TOP: 1px; BORDER-BOTTOM: #e4e4e4 1px solid } FORM#PAForm SPAN { FLOAT: left } FORM#PAForm LABEL { FLOAT: left; WIDTH: 150px; PADDING-TOP: 3px; TEXT-ALIGN: left } FORM#PAForm LABEL { FLOAT: left; WIDTH: 150px; PADDING-TOP: 3px; TEXT-ALIGN: left } FORM#PAForm .legend { BORDER-RIGHT: #69b2d3 1px solid; BORDER-TOP: #69b2d3 1px solid; = MARGIN-TOP: 2px; PADDING-LEFT: 18px; FONT-SIZE: 10px; BACKGROUND: = #fdf493 no-repeat; FLOAT: left; PADDING-BOTTOM: 2px; MARGIN-LEFT: 10px; = BORDER-LEFT: #69b2d3 1px solid; WIDTH: 200px; COLOR: #333; PADDING-TOP: = 2px; BORDER-BOTTOM: #69b2d3 1px solid } FORM#PAForm .content { FLOAT: left; WIDTH: 300px; PADDING-TOP: 10px; TEXT-ALIGN: left } .boutiqueTitre { BORDER-RIGHT: gray 1px dashed; PADDING-RIGHT: 10px; PADDING-LEFT: 10px; = FONT-WEIGHT: bold; FONT-SIZE: 16px; FLOAT: left; WIDTH: 178px } .boutiqueTitreLast { PADDING-RIGHT: 10px; PADDING-LEFT: 10px; FONT-WEIGHT: bold; FONT-SIZE: = 16px; FLOAT: left; WIDTH: 178px } .boutiqueTitre A { FONT-WEIGHT: bold; FONT-SIZE: 18px; COLOR: #014a7f } .boutiqueTitre A:hover { FONT-WEIGHT: bold; FONT-SIZE: 18px; COLOR: #014a7f } .boutiqueTitreLast A { FONT-WEIGHT: bold; FONT-SIZE: 18px; COLOR: #014a7f } .boutiqueTitreLast A:hover { FONT-WEIGHT: bold; FONT-SIZE: 18px; COLOR: #014a7f } .boutiqueSsTitre { FONT-SIZE: 14px } .boutiqueSsTitre A { FONT-WEIGHT: bold; FONT-SIZE: 14px; COLOR: #77787a } .boutiqueSsTitre A:hover { FONT-WEIGHT: bold; FONT-SIZE: 14px; COLOR: #77787a } .btPrice { MARGIN-TOP: -5px; FONT-SIZE: 24px; COLOR: #014a7f; MARGIN-RIGHT: 10px } .btPanierTitre { FONT-WEIGHT: bold; FONT-SIZE: 16px; COLOR: #014a7f } .panierLine { BORDER-BOTTOM: gray 1px dashed } .datePaW { FONT-WEIGHT: bold; FLOAT: left; WIDTH: 80px } .descPaW { FLOAT: left; WIDTH: 200px } .greyText { COLOR: #666666 } .uneDyna A { COLOR: #666; TEXT-DECORATION: none } .uneDyna blueTitle A { COLOR: #666; TEXT-DECORATION: none } .uneDyna A:hover { COLOR: #000; TEXT-DECORATION: none } .uneDyna blueTitle A:hover { COLOR: #000; TEXT-DECORATION: none } .uneDyna .simpleList LI { BACKGROUND-IMAGE: url(../img/flechesNoires.gif) } ------=_NextPart_000_0046_01C968FA.15503320 Content-Type: application/octet-stream Content-Transfer-Encoding: quoted-printable Content-Location: http://www.lasemainedespyrenees.fr/js/aculous/prototype.js /* Prototype JavaScript framework, version 1.6.0=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',=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: ']*>([\\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= if (Prototype.Browser.WebKit)=0A= Prototype.BrowserFeatures.XPath =3D false;=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 =3D=3D=3D undefined) 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 (value !=3D=3D undefined)=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 && arguments[0] =3D=3D=3D undefined) 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 count =3D=3D=3D undefined ? 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 truncation =3D=3D=3D undefined ? '...' : 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.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,'&').replace(//g,'>');=0A= },=0A= unescapeHTML: function() {=0A= return = this.replace(/&/g,'&').replace(/</g,'<').replace(/>/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 /^([^.[]+|\[((?:.*?[^\\])?)\])(\.|\[|$)/, 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 fillWith =3D=3D=3D undefined ? 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 undefined || 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 undefined || 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 '#';=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 (value !=3D=3D undefined) 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= if (function() {=0A= var i =3D 0, Test =3D function(value) { this.key =3D value };=0A= Test.prototype.key =3D 'foo';=0A= for (var property in new Test('bar')) i++;=0A= return i > 1;=0A= }()) {=0A= function each(iterator) {=0A= var cache =3D [];=0A= for (var key in this._object) {=0A= var value =3D this._object[key];=0A= if (cache.include(key)) continue;=0A= cache.push(key);=0A= var pair =3D [key, value];=0A= pair.key =3D key;=0A= pair.value =3D value;=0A= iterator(pair);=0A= }=0A= }=0A= } else {=0A= function each(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= =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: each,=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 '#';=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= if (Object.isString(this.options.parameters))=0A= this.options.parameters =3D = this.options.parameters.toQueryParams();=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 xml =3D=3D=3D undefined ? 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= return null;=0A= try {=0A= return this.transport.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 options || { };=0A= var onComplete =3D options.onComplete;=0A= options.onComplete =3D (function(response, param) {=0A= this.updateContent(response.responseText);=0A= if (Object.isFunction(onComplete)) onComplete(response, param);=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= if (this.success()) {=0A= if (this.onComplete) this.onComplete.bind(this).defer();=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 $A($(element).getElementsByTagName('*')).each(Element.extend);=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 value =3D=3D=3D undefined ? true : value;=0A= =0A= for (var attr in attributes) {=0A= var name =3D t.names[attr] || attr, 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= =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 ancestor) 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= (elementStyle.styleFloat =3D=3D=3D undefined ? '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;=0A= Element.Methods.getStyle =3D function(element, style) {=0A= switch(style) {=0A= case 'left':=0A= case 'top':=0A= case 'right':=0A= case 'bottom':=0A= if (Element._getStyle(element, 'position') =3D=3D 'static') = return null;=0A= default: return Element._getStyle(element, style);=0A= }=0A= };=0A= Element.Methods._readAttribute =3D Element.Methods.readAttribute;=0A= Element.Methods.readAttribute =3D function(element, attribute) {=0A= if (attribute =3D=3D 'title') return element.title;=0A= return Element._readAttribute(element, attribute);=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= var 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 = Position.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: ['', '
', 1],=0A= TBODY: ['', '
', 2],=0A= TR: ['', '
', 3],=0A= TD: ['
', '
', 4],=0A= 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= $w('width height').each(function(d) {=0A= var D =3D d.capitalize();=0A= dimensions[d] =3D self['inner' + D] ||=0A= (document.documentElement['client' + D] || document.body['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= compileMatcher: function() {=0A= // Selectors with namespaced attributes can't use the XPath version=0A= if (Prototype.BrowserFeatures.XPath && = !(/(\[[\w-]*?:|:checked)/).test(this.expression))=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 "#";=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: "[@#{1}]",=0A= attr: function(m) {=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, m, 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, children =3D [], 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(','), 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= 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 (options.hash =3D=3D=3D undefined) 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 (value =3D=3D=3D undefined) return element.checked ? = element.value : null;=0A= else element.checked =3D !!value;=0A= },=0A= =0A= textarea: function(element, value) {=0A= if (value =3D=3D=3D undefined) return element.value;=0A= else element.value =3D value;=0A= },=0A= =0A= select: function(element, index) {=0A= if (index =3D=3D=3D undefined)=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= return element.match(expression) ? element : = element.up(expression);=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;=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("