From: Subject: =?Windows-1252?Q?Le_petit_esquelbecquois_N=B026_mars_2008_-_Calam=E9o_-_P?= =?Windows-1252?Q?ubliez_vos_documents_!?= Date: Mon, 28 Apr 2008 15:39:49 +0200 MIME-Version: 1.0 Content-Type: multipart/related; type="text/html"; boundary="----=_NextPart_000_0000_01C8A946.17CACA30" X-MimeOLE: Produced By Microsoft MimeOLE V6.00.2900.3198 This is a multi-part message in MIME format. ------=_NextPart_000_0000_01C8A946.17CACA30 Content-Type: text/html; charset="utf-8" Content-Transfer-Encoding: quoted-printable Content-Location: http://fr.calameo.com/read/000001428966d4203ed44?editLinks=1 =EF=BB=BF Le petit = esquelbecquois N=C2=B026 mars 2008 - Calam=C3=A9o - Publiez vos = documents !
------=_NextPart_000_0000_01C8A946.17CACA30 Content-Type: application/octet-stream Content-Transfer-Encoding: quoted-printable Content-Location: http://fr.calameo.com/skins/calameo-v1/css/common.css?v2.1.1 BODY { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; BACKGROUND: white; = PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-TOP: 0px } BODY#Background { BACKGROUND: url(../images/bg_body.png) white repeat-x } BODY { FONT-SIZE: 12px; FONT-FAMILY: Arial, Helvetica, sans-serif } TD { FONT-SIZE: 12px; FONT-FAMILY: Arial, Helvetica, sans-serif } IMG { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: = 0px; VERTICAL-ALIGN: middle; BORDER-TOP-STYLE: none; PADDING-TOP: 0px; = BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: = none } A { COLOR: #1959cf } A:hover { COLOR: white; BACKGROUND-COLOR: #1959cf; TEXT-DECORATION: none } A.NoBg:hover { BACKGROUND: none transparent scroll repeat 0% 0%; COLOR: #1959cf } A.NoUnderline { BACKGROUND-POSITION: left bottom; BACKGROUND-IMAGE: = url(../images/dotted_underline.png); BACKGROUND-REPEAT: repeat-x; = TEXT-DECORATION: none } A.NoUnderline:hover { BACKGROUND-IMAGE: none } H1 { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-WEIGHT: bold; FONT-SIZE: = 24px; PADDING-BOTTOM: 0px; MARGIN: 0px 0px 12px; COLOR: #555555; = LINE-HEIGHT: 26px; PADDING-TOP: 0px; LETTER-SPACING: -1px } H1 A { COLOR: black; MARGIN-RIGHT: 4px; WHITE-SPACE: nowrap; TEXT-DECORATION: = none } H1.Shrinked { MARGIN-BOTTOM: 4px } H2 { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-WEIGHT: bold; FONT-SIZE: = 17px; BACKGROUND-IMAGE: none; PADDING-BOTTOM: 8px; MARGIN: 0px; COLOR: = #7cd300; PADDING-TOP: 16px; LETTER-SPACING: -1px } H2.Icon { PADDING-LEFT: 19px; BACKGROUND: url(../images/h3.png) no-repeat left = 20px; COLOR: #8297b4 } H3 { COLOR: #1959cf } .Hide { DISPLAY: none } .Clear { CLEAR: both } .Separator { CLEAR: both; DISPLAY: block; BACKGROUND: url(../images/dotted.png) = repeat-x; OVERFLOW: hidden; HEIGHT: 1px } .Spacer { PADDING-RIGHT: 5px; DISPLAY: inline; PADDING-LEFT: 5px; BACKGROUND: = url(../images/dotted.png) repeat-y center top; PADDING-BOTTOM: 0px; = PADDING-TOP: 0px } .Column { FLOAT: left; OVERFLOW: hidden } .IconPad { MARGIN-LEFT: 20px } .Paragraph { MARGIN-TOP: 12px } .ListItem { PADDING-RIGHT: 8px; PADDING-LEFT: 8px; PADDING-BOTTOM: 8px; = PADDING-TOP: 8px } .ListItem:hover { BACKGROUND: url(../images/bg_rollover.png) #f7fafe repeat-x left top } .New { PADDING-RIGHT: 30px; BACKGROUND-POSITION: right top; BACKGROUND-IMAGE: = url(../images/icons/new.png); BACKGROUND-REPEAT: no-repeat } .CodeVar { FONT-SIZE: 12px; FONT-FAMILY: "Courier New", Courier, monospace } .Bold { FONT-WEIGHT: bold } .HelpItem { PADDING-LEFT: 12px; BACKGROUND: url(../images/help_dot.png) no-repeat = left top; PADDING-BOTTOM: 5px } .ContextualHelp { =09 } .ContextualHelp A { TEXT-DECORATION: none } .ContextualHelp A SPAN { PADDING-RIGHT: 2px; PADDING-LEFT: 19px; BACKGROUND: = url(../images/icons/help.png) no-repeat left center; PADDING-BOTTOM: = 3px; PADDING-TOP: 3px } #Top { MARGIN: 0px } #Top .Content { MARGIN: 0px auto; WIDTH: 860px } #Top .Content #LogoContainer { FLOAT: left; WIDTH: 200px } #Top .Content #TopContainer { FLOAT: left; MARGIN-BOTTOM: 20px; WIDTH: 660px; TEXT-ALIGN: right } #TopLogo { MARGIN-TOP: 4px; MARGIN-BOTTOM: 8px } #Menu { MARGIN-BOTTOM: 8px } #Menu .Container { MARGIN: 6px auto 0px; WIDTH: 870px; HEIGHT: 28px } #Menu .Container #MainMenu { FLOAT: left; WIDTH: 600px; HEIGHT: 28px } #Menu .Container #MenuSearch { FLOAT: left; WIDTH: 270px; HEIGHT: 28px } #MenuSearch INPUT#MenuSearchField { PADDING-LEFT: 17px; BACKGROUND: url(../images/bg_search.png) white = no-repeat 3px center } #Focus { =09 } #Focus .Content { MARGIN: 0px auto; WIDTH: 860px } #Stats { =09 } #Stats .Content { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 10px; MARGIN: = 0px auto; WIDTH: 860px; PADDING-TOP: 10px } #Stats .Content STRONG { COLOR: #1959cf } #Stats .Content B { COLOR: #1959cf } #Stats .Content A:hover STRONG { COLOR: white } #Breadcrumbs { FONT-SIZE: 11px; MARGIN: 0px 0px 12px; COLOR: #d9d9d9 } #Page { BACKGROUND: url(../images/bg_page.png) repeat-x center -16px; = PADDING-TOP: 7px } #HomePage { BACKGROUND: url(../images/bg_page.png) repeat-x center 0px; = PADDING-TOP: 7px } #Main { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 30px; = PADDING-TOP: 8px } #Main .Content { Z-INDEX: -1; MIN-HEIGHT: 300px; MARGIN: 0px auto; WIDTH: 860px; HEIGHT: = 300px } #LeftCol { FLOAT: left; OVERFLOW: hidden; WIDTH: 300px; MARGIN-RIGHT: 20px } #RightCol { FLOAT: left; OVERFLOW: hidden; WIDTH: 540px } #SmallCol { FLOAT: left; OVERFLOW: hidden; WIDTH: 200px; MARGIN-RIGHT: 30px } #BigCol { FLOAT: left; OVERFLOW: hidden; WIDTH: 630px } #Footer { BACKGROUND: white } #Footer .Content { FONT-SIZE: 11px; PADDING-BOTTOM: 16px; MARGIN: 0px auto; WIDTH: 860px; = COLOR: #73818b; PADDING-TOP: 10px } #Footer A { BACKGROUND: none transparent scroll repeat 0% 0%; COLOR: #73818b } #Footer A:hover { BACKGROUND: none transparent scroll repeat 0% 0%; COLOR: #73818b } #Footer .Content .Languages A { TEXT-DECORATION: none } #Footer .Content .Languages A:hover { COLOR: #1959cf; BACKGROUND-COLOR: #f4f5f7; TEXT-DECORATION: underline } #Footer .Content .Languages IMG.Active { BORDER-RIGHT: #dadbdc 2px solid; PADDING-RIGHT: 2px; BORDER-TOP: = #dadbdc 2px solid; PADDING-LEFT: 2px; PADDING-BOTTOM: 2px; BORDER-LEFT: = #dadbdc 2px solid; PADDING-TOP: 2px; BORDER-BOTTOM: #dadbdc 2px solid } .AccountThumbnail { BORDER-RIGHT: #969696 1px solid; BORDER-TOP: #d9d9d9 1px solid; = BORDER-LEFT: #d9d9d9 1px solid; BORDER-BOTTOM: #969696 1px solid } .AccountPicture { =09 } .AccountModePREMIUM { PADDING-RIGHT: 12px; BACKGROUND: = url(../images/icons/account_premium.png) no-repeat right top } .AccountModeFREE { =09 } .Thumbnail { CLEAR: both; BORDER-RIGHT: #969696 1px solid; PADDING-RIGHT: 0px; = BORDER-TOP: #d9d9d9 1px solid; PADDING-LEFT: 1px; BACKGROUND: white; = PADDING-BOTTOM: 0px; OVERFLOW: hidden; BORDER-LEFT: #d9d9d9 1px solid; = WIDTH: 100px; PADDING-TOP: 1px; BORDER-BOTTOM: #969696 1px solid; = POSITION: relative; HEIGHT: 100px } .Thumbnail A.Picture { LEFT: 1px; OVERFLOW: hidden; WIDTH: 100px; POSITION: absolute; TOP: = 1px; HEIGHT: 100px } .Thumbnail A.Picture:hover { BACKGROUND: none transparent scroll repeat 0% 0% } .Thumbnail A.Read { LEFT: 71px; WIDTH: 30px; POSITION: absolute; TOP: 71px; HEIGHT: 30px } .Thumbnail A.Read:hover { BACKGROUND-COLOR: transparent } .BookThumbnail { BORDER-RIGHT: #969696 1px solid; BORDER-TOP: #d9d9d9 1px solid; = BORDER-LEFT: #d9d9d9 1px solid; BORDER-BOTTOM: #969696 1px solid } #CommentsList { =09 } #CommentsLoading { =09 } .Comment { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 8px; = PADDING-TOP: 8px } .Comment .WithBubble { HEIGHT: 68px } .Comment .Avatar { FLOAT: left } .Comment .AuthorFocus { =09 } .Comment .Author { =09 } .Comment .Title { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; MARGIN-BOTTOM: 4px; = PADDING-BOTTOM: 4px; PADDING-TOP: 0px } .Comment .Actions { FLOAT: right; MARGIN: 0px } .Comment .Actions A { MARGIN-LEFT: 8px } .Comment .Text { PADDING-RIGHT: 0px; PADDING-LEFT: 40px; PADDING-BOTTOM: 5px; = PADDING-TOP: 2px } .Comment .Text A.Internal { PADDING-RIGHT: 14px; BACKGROUND-POSITION: right center; = BACKGROUND-IMAGE: url(../images/icons/comment_internal_link.png); = BACKGROUND-REPEAT: no-repeat } .Comment .QuotationMark { MARGIN-TOP: -9px; FONT-SIZE: 38px; FLOAT: left; COLOR: #7cd300; = MARGIN-RIGHT: 4px; FONT-FAMILY: Georgia; POSITION: static; HEIGHT: 12px } .TagList { PADDING-LEFT: 21px; BACKGROUND: url(../images/icons/tag.png) no-repeat } .AwardList { PADDING-LEFT: 21px; BACKGROUND: url(../images/icons/award.png) = no-repeat } .Award { PADDING-LEFT: 21px; BACKGROUND: url(../images/icons/award.png) = no-repeat } .Actions { MARGIN-TOP: 18px } UL.Actions LI { MARGIN-BOTTOM: 4px } .BigAction { PADDING-LEFT: 22px; FONT-WEIGHT: bold; FONT-SIZE: 15px; MARGIN-RIGHT: = 20px; LETTER-SPACING: -1px } .BigAction:hover { =09 } .Action { PADDING-LEFT: 22px } #ReadBook { BACKGROUND-POSITION: 0px center; BACKGROUND-IMAGE: = url(../images/icons/read_off.png); BACKGROUND-REPEAT: no-repeat } #DownloadBook { BACKGROUND-POSITION: 0px center; BACKGROUND-IMAGE: = url(../images/icons/download_off.png); BACKGROUND-REPEAT: no-repeat } #AddToFavorites { BACKGROUND-POSITION: 0px center; BACKGROUND-IMAGE: = url(../images/icons/favorite_off.png); BACKGROUND-REPEAT: no-repeat } #RemoveFromFavorites { BACKGROUND-POSITION: 0px center; BACKGROUND-IMAGE: = url(../images/icons/favorite_on.png); BACKGROUND-REPEAT: no-repeat } #AddToContacts { BACKGROUND-POSITION: 0px center; BACKGROUND-IMAGE: = url(../images/icons/contact_add.png); BACKGROUND-REPEAT: no-repeat } #RemoveFromContacts { BACKGROUND-POSITION: 0px center; BACKGROUND-IMAGE: = url(../images/icons/contact_remove.png); BACKGROUND-REPEAT: no-repeat } #ShareWithFriends { BACKGROUND-POSITION: 0px center; BACKGROUND-IMAGE: = url(../images/icons/share_friends_on.png); BACKGROUND-REPEAT: no-repeat } #ReportAbuse { BACKGROUND-POSITION: 0px center; BACKGROUND-IMAGE: = url(../images/icons/report_abuse_on.png); BACKGROUND-REPEAT: no-repeat } #AddComment { BACKGROUND-POSITION: 0px center; BACKGROUND-IMAGE: = url(../images/icons/add_comment_on.png); BACKGROUND-REPEAT: no-repeat } #EditBook { BACKGROUND-POSITION: 0px center; BACKGROUND-IMAGE: = url(../images/icons/edit_off.png); BACKGROUND-REPEAT: no-repeat } #EmbedHTML { BACKGROUND-POSITION: 0px center; BACKGROUND-IMAGE: = url(../images/icons/embed_html.png); BACKGROUND-REPEAT: no-repeat } #WebsiteLink { BACKGROUND-POSITION: 0px center; BACKGROUND-IMAGE: = url(../images/icons/world.png); BACKGROUND-REPEAT: no-repeat } #ActivateBook { BACKGROUND-POSITION: 0px center; BACKGROUND-IMAGE: = url(../images/icons/thumb_up.png); BACKGROUND-REPEAT: no-repeat } #OverviewBook { BACKGROUND-POSITION: 0px center; BACKGROUND-IMAGE: = url(../images/icons/book_overview.png); BACKGROUND-REPEAT: no-repeat } #LightBulb { BACKGROUND-POSITION: 0px center; BACKGROUND-IMAGE: = url(../images/icons/lightbulb.png); BACKGROUND-REPEAT: no-repeat } .AjaxProcessing { BACKGROUND: url(../images/icons/processing.gif) no-repeat 0px center; = COLOR: #9a9b9d; TEXT-DECORATION: none } .AjaxProcessing:hover { COLOR: #babbbc; TEXT-DECORATION: none } .Comments { BACKGROUND-POSITION: left center; PADDING-LEFT: 22px; BACKGROUND-IMAGE: = url(../images/icons/comments.png); BACKGROUND-REPEAT: no-repeat } .PostComment { BACKGROUND-POSITION: left center; PADDING-LEFT: 22px; BACKGROUND-IMAGE: = url(../images/icons/add_comment_on.png); BACKGROUND-REPEAT: no-repeat } .Related { BACKGROUND-POSITION: left center; PADDING-LEFT: 22px; BACKGROUND-IMAGE: = url(../images/icons/lightbulb.png); BACKGROUND-REPEAT: no-repeat } .ReviseDocument { BACKGROUND-POSITION: left center; PADDING-LEFT: 22px; BACKGROUND-IMAGE: = url(../images/icons/revise_document.png); BACKGROUND-REPEAT: no-repeat } .PrivateUrl { BACKGROUND-POSITION: left center; PADDING-LEFT: 22px; BACKGROUND-IMAGE: = url(../images/icons/private_url.png); BACKGROUND-REPEAT: no-repeat } .VCard { BACKGROUND-POSITION: left center; PADDING-LEFT: 22px; BACKGROUND-IMAGE: = url(../images/icons/vcard.png); BACKGROUND-REPEAT: no-repeat } DIV.BrowsingPanel { PADDING-BOTTOM: 8px } #ListSorting { =09 } #ListSorting { FONT-SIZE: 11px } #ListSorting SELECT { FONT-SIZE: 11px } #ListSorting BUTTON { FONT-SIZE: 11px } #ListSorting LABEL { DISPLAY: inline; MARGIN-RIGHT: 3px } .RSSFeedLink { PADDING-LEFT: 20px; FONT-SIZE: 11px; BACKGROUND: = url(../images/icons/rss_feed.png) no-repeat 1px 1px; COLOR: black; = TEXT-DECORATION: none } .RSSFeedLink:hover { BACKGROUND-POSITION: 1px 1px; BACKGROUND-IMAGE: = url(../images/icons/rss_feed.png); BACKGROUND-REPEAT: no-repeat } .ShareContacts { BORDER-RIGHT: #7f9db9 1px solid; PADDING-RIGHT: 0px; BORDER-TOP: = #7f9db9 1px solid; PADDING-LEFT: 4px; BACKGROUND: white; PADDING-BOTTOM: = 0px; MARGIN: 4px 0px 0px; OVERFLOW: auto; BORDER-LEFT: #7f9db9 1px = solid; PADDING-TOP: 4px; BORDER-BOTTOM: #7f9db9 1px solid } .ShareContacts A { PADDING-RIGHT: 4px; DISPLAY: block; PADDING-LEFT: 4px; FONT-SIZE: 11px; = BACKGROUND: #f2f3f4; PADDING-BOTTOM: 4px; MARGIN: 0px 4px 4px 0px; = WIDTH: 190px; COLOR: black; LINE-HEIGHT: 12px; PADDING-TOP: 4px; HEIGHT: = 22px; TEXT-DECORATION: none } .ShareContacts A:hover { BORDER-TOP-WIDTH: 0px; PADDING-RIGHT: 4px; PADDING-LEFT: 4px; = BORDER-LEFT-WIDTH: 0px; BACKGROUND: #1959cf; BORDER-BOTTOM-WIDTH: 0px; = PADDING-BOTTOM: 4px; WIDTH: 190px; COLOR: white; PADDING-TOP: 4px; = BORDER-RIGHT-WIDTH: 0px } .ShareContacts A.SelectedContact { BORDER-TOP-WIDTH: 0px; PADDING-RIGHT: 4px; PADDING-LEFT: 4px; = BORDER-LEFT-WIDTH: 0px; BACKGROUND: #7cd300; FLOAT: none; = BORDER-BOTTOM-WIDTH: 0px; PADDING-BOTTOM: 4px; MARGIN: 0px 4px 4px 0px; = WIDTH: 190px; COLOR: white; PADDING-TOP: 4px; HEIGHT: 22px; = BORDER-RIGHT-WIDTH: 0px } .ShareContacts A IMG { BORDER-RIGHT: white 1px solid; BORDER-TOP: white 1px solid; FLOAT: = left; BORDER-LEFT: white 1px solid; WIDTH: 20px; MARGIN-RIGHT: 4px; = BORDER-BOTTOM: white 1px solid; HEIGHT: 20px } #ProgressText { PADDING-RIGHT: 0px; PADDING-LEFT: 24px; BACKGROUND: = url(../images/icons/processing.gif) no-repeat left center; = PADDING-BOTTOM: 0px; PADDING-TOP: 8px } .ProgressBar { BACKGROUND: url(../images/progressbar_container.png) no-repeat left = center; MARGIN: 12px 0px 16px; HEIGHT: 24px } .ProgressBar .Container { PADDING-RIGHT: 4px; PADDING-LEFT: 0px; BACKGROUND: = url(../images/progressbar_container.png) no-repeat right center; = PADDING-BOTTOM: 4px; MARGIN-LEFT: 4px; PADDING-TOP: 4px } .ProgressBar .Bar { BACKGROUND: url(../images/progressbar.png) repeat-x; WIDTH: 1px; = HEIGHT: 16px } .TinyProgressBar { BACKGROUND: url(../images/tinyprogressbar_container.png) no-repeat left = center; MARGIN: 2px 0px 4px; HEIGHT: 12px } .TinyProgressBar .Container { PADDING-RIGHT: 3px; PADDING-LEFT: 0px; BACKGROUND: = url(../images/tinyprogressbar_container.png) no-repeat right center; = PADDING-BOTTOM: 3px; MARGIN-LEFT: 3px; PADDING-TOP: 3px } .TinyProgressBar .Bar { BACKGROUND: url(../images/tinyprogressbar.png) repeat-x; WIDTH: 1px; = HEIGHT: 6px } .Pagination { CLEAR: both; FONT-SIZE: 11px; MARGIN: 20px 0px 16px } .Pagination .Infos { MARGIN-TOP: 6px; COLOR: #babbbc; TEXT-ALIGN: center } .Pagination .Pages { FLOAT: left; WIDTH: 40%; TEXT-ALIGN: center } .Pagination A.Current { BORDER-RIGHT: #dadbdc 1px solid; PADDING-RIGHT: 6px; BORDER-TOP: = #dadbdc 1px solid; PADDING-LEFT: 6px; FONT-WEIGHT: bold; BACKGROUND: = #f2f3f4; PADDING-BOTTOM: 2px; MARGIN: 0px; BORDER-LEFT: #dadbdc 1px = solid; LINE-HEIGHT: 20px; PADDING-TOP: 2px; BORDER-BOTTOM: #dadbdc 1px = solid; TEXT-DECORATION: none } .Pagination A.Current:hover { COLOR: #1959cf } .Pagination A.Page { PADDING-RIGHT: 6px; PADDING-LEFT: 6px; PADDING-BOTTOM: 2px; MARGIN: = 0px; CURSOR: pointer; COLOR: #1959cf; LINE-HEIGHT: 20px; PADDING-TOP: = 2px; TEXT-DECORATION: none } .Pagination A.Page:hover { COLOR: white } .Pagination .Next { FLOAT: left; MARGIN: 0px; WIDTH: 30% } .Pagination .Previous { FLOAT: left; MARGIN: 0px; WIDTH: 30% } .Pagination .Next { TEXT-ALIGN: right } .Pagination .Next A { PADDING-RIGHT: 2px; PADDING-LEFT: 2px; PADDING-BOTTOM: 2px; = PADDING-TOP: 2px; TEXT-DECORATION: none } .Pagination .Previous A { PADDING-RIGHT: 2px; PADDING-LEFT: 2px; PADDING-BOTTOM: 2px; = PADDING-TOP: 2px; TEXT-DECORATION: none } .Pagination .Next A:hover { COLOR: #146fe6; BACKGROUND-COLOR: white } .Pagination .Previous A:hover { COLOR: #146fe6; BACKGROUND-COLOR: white } .Tabs { CLEAR: both; MARGIN: 12px 0px 0px; BORDER-BOTTOM: #bacee2 1px solid; = HEIGHT: 28px } .Tabs .Tab { FLOAT: left; MARGIN-BOTTOM: -2px; MARGIN-LEFT: 4px; POSITION: relative } .Tabs .Tab A { PADDING-RIGHT: 12px; MARGIN-TOP: 5px; DISPLAY: block; PADDING-LEFT: = 12px; BACKGROUND: url(../images/bg_menu_item.png) no-repeat left top; = PADDING-BOTTOM: 4px; COLOR: white; PADDING-TOP: 4px; TEXT-DECORATION: = none } .Tabs .Active A { BORDER-RIGHT: #bacee2 1px solid; BORDER-TOP: #bacee2 1px solid; = MARGIN-TOP: 0px; FONT-WEIGHT: bold; FONT-SIZE: 15px; BACKGROUND: white; = BORDER-LEFT: #bacee2 1px solid; COLOR: #7cd300; LINE-HEIGHT: 20px; = BORDER-BOTTOM: white 1px solid; LETTER-SPACING: 0px; TEXT-DECORATION: = none } .Tabs .Tab A:hover { COLOR: white; TEXT-DECORATION: underline } .Tabs .Active A:hover { COLOR: #7cd300; TEXT-DECORATION: underline } .TabPanel { CLEAR: both; BORDER-RIGHT: #bacee2 1px solid; PADDING-RIGHT: 20px; = PADDING-LEFT: 20px; BACKGROUND: url(../images/bg_focus.png) #f6f8fe = repeat-x 50% top; PADDING-BOTTOM: 10px; BORDER-LEFT: #bacee2 1px solid; = PADDING-TOP: 10px; BORDER-BOTTOM: #bacee2 1px solid } .SlidePanel { =09 } .SlidePanel .Title { MARGIN-BOTTOM: 12px; POSITION: relative } .SlidePanel .Container { HEIGHT: 100px } .SlidePanel .Mask { OVERFLOW: hidden; WIDTH: 254px; POSITION: absolute; HEIGHT: 100px } .SlidePanel .Mask .Box { OVERFLOW: visible; WIDTH: 99999px; HEIGHT: 100px } .SlidePanel .Mask .Box .Item { FLOAT: left; WIDTH: 260px; HEIGHT: 96px } .SlidePanel .Infos { FONT-SIZE: 11px; FLOAT: left; WIDTH: 40%; COLOR: #8a8b8c; TEXT-ALIGN: = center } .SlidePanel .LeftButton { FLOAT: left; WIDTH: 30%; HEIGHT: 16px } .SlidePanel .LeftButton A { DISPLAY: block; BACKGROUND: url(../images/slider_left.png) no-repeat = left center; HEIGHT: 16px } .SlidePanel .LeftButton A:hover { BACKGROUND-IMAGE: url(../images/slider_left_over.png) } .SlidePanel .RightButton { FLOAT: left; WIDTH: 30%; HEIGHT: 16px; TEXT-ALIGN: right } .SlidePanel .RightButton A { DISPLAY: block; BACKGROUND: url(../images/slider_right.png) no-repeat = right center; HEIGHT: 16px } .SlidePanel .RightButton A:hover { BACKGROUND-IMAGE: url(../images/slider_right_over.png) } .Switch { =09 } .Switch .Title { DISPLAY: block; FONT-WEIGHT: bold; MARGIN: 0px 4px 4px } .Switch A { PADDING-RIGHT: 4px; BACKGROUND-POSITION: left top; DISPLAY: block; = PADDING-LEFT: 4px; BACKGROUND-IMAGE: url(../images/dotted.png); = PADDING-BOTTOM: 3px; PADDING-TOP: 3px; BACKGROUND-REPEAT: repeat-x; = TEXT-DECORATION: none } .Switch A.Active { FONT-WEIGHT: bold; BACKGROUND: #f3f6fe } .Switch A.Active:hover { COLOR: #1959cf } .Contact { BORDER-RIGHT: #f0f4f8 1px solid; BORDER-TOP: #f0f4f8 1px solid; = BACKGROUND: white; FLOAT: left; MARGIN-BOTTOM: 8px; BORDER-LEFT: #f0f4f8 = 1px solid; WIDTH: 404px; CURSOR: pointer; MARGIN-RIGHT: 8px; = BORDER-BOTTOM: #f0f4f8 1px solid; HEIGHT: 70px } .Contact:hover { =09 } .SelectedContact { BORDER-RIGHT: #d0dac0 1px solid; BORDER-TOP: #d0dac0 1px solid; = BACKGROUND: #f0fae0; FLOAT: left; MARGIN-BOTTOM: 8px; BORDER-LEFT: = #d0dac0 1px solid; WIDTH: 404px; CURSOR: pointer; MARGIN-RIGHT: 8px; = BORDER-BOTTOM: #d0dac0 1px solid; HEIGHT: 70px } .SelectedContact:hover { BORDER-RIGHT: #d0dac0 1px solid; BORDER-TOP: #d0dac0 1px solid; = BACKGROUND: #f0fae0; FLOAT: left; MARGIN-BOTTOM: 8px; BORDER-LEFT: = #d0dac0 1px solid; WIDTH: 404px; CURSOR: pointer; MARGIN-RIGHT: 8px; = BORDER-BOTTOM: #d0dac0 1px solid; HEIGHT: 70px } .Contact:hover IMG.AccountThumbnail { BORDER-LEFT-COLOR: white; BORDER-BOTTOM-COLOR: white; BORDER-TOP-COLOR: = white; BORDER-RIGHT-COLOR: white } .SelectedContact IMG.AccountThumbnail { BORDER-LEFT-COLOR: #d0dac0; BORDER-BOTTOM-COLOR: #d0dac0; = BORDER-TOP-COLOR: #d0dac0; BORDER-RIGHT-COLOR: #d0dac0 } .Contact DIV.Infos { PADDING-RIGHT: 8px; PADDING-LEFT: 8px; PADDING-BOTTOM: 0px; = MARGIN-LEFT: 6px; BORDER-LEFT: #d8e2ed 1px solid; PADDING-TOP: 0px } .SelectedContact DIV.Infos { PADDING-RIGHT: 8px; PADDING-LEFT: 8px; PADDING-BOTTOM: 0px; = MARGIN-LEFT: 6px; BORDER-LEFT: #d8e2ed 1px solid; PADDING-TOP: 0px } .CaptchaImg { MARGIN-TOP: 8px } .CaptchaImg IMG { BORDER-RIGHT: #e4e4e4 1px solid; BORDER-TOP: #e4e4e4 1px solid; = BACKGROUND: #f4f4f4; BORDER-LEFT: #e4e4e4 1px solid; BORDER-BOTTOM: = #e4e4e4 1px solid } #ava { BORDER-RIGHT: #d9d9d9 1px solid; BORDER-TOP: #d9d9d9 1px solid; = BORDER-LEFT: #d9d9d9 1px solid; WIDTH: 200px; BORDER-BOTTOM: #d9d9d9 1px = solid } #ava_img { OVERFLOW: hidden; WIDTH: 200px; POSITION: relative; HEIGHT: 200px } #ava_overlay { Z-INDEX: 50; BACKGROUND: url(../images/avatar_overlay.png); LEFT: 0px; = WIDTH: 200px; POSITION: absolute; TOP: 0px; HEIGHT: 200px } #ava_drager { Z-INDEX: 100; WIDTH: 400px; CURSOR: move; COLOR: #fff; POSITION: = absolute; HEIGHT: 400px } #avatar { POSITION: absolute } #ava_slider { BORDER-TOP: #d9d9d9 1px solid; BACKGROUND: = url(../images/slider_back.png); WIDTH: 200px; POSITION: relative; = HEIGHT: 27px } #ava_handle { BACKGROUND: url(../images/handle.png); WIDTH: 19px; CURSOR: pointer; = POSITION: absolute; HEIGHT: 20px } .PageListContainer { BORDER-RIGHT: #d8caa8 1px dotted; PADDING-RIGHT: 35px; BORDER-TOP: = #d8caa8 1px dotted; PADDING-LEFT: 35px; BACKGROUND: #fbf6ea; = PADDING-BOTTOM: 8px; BORDER-LEFT: #d8caa8 1px dotted; WIDTH: 670px; = PADDING-TOP: 8px; BORDER-BOTTOM: #d8caa8 1px dotted } #PageList DIV.OnePage { BORDER-RIGHT: #b3c1cb 2px solid; BORDER-TOP: #b3c1cb 2px solid; = BACKGROUND: white; FLOAT: left; MARGIN: 8px 0px; BORDER-LEFT: #b3c1cb = 2px solid; CURSOR: pointer; BORDER-BOTTOM: #b3c1cb 2px solid } #PageList DIV IMG.PageThumbnail { MARGIN-TOP: -17px; DISPLAY: block; Z-INDEX: -1 } #PageList DIV.First { MARGIN: 8px } #PageList DIV.Last { MARGIN: 8px } #PageList DIV.Left { BORDER-RIGHT: #e0e6eb 1px dotted; MARGIN-LEFT: 8px } #PageList DIV.Right { MARGIN-LEFT: -1px; BORDER-LEFT: #e0e6eb 1px dotted; MARGIN-RIGHT: 8px } #PageList DIV SPAN.PageListIndex { PADDING-RIGHT: 4px; DISPLAY: block; PADDING-LEFT: 4px; FONT-SIZE: 9px; = Z-INDEX: 10; BACKGROUND: url(../images/bg_pagelistindex.png) no-repeat = -14px -20px; PADDING-BOTTOM: 3px; WIDTH: 92px; COLOR: white; = PADDING-TOP: 2px; FONT-FAMILY: Tahoma, Verdana, Arial, Helvetica, = sans-serif; POSITION: relative; HEIGHT: 12px } #PageList DIV.Left SPAN.PageListIndex { =09 } #PageList DIV.Right SPAN.PageListIndex { BACKGROUND-POSITION: 78px -20px; TEXT-ALIGN: right } #PageList DIV.First SPAN.PageListIndex { BACKGROUND-POSITION: 78px -20px; TEXT-ALIGN: right } .Toc { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: = 0px; PADDING-TOP: 0px; LIST-STYLE-TYPE: none } .Toc LI { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; Z-INDEX: 10; BACKGROUND: = url(../images/dotted.png) white repeat-x left bottom; PADDING-BOTTOM: = 2px; CURSOR: move; PADDING-TOP: 2px; POSITION: relative } .Toc LI INPUT { BORDER-TOP-WIDTH: 0px; PADDING-RIGHT: 3px; PADDING-LEFT: 3px; = BORDER-LEFT-WIDTH: 0px; BACKGROUND: #f8f9fa; BORDER-BOTTOM-WIDTH: 0px; = PADDING-BOTTOM: 3px; PADDING-TOP: 3px; BORDER-RIGHT-WIDTH: 0px } .Toc .Level1 { MARGIN-LEFT: 0px } .Toc .Level2 { MARGIN-LEFT: 20px } .Toc .Level3 { MARGIN-LEFT: 40px } .Toc .Level4 { MARGIN-LEFT: 60px } .Toc .Level5 { MARGIN-LEFT: 80px } .Toc .Level6 { MARGIN-LEFT: 100px } .Calendar { MARGIN: 10px auto; WIDTH: 690px } .Calendar .DayName { BORDER-RIGHT: white 1px solid; BORDER-TOP: white 1px solid; = FONT-WEIGHT: bold; FONT-SIZE: 14px; FLOAT: left; MARGIN: 0px 6px 8px = 0px; BORDER-LEFT: white 1px solid; WIDTH: 90px; COLOR: #2a2b2c; = BORDER-BOTTOM: white 1px solid; TEXT-ALIGN: center } .Calendar .Day { BORDER-RIGHT: #aaabac 1px solid; BORDER-TOP: #aaabac 1px solid; FLOAT: = left; MARGIN: 0px 6px 8px 0px; BORDER-LEFT: #aaabac 1px solid; WIDTH: = 90px; BORDER-BOTTOM: #aaabac 1px solid; HEIGHT: 80px } .Calendar .EmptyDay { BORDER-RIGHT: #eaebec 1px solid; BORDER-TOP: #eaebec 1px solid; FLOAT: = left; MARGIN: 0px 6px 8px 0px; BORDER-LEFT: #eaebec 1px solid; WIDTH: = 90px; BORDER-BOTTOM: #eaebec 1px solid; HEIGHT: 80px } .Calendar .BlankDay { BORDER-RIGHT: white 1px solid; BORDER-TOP: white 1px solid; FLOAT: = left; MARGIN: 0px 6px 8px 0px; BORDER-LEFT: white 1px solid; WIDTH: = 90px; BORDER-BOTTOM: white 1px solid; HEIGHT: 80px } .Calendar .Day .DayThumb { OVERFLOW: hidden; WIDTH: 90px; HEIGHT: 80px } .Calendar .Day .DayThumb IMG { WIDTH: 90px } .Calendar .Day .Number { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-SIZE: 11px; BACKGROUND: = #2a2b2c; PADDING-BOTTOM: 3px; WIDTH: 20px; COLOR: white; PADDING-TOP: = 3px; POSITION: absolute; TEXT-ALIGN: center } .Calendar .EmptyDay .Number { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-SIZE: 11px; BACKGROUND: = #cacbcc; PADDING-BOTTOM: 3px; WIDTH: 20px; COLOR: white; PADDING-TOP: = 3px; POSITION: absolute; TEXT-ALIGN: center } .ToolTipContainer { BORDER-RIGHT: #969696 1px solid; BORDER-TOP: #d9d9d9 1px solid; = BACKGROUND: url(../images/bg_menu.png) #eef5fd repeat-x 50% top; = BORDER-LEFT: #d9d9d9 1px solid; BORDER-BOTTOM: #969696 1px solid } .ToolTipSimple { MARGIN: 3px 6px } .ToolTip { MARGIN: 3px 4px; WIDTH: 190px } .ToolTipPrivate { MARGIN: 3px 6px; WIDTH: 190px } .ToolTipText { FONT-SIZE: 9px; COLOR: #76777a; LINE-HEIGHT: 12px; FONT-FAMILY: Tahoma, = Arial, Helvetica, sans-serif } .ToolTipSimple .ToolTipText { PADDING-LEFT: 6px; FONT-SIZE: 11px; COLOR: black } .ToolTipText B { FONT-SIZE: 11px; COLOR: black; FONT-FAMILY: Arial, Helvetica, = sans-serif } .Tip { =09 } .TagCloud { LINE-HEIGHT: 27px } .TagCloud A { MARGIN: 0px 4px; TEXT-DECORATION: none } .TagCloud A.TagSize1 { FONT-SIZE: 11px } .TagCloud A.TagSize2 { FONT-SIZE: 14px } .TagCloud A.TagSize3 { FONT-SIZE: 18px } .TagCloud A.TagSize4 { FONT-SIZE: 21px } .TagCloud A.TagSize5 { FONT-SIZE: 24px } .TagCloud A.TagSize6 { FONT-SIZE: 32px; LETTER-SPACING: -1px } .Red { COLOR: #ed3622 } .Green { COLOR: #7cc300 } .Orange { COLOR: #f19300 } .Grey { COLOR: #7287a4 } .Black { COLOR: black } .Blue { COLOR: #1959cf } .Small { FONT-SIZE: 9px; FONT-FAMILY: Tahoma, Verdana, Arial, Helvetica, = sans-serif } .Reduced { FONT-SIZE: 11px } .Normal { FONT-SIZE: 12px } .Medium { FONT-SIZE: 14px } .Big { FONT-SIZE: 18px } .Huge { FONT-SIZE: 24px; LETTER-SPACING: -1px } .LBBody P { MARGIN: 0px } .LightGreyBox { MARGIN: 6px 0px 12px } .LightGreyBox .LBTop { BORDER-RIGHT: #ededed 1px solid; BACKGROUND: = url(../images/box_grey_topleft.png) no-repeat; HEIGHT: 15px } .LightGreyBox .LBBottom { BACKGROUND: url(../images/box_grey_bottomright.png) no-repeat right = 50%; BORDER-LEFT: #ededed 1px solid; HEIGHT: 16px } .LightGreyBox .LBBody { BORDER-RIGHT: #ededed 1px solid; PADDING-RIGHT: 12px; PADDING-LEFT: = 12px; PADDING-BOTTOM: 0px; BORDER-LEFT: #ededed 1px solid; PADDING-TOP: = 0px; BACKGROUND-COLOR: #f7f7f7 } .LightBlueBox { MARGIN: 6px 0px 12px } .LightBlueBox .LBTop { BORDER-RIGHT: #d6dcff 1px solid; BACKGROUND: = url(../images/box_blue_topleft.png) no-repeat; HEIGHT: 15px } .LightBlueBox .LBBottom { BACKGROUND: url(../images/box_blue_bottomright.png) no-repeat right = 50%; BORDER-LEFT: #d6dcff 1px solid; HEIGHT: 16px } .LightBlueBox .LBBody { BORDER-RIGHT: #d6dcff 1px solid; PADDING-RIGHT: 12px; PADDING-LEFT: = 12px; PADDING-BOTTOM: 0px; BORDER-LEFT: #d6dcff 1px solid; PADDING-TOP: = 0px; BACKGROUND-COLOR: #ebeefe } .LightOrangeBox { MARGIN: 6px 0px 12px } .LightOrangeBox .LBTop { BORDER-RIGHT: #ffe17f 1px solid; BACKGROUND: = url(../images/box_orange_topleft.png) no-repeat; HEIGHT: 15px } .LightOrangeBox .LBBottom { BACKGROUND: url(../images/box_orange_bottomright.png) no-repeat right = 50%; BORDER-LEFT: #ffe17f 1px solid; HEIGHT: 16px } .LightOrangeBox .LBBody { BORDER-RIGHT: #ffe17f 1px solid; PADDING-RIGHT: 12px; PADDING-LEFT: = 12px; PADDING-BOTTOM: 0px; BORDER-LEFT: #ffe17f 1px solid; PADDING-TOP: = 0px; BACKGROUND-COLOR: #fdf6cf } .LightGreenBox { MARGIN: 6px 0px 12px } .LightGreenBox .LBTop { BORDER-RIGHT: #d7f1a6 1px solid; BACKGROUND: = url(../images/box_green_topleft.png) no-repeat; HEIGHT: 15px } .LightGreenBox .LBBottom { BACKGROUND: url(../images/box_green_bottomright.png) no-repeat right = 50%; BORDER-LEFT: #d7f1a6 1px solid; HEIGHT: 16px } .LightGreenBox .LBBody { BORDER-RIGHT: #d7f1a6 1px solid; PADDING-RIGHT: 12px; PADDING-LEFT: = 12px; PADDING-BOTTOM: 0px; BORDER-LEFT: #d7f1a6 1px solid; PADDING-TOP: = 0px; BACKGROUND-COLOR: #f0ffd9 } .LightRedBox { MARGIN: 6px 0px 12px } .LightRedBox .LBTop { BORDER-RIGHT: #ffd9d9 1px solid; BACKGROUND: = url(../images/box_red_topleft.png) no-repeat; HEIGHT: 15px } .LightRedBox .LBBottom { BACKGROUND: url(../images/box_red_bottomright.png) no-repeat right 50%; = BORDER-LEFT: #ffd9d9 1px solid; HEIGHT: 16px } .LightRedBox .LBBody { BORDER-RIGHT: #ffd9d9 1px solid; PADDING-RIGHT: 12px; PADDING-LEFT: = 12px; PADDING-BOTTOM: 0px; BORDER-LEFT: #ffd9d9 1px solid; PADDING-TOP: = 0px; POSITION: relative; BACKGROUND-COLOR: #fff1f1 } .Uploading { PADDING-LEFT: 57px! important; BACKGROUND: = url(../images/bigicons/uploading.png) no-repeat 10px top } .Converting { PADDING-LEFT: 57px! important; BACKGROUND: = url(../images/bigicons/converting.png) no-repeat 10px top } .Error { PADDING-LEFT: 57px! important; BACKGROUND: = url(../images/bigicons/error.png) no-repeat 10px top } .Warning { PADDING-LEFT: 57px! important; BACKGROUND: = url(../images/bigicons/warning.png) no-repeat 10px top } .Help { PADDING-LEFT: 42px! important; BACKGROUND: = url(../images/icons/bighelp.png) no-repeat 0px top } .Info { PADDING-LEFT: 57px! important; BACKGROUND: = url(../images/bigicons/info.png) no-repeat 10px top } .Success { PADDING-LEFT: 57px! important; BACKGROUND: = url(../images/bigicons/success.png) no-repeat 10px top } .ValidMsg { BORDER-RIGHT: #d7f1a6 1px solid; PADDING-RIGHT: 8px; BORDER-TOP: = #d7f1a6 1px solid; PADDING-LEFT: 28px; BACKGROUND: = url(../images/icons/success.png) #f0ffd9 no-repeat 4px 5px; = PADDING-BOTTOM: 2px; MARGIN: 8px 0px 12px; BORDER-LEFT: #d7f1a6 1px = solid; COLOR: #669922; PADDING-TOP: 6px; BORDER-BOTTOM: #d7f1a6 1px = solid } .ValidMsg DIV { MARGIN-BOTTOM: 4px } .WarningMsg { BORDER-RIGHT: #f8e3b3 1px solid; PADDING-RIGHT: 8px; BORDER-TOP: = #f8e3b3 1px solid; PADDING-LEFT: 28px; BACKGROUND: = url(../images/icons/warning.png) #fdf6cf no-repeat 4px 5px; = PADDING-BOTTOM: 2px; MARGIN: 8px 0px 12px; BORDER-LEFT: #f8e3b3 1px = solid; COLOR: black; PADDING-TOP: 6px; BORDER-BOTTOM: #f8e3b3 1px solid } .WarningMsg DIV { MARGIN-BOTTOM: 4px } .InfoMsg { BORDER-RIGHT: #f8e3b3 1px solid; PADDING-RIGHT: 8px; BORDER-TOP: = #f8e3b3 1px solid; PADDING-LEFT: 28px; BACKGROUND: = url(../images/icons/info.png) #fdf6cf no-repeat 7px 7px; PADDING-BOTTOM: = 2px; MARGIN: 8px 0px 12px; BORDER-LEFT: #f8e3b3 1px solid; COLOR: black; = PADDING-TOP: 6px; BORDER-BOTTOM: #f8e3b3 1px solid } .InfoMsg DIV { MARGIN-BOTTOM: 4px } .ErrorMsg { BORDER-RIGHT: #ffd9d9 1px solid; PADDING-RIGHT: 8px; BORDER-TOP: = #ffd9d9 1px solid; PADDING-LEFT: 28px; BACKGROUND: = url(../images/icons/error.png) #ffebe8 no-repeat 4px 5px; = PADDING-BOTTOM: 2px; MARGIN: 8px 0px 12px; BORDER-LEFT: #ffd9d9 1px = solid; PADDING-TOP: 6px; BORDER-BOTTOM: #ffd9d9 1px solid } .ErrorMsg DIV { MARGIN-BOTTOM: 4px } FORM { DISPLAY: inline } FORM LABEL { DISPLAY: block; FONT-WEIGHT: bold; MARGIN-BOTTOM: 4px; COLOR: #5a5b5c } FORM LABEL.Choice { DISPLAY: inline; FONT-WEIGHT: normal; MARGIN-BOTTOM: 0px } FORM DIV.Tip { MARGIN-TOP: -3px; FONT-SIZE: 11px; MARGIN-BOTTOM: 6px; COLOR: #a9b9c9 } FORM DIV.Separator { MARGIN: 12px 0px } FORM.Unspaced DIV.Separator { MARGIN: 0px } INPUT { FONT-SIZE: 12px; FONT-FAMILY: Arial, Verdana, Arial, Helvetica, = sans-serif } TEXTAREA { FONT-SIZE: 12px; FONT-FAMILY: Arial, Verdana, Arial, Helvetica, = sans-serif } SELECT { FONT-SIZE: 12px; FONT-FAMILY: Arial, Verdana, Arial, Helvetica, = sans-serif } SELECT OPTGROUP { FONT-WEIGHT: bold; FONT-SIZE: 12px; FONT-STYLE: normal; FONT-FAMILY: = Arial, Verdana, Arial, Helvetica, sans-serif } SELECT OPTGROUP OPTION { FONT-SIZE: 12px; FONT-FAMILY: Arial, Verdana, Arial, Helvetica, = sans-serif } .Required { PADDING-LEFT: 11px; FONT-WEIGHT: bold; BACKGROUND: = url(../images/icons/form_field_required.png) no-repeat left top; COLOR: = #1959cf } .Button { BORDER-RIGHT: #0969df 1px solid; PADDING-RIGHT: 6px; BORDER-TOP: = #2989ff 0px solid; PADDING-LEFT: 6px; FONT-WEIGHT: bold; FONT-SIZE: = 13px; BACKGROUND: url(../images/buttons/bg_button.png) repeat-x; = PADDING-BOTTOM: 2px; BORDER-LEFT: #2989ff 0px solid; CURSOR: pointer; = COLOR: white; MARGIN-RIGHT: 4px; PADDING-TOP: 2px; BORDER-BOTTOM: = #0969df 1px solid } .Button:hover { BORDER-RIGHT: #6cc300 1px solid; BORDER-TOP: #8cf300 0px solid; = BACKGROUND: url(../images/buttons/bg_button_hover.png) repeat-x; = BORDER-LEFT: #8cf300 0px solid; BORDER-BOTTOM: #6cc300 1px solid } .CancelButton { BORDER-RIGHT: #e4e4e4 1px solid; PADDING-RIGHT: 6px; BORDER-TOP: = #f4f4f4 0px solid; PADDING-LEFT: 6px; FONT-SIZE: 13px; BACKGROUND: = #eeeeee; PADDING-BOTTOM: 2px; BORDER-LEFT: #f4f4f4 0px solid; CURSOR: = pointer; COLOR: #767676; MARGIN-RIGHT: 4px; PADDING-TOP: 2px; = BORDER-BOTTOM: #e4e4e4 1px solid } .CancelButton:hover { BORDER-RIGHT: #eeeeee 1px solid; BORDER-TOP: #f9f9f9 0px solid; = BACKGROUND: #f4f4f4; BORDER-LEFT: #f9f9f9 0px solid; BORDER-BOTTOM: = #eeeeee 1px solid } FORM .Separator { MARGIN-TOP: 16px } .IFrameLister { BORDER-RIGHT: #d2d3d4 1px solid; PADDING-RIGHT: 8px; BORDER-TOP: = #d2d3d4 1px solid; PADDING-LEFT: 8px; PADDING-BOTTOM: 8px; OVERFLOW: = auto; BORDER-LEFT: #d2d3d4 1px solid; PADDING-TOP: 8px; BORDER-BOTTOM: = #d2d3d4 1px solid } .FileField { =09 } .FileField .Label { BORDER-RIGHT: #7f9db9 1px solid; PADDING-RIGHT: 4px; BORDER-TOP: = #7f9db9 1px solid; PADDING-LEFT: 4px; BACKGROUND: white; FLOAT: left; = PADDING-BOTTOM: 0px; OVERFLOW: hidden; BORDER-LEFT: #7f9db9 1px solid; = WIDTH: 300px; LINE-HEIGHT: 20px; MARGIN-RIGHT: 4px; PADDING-TOP: 0px; = BORDER-BOTTOM: #7f9db9 1px solid; HEIGHT: 20px } .FileField .Button { BACKGROUND: none transparent scroll repeat 0% 0%; FLOAT: left; WIDTH: = 80px; HEIGHT: 20px } .BrowseList { BORDER-RIGHT: #7f9db9 1px solid; BORDER-TOP: #7f9db9 1px solid; = BACKGROUND: #c9d9ef; OVERFLOW: auto; BORDER-LEFT: #7f9db9 1px solid; = BORDER-BOTTOM: #7f9db9 1px solid; max-height: 250px } .BrowseList .Header { PADDING-RIGHT: 4px; MARGIN-TOP: 1px; PADDING-LEFT: 4px; FONT-SIZE: = 14px; BACKGROUND: white; PADDING-BOTTOM: 4px; COLOR: #7cd300; = PADDING-TOP: 8px } .BrowseList .Items { =09 } .BrowseList .Items .Item { PADDING-RIGHT: 1px; PADDING-LEFT: 1px; FONT-SIZE: 11px; BACKGROUND: = white; PADDING-BOTTOM: 1px; MARGIN: 1px 0px 0px; PADDING-TOP: 1px; = HEIGHT: 20px } .BrowseList .Items .ItemActive { PADDING-RIGHT: 1px; PADDING-LEFT: 1px; FONT-SIZE: 11px; BACKGROUND: = white; PADDING-BOTTOM: 1px; MARGIN: 1px 0px 0px; PADDING-TOP: 1px; = HEIGHT: 20px } .BrowseList .Items .ItemActive { BACKGROUND: url(../images/bg_rollover.png) repeat-x } .DateField { BORDER-RIGHT: #7f9db9 1px solid; PADDING-RIGHT: 4px; BORDER-TOP: = #7f9db9 1px solid; DISPLAY: block; PADDING-LEFT: 24px; FONT-SIZE: 12px; = BACKGROUND: url(../images/icons/calendar.png) no-repeat 2px center; = PADDING-BOTTOM: 4px; MARGIN: 4px 1px; BORDER-LEFT: #7f9db9 1px solid; = WIDTH: 124px; CURSOR: pointer; LINE-HEIGHT: 14px; PADDING-TOP: 4px; = BORDER-BOTTOM: #7f9db9 1px solid; FONT-FAMILY: Arial, Verdana, Arial, = Helvetica, sans-serif; HEIGHT: 14px } .DateField:hover { COLOR: #146fe6; BACKGROUND-COLOR: #dbecff } .SelectImageField { =09 } .SelectImageDisplay { BORDER-RIGHT: #7f9db9 1px solid; BORDER-TOP: #7f9db9 1px solid; = DISPLAY: block; MARGIN: 1px 4px 4px 1px; BORDER-LEFT: #7f9db9 1px solid; = WIDTH: 50px; CURSOR: pointer; BORDER-BOTTOM: #7f9db9 1px solid; HEIGHT: = 50px } .SelectImageDisplay:hover { BORDER-RIGHT: #1959cf 2px solid; BORDER-TOP: #1959cf 2px solid; MARGIN: = 0px 3px 3px 0px; BORDER-LEFT: #1959cf 2px solid; BORDER-BOTTOM: #1959cf = 2px solid } .SelectImageDisplay IMG { WIDTH: 50px; HEIGHT: 50px } .SelectImageContainer { BORDER-RIGHT: #7f9db9 1px solid; PADDING-RIGHT: 8px; BORDER-TOP: = #7f9db9 1px solid; MARGIN-TOP: 4px; PADDING-LEFT: 8px; BACKGROUND: = white; PADDING-BOTTOM: 8px; OVERFLOW: auto; BORDER-LEFT: #7f9db9 1px = solid; PADDING-TOP: 8px; BORDER-BOTTOM: #7f9db9 1px solid; HEIGHT: 180px } .SelectImageContainer A { BORDER-RIGHT: #7f9db9 1px solid; BORDER-TOP: #7f9db9 1px solid; = DISPLAY: block; BACKGROUND: white; FLOAT: left; MARGIN: 1px 4px 4px 1px; = BORDER-LEFT: #7f9db9 1px solid; WIDTH: 52px; BORDER-BOTTOM: #7f9db9 1px = solid; HEIGHT: 52px } .SelectImageContainer A:hover { BORDER-RIGHT: #7cd300 3px solid; BORDER-TOP: #7cd300 3px solid; MARGIN: = 0px 3px 3px 0px; BORDER-LEFT: #7cd300 3px solid; WIDTH: 50px; = BORDER-BOTTOM: #7cd300 3px solid; HEIGHT: 50px } .SelectImageContainer A IMG { PADDING-RIGHT: 1px; PADDING-LEFT: 1px; PADDING-BOTTOM: 1px; WIDTH: = 50px; PADDING-TOP: 1px; HEIGHT: 50px } .SelectImageContainer A:hover IMG { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; = PADDING-TOP: 0px } .CategoryLabel { PADDING-RIGHT: 0px; PADDING-LEFT: 24px; BACKGROUND: = url(../images/icons/category.png) no-repeat; PADDING-BOTTOM: 2px; = PADDING-TOP: 0px } .TextFieldLabel { PADDING-RIGHT: 0px; PADDING-LEFT: 24px; BACKGROUND: = url(../images/icons/textfield.png) no-repeat; PADDING-BOTTOM: 2px; = PADDING-TOP: 0px } .PanelPublishMode { PADDING-RIGHT: 0px; PADDING-LEFT: 24px; BACKGROUND: = url(../images/icons/panel_publish_mode.png) no-repeat; PADDING-BOTTOM: = 2px; PADDING-TOP: 0px } .PanelMoreOptions { PADDING-RIGHT: 0px; PADDING-LEFT: 24px; BACKGROUND: = url(../images/icons/panel_more_options.png) no-repeat; PADDING-BOTTOM: = 2px; PADDING-TOP: 0px } .PanelShareOptions { PADDING-RIGHT: 0px; PADDING-LEFT: 24px; BACKGROUND: = url(../images/icons/panel_share_options.png) no-repeat; PADDING-BOTTOM: = 2px; PADDING-TOP: 0px } .PanelCustomOptions { PADDING-RIGHT: 0px; PADDING-LEFT: 24px; BACKGROUND: = url(../images/icons/panel_custom_options.png) no-repeat; PADDING-BOTTOM: = 2px; PADDING-TOP: 0px } .PanelConvertOptions { PADDING-RIGHT: 0px; PADDING-LEFT: 24px; BACKGROUND: = url(../images/icons/panel_convert_options.png) no-repeat; = PADDING-BOTTOM: 2px; PADDING-TOP: 0px } .LV_validation_message { MARGIN: 4px 0px } .LV_valid { PADDING-RIGHT: 16px; PADDING-LEFT: 16px; BACKGROUND: = url(../images/icons/form_field_valid.png) no-repeat 4px 0px; = PADDING-BOTTOM: 0px; COLOR: #00aa00; PADDING-TOP: 0px } .LV_invalid { DISPLAY: block; FONT-SIZE: 12px; COLOR: #cc0000 } .LV_valid_field { =09 } INPUT.LV_valid_field:hover { =09 } INPUT.LV_valid_field:active { =09 } TEXTAREA.LV_valid_field:hover { =09 } TEXTAREA.LV_valid_field:active { =09 } .LV_invalid_field { =09 } INPUT.LV_invalid_field:hover { =09 } INPUT.LV_invalid_field:active { =09 } TEXTAREA.LV_invalid_field:hover { =09 } TEXTAREA.LV_invalid_field:active { =09 } .BrowseGridView { CLEAR: both; OVERFLOW: hidden } .BrowseGridView .BrowseItem { BORDER-RIGHT: white 1px solid; PADDING-RIGHT: 8px; BORDER-TOP: white = 1px solid; PADDING-LEFT: 8px; FLOAT: left; PADDING-BOTTOM: 8px; = OVERFLOW: hidden; BORDER-LEFT: white 1px solid; WIDTH: 124px; = PADDING-TOP: 8px; BORDER-BOTTOM: white 1px solid; HEIGHT: 180px } .BrowseGridView .Separator { DISPLAY: none } .BrowseGridView .BrowseItem .Separator { DISPLAY: none } .BrowseGridView .BrowseItem:hover { BORDER-RIGHT: #e8edfd 1px solid; BORDER-TOP: #e8edfd 1px solid; = BACKGROUND: url(../images/bg_rollover.png) #f7fafe repeat-x left top; = BORDER-LEFT: #e8edfd 1px solid; BORDER-BOTTOM: #e8edfd 1px solid } .BrowseGridView .BrowseItem .BrowseThumbnail { HEIGHT: 106px } .BrowseGridView .BrowseItem .BrowseThumbnail .Thumbnail { MARGIN: 0px } .BrowseGridView .BrowseItem .BrowseMain { =09 } .BrowseGridView .BrowseItem .BrowseMain .BrowseLongTitle { DISPLAY: none } .BrowseGridView .BrowseItem .BrowseMain .BrowseShortTitle { FONT-WEIGHT: bold; FONT-SIZE: 11px; OVERFLOW: hidden; WIDTH: 124px; = HEIGHT: 28px } .BrowseGridView .BrowseItem .BrowseMain .BrowseDescription { DISPLAY: none } .BrowseGridView .BrowseItem .BrowseInfos { MARGIN-TOP: 4px; FONT-SIZE: 11px; MARGIN-BOTTOM: 5px; OVERFLOW: hidden; = WIDTH: 124px } .BrowseGridView .BrowseItem .BrowseInfos .BrowseDate { DISPLAY: none } .BrowseGridView .BrowseItem .BrowseInfos .BrowseAccount { FONT-SIZE: 11px; MARGIN-BOTTOM: 2px; OVERFLOW: hidden; WIDTH: 124px; = WHITE-SPACE: nowrap } .BrowseGridView .BrowseItem .BrowseInfos .BrowseAccount A { =09 } .BrowseGridView .BrowseItem .BrowseInfos .BrowseAccount A:hover { =09 } .BrowseGridView .BrowseItem .BrowseInfos .BrowseViews { =09 } .BrowseGridView .BrowseItem .BrowseInfos .BrowsePages { =09 } .BrowseGridView .BrowseItem .BrowseInfos .BrowseRating { MARGIN-TOP: 2px; FLOAT: right } .BrowseListView { CLEAR: both; OVERFLOW: hidden } .BrowseListView .Separator { =09 } .BrowseListView .BrowseItem .Separator { DISPLAY: none } .BrowseListView .BrowseItem { PADDING-RIGHT: 8px; PADDING-LEFT: 8px; PADDING-BOTTOM: 8px; OVERFLOW: = hidden; PADDING-TOP: 8px } .BrowseListView .BrowseItem:hover { BACKGROUND: url(../images/bg_rollover.png) #f7fafe repeat-x left top } .BrowseListView .BrowseItem .BrowseThumbnail { FLOAT: left; OVERFLOW: hidden; WIDTH: 116px; HEIGHT: 106px } .BrowseListView .BrowseItem .BrowseThumbnail .Thumbnail { MARGIN: 0px } .BrowseListView .BrowseItem .BrowseMain { PADDING-RIGHT: 12px; FLOAT: left; OVERFLOW: hidden; WIDTH: 404px } .BrowseListView .BrowseItem .BrowseMain .BrowseLongTitle { FONT-WEIGHT: bold; FONT-SIZE: 15px } .BrowseListView .BrowseItem .BrowseMain .BrowseShortTitle { DISPLAY: none } .BrowseListView .BrowseItem .BrowseMain .BrowseDescription { MARGIN-TOP: 6px; OVERFLOW: hidden; WIDTH: 404px } .BrowseListView .BrowseItem .BrowseInfos { PADDING-RIGHT: 8px; PADDING-LEFT: 8px; FONT-SIZE: 11px; FLOAT: left; = PADDING-BOTTOM: 0px; OVERFLOW: hidden; BORDER-LEFT: #d8e2ed 1px solid; = WIDTH: 138px; LINE-HEIGHT: 17px; MARGIN-RIGHT: 7px; PADDING-TOP: 0px } .BrowseListView .BrowseItem .BrowseInfos .BrowseDate { =09 } .BrowseListView .BrowseItem .BrowseInfos .BrowseAccount { FONT-SIZE: 11px; WHITE-SPACE: nowrap } .BrowseListView .BrowseItem .BrowseInfos .BrowseAccount A { =09 } .BrowseListView .BrowseItem .BrowseInfos .BrowseAccount A:hover { =09 } .BrowseListView .BrowseItem .BrowseInfos .BrowseViews { =09 } .BrowseListView .BrowseItem .BrowseInfos .BrowseRating { MARGIN-TOP: 3px; MARGIN-BOTTOM: 3px; VERTICAL-ALIGN: middle } .BrowseListView .BrowseItem .BrowseInfos .BrowsePages { VERTICAL-ALIGN: middle } DIV.BrowseViewSwitch { FLOAT: right; MARGIN-BOTTOM: 5px; WHITE-SPACE: nowrap } DIV.BrowseViewSwitch LABEL { DISPLAY: inline; FONT-WEIGHT: bold; MARGIN-RIGHT: 3px } .VarTable { BORDER-TOP: #e4e4e9 1px solid } .VarTable .Even TD { BACKGROUND: #fafafb; BORDER-BOTTOM: #e4e4e9 1px solid } .VarTable .Odd TD { BACKGROUND: white; BORDER-BOTTOM: #e4e4e9 1px solid } #lbOverlay { Z-INDEX: 90; LEFT: 0px; WIDTH: 100%; CURSOR: pointer; POSITION: = absolute; TOP: 0px; HEIGHT: 500px; BACKGROUND-COLOR: #000 } .LightBox { BORDER-RIGHT: #e4e6e9 8px solid; PADDING-RIGHT: 18px; BORDER-TOP: = #e4e6e9 8px solid; PADDING-LEFT: 18px; Z-INDEX: 100; BACKGROUND: white; = LEFT: 0px; PADDING-BOTTOM: 15px; BORDER-LEFT: #e4e6e9 8px solid; = PADDING-TOP: 15px; BORDER-BOTTOM: #e4e6e9 8px solid; POSITION: absolute } .LightBox .LightBoxClose { PADDING-RIGHT: 19px; FONT-SIZE: 11px; BACKGROUND: = url(../images/icons/close_lightbox.png) no-repeat right center; = MARGIN-BOTTOM: 12px; MARGIN-LEFT: 12px; COLOR: #999999; TEXT-DECORATION: = none } .LightBox .LightBoxClose:hover { PADDING-RIGHT: 19px; FONT-SIZE: 11px; BACKGROUND: = url(../images/icons/close_lightbox.png) no-repeat right center; = MARGIN-BOTTOM: 12px; MARGIN-LEFT: 12px; COLOR: #999999; TEXT-DECORATION: = none } .StarRatingComponent { BORDER-RIGHT: #ededed 1px solid; BACKGROUND: #f8f9fa; MARGIN-BOTTOM: = 4px; BORDER-LEFT: #ededed 1px solid; BORDER-BOTTOM: #ededed 1px solid; = TEXT-ALIGN: center } .StarRatingComponent .Stars { PADDING-RIGHT: 2px; PADDING-LEFT: 2px; PADDING-BOTTOM: 0px; MARGIN: 0px = auto; WIDTH: 80px; CURSOR: pointer; PADDING-TOP: 4px; HEIGHT: 16px } .StarRatingComponent .Star { DISPLAY: block; FLOAT: left; WIDTH: 16px; HEIGHT: 16px } .StarRatingComponent .Indicator { CLEAR: both; PADDING-RIGHT: 2px; PADDING-LEFT: 2px; PADDING-BOTTOM: = 4px; PADDING-TOP: 2px } .StarRatingComponent .Loading { CLEAR: both; PADDING-RIGHT: 2px; PADDING-LEFT: 2px; PADDING-BOTTOM: = 4px; COLOR: #9a9b9d; PADDING-TOP: 2px } .StarRatingComponent .Full { BACKGROUND: url(../images/icons/big_star_full.png) no-repeat } .StarRatingComponent .Half { BACKGROUND: url(../images/icons/big_star_half.png) no-repeat } .StarRatingComponent .Over { BACKGROUND: url(../images/icons/big_star_hover.png) no-repeat } .StarRatingComponent .Blank { BACKGROUND: url(../images/icons/big_star_blank.png) no-repeat } .ArrowSwitch { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: = 16px 0px 6px; PADDING-TOP: 0px } .ArrowSwitch A { COLOR: black; TEXT-DECORATION: none } .ArrowSwitch A:hover { COLOR: black; BACKGROUND-COLOR: transparent; TEXT-DECORATION: underline } .ArrowSwitch .On { PADDING-LEFT: 20px; BACKGROUND: = url(../images/icons/arrow_switch_opened.png) no-repeat } .ArrowSwitch .Off { PADDING-LEFT: 20px; BACKGROUND: = url(../images/icons/arrow_switch_closed.png) no-repeat } #ErrorPages { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: = 0px; PADDING-TOP: 0px } #ErrorPages LI { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 2px; = PADDING-TOP: 2px; LIST-STYLE-TYPE: none } ------=_NextPart_000_0000_01C8A946.17CACA30 Content-Type: application/octet-stream Content-Transfer-Encoding: quoted-printable Content-Location: http://fr.calameo.com/skins/calameo-v1/css/menu.css?v2.1.1 .yuimenubar { FONT-SIZE: 12px; VISIBILITY: visible; LINE-HEIGHT: 1.9; POSITION: = static } .yuimenubar A { COLOR: white; BACKGROUND-COLOR: transparent } .yuimenubar A:hover { COLOR: white; BACKGROUND-COLOR: transparent } .yuimenubar A:hover { TEXT-DECORATION: underline } .yuimenu A { COLOR: black; BACKGROUND-COLOR: transparent } .yuimenu A:hover { COLOR: black; BACKGROUND-COLOR: transparent } .yuimenu A:hover { TEXT-DECORATION: underline } .yuimenu .yuimenu { LEFT: -10000px; VISIBILITY: hidden; POSITION: absolute; TOP: -10000px } .yuimenubar .yuimenu { LEFT: -10000px; VISIBILITY: hidden; POSITION: absolute; TOP: -10000px } .yuimenu UL { MARGIN: -1px 0px; POSITION: relative } .yuimenubar LI { LIST-STYLE-TYPE: none } .yuimenu LI { LIST-STYLE-TYPE: none } .yuimenubar UL { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: = 0px; PADDING-TOP: 0px } .yuimenu UL { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: = 0px; PADDING-TOP: 0px } .yuimenubar LI { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: = 0px; PADDING-TOP: 0px } .yuimenu LI { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: = 0px; PADDING-TOP: 0px } .yuimenu H6 { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: = 0px; PADDING-TOP: 0px } .yuimenubar H6 { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: = 0px; PADDING-TOP: 0px } .yuimenuitemlabel { WHITE-SPACE: nowrap; TEXT-ALIGN: left } .yuimenubaritemlabel { WHITE-SPACE: nowrap; TEXT-ALIGN: left } .yuimenubar UL { ZOOM: 1 } .yuimenubar .yuimenu UL { ZOOM: normal } UNKNOWN { CLEAR: both; DISPLAY: block; VISIBILITY: hidden; LINE-HEIGHT: 0; = HEIGHT: 0px; content: "." } .yuimenubaritem { FLOAT: left; MARGIN-RIGHT: 2px } .yuimenubaritem-hassubmenu { FLOAT: left; MARGIN-RIGHT: 2px } .yuimenubaritemlabel { DISPLAY: block } .yuimenuitemlabel { DISPLAY: block } .yuimenuitemlabel .helptext { DISPLAY: block; MARGIN: -1em 0px 0px 10em; FONT-STYLE: normal } .yui-menu-shadow { Z-INDEX: -1; VISIBILITY: hidden; POSITION: absolute } .yui-menu-shadow-visible { RIGHT: -3px; FILTER: alpha(opacity=3D0); LEFT: -3px; VISIBILITY: = visible; BOTTOM: -3px; TOP: 0px; BACKGROUND-COLOR: #444; opacity: 0 } .hide-scrollbars { OVERFLOW: hidden } .hide-scrollbars SELECT { DISPLAY: none } .show-scrollbars { OVERFLOW: visible } .show-scrollbars { OVERFLOW: visible } .hide-scrollbars .yui-menu-shadow { OVERFLOW: hidden } .hide-scrollbars .yui-menu-shadow { OVERFLOW: hidden } .show-scrollbars .yui-menu-shadow { OVERFLOW: auto } .show-scrollbars .yui-menu-shadow { OVERFLOW: auto } .yuimenubar { =09 } .yuimenu { FONT-SIZE: 11px; LINE-HEIGHT: 1.45 } .yuimenu .bd { BORDER-RIGHT: #7a7b7c 1px solid; BORDER-TOP: #dadbdc 1px solid; = BACKGROUND: white; BORDER-LEFT: #dadbdc 1px solid; BORDER-BOTTOM: = #7a7b7c 1px solid } .yui-menu-shadow { =09 } .yuimenu UL { PADDING-RIGHT: 0px; BORDER-TOP: #f0f0f0 1px solid; PADDING-LEFT: 0px; = PADDING-BOTTOM: 3px; PADDING-TOP: 3px } .yuimenu .yui-menu-body-scrolled { OVERFLOW: hidden } .yuimenu H6 { BORDER-RIGHT: #c4c4be 1px solid; BORDER-TOP: #c4c4be 1px solid; = FONT-WEIGHT: normal; FONT-SIZE: 100%; BORDER-LEFT: #c4c4be 1px solid; = COLOR: #1959cf; BORDER-BOTTOM: #c4c4be 1px solid } .yuimenubar H6 { BORDER-RIGHT: #c4c4be 1px solid; BORDER-TOP: #c4c4be 1px solid; = FONT-WEIGHT: normal; FONT-SIZE: 100%; BORDER-LEFT: #c4c4be 1px solid; = COLOR: #1959cf; BORDER-BOTTOM: #c4c4be 1px solid } .yuimenubar H6 { BORDER-TOP-WIDTH: 0px; PADDING-RIGHT: 12px; PADDING-LEFT: 12px; = BORDER-LEFT-WIDTH: 0px; FLOAT: left; BORDER-BOTTOM-WIDTH: 0px; = PADDING-BOTTOM: 4px; PADDING-TOP: 4px; BORDER-RIGHT-WIDTH: 1px } .yuimenubar .yuimenu H6 { BORDER-RIGHT: #ccc 0px solid; PADDING-RIGHT: 10px; BORDER-TOP: #ccc 1px = solid; PADDING-LEFT: 10px; FONT-WEIGHT: bold; FLOAT: none; = PADDING-BOTTOM: 0px; BORDER-LEFT: #ccc 0px solid; COLOR: #1959cf; = PADDING-TOP: 3px; BORDER-BOTTOM: #ccc 0px solid } .yuimenu H6 { BORDER-TOP-WIDTH: 1px; PADDING-RIGHT: 10px; PADDING-LEFT: 10px; = BORDER-LEFT-WIDTH: 0px; BORDER-BOTTOM-WIDTH: 0px; PADDING-BOTTOM: 0px; = PADDING-TOP: 5px; BORDER-RIGHT-WIDTH: 0px } .yuimenu UL.first-of-type { BORDER-TOP-WIDTH: 0px; BORDER-LEFT-WIDTH: 0px; BORDER-BOTTOM-WIDTH: = 0px; BORDER-RIGHT-WIDTH: 0px } .yuimenu UL.hastitle { BORDER-TOP-WIDTH: 0px; BORDER-LEFT-WIDTH: 0px; BORDER-BOTTOM-WIDTH: = 0px; BORDER-RIGHT-WIDTH: 0px } .yuimenu H6.first-of-type { BORDER-TOP-WIDTH: 0px; BORDER-LEFT-WIDTH: 0px; BORDER-BOTTOM-WIDTH: = 0px; BORDER-RIGHT-WIDTH: 0px } .yuimenu .topscrollbar { BACKGROUND-POSITION: center center; BACKGROUND-REPEAT: no-repeat; = HEIGHT: 12px; BACKGROUND-COLOR: white } .yuimenu .bottomscrollbar { BACKGROUND-POSITION: center center; BACKGROUND-REPEAT: no-repeat; = HEIGHT: 12px; BACKGROUND-COLOR: white } .yuimenu .topscrollbar { BACKGROUND-IMAGE: url(../images/menu_up_arrow.png) } .yuimenu .topscrollbar_disabled { BACKGROUND-IMAGE: url(../images/menu_up_arrow_disabled.png) } .yuimenu .bottomscrollbar { BACKGROUND-IMAGE: url(../images/menu_down_arrow.png) } .yuimenu .bottomscrollbar_disabled { BACKGROUND-IMAGE: url(../images/menu_down_arrow_disabled.png) } .yuimenuitem { MARGIN: -1px 0px; BORDER-BOTTOM: white 1px solid; POSITION: relative; = TEXT-DECORATION: none } .yuimenubaritem { BORDER-RIGHT: #f2f2f2 2px solid; BACKGROUND: = url(../images/bg_menu_item.png) no-repeat } .yuimenubaritem-hassubmenu { BORDER-RIGHT: #f2f2f2 2px solid; BACKGROUND: = url(../images/bg_menu_item.png) no-repeat } .yuimenubarsearchfield { BACKGROUND: none transparent scroll repeat 0% 0%; FLOAT: left } .yuimenubar .yuimenubaritemlabel { PADDING-RIGHT: 10px; DISPLAY: inline-block; PADDING-LEFT: 10px; = FONT-WEIGHT: bold; FONT-SIZE: 14px; PADDING-BOTTOM: 0px; MARGIN: -1px = 0px; COLOR: #fff; PADDING-TOP: 0px; LETTER-SPACING: -1px; POSITION: = relative; TEXT-DECORATION: none } .yuimenuitemlabel { PADDING-RIGHT: 12px; PADDING-LEFT: 10px; PADDING-BOTTOM: 2px; MARGIN: = -1px 0px; COLOR: #000; PADDING-TOP: 2px; POSITION: relative; = TEXT-DECORATION: none } .yuimenubar LI.first-of-type .yuimenubaritemlabel { COLOR: white } .yuimenubaritem-hassubmenu { =09 } .yuimenubaritem-hassubmenu .yuimenubaritemlabel { PADDING-RIGHT: 20px; BACKGROUND: url(../images/menu_dot.png) no-repeat = right center; COLOR: #fff; MARGIN-RIGHT: 8px } .yuimenuitem-hassubmenu { =09 } .yuimenuitem-checked { =09 } .yuimenuitemlabel .helptext { MARGIN-TOP: -1.45em } .yuimenubaritem-selected .yuimenubaritemlabel { BACKGROUND-COLOR: transparent; TEXT-DECORATION: underline } .yuimenuitem-selected .yuimenuitemlabel { COLOR: black; TEXT-DECORATION: underline } .yuimenubaritemlabel-selected { =09 } .yuimenuitemlabel-selected { =09 } .yuimenubaritem-hassubmenu-selected { =09 } .yuimenubaritem-hassubmenu-selected .yuimenubaritemlabel { BACKGROUND-IMAGE: url(../images/menu_dot_hover.png); TEXT-DECORATION: = underline } .yuimenuitem-checked-selected { =09 } .yuimenubaritemlabel-disabled { CURSOR: default; COLOR: #b9b9b9 } .yuimenuitemlabel-disabled { CURSOR: default; COLOR: #b9b9b9 } .yuimenubaritem-hassubmenu-disabled { =09 } .yuimenuitem-hassubmenu-disabled { =09 } .yuimenuitem-checked-disabled { =09 } ------=_NextPart_000_0000_01C8A946.17CACA30 Content-Type: application/octet-stream Content-Transfer-Encoding: quoted-printable Content-Location: http://fr.calameo.com/global/components/scriptaculous/prototype.js /* Prototype JavaScript framework, version 1.6.0.1=0A= * (c) 2005-2007 Sam Stephenson=0A= *=0A= * Prototype is freely distributable under the terms of an MIT-style = license.=0A= * For details, see the Prototype web site: http://www.prototypejs.org/=0A= *=0A= = *------------------------------------------------------------------------= --*/=0A= =0A= var Prototype =3D {=0A= Version: '1.6.0.1',=0A= =0A= Browser: {=0A= IE: !!(window.attachEvent && !window.opera),=0A= Opera: !!window.opera,=0A= WebKit: navigator.userAgent.indexOf('AppleWebKit/') > -1,=0A= Gecko: navigator.userAgent.indexOf('Gecko') > -1 && = navigator.userAgent.indexOf('KHTML') =3D=3D -1,=0A= MobileSafari: !!navigator.userAgent.match(/Apple.*Mobile.*Safari/)=0A= },=0A= =0A= BrowserFeatures: {=0A= XPath: !!document.evaluate,=0A= ElementExtensions: !!window.HTMLElement,=0A= SpecificElementExtensions:=0A= document.createElement('div').__proto__ &&=0A= document.createElement('div').__proto__ !=3D=3D=0A= document.createElement('form').__proto__=0A= },=0A= =0A= ScriptFragment: ']*>([\\S\\s]*?)<\/script>',=0A= JSONFilter: /^\/\*-secure-([\s\S]*)\*\/\s*$/,=0A= =0A= emptyFunction: function() { },=0A= K: function(x) { return x }=0A= };=0A= =0A= if (Prototype.Browser.MobileSafari)=0A= Prototype.BrowserFeatures.SpecificElementExtensions =3D false;=0A= =0A= =0A= /* Based on Alex Arnell's inheritance implementation. */=0A= var Class =3D {=0A= create: function() {=0A= var parent =3D null, properties =3D $A(arguments);=0A= if (Object.isFunction(properties[0]))=0A= parent =3D properties.shift();=0A= =0A= function klass() {=0A= this.initialize.apply(this, arguments);=0A= }=0A= =0A= Object.extend(klass, Class.Methods);=0A= klass.superclass =3D parent;=0A= klass.subclasses =3D [];=0A= =0A= if (parent) {=0A= var subclass =3D function() { };=0A= subclass.prototype =3D parent.prototype;=0A= klass.prototype =3D new subclass;=0A= parent.subclasses.push(klass);=0A= }=0A= =0A= for (var i =3D 0; i < properties.length; i++)=0A= klass.addMethods(properties[i]);=0A= =0A= if (!klass.prototype.initialize)=0A= klass.prototype.initialize =3D Prototype.emptyFunction;=0A= =0A= klass.prototype.constructor =3D klass;=0A= =0A= return klass;=0A= }=0A= };=0A= =0A= Class.Methods =3D {=0A= addMethods: function(source) {=0A= var ancestor =3D this.superclass && this.superclass.prototype;=0A= var properties =3D Object.keys(source);=0A= =0A= if (!Object.keys({ toString: true }).length)=0A= properties.push("toString", "valueOf");=0A= =0A= for (var i =3D 0, length =3D properties.length; i < length; i++) {=0A= var property =3D properties[i], value =3D source[property];=0A= if (ancestor && Object.isFunction(value) &&=0A= value.argumentNames().first() =3D=3D "$super") {=0A= var method =3D value, value =3D Object.extend((function(m) {=0A= return function() { return ancestor[m].apply(this, arguments) = };=0A= })(property).wrap(method), {=0A= valueOf: function() { return method },=0A= toString: function() { return method.toString() }=0A= });=0A= }=0A= this.prototype[property] =3D value;=0A= }=0A= =0A= return this;=0A= }=0A= };=0A= =0A= var Abstract =3D { };=0A= =0A= Object.extend =3D function(destination, source) {=0A= for (var property in source)=0A= destination[property] =3D source[property];=0A= return destination;=0A= };=0A= =0A= Object.extend(Object, {=0A= inspect: function(object) {=0A= try {=0A= if (Object.isUndefined(object)) return 'undefined';=0A= if (object =3D=3D=3D null) return 'null';=0A= return object.inspect ? object.inspect() : object.toString();=0A= } catch (e) {=0A= if (e instanceof RangeError) return '...';=0A= throw e;=0A= }=0A= },=0A= =0A= toJSON: function(object) {=0A= var type =3D typeof object;=0A= switch (type) {=0A= case 'undefined':=0A= case 'function':=0A= case 'unknown': return;=0A= case 'boolean': return object.toString();=0A= }=0A= =0A= if (object =3D=3D=3D null) return 'null';=0A= if (object.toJSON) return object.toJSON();=0A= if (Object.isElement(object)) return;=0A= =0A= var results =3D [];=0A= for (var property in object) {=0A= var value =3D Object.toJSON(object[property]);=0A= if (!Object.isUndefined(value))=0A= results.push(property.toJSON() + ': ' + value);=0A= }=0A= =0A= return '{' + results.join(', ') + '}';=0A= },=0A= =0A= toQueryString: function(object) {=0A= return $H(object).toQueryString();=0A= },=0A= =0A= toHTML: function(object) {=0A= return object && object.toHTML ? object.toHTML() : = String.interpret(object);=0A= },=0A= =0A= keys: function(object) {=0A= var keys =3D [];=0A= for (var property in object)=0A= keys.push(property);=0A= return keys;=0A= },=0A= =0A= values: function(object) {=0A= var values =3D [];=0A= for (var property in object)=0A= values.push(object[property]);=0A= return values;=0A= },=0A= =0A= clone: function(object) {=0A= return Object.extend({ }, object);=0A= },=0A= =0A= isElement: function(object) {=0A= return object && object.nodeType =3D=3D 1;=0A= },=0A= =0A= isArray: function(object) {=0A= return object && object.constructor =3D=3D=3D Array;=0A= },=0A= =0A= isHash: function(object) {=0A= return object instanceof Hash;=0A= },=0A= =0A= isFunction: function(object) {=0A= return typeof object =3D=3D "function";=0A= },=0A= =0A= isString: function(object) {=0A= return typeof object =3D=3D "string";=0A= },=0A= =0A= isNumber: function(object) {=0A= return typeof object =3D=3D "number";=0A= },=0A= =0A= isUndefined: function(object) {=0A= return typeof object =3D=3D "undefined";=0A= }=0A= });=0A= =0A= Object.extend(Function.prototype, {=0A= argumentNames: function() {=0A= var names =3D = this.toString().match(/^[\s\(]*function[^(]*\((.*?)\)/)[1].split(",").inv= oke("strip");=0A= return names.length =3D=3D 1 && !names[0] ? [] : names;=0A= },=0A= =0A= bind: function() {=0A= if (arguments.length < 2 && Object.isUndefined(arguments[0])) return = this;=0A= var __method =3D this, args =3D $A(arguments), object =3D = args.shift();=0A= return function() {=0A= return __method.apply(object, args.concat($A(arguments)));=0A= }=0A= },=0A= =0A= bindAsEventListener: function() {=0A= var __method =3D this, args =3D $A(arguments), object =3D = args.shift();=0A= return function(event) {=0A= return __method.apply(object, [event || = window.event].concat(args));=0A= }=0A= },=0A= =0A= curry: function() {=0A= if (!arguments.length) return this;=0A= var __method =3D this, args =3D $A(arguments);=0A= return function() {=0A= return __method.apply(this, args.concat($A(arguments)));=0A= }=0A= },=0A= =0A= delay: function() {=0A= var __method =3D this, args =3D $A(arguments), timeout =3D = args.shift() * 1000;=0A= return window.setTimeout(function() {=0A= return __method.apply(__method, args);=0A= }, timeout);=0A= },=0A= =0A= wrap: function(wrapper) {=0A= var __method =3D this;=0A= return function() {=0A= return wrapper.apply(this, = [__method.bind(this)].concat($A(arguments)));=0A= }=0A= },=0A= =0A= methodize: function() {=0A= if (this._methodized) return this._methodized;=0A= var __method =3D this;=0A= return this._methodized =3D function() {=0A= return __method.apply(null, [this].concat($A(arguments)));=0A= };=0A= }=0A= });=0A= =0A= Function.prototype.defer =3D Function.prototype.delay.curry(0.01);=0A= =0A= Date.prototype.toJSON =3D function() {=0A= return '"' + this.getUTCFullYear() + '-' +=0A= (this.getUTCMonth() + 1).toPaddedString(2) + '-' +=0A= this.getUTCDate().toPaddedString(2) + 'T' +=0A= this.getUTCHours().toPaddedString(2) + ':' +=0A= this.getUTCMinutes().toPaddedString(2) + ':' +=0A= this.getUTCSeconds().toPaddedString(2) + 'Z"';=0A= };=0A= =0A= var Try =3D {=0A= these: function() {=0A= var returnValue;=0A= =0A= for (var i =3D 0, length =3D arguments.length; i < length; i++) {=0A= var lambda =3D arguments[i];=0A= try {=0A= returnValue =3D lambda();=0A= break;=0A= } catch (e) { }=0A= }=0A= =0A= return returnValue;=0A= }=0A= };=0A= =0A= RegExp.prototype.match =3D RegExp.prototype.test;=0A= =0A= RegExp.escape =3D function(str) {=0A= return String(str).replace(/([.*+?^=3D!:${}()|[\]\/\\])/g, '\\$1');=0A= };=0A= =0A= /*-----------------------------------------------------------------------= ---*/=0A= =0A= var PeriodicalExecuter =3D Class.create({=0A= initialize: function(callback, frequency) {=0A= this.callback =3D callback;=0A= this.frequency =3D frequency;=0A= this.currentlyExecuting =3D false;=0A= =0A= this.registerCallback();=0A= },=0A= =0A= registerCallback: function() {=0A= this.timer =3D setInterval(this.onTimerEvent.bind(this), = this.frequency * 1000);=0A= },=0A= =0A= execute: function() {=0A= this.callback(this);=0A= },=0A= =0A= stop: function() {=0A= if (!this.timer) return;=0A= clearInterval(this.timer);=0A= this.timer =3D null;=0A= },=0A= =0A= onTimerEvent: function() {=0A= if (!this.currentlyExecuting) {=0A= try {=0A= this.currentlyExecuting =3D true;=0A= this.execute();=0A= } finally {=0A= this.currentlyExecuting =3D false;=0A= }=0A= }=0A= }=0A= });=0A= Object.extend(String, {=0A= interpret: function(value) {=0A= return value =3D=3D null ? '' : String(value);=0A= },=0A= specialChar: {=0A= '\b': '\\b',=0A= '\t': '\\t',=0A= '\n': '\\n',=0A= '\f': '\\f',=0A= '\r': '\\r',=0A= '\\': '\\\\'=0A= }=0A= });=0A= =0A= Object.extend(String.prototype, {=0A= gsub: function(pattern, replacement) {=0A= var result =3D '', source =3D this, match;=0A= replacement =3D arguments.callee.prepareReplacement(replacement);=0A= =0A= while (source.length > 0) {=0A= if (match =3D source.match(pattern)) {=0A= result +=3D source.slice(0, match.index);=0A= result +=3D String.interpret(replacement(match));=0A= source =3D source.slice(match.index + match[0].length);=0A= } else {=0A= result +=3D source, source =3D '';=0A= }=0A= }=0A= return result;=0A= },=0A= =0A= sub: function(pattern, replacement, count) {=0A= replacement =3D this.gsub.prepareReplacement(replacement);=0A= count =3D Object.isUndefined(count) ? 1 : count;=0A= =0A= return this.gsub(pattern, function(match) {=0A= if (--count < 0) return match[0];=0A= return replacement(match);=0A= });=0A= },=0A= =0A= scan: function(pattern, iterator) {=0A= this.gsub(pattern, iterator);=0A= return String(this);=0A= },=0A= =0A= truncate: function(length, truncation) {=0A= length =3D length || 30;=0A= truncation =3D Object.isUndefined(truncation) ? '...' : truncation;=0A= return this.length > length ?=0A= this.slice(0, length - truncation.length) + truncation : = String(this);=0A= },=0A= =0A= strip: function() {=0A= return this.replace(/^\s+/, '').replace(/\s+$/, '');=0A= },=0A= =0A= stripTags: function() {=0A= return this.replace(/<\/?[^>]+>/gi, '');=0A= },=0A= =0A= stripScripts: function() {=0A= return this.replace(new RegExp(Prototype.ScriptFragment, 'img'), '');=0A= },=0A= =0A= extractScripts: function() {=0A= var matchAll =3D new RegExp(Prototype.ScriptFragment, 'img');=0A= var matchOne =3D new RegExp(Prototype.ScriptFragment, 'im');=0A= return (this.match(matchAll) || []).map(function(scriptTag) {=0A= return (scriptTag.match(matchOne) || ['', ''])[1];=0A= });=0A= },=0A= =0A= evalScripts: function() {=0A= return this.extractScripts().map(function(script) { return = eval(script) });=0A= },=0A= =0A= escapeHTML: function() {=0A= var self =3D arguments.callee;=0A= self.text.data =3D this;=0A= return self.div.innerHTML;=0A= },=0A= =0A= unescapeHTML: function() {=0A= var div =3D new Element('div');=0A= div.innerHTML =3D this.stripTags();=0A= return div.childNodes[0] ? (div.childNodes.length > 1 ?=0A= $A(div.childNodes).inject('', function(memo, node) { return = memo+node.nodeValue }) :=0A= div.childNodes[0].nodeValue) : '';=0A= },=0A= =0A= toQueryParams: function(separator) {=0A= var match =3D this.strip().match(/([^?#]*)(#.*)?$/);=0A= if (!match) return { };=0A= =0A= return match[1].split(separator || '&').inject({ }, function(hash, = pair) {=0A= if ((pair =3D pair.split('=3D'))[0]) {=0A= var key =3D decodeURIComponent(pair.shift());=0A= var value =3D pair.length > 1 ? pair.join('=3D') : pair[0];=0A= if (value !=3D undefined) value =3D decodeURIComponent(value);=0A= =0A= if (key in hash) {=0A= if (!Object.isArray(hash[key])) hash[key] =3D [hash[key]];=0A= hash[key].push(value);=0A= }=0A= else hash[key] =3D value;=0A= }=0A= return hash;=0A= });=0A= },=0A= =0A= toArray: function() {=0A= return this.split('');=0A= },=0A= =0A= succ: function() {=0A= return this.slice(0, this.length - 1) +=0A= String.fromCharCode(this.charCodeAt(this.length - 1) + 1);=0A= },=0A= =0A= times: function(count) {=0A= return count < 1 ? '' : new Array(count + 1).join(this);=0A= },=0A= =0A= camelize: function() {=0A= var parts =3D this.split('-'), len =3D parts.length;=0A= if (len =3D=3D 1) return parts[0];=0A= =0A= var camelized =3D this.charAt(0) =3D=3D '-'=0A= ? parts[0].charAt(0).toUpperCase() + parts[0].substring(1)=0A= : parts[0];=0A= =0A= for (var i =3D 1; i < len; i++)=0A= camelized +=3D parts[i].charAt(0).toUpperCase() + = parts[i].substring(1);=0A= =0A= return camelized;=0A= },=0A= =0A= capitalize: function() {=0A= return this.charAt(0).toUpperCase() + = this.substring(1).toLowerCase();=0A= },=0A= =0A= underscore: function() {=0A= return this.gsub(/::/, = '/').gsub(/([A-Z]+)([A-Z][a-z])/,'#{1}_#{2}').gsub(/([a-z\d])([A-Z])/,'#{= 1}_#{2}').gsub(/-/,'_').toLowerCase();=0A= },=0A= =0A= dasherize: function() {=0A= return this.gsub(/_/,'-');=0A= },=0A= =0A= inspect: function(useDoubleQuotes) {=0A= var escapedString =3D this.gsub(/[\x00-\x1f\\]/, function(match) {=0A= var character =3D String.specialChar[match[0]];=0A= return character ? character : '\\u00' + = match[0].charCodeAt().toPaddedString(2, 16);=0A= });=0A= if (useDoubleQuotes) return '"' + escapedString.replace(/"/g, '\\"') = + '"';=0A= return "'" + escapedString.replace(/'/g, '\\\'') + "'";=0A= },=0A= =0A= toJSON: function() {=0A= return this.inspect(true);=0A= },=0A= =0A= unfilterJSON: function(filter) {=0A= return this.sub(filter || Prototype.JSONFilter, '#{1}');=0A= },=0A= =0A= isJSON: function() {=0A= var str =3D this;=0A= if (str.blank()) return false;=0A= str =3D this.replace(/\\./g, '@').replace(/"[^"\\\n\r]*"/g, '');=0A= return (/^[,:{}\[\]0-9.\-+Eaeflnr-u \n\r\t]*$/).test(str);=0A= },=0A= =0A= evalJSON: function(sanitize) {=0A= var json =3D this.unfilterJSON();=0A= try {=0A= if (!sanitize || json.isJSON()) return eval('(' + json + ')');=0A= } catch (e) { }=0A= throw new SyntaxError('Badly formed JSON string: ' + this.inspect());=0A= },=0A= =0A= include: function(pattern) {=0A= return this.indexOf(pattern) > -1;=0A= },=0A= =0A= startsWith: function(pattern) {=0A= return this.indexOf(pattern) =3D=3D=3D 0;=0A= },=0A= =0A= endsWith: function(pattern) {=0A= var d =3D this.length - pattern.length;=0A= return d >=3D 0 && this.lastIndexOf(pattern) =3D=3D=3D d;=0A= },=0A= =0A= empty: function() {=0A= return this =3D=3D '';=0A= },=0A= =0A= blank: function() {=0A= return /^\s*$/.test(this);=0A= },=0A= =0A= interpolate: function(object, pattern) {=0A= return new Template(this, pattern).evaluate(object);=0A= }=0A= });=0A= =0A= if (Prototype.Browser.WebKit || Prototype.Browser.IE) = Object.extend(String.prototype, {=0A= escapeHTML: function() {=0A= return = this.replace(/&/g,'&').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 /^([^.[]+|\[((?:.*?[^\\])?)\])(\.|\[|$)/;=0A= match =3D pattern.exec(expr);=0A= if (match =3D=3D null) return before;=0A= =0A= while (match !=3D null) {=0A= var comp =3D match[1].startsWith('[') ? match[2].gsub('\\\\]', = ']') : match[1];=0A= ctx =3D ctx[comp];=0A= if (null =3D=3D ctx || '' =3D=3D match[3]) break;=0A= expr =3D expr.substring('[' =3D=3D match[3] ? match[1].length : = match[0].length);=0A= match =3D pattern.exec(expr);=0A= }=0A= =0A= return before + String.interpret(ctx);=0A= }.bind(this));=0A= }=0A= });=0A= Template.Pattern =3D /(^|.|\r|\n)(#\{(.*?)\})/;=0A= =0A= var $break =3D { };=0A= =0A= var Enumerable =3D {=0A= each: function(iterator, context) {=0A= var index =3D 0;=0A= iterator =3D iterator.bind(context);=0A= try {=0A= this._each(function(value) {=0A= iterator(value, index++);=0A= });=0A= } catch (e) {=0A= if (e !=3D $break) throw e;=0A= }=0A= return this;=0A= },=0A= =0A= eachSlice: function(number, iterator, context) {=0A= iterator =3D iterator ? iterator.bind(context) : Prototype.K;=0A= var index =3D -number, slices =3D [], array =3D this.toArray();=0A= while ((index +=3D number) < array.length)=0A= slices.push(array.slice(index, index+number));=0A= return slices.collect(iterator, context);=0A= },=0A= =0A= all: function(iterator, context) {=0A= iterator =3D iterator ? iterator.bind(context) : Prototype.K;=0A= var result =3D true;=0A= this.each(function(value, index) {=0A= result =3D result && !!iterator(value, index);=0A= if (!result) throw $break;=0A= });=0A= return result;=0A= },=0A= =0A= any: function(iterator, context) {=0A= iterator =3D iterator ? iterator.bind(context) : Prototype.K;=0A= var result =3D false;=0A= this.each(function(value, index) {=0A= if (result =3D !!iterator(value, index))=0A= throw $break;=0A= });=0A= return result;=0A= },=0A= =0A= collect: function(iterator, context) {=0A= iterator =3D iterator ? iterator.bind(context) : Prototype.K;=0A= var results =3D [];=0A= this.each(function(value, index) {=0A= results.push(iterator(value, index));=0A= });=0A= return results;=0A= },=0A= =0A= detect: function(iterator, context) {=0A= iterator =3D iterator.bind(context);=0A= var result;=0A= this.each(function(value, index) {=0A= if (iterator(value, index)) {=0A= result =3D value;=0A= throw $break;=0A= }=0A= });=0A= return result;=0A= },=0A= =0A= findAll: function(iterator, context) {=0A= iterator =3D iterator.bind(context);=0A= var results =3D [];=0A= this.each(function(value, index) {=0A= if (iterator(value, index))=0A= results.push(value);=0A= });=0A= return results;=0A= },=0A= =0A= grep: function(filter, iterator, context) {=0A= iterator =3D iterator ? iterator.bind(context) : Prototype.K;=0A= var results =3D [];=0A= =0A= if (Object.isString(filter))=0A= filter =3D new RegExp(filter);=0A= =0A= this.each(function(value, index) {=0A= if (filter.match(value))=0A= results.push(iterator(value, index));=0A= });=0A= return results;=0A= },=0A= =0A= include: function(object) {=0A= if (Object.isFunction(this.indexOf))=0A= if (this.indexOf(object) !=3D -1) return true;=0A= =0A= var found =3D false;=0A= this.each(function(value) {=0A= if (value =3D=3D object) {=0A= found =3D true;=0A= throw $break;=0A= }=0A= });=0A= return found;=0A= },=0A= =0A= inGroupsOf: function(number, fillWith) {=0A= fillWith =3D Object.isUndefined(fillWith) ? null : fillWith;=0A= return this.eachSlice(number, function(slice) {=0A= while(slice.length < number) slice.push(fillWith);=0A= return slice;=0A= });=0A= },=0A= =0A= inject: function(memo, iterator, context) {=0A= iterator =3D iterator.bind(context);=0A= this.each(function(value, index) {=0A= memo =3D iterator(memo, value, index);=0A= });=0A= return memo;=0A= },=0A= =0A= invoke: function(method) {=0A= var args =3D $A(arguments).slice(1);=0A= return this.map(function(value) {=0A= return value[method].apply(value, args);=0A= });=0A= },=0A= =0A= max: function(iterator, context) {=0A= iterator =3D iterator ? iterator.bind(context) : Prototype.K;=0A= var result;=0A= this.each(function(value, index) {=0A= value =3D iterator(value, index);=0A= if (result =3D=3D null || value >=3D result)=0A= result =3D value;=0A= });=0A= return result;=0A= },=0A= =0A= min: function(iterator, context) {=0A= iterator =3D iterator ? iterator.bind(context) : Prototype.K;=0A= var result;=0A= this.each(function(value, index) {=0A= value =3D iterator(value, index);=0A= if (result =3D=3D null || value < result)=0A= result =3D value;=0A= });=0A= return result;=0A= },=0A= =0A= partition: function(iterator, context) {=0A= iterator =3D iterator ? iterator.bind(context) : Prototype.K;=0A= var trues =3D [], falses =3D [];=0A= this.each(function(value, index) {=0A= (iterator(value, index) ?=0A= trues : falses).push(value);=0A= });=0A= return [trues, falses];=0A= },=0A= =0A= pluck: function(property) {=0A= var results =3D [];=0A= this.each(function(value) {=0A= results.push(value[property]);=0A= });=0A= return results;=0A= },=0A= =0A= reject: function(iterator, context) {=0A= iterator =3D iterator.bind(context);=0A= var results =3D [];=0A= this.each(function(value, index) {=0A= if (!iterator(value, index))=0A= results.push(value);=0A= });=0A= return results;=0A= },=0A= =0A= sortBy: function(iterator, context) {=0A= iterator =3D iterator.bind(context);=0A= return this.map(function(value, index) {=0A= return {value: value, criteria: iterator(value, index)};=0A= }).sort(function(left, right) {=0A= var a =3D left.criteria, b =3D right.criteria;=0A= return a < b ? -1 : a > b ? 1 : 0;=0A= }).pluck('value');=0A= },=0A= =0A= toArray: function() {=0A= return this.map();=0A= },=0A= =0A= zip: function() {=0A= var iterator =3D Prototype.K, args =3D $A(arguments);=0A= if (Object.isFunction(args.last()))=0A= iterator =3D args.pop();=0A= =0A= var collections =3D [this].concat(args).map($A);=0A= return this.map(function(value, index) {=0A= return iterator(collections.pluck(index));=0A= });=0A= },=0A= =0A= size: function() {=0A= return this.toArray().length;=0A= },=0A= =0A= inspect: function() {=0A= return '#';=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 || 0, 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 || 0, results =3D new Array(length);=0A= while (length--) results[length] =3D iterable[length];=0A= return results;=0A= }=0A= }=0A= =0A= Array.from =3D $A;=0A= =0A= Object.extend(Array.prototype, Enumerable);=0A= =0A= if (!Array.prototype._reverse) Array.prototype._reverse =3D = Array.prototype.reverse;=0A= =0A= Object.extend(Array.prototype, {=0A= _each: function(iterator) {=0A= for (var i =3D 0, length =3D this.length; i < length; i++)=0A= iterator(this[i]);=0A= },=0A= =0A= clear: function() {=0A= this.length =3D 0;=0A= return this;=0A= },=0A= =0A= first: function() {=0A= return this[0];=0A= },=0A= =0A= last: function() {=0A= return this[this.length - 1];=0A= },=0A= =0A= compact: function() {=0A= return this.select(function(value) {=0A= return value !=3D null;=0A= });=0A= },=0A= =0A= flatten: function() {=0A= return this.inject([], function(array, value) {=0A= return array.concat(Object.isArray(value) ?=0A= value.flatten() : [value]);=0A= });=0A= },=0A= =0A= without: function() {=0A= var values =3D $A(arguments);=0A= return this.select(function(value) {=0A= return !values.include(value);=0A= });=0A= },=0A= =0A= reverse: function(inline) {=0A= return (inline !=3D=3D false ? this : this.toArray())._reverse();=0A= },=0A= =0A= reduce: function() {=0A= return this.length > 1 ? this : this[0];=0A= },=0A= =0A= uniq: function(sorted) {=0A= return this.inject([], function(array, value, index) {=0A= if (0 =3D=3D index || (sorted ? array.last() !=3D value : = !array.include(value)))=0A= array.push(value);=0A= return array;=0A= });=0A= },=0A= =0A= intersect: function(array) {=0A= return this.uniq().findAll(function(item) {=0A= return array.detect(function(value) { return item =3D=3D=3D value = });=0A= });=0A= },=0A= =0A= clone: function() {=0A= return [].concat(this);=0A= },=0A= =0A= size: function() {=0A= return this.length;=0A= },=0A= =0A= inspect: function() {=0A= return '[' + this.map(Object.inspect).join(', ') + ']';=0A= },=0A= =0A= toJSON: function() {=0A= var results =3D [];=0A= this.each(function(object) {=0A= var value =3D Object.toJSON(object);=0A= if (!Object.isUndefined(value)) results.push(value);=0A= });=0A= return '[' + results.join(', ') + ']';=0A= }=0A= });=0A= =0A= // use native browser JS 1.6 implementation if available=0A= if (Object.isFunction(Array.prototype.forEach))=0A= Array.prototype._each =3D Array.prototype.forEach;=0A= =0A= if (!Array.prototype.indexOf) Array.prototype.indexOf =3D function(item, = i) {=0A= i || (i =3D 0);=0A= var length =3D this.length;=0A= if (i < 0) i =3D length + i;=0A= for (; i < length; i++)=0A= if (this[i] =3D=3D=3D item) return i;=0A= return -1;=0A= };=0A= =0A= if (!Array.prototype.lastIndexOf) Array.prototype.lastIndexOf =3D = function(item, i) {=0A= i =3D isNaN(i) ? this.length : (i < 0 ? this.length + i : i) + 1;=0A= var n =3D this.slice(0, i).reverse().indexOf(item);=0A= return (n < 0) ? n : i - n - 1;=0A= };=0A= =0A= Array.prototype.toArray =3D Array.prototype.clone;=0A= =0A= function $w(string) {=0A= if (!Object.isString(string)) return [];=0A= string =3D string.strip();=0A= return string ? string.split(/\s+/) : [];=0A= }=0A= =0A= if (Prototype.Browser.Opera){=0A= Array.prototype.concat =3D function() {=0A= var array =3D [];=0A= for (var i =3D 0, length =3D this.length; i < length; i++) = array.push(this[i]);=0A= for (var i =3D 0, length =3D arguments.length; i < length; i++) {=0A= if (Object.isArray(arguments[i])) {=0A= for (var j =3D 0, arrayLength =3D arguments[i].length; j < = arrayLength; j++)=0A= array.push(arguments[i][j]);=0A= } else {=0A= array.push(arguments[i]);=0A= }=0A= }=0A= return array;=0A= };=0A= }=0A= Object.extend(Number.prototype, {=0A= toColorPart: function() {=0A= return this.toPaddedString(2, 16);=0A= },=0A= =0A= succ: function() {=0A= return this + 1;=0A= },=0A= =0A= times: function(iterator) {=0A= $R(0, this, true).each(iterator);=0A= return this;=0A= },=0A= =0A= toPaddedString: function(length, radix) {=0A= var string =3D this.toString(radix || 10);=0A= return '0'.times(length - string.length) + string;=0A= },=0A= =0A= toJSON: function() {=0A= return isFinite(this) ? this.toString() : 'null';=0A= }=0A= });=0A= =0A= $w('abs round ceil floor').each(function(method){=0A= Number.prototype[method] =3D Math[method].methodize();=0A= });=0A= function $H(object) {=0A= return new Hash(object);=0A= };=0A= =0A= var Hash =3D Class.create(Enumerable, (function() {=0A= =0A= function toQueryPair(key, value) {=0A= if (Object.isUndefined(value)) return key;=0A= return key + '=3D' + encodeURIComponent(String.interpret(value));=0A= }=0A= =0A= return {=0A= initialize: function(object) {=0A= this._object =3D Object.isHash(object) ? object.toObject() : = Object.clone(object);=0A= },=0A= =0A= _each: function(iterator) {=0A= for (var key in this._object) {=0A= var value =3D this._object[key], pair =3D [key, value];=0A= pair.key =3D key;=0A= pair.value =3D value;=0A= iterator(pair);=0A= }=0A= },=0A= =0A= set: function(key, value) {=0A= return this._object[key] =3D value;=0A= },=0A= =0A= get: function(key) {=0A= return this._object[key];=0A= },=0A= =0A= unset: function(key) {=0A= var value =3D this._object[key];=0A= delete this._object[key];=0A= return value;=0A= },=0A= =0A= toObject: function() {=0A= return Object.clone(this._object);=0A= },=0A= =0A= keys: function() {=0A= return this.pluck('key');=0A= },=0A= =0A= values: function() {=0A= return this.pluck('value');=0A= },=0A= =0A= index: function(value) {=0A= var match =3D this.detect(function(pair) {=0A= return pair.value =3D=3D=3D value;=0A= });=0A= return match && match.key;=0A= },=0A= =0A= merge: function(object) {=0A= return this.clone().update(object);=0A= },=0A= =0A= update: function(object) {=0A= return new Hash(object).inject(this, function(result, pair) {=0A= result.set(pair.key, pair.value);=0A= return result;=0A= });=0A= },=0A= =0A= toQueryString: function() {=0A= return this.map(function(pair) {=0A= var key =3D encodeURIComponent(pair.key), values =3D pair.value;=0A= =0A= if (values && typeof values =3D=3D 'object') {=0A= if (Object.isArray(values))=0A= return values.map(toQueryPair.curry(key)).join('&');=0A= }=0A= return toQueryPair(key, values);=0A= }).join('&');=0A= },=0A= =0A= inspect: function() {=0A= return '#';=0A= },=0A= =0A= toJSON: function() {=0A= return Object.toJSON(this.toObject());=0A= },=0A= =0A= clone: function() {=0A= return new Hash(this);=0A= }=0A= }=0A= })());=0A= =0A= Hash.prototype.toTemplateReplacements =3D Hash.prototype.toObject;=0A= Hash.from =3D $H;=0A= var ObjectRange =3D Class.create(Enumerable, {=0A= initialize: function(start, end, exclusive) {=0A= this.start =3D start;=0A= this.end =3D end;=0A= this.exclusive =3D exclusive;=0A= },=0A= =0A= _each: function(iterator) {=0A= var value =3D this.start;=0A= while (this.include(value)) {=0A= iterator(value);=0A= value =3D value.succ();=0A= }=0A= },=0A= =0A= include: function(value) {=0A= if (value < this.start)=0A= return false;=0A= if (this.exclusive)=0A= return value < this.end;=0A= return value <=3D this.end;=0A= }=0A= });=0A= =0A= var $R =3D function(start, end, exclusive) {=0A= return new ObjectRange(start, end, exclusive);=0A= };=0A= =0A= var Ajax =3D {=0A= getTransport: function() {=0A= return Try.these(=0A= function() {return new XMLHttpRequest()},=0A= function() {return new ActiveXObject('Msxml2.XMLHTTP')},=0A= function() {return new ActiveXObject('Microsoft.XMLHTTP')}=0A= ) || false;=0A= },=0A= =0A= activeRequestCount: 0=0A= };=0A= =0A= Ajax.Responders =3D {=0A= responders: [],=0A= =0A= _each: function(iterator) {=0A= this.responders._each(iterator);=0A= },=0A= =0A= register: function(responder) {=0A= if (!this.include(responder))=0A= this.responders.push(responder);=0A= },=0A= =0A= unregister: function(responder) {=0A= this.responders =3D this.responders.without(responder);=0A= },=0A= =0A= dispatch: function(callback, request, transport, json) {=0A= this.each(function(responder) {=0A= if (Object.isFunction(responder[callback])) {=0A= try {=0A= responder[callback].apply(responder, [request, transport, = json]);=0A= } catch (e) { }=0A= }=0A= });=0A= }=0A= };=0A= =0A= Object.extend(Ajax.Responders, Enumerable);=0A= =0A= Ajax.Responders.register({=0A= onCreate: function() { Ajax.activeRequestCount++ },=0A= onComplete: function() { Ajax.activeRequestCount-- }=0A= });=0A= =0A= Ajax.Base =3D Class.create({=0A= initialize: function(options) {=0A= this.options =3D {=0A= method: 'post',=0A= asynchronous: true,=0A= contentType: 'application/x-www-form-urlencoded',=0A= encoding: 'UTF-8',=0A= parameters: '',=0A= evalJSON: true,=0A= evalJS: true=0A= };=0A= Object.extend(this.options, options || { });=0A= =0A= this.options.method =3D this.options.method.toLowerCase();=0A= =0A= if (Object.isString(this.options.parameters))=0A= this.options.parameters =3D = this.options.parameters.toQueryParams();=0A= else if (Object.isHash(this.options.parameters))=0A= this.options.parameters =3D this.options.parameters.toObject();=0A= }=0A= });=0A= =0A= Ajax.Request =3D Class.create(Ajax.Base, {=0A= _complete: false,=0A= =0A= initialize: function($super, url, options) {=0A= $super(options);=0A= this.transport =3D Ajax.getTransport();=0A= this.request(url);=0A= },=0A= =0A= request: function(url) {=0A= this.url =3D url;=0A= this.method =3D this.options.method;=0A= var params =3D Object.clone(this.options.parameters);=0A= =0A= if (!['get', 'post'].include(this.method)) {=0A= // simulate other verbs over post=0A= params['_method'] =3D this.method;=0A= this.method =3D 'post';=0A= }=0A= =0A= this.parameters =3D params;=0A= =0A= if (params =3D Object.toQueryString(params)) {=0A= // when GET, append parameters to URL=0A= if (this.method =3D=3D 'get')=0A= this.url +=3D (this.url.include('?') ? '&' : '?') + params;=0A= else if (/Konqueror|Safari|KHTML/.test(navigator.userAgent))=0A= params +=3D '&_=3D';=0A= }=0A= =0A= try {=0A= var response =3D new Ajax.Response(this);=0A= if (this.options.onCreate) this.options.onCreate(response);=0A= Ajax.Responders.dispatch('onCreate', this, response);=0A= =0A= this.transport.open(this.method.toUpperCase(), this.url,=0A= this.options.asynchronous);=0A= =0A= if (this.options.asynchronous) = this.respondToReadyState.bind(this).defer(1);=0A= =0A= this.transport.onreadystatechange =3D = this.onStateChange.bind(this);=0A= this.setRequestHeaders();=0A= =0A= this.body =3D this.method =3D=3D 'post' ? (this.options.postBody = || params) : null;=0A= this.transport.send(this.body);=0A= =0A= /* Force Firefox to handle ready state 4 for synchronous requests = */=0A= if (!this.options.asynchronous && this.transport.overrideMimeType)=0A= this.onStateChange();=0A= =0A= }=0A= catch (e) {=0A= this.dispatchException(e);=0A= }=0A= },=0A= =0A= onStateChange: function() {=0A= var readyState =3D this.transport.readyState;=0A= if (readyState > 1 && !((readyState =3D=3D 4) && this._complete))=0A= this.respondToReadyState(this.transport.readyState);=0A= },=0A= =0A= setRequestHeaders: function() {=0A= var headers =3D {=0A= 'X-Requested-With': 'XMLHttpRequest',=0A= 'X-Prototype-Version': Prototype.Version,=0A= 'Accept': 'text/javascript, text/html, application/xml, text/xml, = */*'=0A= };=0A= =0A= if (this.method =3D=3D 'post') {=0A= headers['Content-type'] =3D this.options.contentType +=0A= (this.options.encoding ? '; charset=3D' + this.options.encoding = : '');=0A= =0A= /* Force "Connection: close" for older Mozilla browsers to work=0A= * around a bug where XMLHttpRequest sends an incorrect=0A= * Content-length header. See Mozilla Bugzilla #246651.=0A= */=0A= if (this.transport.overrideMimeType &&=0A= (navigator.userAgent.match(/Gecko\/(\d{4})/) || [0,2005])[1] < = 2005)=0A= headers['Connection'] =3D 'close';=0A= }=0A= =0A= // user-defined headers=0A= if (typeof this.options.requestHeaders =3D=3D 'object') {=0A= var extras =3D this.options.requestHeaders;=0A= =0A= if (Object.isFunction(extras.push))=0A= for (var i =3D 0, length =3D extras.length; i < length; i +=3D 2)=0A= headers[extras[i]] =3D extras[i+1];=0A= else=0A= $H(extras).each(function(pair) { headers[pair.key] =3D = pair.value });=0A= }=0A= =0A= for (var name in headers)=0A= this.transport.setRequestHeader(name, headers[name]);=0A= },=0A= =0A= success: function() {=0A= var status =3D this.getStatus();=0A= return !status || (status >=3D 200 && status < 300);=0A= },=0A= =0A= getStatus: function() {=0A= try {=0A= return this.transport.status || 0;=0A= } catch (e) { return 0 }=0A= },=0A= =0A= respondToReadyState: function(readyState) {=0A= var state =3D Ajax.Request.Events[readyState], response =3D new = Ajax.Response(this);=0A= =0A= if (state =3D=3D 'Complete') {=0A= try {=0A= this._complete =3D true;=0A= (this.options['on' + response.status]=0A= || this.options['on' + (this.success() ? 'Success' : 'Failure')]=0A= || Prototype.emptyFunction)(response, response.headerJSON);=0A= } catch (e) {=0A= this.dispatchException(e);=0A= }=0A= =0A= var contentType =3D response.getHeader('Content-type');=0A= if (this.options.evalJS =3D=3D 'force'=0A= || (this.options.evalJS && contentType=0A= && = contentType.match(/^\s*(text|application)\/(x-)?(java|ecma)script(;.*)?\s= *$/i)))=0A= this.evalResponse();=0A= }=0A= =0A= try {=0A= (this.options['on' + state] || Prototype.emptyFunction)(response, = response.headerJSON);=0A= Ajax.Responders.dispatch('on' + state, this, response, = response.headerJSON);=0A= } catch (e) {=0A= this.dispatchException(e);=0A= }=0A= =0A= if (state =3D=3D 'Complete') {=0A= // avoid memory leak in MSIE: clean up=0A= this.transport.onreadystatechange =3D Prototype.emptyFunction;=0A= }=0A= },=0A= =0A= getHeader: function(name) {=0A= try {=0A= return this.transport.getResponseHeader(name) || null;=0A= } catch (e) { return null }=0A= },=0A= =0A= evalResponse: function() {=0A= try {=0A= return eval((this.transport.responseText || '').unfilterJSON());=0A= } catch (e) {=0A= this.dispatchException(e);=0A= }=0A= },=0A= =0A= dispatchException: function(exception) {=0A= (this.options.onException || Prototype.emptyFunction)(this, = exception);=0A= Ajax.Responders.dispatch('onException', this, exception);=0A= }=0A= });=0A= =0A= Ajax.Request.Events =3D=0A= ['Uninitialized', 'Loading', 'Loaded', 'Interactive', 'Complete'];=0A= =0A= Ajax.Response =3D Class.create({=0A= initialize: function(request){=0A= this.request =3D request;=0A= var transport =3D this.transport =3D request.transport,=0A= readyState =3D this.readyState =3D transport.readyState;=0A= =0A= if((readyState > 2 && !Prototype.Browser.IE) || readyState =3D=3D 4) = {=0A= this.status =3D this.getStatus();=0A= this.statusText =3D this.getStatusText();=0A= this.responseText =3D String.interpret(transport.responseText);=0A= this.headerJSON =3D this._getHeaderJSON();=0A= }=0A= =0A= if(readyState =3D=3D 4) {=0A= var xml =3D transport.responseXML;=0A= this.responseXML =3D Object.isUndefined(xml) ? null : xml;=0A= this.responseJSON =3D this._getResponseJSON();=0A= }=0A= },=0A= =0A= status: 0,=0A= statusText: '',=0A= =0A= getStatus: Ajax.Request.prototype.getStatus,=0A= =0A= getStatusText: function() {=0A= try {=0A= return this.transport.statusText || '';=0A= } catch (e) { return '' }=0A= },=0A= =0A= getHeader: Ajax.Request.prototype.getHeader,=0A= =0A= getAllHeaders: function() {=0A= try {=0A= return this.getAllResponseHeaders();=0A= } catch (e) { return null }=0A= },=0A= =0A= getResponseHeader: function(name) {=0A= return this.transport.getResponseHeader(name);=0A= },=0A= =0A= getAllResponseHeaders: function() {=0A= return this.transport.getAllResponseHeaders();=0A= },=0A= =0A= _getHeaderJSON: function() {=0A= var json =3D this.getHeader('X-JSON');=0A= if (!json) return null;=0A= json =3D decodeURIComponent(escape(json));=0A= try {=0A= return json.evalJSON(this.request.options.sanitizeJSON);=0A= } catch (e) {=0A= this.request.dispatchException(e);=0A= }=0A= },=0A= =0A= _getResponseJSON: function() {=0A= var options =3D this.request.options;=0A= if (!options.evalJSON || (options.evalJSON !=3D 'force' &&=0A= !(this.getHeader('Content-type') || = '').include('application/json')) ||=0A= this.responseText.blank())=0A= return null;=0A= try {=0A= return this.responseText.evalJSON(options.sanitizeJSON);=0A= } catch (e) {=0A= this.request.dispatchException(e);=0A= }=0A= }=0A= });=0A= =0A= Ajax.Updater =3D Class.create(Ajax.Request, {=0A= initialize: function($super, container, url, options) {=0A= this.container =3D {=0A= success: (container.success || container),=0A= failure: (container.failure || (container.success ? null : = container))=0A= };=0A= =0A= options =3D Object.clone(options);=0A= var onComplete =3D options.onComplete;=0A= options.onComplete =3D (function(response, json) {=0A= this.updateContent(response.responseText);=0A= if (Object.isFunction(onComplete)) onComplete(response, json);=0A= }).bind(this);=0A= =0A= $super(url, options);=0A= },=0A= =0A= updateContent: function(responseText) {=0A= var receiver =3D this.container[this.success() ? 'success' : = 'failure'],=0A= options =3D this.options;=0A= =0A= if (!options.evalScripts) responseText =3D = responseText.stripScripts();=0A= =0A= if (receiver =3D $(receiver)) {=0A= if (options.insertion) {=0A= if (Object.isString(options.insertion)) {=0A= var insertion =3D { }; insertion[options.insertion] =3D = responseText;=0A= receiver.insert(insertion);=0A= }=0A= else options.insertion(receiver, responseText);=0A= }=0A= else receiver.update(responseText);=0A= }=0A= }=0A= });=0A= =0A= Ajax.PeriodicalUpdater =3D Class.create(Ajax.Base, {=0A= initialize: function($super, container, url, options) {=0A= $super(options);=0A= this.onComplete =3D this.options.onComplete;=0A= =0A= this.frequency =3D (this.options.frequency || 2);=0A= this.decay =3D (this.options.decay || 1);=0A= =0A= this.updater =3D { };=0A= this.container =3D container;=0A= this.url =3D url;=0A= =0A= this.start();=0A= },=0A= =0A= start: function() {=0A= this.options.onComplete =3D this.updateComplete.bind(this);=0A= this.onTimerEvent();=0A= },=0A= =0A= stop: function() {=0A= this.updater.options.onComplete =3D undefined;=0A= clearTimeout(this.timer);=0A= (this.onComplete || Prototype.emptyFunction).apply(this, arguments);=0A= },=0A= =0A= updateComplete: function(response) {=0A= if (this.options.decay) {=0A= this.decay =3D (response.responseText =3D=3D this.lastText ?=0A= this.decay * this.options.decay : 1);=0A= =0A= this.lastText =3D response.responseText;=0A= }=0A= this.timer =3D this.onTimerEvent.bind(this).delay(this.decay * = this.frequency);=0A= },=0A= =0A= onTimerEvent: function() {=0A= this.updater =3D new Ajax.Updater(this.container, this.url, = this.options);=0A= }=0A= });=0A= function $(element) {=0A= if (arguments.length > 1) {=0A= for (var i =3D 0, elements =3D [], length =3D arguments.length; i < = length; i++)=0A= elements.push($(arguments[i]));=0A= return elements;=0A= }=0A= if (Object.isString(element))=0A= element =3D document.getElementById(element);=0A= return Element.extend(element);=0A= }=0A= =0A= if (Prototype.BrowserFeatures.XPath) {=0A= document._getElementsByXPath =3D function(expression, parentElement) {=0A= var results =3D [];=0A= var query =3D document.evaluate(expression, $(parentElement) || = document,=0A= null, XPathResult.ORDERED_NODE_SNAPSHOT_TYPE, null);=0A= for (var i =3D 0, length =3D query.snapshotLength; i < length; i++)=0A= results.push(Element.extend(query.snapshotItem(i)));=0A= return results;=0A= };=0A= }=0A= =0A= /*-----------------------------------------------------------------------= ---*/=0A= =0A= if (!window.Node) var Node =3D { };=0A= =0A= if (!Node.ELEMENT_NODE) {=0A= // DOM level 2 ECMAScript Language Binding=0A= Object.extend(Node, {=0A= ELEMENT_NODE: 1,=0A= ATTRIBUTE_NODE: 2,=0A= TEXT_NODE: 3,=0A= CDATA_SECTION_NODE: 4,=0A= ENTITY_REFERENCE_NODE: 5,=0A= ENTITY_NODE: 6,=0A= PROCESSING_INSTRUCTION_NODE: 7,=0A= COMMENT_NODE: 8,=0A= DOCUMENT_NODE: 9,=0A= DOCUMENT_TYPE_NODE: 10,=0A= DOCUMENT_FRAGMENT_NODE: 11,=0A= NOTATION_NODE: 12=0A= });=0A= }=0A= =0A= (function() {=0A= var element =3D this.Element;=0A= this.Element =3D function(tagName, attributes) {=0A= attributes =3D attributes || { };=0A= tagName =3D tagName.toLowerCase();=0A= var cache =3D Element.cache;=0A= if (Prototype.Browser.IE && attributes.name) {=0A= tagName =3D '<' + tagName + ' name=3D"' + attributes.name + '">';=0A= delete attributes.name;=0A= return Element.writeAttribute(document.createElement(tagName), = attributes);=0A= }=0A= if (!cache[tagName]) cache[tagName] =3D = Element.extend(document.createElement(tagName));=0A= return Element.writeAttribute(cache[tagName].cloneNode(false), = attributes);=0A= };=0A= Object.extend(this.Element, element || { });=0A= }).call(window);=0A= =0A= Element.cache =3D { };=0A= =0A= Element.Methods =3D {=0A= visible: function(element) {=0A= return $(element).style.display !=3D 'none';=0A= },=0A= =0A= toggle: function(element) {=0A= element =3D $(element);=0A= Element[Element.visible(element) ? 'hide' : 'show'](element);=0A= return element;=0A= },=0A= =0A= hide: function(element) {=0A= $(element).style.display =3D 'none';=0A= return element;=0A= },=0A= =0A= show: function(element) {=0A= $(element).style.display =3D '';=0A= return element;=0A= },=0A= =0A= remove: function(element) {=0A= element =3D $(element);=0A= element.parentNode.removeChild(element);=0A= return element;=0A= },=0A= =0A= update: function(element, content) {=0A= element =3D $(element);=0A= if (content && content.toElement) content =3D content.toElement();=0A= if (Object.isElement(content)) return = element.update().insert(content);=0A= content =3D Object.toHTML(content);=0A= element.innerHTML =3D content.stripScripts();=0A= content.evalScripts.bind(content).defer();=0A= return element;=0A= },=0A= =0A= replace: function(element, content) {=0A= element =3D $(element);=0A= if (content && content.toElement) content =3D content.toElement();=0A= else if (!Object.isElement(content)) {=0A= content =3D Object.toHTML(content);=0A= var range =3D element.ownerDocument.createRange();=0A= range.selectNode(element);=0A= content.evalScripts.bind(content).defer();=0A= content =3D range.createContextualFragment(content.stripScripts());=0A= }=0A= element.parentNode.replaceChild(content, element);=0A= return element;=0A= },=0A= =0A= insert: function(element, insertions) {=0A= element =3D $(element);=0A= =0A= if (Object.isString(insertions) || Object.isNumber(insertions) ||=0A= Object.isElement(insertions) || (insertions && = (insertions.toElement || insertions.toHTML)))=0A= insertions =3D {bottom:insertions};=0A= =0A= var content, insert, tagName, childNodes;=0A= =0A= for (position in insertions) {=0A= content =3D insertions[position];=0A= position =3D position.toLowerCase();=0A= insert =3D Element._insertionTranslations[position];=0A= =0A= if (content && content.toElement) content =3D content.toElement();=0A= if (Object.isElement(content)) {=0A= insert(element, content);=0A= continue;=0A= }=0A= =0A= content =3D Object.toHTML(content);=0A= =0A= tagName =3D ((position =3D=3D 'before' || position =3D=3D 'after')=0A= ? element.parentNode : element).tagName.toUpperCase();=0A= =0A= childNodes =3D Element._getContentFromAnonymousElement(tagName, = content.stripScripts());=0A= =0A= if (position =3D=3D 'top' || position =3D=3D 'after') = childNodes.reverse();=0A= childNodes.each(insert.curry(element));=0A= =0A= content.evalScripts.bind(content).defer();=0A= }=0A= =0A= return element;=0A= },=0A= =0A= wrap: function(element, wrapper, attributes) {=0A= element =3D $(element);=0A= if (Object.isElement(wrapper))=0A= $(wrapper).writeAttribute(attributes || { });=0A= else if (Object.isString(wrapper)) wrapper =3D new Element(wrapper, = attributes);=0A= else wrapper =3D new Element('div', wrapper);=0A= if (element.parentNode)=0A= element.parentNode.replaceChild(wrapper, element);=0A= wrapper.appendChild(element);=0A= return wrapper;=0A= },=0A= =0A= inspect: function(element) {=0A= element =3D $(element);=0A= var result =3D '<' + element.tagName.toLowerCase();=0A= $H({'id': 'id', 'className': 'class'}).each(function(pair) {=0A= var property =3D pair.first(), attribute =3D pair.last();=0A= var value =3D (element[property] || '').toString();=0A= if (value) result +=3D ' ' + attribute + '=3D' + = value.inspect(true);=0A= });=0A= return result + '>';=0A= },=0A= =0A= recursivelyCollect: function(element, property) {=0A= element =3D $(element);=0A= var elements =3D [];=0A= while (element =3D element[property])=0A= if (element.nodeType =3D=3D 1)=0A= elements.push(Element.extend(element));=0A= return elements;=0A= },=0A= =0A= ancestors: function(element) {=0A= return $(element).recursivelyCollect('parentNode');=0A= },=0A= =0A= descendants: function(element) {=0A= return $(element).getElementsBySelector("*");=0A= },=0A= =0A= firstDescendant: function(element) {=0A= element =3D $(element).firstChild;=0A= while (element && element.nodeType !=3D 1) element =3D = element.nextSibling;=0A= return $(element);=0A= },=0A= =0A= immediateDescendants: function(element) {=0A= if (!(element =3D $(element).firstChild)) return [];=0A= while (element && element.nodeType !=3D 1) element =3D = element.nextSibling;=0A= if (element) return [element].concat($(element).nextSiblings());=0A= return [];=0A= },=0A= =0A= previousSiblings: function(element) {=0A= return $(element).recursivelyCollect('previousSibling');=0A= },=0A= =0A= nextSiblings: function(element) {=0A= return $(element).recursivelyCollect('nextSibling');=0A= },=0A= =0A= siblings: function(element) {=0A= element =3D $(element);=0A= return = element.previousSiblings().reverse().concat(element.nextSiblings());=0A= },=0A= =0A= match: function(element, selector) {=0A= if (Object.isString(selector))=0A= selector =3D new Selector(selector);=0A= return selector.match($(element));=0A= },=0A= =0A= up: function(element, expression, index) {=0A= element =3D $(element);=0A= if (arguments.length =3D=3D 1) return $(element.parentNode);=0A= var ancestors =3D element.ancestors();=0A= return Object.isNumber(expression) ? ancestors[expression] :=0A= Selector.findElement(ancestors, expression, index);=0A= },=0A= =0A= down: function(element, expression, index) {=0A= element =3D $(element);=0A= if (arguments.length =3D=3D 1) return element.firstDescendant();=0A= return Object.isNumber(expression) ? = element.descendants()[expression] :=0A= element.select(expression)[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 Object.isNumber(expression) ? previousSiblings[expression] :=0A= Selector.findElement(previousSiblings, expression, index);=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 Object.isNumber(expression) ? nextSiblings[expression] :=0A= Selector.findElement(nextSiblings, expression, index);=0A= },=0A= =0A= select: function() {=0A= var args =3D $A(arguments), element =3D $(args.shift());=0A= return Selector.findChildElements(element, args);=0A= },=0A= =0A= adjacent: function() {=0A= var args =3D $A(arguments), element =3D $(args.shift());=0A= return Selector.findChildElements(element.parentNode, = args).without(element);=0A= },=0A= =0A= identify: function(element) {=0A= element =3D $(element);=0A= var id =3D element.readAttribute('id'), self =3D arguments.callee;=0A= if (id) return id;=0A= do { id =3D 'anonymous_element_' + self.counter++ } while ($(id));=0A= element.writeAttribute('id', id);=0A= return id;=0A= },=0A= =0A= readAttribute: function(element, name) {=0A= element =3D $(element);=0A= if (Prototype.Browser.IE) {=0A= var t =3D Element._attributeTranslations.read;=0A= if (t.values[name]) return t.values[name](element, name);=0A= if (t.names[name]) name =3D t.names[name];=0A= if (name.include(':')) {=0A= return (!element.attributes || !element.attributes[name]) ? null = :=0A= element.attributes[name].value;=0A= }=0A= }=0A= return element.getAttribute(name);=0A= },=0A= =0A= writeAttribute: function(element, name, value) {=0A= element =3D $(element);=0A= var attributes =3D { }, t =3D Element._attributeTranslations.write;=0A= =0A= if (typeof name =3D=3D 'object') attributes =3D name;=0A= else attributes[name] =3D Object.isUndefined(value) ? true : value;=0A= =0A= for (var attr in attributes) {=0A= name =3D t.names[attr] || attr;=0A= value =3D attributes[attr];=0A= if (t.values[attr]) name =3D t.values[attr](element, value);=0A= if (value =3D=3D=3D false || value =3D=3D=3D null)=0A= element.removeAttribute(name);=0A= else if (value =3D=3D=3D true)=0A= element.setAttribute(name, name);=0A= else element.setAttribute(name, value);=0A= }=0A= return element;=0A= },=0A= =0A= getHeight: function(element) {=0A= return $(element).getDimensions().height;=0A= },=0A= =0A= getWidth: function(element) {=0A= return $(element).getDimensions().width;=0A= },=0A= =0A= classNames: function(element) {=0A= return new Element.ClassNames(element);=0A= },=0A= =0A= hasClassName: function(element, className) {=0A= if (!(element =3D $(element))) return;=0A= var elementClassName =3D element.className;=0A= return (elementClassName.length > 0 && (elementClassName =3D=3D = className ||=0A= new RegExp("(^|\\s)" + className + = "(\\s|$)").test(elementClassName)));=0A= },=0A= =0A= addClassName: function(element, className) {=0A= if (!(element =3D $(element))) return;=0A= if (!element.hasClassName(className))=0A= element.className +=3D (element.className ? ' ' : '') + className;=0A= return element;=0A= },=0A= =0A= removeClassName: function(element, className) {=0A= if (!(element =3D $(element))) return;=0A= element.className =3D element.className.replace(=0A= new RegExp("(^|\\s+)" + className + "(\\s+|$)"), ' ').strip();=0A= return element;=0A= },=0A= =0A= toggleClassName: function(element, className) {=0A= if (!(element =3D $(element))) return;=0A= return element[element.hasClassName(className) ?=0A= 'removeClassName' : 'addClassName'](className);=0A= },=0A= =0A= // removes whitespace-only text node children=0A= cleanWhitespace: function(element) {=0A= element =3D $(element);=0A= var node =3D element.firstChild;=0A= while (node) {=0A= var nextNode =3D node.nextSibling;=0A= if (node.nodeType =3D=3D 3 && !/\S/.test(node.nodeValue))=0A= element.removeChild(node);=0A= node =3D nextNode;=0A= }=0A= return element;=0A= },=0A= =0A= empty: function(element) {=0A= return $(element).innerHTML.blank();=0A= },=0A= =0A= descendantOf: function(element, ancestor) {=0A= element =3D $(element), ancestor =3D $(ancestor);=0A= var originalAncestor =3D ancestor;=0A= =0A= if (element.compareDocumentPosition)=0A= return (element.compareDocumentPosition(ancestor) & 8) =3D=3D=3D 8;=0A= =0A= if (element.sourceIndex && !Prototype.Browser.Opera) {=0A= var e =3D element.sourceIndex, a =3D ancestor.sourceIndex,=0A= nextAncestor =3D ancestor.nextSibling;=0A= if (!nextAncestor) {=0A= do { ancestor =3D ancestor.parentNode; }=0A= while (!(nextAncestor =3D ancestor.nextSibling) && = ancestor.parentNode);=0A= }=0A= if (nextAncestor) return (e > a && e < nextAncestor.sourceIndex);=0A= }=0A= =0A= while (element =3D element.parentNode)=0A= if (element =3D=3D originalAncestor) return true;=0A= return false;=0A= },=0A= =0A= scrollTo: function(element) {=0A= element =3D $(element);=0A= var pos =3D element.cumulativeOffset();=0A= window.scrollTo(pos[0], pos[1]);=0A= return element;=0A= },=0A= =0A= getStyle: function(element, style) {=0A= element =3D $(element);=0A= style =3D style =3D=3D 'float' ? 'cssFloat' : style.camelize();=0A= var value =3D element.style[style];=0A= if (!value) {=0A= var css =3D document.defaultView.getComputedStyle(element, null);=0A= value =3D css ? css[style] : null;=0A= }=0A= if (style =3D=3D 'opacity') return value ? parseFloat(value) : 1.0;=0A= return value =3D=3D 'auto' ? null : value;=0A= },=0A= =0A= getOpacity: function(element) {=0A= return $(element).getStyle('opacity');=0A= },=0A= =0A= setStyle: function(element, styles) {=0A= element =3D $(element);=0A= var elementStyle =3D element.style, match;=0A= if (Object.isString(styles)) {=0A= element.style.cssText +=3D ';' + styles;=0A= return styles.include('opacity') ?=0A= element.setOpacity(styles.match(/opacity:\s*(\d?\.?\d*)/)[1]) : = element;=0A= }=0A= for (var property in styles)=0A= if (property =3D=3D 'opacity') = element.setOpacity(styles[property]);=0A= else=0A= elementStyle[(property =3D=3D 'float' || property =3D=3D = 'cssFloat') ?=0A= (Object.isUndefined(elementStyle.styleFloat) ? 'cssFloat' : = 'styleFloat') :=0A= property] =3D styles[property];=0A= =0A= return element;=0A= },=0A= =0A= setOpacity: function(element, value) {=0A= element =3D $(element);=0A= element.style.opacity =3D (value =3D=3D 1 || value =3D=3D=3D '') ? = '' :=0A= (value < 0.00001) ? 0 : value;=0A= return element;=0A= },=0A= =0A= getDimensions: function(element) {=0A= element =3D $(element);=0A= var display =3D $(element).getStyle('display');=0A= if (display !=3D 'none' && display !=3D null) // Safari bug=0A= return {width: element.offsetWidth, height: element.offsetHeight};=0A= =0A= // All *Width and *Height properties give 0 on elements with display = none,=0A= // so enable the element temporarily=0A= var els =3D element.style;=0A= var originalVisibility =3D els.visibility;=0A= var originalPosition =3D els.position;=0A= var originalDisplay =3D els.display;=0A= els.visibility =3D 'hidden';=0A= els.position =3D 'absolute';=0A= els.display =3D 'block';=0A= var originalWidth =3D element.clientWidth;=0A= var originalHeight =3D element.clientHeight;=0A= els.display =3D originalDisplay;=0A= els.position =3D originalPosition;=0A= els.visibility =3D originalVisibility;=0A= return {width: originalWidth, height: originalHeight};=0A= },=0A= =0A= makePositioned: function(element) {=0A= element =3D $(element);=0A= var pos =3D Element.getStyle(element, 'position');=0A= if (pos =3D=3D 'static' || !pos) {=0A= element._madePositioned =3D true;=0A= element.style.position =3D 'relative';=0A= // Opera returns the offset relative to the positioning context, = when an=0A= // element is position relative but top and left have not been = defined=0A= if (window.opera) {=0A= element.style.top =3D 0;=0A= element.style.left =3D 0;=0A= }=0A= }=0A= return element;=0A= },=0A= =0A= undoPositioned: function(element) {=0A= element =3D $(element);=0A= if (element._madePositioned) {=0A= element._madePositioned =3D undefined;=0A= element.style.position =3D=0A= element.style.top =3D=0A= element.style.left =3D=0A= element.style.bottom =3D=0A= element.style.right =3D '';=0A= }=0A= return element;=0A= },=0A= =0A= makeClipping: function(element) {=0A= element =3D $(element);=0A= if (element._overflow) return element;=0A= element._overflow =3D Element.getStyle(element, 'overflow') || = 'auto';=0A= if (element._overflow !=3D=3D 'hidden')=0A= element.style.overflow =3D 'hidden';=0A= return element;=0A= },=0A= =0A= undoClipping: function(element) {=0A= element =3D $(element);=0A= if (!element._overflow) return element;=0A= element.style.overflow =3D element._overflow =3D=3D 'auto' ? '' : = element._overflow;=0A= element._overflow =3D null;=0A= return element;=0A= },=0A= =0A= cumulativeOffset: function(element) {=0A= var valueT =3D 0, valueL =3D 0;=0A= do {=0A= valueT +=3D element.offsetTop || 0;=0A= valueL +=3D element.offsetLeft || 0;=0A= element =3D element.offsetParent;=0A= } while (element);=0A= return Element._returnOffset(valueL, valueT);=0A= },=0A= =0A= positionedOffset: function(element) {=0A= var valueT =3D 0, valueL =3D 0;=0A= do {=0A= valueT +=3D element.offsetTop || 0;=0A= valueL +=3D element.offsetLeft || 0;=0A= element =3D element.offsetParent;=0A= if (element) {=0A= if (element.tagName =3D=3D 'BODY') break;=0A= var p =3D Element.getStyle(element, 'position');=0A= if (p =3D=3D 'relative' || p =3D=3D 'absolute') break;=0A= }=0A= } while (element);=0A= return Element._returnOffset(valueL, valueT);=0A= },=0A= =0A= absolutize: function(element) {=0A= element =3D $(element);=0A= if (element.getStyle('position') =3D=3D 'absolute') return;=0A= // Position.prepare(); // To be done manually by Scripty when it = needs it.=0A= =0A= var offsets =3D element.positionedOffset();=0A= var top =3D offsets[1];=0A= var left =3D offsets[0];=0A= var width =3D element.clientWidth;=0A= var height =3D element.clientHeight;=0A= =0A= element._originalLeft =3D left - parseFloat(element.style.left || = 0);=0A= element._originalTop =3D top - parseFloat(element.style.top || = 0);=0A= element._originalWidth =3D element.style.width;=0A= element._originalHeight =3D element.style.height;=0A= =0A= element.style.position =3D 'absolute';=0A= element.style.top =3D top + 'px';=0A= element.style.left =3D left + 'px';=0A= element.style.width =3D width + 'px';=0A= element.style.height =3D height + 'px';=0A= return element;=0A= },=0A= =0A= relativize: function(element) {=0A= element =3D $(element);=0A= if (element.getStyle('position') =3D=3D 'relative') return;=0A= // Position.prepare(); // To be done manually by Scripty when it = needs it.=0A= =0A= element.style.position =3D 'relative';=0A= var top =3D parseFloat(element.style.top || 0) - = (element._originalTop || 0);=0A= var left =3D parseFloat(element.style.left || 0) - = (element._originalLeft || 0);=0A= =0A= element.style.top =3D top + 'px';=0A= element.style.left =3D left + 'px';=0A= element.style.height =3D element._originalHeight;=0A= element.style.width =3D element._originalWidth;=0A= return element;=0A= },=0A= =0A= cumulativeScrollOffset: function(element) {=0A= var valueT =3D 0, valueL =3D 0;=0A= do {=0A= valueT +=3D element.scrollTop || 0;=0A= valueL +=3D element.scrollLeft || 0;=0A= element =3D element.parentNode;=0A= } while (element);=0A= return Element._returnOffset(valueL, valueT);=0A= },=0A= =0A= getOffsetParent: function(element) {=0A= if (element.offsetParent) return $(element.offsetParent);=0A= if (element =3D=3D document.body) return $(element);=0A= =0A= while ((element =3D element.parentNode) && element !=3D = document.body)=0A= if (Element.getStyle(element, 'position') !=3D 'static')=0A= return $(element);=0A= =0A= return $(document.body);=0A= },=0A= =0A= viewportOffset: function(forElement) {=0A= var valueT =3D 0, valueL =3D 0;=0A= =0A= var element =3D forElement;=0A= do {=0A= valueT +=3D element.offsetTop || 0;=0A= valueL +=3D element.offsetLeft || 0;=0A= =0A= // Safari fix=0A= if (element.offsetParent =3D=3D document.body &&=0A= Element.getStyle(element, 'position') =3D=3D 'absolute') break;=0A= =0A= } wh