From: Subject: Graduate Junction - A global graduate research community Date: Fri, 22 Aug 2008 15:39:33 -0700 MIME-Version: 1.0 Content-Type: multipart/related; type="text/html"; boundary="----=_NextPart_000_0000_01C9046D.463CB5E0" X-MimeOLE: Produced By Microsoft MimeOLE V6.00.2900.3350 This is a multi-part message in MIME format. ------=_NextPart_000_0000_01C9046D.463CB5E0 Content-Type: text/html; charset="utf-8" Content-Transfer-Encoding: quoted-printable Content-Location: http://www.graduatejunction.com/ =EF=BB=BF Graduate Junction - = A global graduate research community
=20
3DSitelogo=20=20

About
Us = Take a =
Tour=20 University=20
Testimonials
Register =
Now=20


About Us | = FAQ | Future | Invite | = Contact Us | = University=20 Testimonials | Member = terms | Listing = Terms | Privacy Policy =

=C2=A9 The Graduate Junction 2008, Block 2 Mountjoy = Research Centre,=20 Stockton Road, Durham, DH1 3UP | Original design by G. Wolfgang=20

------=_NextPart_000_0000_01C9046D.463CB5E0 Content-Type: application/octet-stream Content-Transfer-Encoding: base64 Content-Location: http://www.graduatejunction.com/images/sitelogo.jpg?1218607944 /9j/4AAQSkZJRgABAQEAYABgAAD/2wBDAAgGBgcGBQgHBwcJCQgKDBQNDAsLDBkSEw8UHRofHh0a HBwgJC4nICIsIxwcKDcpLDAxNDQ0Hyc5PTgyPC4zNDL/2wBDAQkJCQwLDBgNDRgyIRwhMjIyMjIy MjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjL/wAARCAFVAm4DASIA AhEBAxEB/8QAHwAAAQUBAQEBAQEAAAAAAAAAAAECAwQFBgcICQoL/8QAtRAAAgEDAwIEAwUFBAQA AAF9AQIDAAQRBRIhMUEGE1FhByJxFDKBkaEII0KxwRVS0fAkM2JyggkKFhcYGRolJicoKSo0NTY3 ODk6Q0RFRkdISUpTVFVWV1hZWmNkZWZnaGlqc3R1dnd4eXqDhIWGh4iJipKTlJWWl5iZmqKjpKWm p6ipqrKztLW2t7i5usLDxMXGx8jJytLT1NXW19jZ2uHi4+Tl5ufo6erx8vP09fb3+Pn6/8QAHwEA AwEBAQEBAQEBAQAAAAAAAAECAwQFBgcICQoL/8QAtREAAgECBAQDBAcFBAQAAQJ3AAECAxEEBSEx BhJBUQdhcRMiMoEIFEKRobHBCSMzUvAVYnLRChYkNOEl8RcYGRomJygpKjU2Nzg5OkNERUZHSElK U1RVVldYWVpjZGVmZ2hpanN0dXZ3eHl6goOEhYaHiImKkpOUlZaXmJmaoqOkpaanqKmqsrO0tba3 uLm6wsPExcbHyMnK0tPU1dbX2Nna4uPk5ebn6Onq8vP09fb3+Pn6/9oADAMBAAIRAxEAPwD3+iii gAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKQnF G6gBaKTdRmgBaKTNGaAFopM0ZoAWikzRmgBaKTNGaAFoozRmgAoozSZoAWikzRn2oAWikzRuoAWi kzRuoAWik3UbqAFopN1G6gBaKTdRuoAWik3UZoAWikzRmgBaKTNGaAFoozRmgAooooAKKKKACiii gAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKA CiiigAooooAKKKKACkZsfWmvIF471GXxyTQA7NGaiMlJv96YE2aM1Fvpd+aAJd1JuqPcPWjeKAJc 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 frXsIAUAAAAdAKWuOWKqPbQ0UEcHpfwr0qxkEt1eXV1J6BvLX8hz+tdVZ+H9JsMG30+BWH8ZTc35 nmtKisZVZy3ZSSQYwMCiiioGFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFF ABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABXzb8VNWl1D x5ehGIhtVW3Q9sgZP6k/lX0fLIIoXkY4VFLE/SvlPxJNdX95LcLAf3sjSN65JzXbgUudyZnU2Mu0 trm7k2wxszHuatf2TdGUxsu1h6VJpE+oW0gIiYr+VdLbXcLyeZIgRh1Br0KlRp6GUY9xmk+GvMgD XPy4/WtOa3jt4dseAF7iq8niWN0aIJ04GKxH1edpyAQqn+8a537ST1NFyos3WrFP3e4k/SoxJPKu 9MDFZl5O3mg5Vn/2aRLkMCHlMbe1aqCSE2agS+uMDAxST6PPFGZZgNp7Cq1neTqpRZjjsana91BJ V83E0PXrRaS2HoTWVoyAMPMC9gKvR3G+QqZSm3+9QNXzbFrVV3AfdrJ/tgO5+1Roj+9Q1JhdG+0d u8RZHDSj0qWwuLhGCyKGT0NZIvbeO3E0LJuqzZ6nIw8zKbT1FS4SC6OmEsKjc0Skegp39qZGGt8R gcZrnZtZUuFVQpPvTI9dFo+LnDITx3qHTkyuYq66POuxNDb4UdeKzbMvPeYtxsbvXe2lxp+pwYyo JHGaoSaNbWszSKQD14qoz5dBPUzpEljdHkJ3r6VpWF/d6hMtuhIA4OajW6BukjETSseAqruJ/AV0 eh+F9euL4XK2otLduS0/yn8F61MpL7QLTY1LPRUEO6TDNjnNc34h0HfMDCjSMTwiKWJ/AV6jaaHF Co8+VpW7joK0ooIoRiONU+grkdW0roteZ4jZ/DDWtRYP5EdjG3Vrg/N/3yOfzxXT6Z8F9DgZZNUu bi/cc7AfKj/Ic/rXpdFU8VVeidhciM7S9B0nRY/L03Tra1HrHGAT9T1NaNFFc7bbuygooopAFFFF ABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUA FFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFAGJ4vv10zwfq14xwI7Z/zIwP 5181RazFdXPlxk4bkg19BfE0j/hX2qIejhF/8fWvna0jsLe9JlO0fSvSwcVyNmVTc0pdTitl2IwE h7daxr6/z8zFlPtxVuXUtOW7byYA7DoxrKunF5Md3y12Qj3IctCsNQk8z925xVq3tLm6PnuGaMde agXTo4zuEmfpV6O+khtTEp2j+day8jNa7l6FxkC0tskcEmrFxpjGAzzskftWFHeXyIRGdqnoajlm vJSBJKWB9TWfJfUvmRJLL5efKmGRUR1W6VSrP144NVpIHRwGkGD3FRFFZ+GyM9a3jFJGbbLUN5PE ++KQg9cZqe41CW8AEqLkdxVORUiKsG3eoq9H9na1LKpEh7ChpIEQhZjERHIcemabHeXMChDIfzqZ oJrKFWfI39iKWx0i71WYRW8Ms0rdEjUsT+ApXjbULvoR/a3JyZTz71eNveTQJIrbl967bQfgjrmo 7H1KZNNtzyQ3zyn/AICOB+Jr13w98O/D/h6JBHbtdTL/AMtro7zn2HQflXJWxdKGkdWaRhJ7ni/h /wAM+JtWVPsFlKU/57SfJGPxPX8K9T0n4bkQodavzM/eOD5V/wC+jyf0rvwAAABgDoBS151TEynt obqKRS0/R9P0qPZZWkUPGCyj5j9T1NXaKK5m7lBRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQA UUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABR RRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAcZ8VFkbwDeiPqHjJ+m4V8yX0zSTlUVmI44H NfVfjy2a78F6jChwxVTn6MK8C/4RqW1xKhGT3Nejg6ijGzMpxuzjreGdnwq8+h61LPazKwLDafSt kaddW88k8mOKzWvA0hMoBINehGpzbGPLYrBZQwRWPNXJrNoEUuQzHnI7VPZanpom/fIRitNtf0uO NgsWR6kUpuXYaszC862G1JZTuPcCtO10FtUt3lglPyjpjGaWCbR7m6VjsROrZreh1rT7MFI7lPK6 AIKiUmlohqKucBf6fNaSFJCaqjYqYD810fiG+h1A7bSBmP8AfxVzwv8ADTxH4jeN4rIw2p63E/yJ +Hc/hW0KyjC8wlC70OSjRSwLZOe9bmjeGNf1m9WPSNOnuf8AbAwi/wC8x4Fe8+Hvg/oOlokmoj+0 JxzhhtjB+nf8a9Bgt4bWFYbeJIolGFSNQoH4CuGpmC2grlKj3PJND+C73DR3PirUPOYAYtbXhR9X 6n8MV6fpWh6ZodsINMsYbaMDH7teT9T1P41oUV59StOp8TNVFLYKKKKyKCiiigAooooAKKKKACii igAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKK ACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigDO19Gk 8PagqjLfZ3Kj1IGRXh91dvLpyTRgMcZ2ivf3UOjIejAg18nz6zc6Brl9plwpItbh4gD6BiB+lduE p+0TSM6kuWx0ENzFfxtFKoVsc1yOr2NtHceXbMDIT61DdatdXEzyWysqMccCqy2t3K4cxyH1NehT pcru2Q59EQT6fPGu8ofqOlSxROkTIbZ3LDrjgV2/h/Qs2vm3hyh52nn867vS/CN1qyobW0SG2/57 SrgfgOppTxSjoJU76ni2laW927oxECjqWHWvRvCfwyk1Rlla1dYc/wDHxMMKR7Dqa9X0T4f6JpEo uHgW6uuvmSqCFPsvQV1YAAwBgVxVsa5aRNI07HK6P8P9C0opI1pHczryHlUEA+y9K6oAAAAYA7UU VxSk5atmlrBRRRUgFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAU UUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRR RQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFfNvxm0P7D48e7iiIW/hE27sWHyt/IfnX0lX AfFbwhe+KtDtf7KiV9Qt5xsBYKCjcNknt0P4V1YOqqdVN7MipG8TwrQbG3uoMtcfvAc7Sa7nQNA1 DXZTBaWAMSnDXLjbGPx7n2FdJ4N+Cmn6O6XuuTm+u+vkISsKH37t+PHtXqscccMaxxIqIowqqMAD 2Fb4jFRvanqTCD6nOaJ4K07SY0aZRczjnc4+UH2H+NdKBgYHSimSxrNE8TFgrqVJRipwfQjkH3HN ee5Nu7NR9FcXq1gtt4u8O2MN5qS2159p89P7RnO/ZGCvJfIwfSpfEcB0f+xPsV1fJ9o1i2jl33ks m5PmyvzMeD3HfjPSkB19FUrPWNM1CUxWWo2dzIF3FIZ1cgdM4B6cj86LzWNM0+URXuo2dtIV3BJp 1QkdM4J6cH8qALtFRW11b3lutxazxTwvnbJE4ZTg4OCOOoqWgAooooAKKKKACiiigAooooAKKKKA CiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAK KKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACio5pora B5p5FjiRSzOxwFHqa8P8bfEx/Ejy6NoNw9tY5Ky3H3XnHcDuF/U1rSpSqOyE3Y2PiL8YoNGE2leH HjudQGVkuvvRwH0H95v0HvXeeBryfUPA+j3dzM008tsrSSMclm7k1803XhhmtSYAc47V9HfDlHi+ HuixyffS32n8GNdOIhThSShvciPNzanUUUUVwmgUUUUActrv/I++Ev8At8/9FCmeO4o54tAilRZI 31q3V0cZDA7gQR3Fbl3pFveavp2pSPKJrDzfKVSNp3rtO7jPQcYIo1TSLfV/sX2h5V+x3SXcflkD LpnAOQeOaAMbxn+7uPDdwnyzDWIIxIvDBHDBlz1wQBkd6peF5dTN74jntrOzuWbVpo2muLpo3wuA qcRtlVHTnjJ4rptU0i31f7F9oeVfsd0l3H5ZAy6ZwDkHjmoDoCRXtzc2F/eWBuWDzR2/llHfu+10 bDHjJGM4GeaAK+g6VqFjq+s3l2ttDDfPHJHbW0rOqOFIdjlVGWOCTjnv0rfrP0zSLfS/tDo8s9zc v5k9zOQZJT2yQAAAOAAAAO3WtCgAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigA ooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACi iigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKhu7uCxtnuLmVY4kHLMaqa3rlh4e0uXUNRn EUEY/Fj2VR3Jr518TfELUvFeqeZuNtaRn9xbBuAPVvVq3o0JVXpsTKSR6jr+sv4hR4B8lnniPP3v dv8ACvLtW0H7JcmaAYbPHFavh3xBvIhuOvrXRXFtHeDcvIrZxlSdkCaZzGk3R2CK4AD9817f4PZW 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 jnpRcDJtIgH2kc+taS2CSc7fmp4teQyjmr8GO/Bok7gjAutMkjk8xBxRAHTrXSPGHGMVUksM8qOa Sn3CxBGxwDVqNhiq6xPGcYqykffHWhgTJtNSbARUSKVPSp1qWAgT2p2zinAgmnbRSGaunz+bbhT9 5ODVuse0k8mcHPytwa2KhgFFFFIAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigA ooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACi iigAooooAKKKKACiiigAooooAKq3rZQIO/Jq1VWQb2JoQGcYu9MMQIzir5jpnl4qrgZzw/lUQt8M TWq0QPameTTuBmmHJpfJBXGKvGHBpfLp3AzhbFelNMJ3ZHWtIxmmCDnNO4imu4cMKnXGKlMPqKUR cUgIjbrIKYtuyH1qyqspqZBmgCkYiTnpTvKyPerpiBpvlYPFK4yp5JXmpFT1qfa2elHOelFwIfLF adrL5kWCcsvBqmQuORToMRyh1+hFJ6gaNFHWipAKKKKACiiigAooooAKKKKACiiigAooooAKKKKA CiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAK KKKACiiigAooooAKKKKACiiigAooooAKKKKAEb7tRFakbmkxQBEVpCtS4oxQBDspNlTYoxTAgKU3 y8VY20baLgV9lL5dT7KNtFwIPLpPLx2qxtpcUXAqmPPagRkVZ2Cl2Ci4EABpdlTbKNtFwIttBSpc UUAQmMHtSCP2qfFLii4BExxtP4VJUWMc1IDkUgFooooAKKKKACiiigAooooAKKKKACiiigAooooA KKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAo oooAKKKKACiiigAooooAKKKKACiiigAooooAQ0UUUAJRRRQAUYoooAMUYoooAMUYoooAMUUUUAFF FFABRRRQAUYoooAMUYoooASlHFFFADqKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooo oAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiig AooooAKKKKAP/9k= ------=_NextPart_000_0000_01C9046D.463CB5E0 Content-Type: application/octet-stream Content-Transfer-Encoding: quoted-printable Content-Location: http://www.graduatejunction.com/stylesheets/layout_3_column.css?1218620159 * { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: = 0px; PADDING-TOP: 0px } BODY { FONT-SIZE: 62.5%; FONT-FAMILY: verdana,arial,sans-serif; = BACKGROUND-COLOR: rgb(255,255,255) } .page-container { BORDER-RIGHT: rgb(150,150,150) 1px solid; BORDER-TOP: rgb(150,150,150) = 1px solid; FONT-SIZE: 1em; MARGIN: 10px auto; BORDER-LEFT: = rgb(150,150,150) 1px solid; WIDTH: 900px; BORDER-BOTTOM: = rgb(150,150,150) 1px solid } .main { CLEAR: both; BACKGROUND: url(../images/bg_main_withnav_reverse.jpg) = repeat-y left top; PADDING-BOTTOM: 30px; WIDTH: 900px } .main-navigation { DISPLAY: inline; FLOAT: right; OVERFLOW: visible! important; WIDTH: = 200px } .main-subcontent { DISPLAY: inline; FLOAT: left; MARGIN: 0px 0px 0px 15px; OVERFLOW: = visible! important; WIDTH: 0px } .footer { CLEAR: both; BACKGROUND: url(../images/Top Option 2.jpg) = rgb(240,240,240); OVERFLOW: visible! important; WIDTH: 900px; HEIGHT: = 80px } .header { WIDTH: 900px; FONT-FAMILY: "trebuchet ms",arial,sans-serif } .header-top { BACKGROUND: url(../images/Top Option 2.jpg) rgb(240,240,240); OVERFLOW: = visible! important; WIDTH: 900px; HEIGHT: 80px } .header-middle { BACKGROUND: url(../images/bg_head_middle.jpg) rgb(230,230,230); = OVERFLOW: visible! important; WIDTH: 900px; HEIGHT: 150px } .header-bottom { BACKGROUND: url(../images/bg_head_breadcrumbs.jpg) rgb(255,255,255) = repeat-y; WIDTH: 900px; HEIGHT: 40px } .header-breadcrumbs { CLEAR: both; PADDING-RIGHT: 0px; PADDING-LEFT: 0px; BACKGROUND: = url(../images/bg_main_withnav_forsearch.jpg) #ffffff repeat-y; = PADDING-BOTTOM: 1.5em; WIDTH: 900px; PADDING-TOP: 1em } .sitename { Z-INDEX: 1; MARGIN: 0px 0px 0px 70px; OVERFLOW: visible! important; = PADDING-TOP: 20px; HEIGHT: 45px } .sitename H1 { FONT-SIZE: 240%; COLOR: white } .sitename H2 { FONT-SIZE: 120%; MARGIN: -4px 0px 0px; COLOR: white } .sitename A { COLOR: white; TEXT-DECORATION: none } .sitename A:hover { COLOR: rgb(50,50,50); TEXT-DECORATION: none } .nav0 { Z-INDEX: 2; MARGIN: 25px 0px 0px 550px; WIDTH: 350px; POSITION: = absolute } .nav0 UL { PADDING-RIGHT: 20px; PADDING-LEFT: 0px; FLOAT: right; PADDING-BOTTOM: = 0px; PADDING-TOP: 0px } .nav0 LI { DISPLAY: inline; LIST-STYLE-TYPE: none } .nav0 LI A { PADDING-RIGHT: 0px; PADDING-LEFT: 3px; PADDING-BOTTOM: 0px; = PADDING-TOP: 0px } .nav0 A:hover { TEXT-DECORATION: none } .nav0 A IMG { BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: = none; HEIGHT: 14px; BORDER-BOTTOM-STYLE: none } .nav1 { Z-INDEX: 3; MARGIN: 45px 0px 0px 350px; WIDTH: 550px; POSITION: = absolute } .nav1 UL { PADDING-RIGHT: 15px; PADDING-LEFT: 0px; FONT-WEIGHT: bold; FLOAT: = right; PADDING-BOTTOM: 0px; PADDING-TOP: 0px } .nav1 LI { DISPLAY: block; FLOAT: left; LIST-STYLE-TYPE: none } .nav1 LI A { PADDING-RIGHT: 5px; DISPLAY: block; PADDING-LEFT: 5px; FONT-SIZE: 120%; = FLOAT: left; PADDING-BOTTOM: 2px; COLOR: rgb(125,125,125); PADDING-TOP: = 2px; TEXT-DECORATION: none } .nav1 A:hover { COLOR: rgb(50,50,50); TEXT-DECORATION: none } .sitemessage { Z-INDEX: 1; MARGIN: 20px 0px 0px 530px; OVERFLOW: hidden; WIDTH: 350px; = COLOR: rgb(234,239,247); POSITION: absolute; HEIGHT: 120px } .sitemessage H1 { FONT-SIZE: 230%; WIDTH: 350px; TEXT-ALIGN: right } .sitemessage H2 { FONT-SIZE: 160%; FLOAT: right; MARGIN: 8px 0px 0px; WIDTH: 270px; = LINE-HEIGHT: 100%; TEXT-ALIGN: right } .sitemessage H3 { FONT-SIZE: 140%; FLOAT: right; MARGIN: 10px 0px 0px; WIDTH: 270px; = TEXT-ALIGN: right } .sitemessage H3 A { COLOR: rgb(234,239,247); TEXT-DECORATION: none } .sitemessage H3 A:hover { COLOR: rgb(50,50,50); TEXT-DECORATION: none } .nav2 { FONT-SIZE: 130%; BACKGROUND: url(../images/Bottom Nav Option3.jpg) = rgb(220,220,220) repeat-x; FLOAT: left; WIDTH: 900px; COLOR: = rgb(75,75,75); BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: none; = BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: none } .nav2 UL { LIST-STYLE-TYPE: none } .nav2 UL LI { BORDER-RIGHT: rgb(175,175,175) 1px solid; Z-INDEX: 1000; FLOAT: left; = POSITION: relative } .nav2 UL LI UL { DISPLAY: none; BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: none; = BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: none } .nav2 UL LI UL { PADDING-RIGHT: 30px; PADDING-LEFT: 30px; BACKGROUND: = url(../images/bg_head_bottom_nav_hover.gif) center top; PADDING-BOTTOM: = 30px; MARGIN-LEFT: -30px; PADDING-TOP: 0px } .nav2 UL LI A { PADDING-RIGHT: 16px; DISPLAY: block; PADDING-LEFT: 16px; FONT-WEIGHT: = bold; FLOAT: left; PADDING-BOTTOM: 0px; COLOR: white; LINE-HEIGHT: = 3.1em; PADDING-TOP: 0px; HEIGHT: 3.1em; TEXT-DECORATION: none } .nav2 UL LI:hover { WIDTH: auto } .nav2 TABLE { Z-INDEX: 999; LEFT: 0px; POSITION: absolute; TOP: 0px; BORDER-COLLAPSE: = collapse } .nav2 UL LI:hover A { BACKGROUND-COLOR: #cae1ff; TEXT-DECORATION: none } .nav2 UL LI:hover UL { MARGIN-TOP: 0.1em; DISPLAY: block; Z-INDEX: 998; LEFT: 0px; POSITION: = absolute; TOP: 3em } .nav2 UL LI:hover UL LI UL { DISPLAY: none } .nav2 UL LI:hover UL LI A { PADDING-RIGHT: 16px; DISPLAY: block; PADDING-LEFT: 16px; FONT-WEIGHT: = normal; PADDING-BOTTOM: 4px; MARGIN-LEFT: -1px; BORDER-LEFT: = rgb(175,175,175) 1px solid; WIDTH: 10em; COLOR: rgb(50,50,50); = LINE-HEIGHT: 1.3em; PADDING-TOP: 4px; BORDER-BOTTOM: rgb(175,175,175) = 1px solid; HEIGHT: auto; BACKGROUND-COLOR: rgb(237,237,237) } .nav2 UL LI:hover UL LI A:hover { BACKGROUND-COLOR: #cae1ff; TEXT-DECORATION: none } .nav2 UL LI A:hover { BACKGROUND-COLOR: #b0c4de; TEXT-DECORATION: none } .nav2 UL LI A:hover UL { MARGIN-TOP: 0.1em; DISPLAY: block; Z-INDEX: 998; LEFT: 0px; POSITION: = absolute; TOP: 3em } .nav2 UL LI A:hover UL LI A { PADDING-RIGHT: 16px; DISPLAY: block; PADDING-LEFT: 16px; FONT-WEIGHT: = normal; PADDING-BOTTOM: 4px; BORDER-LEFT: rgb(175,175,175) 1px solid; = WIDTH: 10em; COLOR: rgb(50,50,50); LINE-HEIGHT: 1.3em; PADDING-TOP: 4px; = BORDER-BOTTOM: rgb(175,175,175) 1px solid; HEIGHT: 1px; = BACKGROUND-COLOR: rgb(237,237,237) } .nav2 UL LI A:hover UL LI A UL { Z-INDEX: 997; VISIBILITY: hidden; WIDTH: 0px; POSITION: absolute; = HEIGHT: 0px } .nav2 UL LI A:hover UL LI A:hover { BACKGROUND-COLOR: #b0c4de; TEXT-DECORATION: none } .header-breadcrumbs SPAN { PADDING-RIGHT: 0px; PADDING-LEFT: 15px; FONT-SIZE: 120%; FLOAT: left; = PADDING-BOTTOM: 0px; COLOR: rgb(70,122,167); PADDING-TOP: 0px; = FONT-FAMILY: verdana,arial,sans-serif } .header-breadcrumbs UL { PADDING-RIGHT: 0px; PADDING-LEFT: 15px; FLOAT: left; PADDING-BOTTOM: = 0px; WIDTH: 560px; PADDING-TOP: 0px; FONT-FAMILY: = verdana,arial,sans-serif; LIST-STYLE-TYPE: none } .header-breadcrumbs UL LI { PADDING-RIGHT: 0px; DISPLAY: inline; PADDING-LEFT: 10px; FONT-WEIGHT: = bold; FONT-SIZE: 100%; BACKGROUND: url(../images/bg_bullet_arrow.gif) = no-repeat 0px 50%; PADDING-BOTTOM: 0px; COLOR: rgb(125,125,125); = PADDING-TOP: 0px } .header-breadcrumbs UL A { COLOR: rgb(70,122,167); TEXT-DECORATION: none } .header-breadcrumbs UL A:hover { COLOR: rgb(42,90,138); TEXT-DECORATION: underline } .sitename .header_logo { FLOAT: left; WIDTH: 400px } .sitename .searchform { PADDING-RIGHT: 17px! important; PADDING-LEFT: 0px! important; FLOAT: = left; PADDING-BOTTOM: 0px! important; MARGIN: 0px 0px 0px 100px; WIDTH: = 300px; PADDING-TOP: 0px! important } .sitename .searchform FORM FIELDSET { FLOAT: right; BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: none; = BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: none } .sitename .searchform INPUT.field { BORDER-RIGHT: rgb(200,200,200) 1px solid; PADDING-RIGHT: 0px; = BORDER-TOP: rgb(200,200,200) 1px solid; PADDING-LEFT: 0px; FONT-SIZE: = 120%; PADDING-BOTTOM: 0.2em; BORDER-LEFT: rgb(200,200,200) 1px solid; = WIDTH: 10em; PADDING-TOP: 0.2em; BORDER-BOTTOM: rgb(200,200,200) 1px = solid; FONT-FAMILY: verdana,arial,sans-serif } .sitename .searchform INPUT.button { BORDER-RIGHT: rgb(150,150,150) 1px solid; PADDING-RIGHT: 1px! = important; BORDER-TOP: rgb(150,150,150) 1px solid; PADDING-LEFT: 1px! = important; FONT-SIZE: 120%; BACKGROUND: rgb(230,230,230); = PADDING-BOTTOM: 1px! important; BORDER-LEFT: rgb(150,150,150) 1px solid; = WIDTH: 3em; COLOR: rgb(150,150,150); PADDING-TOP: 1px! important; = BORDER-BOTTOM: rgb(150,150,150) 1px solid; FONT-FAMILY: = verdana,arial,sans-serif; TEXT-ALIGN: center } .sitename .searchform INPUT.button:hover { BORDER-RIGHT: rgb(80,80,80) 1px solid; BORDER-TOP: rgb(80,80,80) 1px = solid; BACKGROUND: rgb(220,220,220); BORDER-LEFT: rgb(80,80,80) 1px = solid; CURSOR: pointer; COLOR: rgb(80,80,80); BORDER-BOTTOM: = rgb(80,80,80) 1px solid } .main-navigation .round-border-topleft { Z-INDEX: 100; BACKGROUND: url(../images/bg_corner_topleft.gif) = no-repeat; MARGIN: 0px; WIDTH: 10px; POSITION: absolute; HEIGHT: 10px } .column1-unit { MARGIN-BOTTOM: 2px! important; WIDTH: 440px } .column2-unit-left { FLOAT: left; MARGIN-BOTTOM: 10px! important; WIDTH: 300px } .column2-unit-right { FLOAT: right; MARGIN-BOTTOM: 10px! important; WIDTH: 300px } .column3-unit-left { FLOAT: left; MARGIN-BOTTOM: 10px! important; WIDTH: 120px } .column3-unit-middle { FLOAT: left; MARGIN-BOTTOM: 10px! important; MARGIN-LEFT: 40px; WIDTH: = 120px } .column3-unit-right { FLOAT: right; MARGIN-BOTTOM: 10px! important; WIDTH: 120px } .subcontent-unit-border { BORDER-RIGHT: rgb(190,190,190) 1px solid; PADDING-RIGHT: 0px; = BORDER-TOP: rgb(190,190,190) 1px solid; PADDING-LEFT: 0px; BACKGROUND: = rgb(235,235,235); PADDING-BOTTOM: 5px; MARGIN: 0px 0px 2em; BORDER-LEFT: = rgb(190,190,190) 1px solid; WIDTH: 183px; PADDING-TOP: 0px; = BORDER-BOTTOM: rgb(190,190,190) 1px solid } .subcontent-unit-border-green { BORDER-RIGHT: rgb(160,214,81) 1px solid; PADDING-RIGHT: 0px; = BORDER-TOP: rgb(160,214,81) 1px solid; PADDING-LEFT: 0px; = PADDING-BOTTOM: 10px; MARGIN: 0px 0px 2.5em; BORDER-LEFT: = rgb(160,214,81) 1px solid; WIDTH: 183px; PADDING-TOP: 0px; = BORDER-BOTTOM: rgb(160,214,81) 1px solid; BACKGROUND-COLOR: = rgb(217,239,185) } .subcontent-unit-border-blue { BORDER-RIGHT: rgb(137,170,214) 1px solid; PADDING-RIGHT: 0px; = BORDER-TOP: rgb(137,170,214) 1px solid; PADDING-LEFT: 0px; BACKGROUND: = url(../images/fading_background_24.png); PADDING-BOTTOM: 10px; MARGIN: = 0px 0px 2.5em; BORDER-LEFT: rgb(137,170,214) 1px solid; WIDTH: 183px; = PADDING-TOP: 0px; BORDER-BOTTOM: rgb(137,170,214) 1px solid } .subcontent-unit-border-orange { BORDER-RIGHT: rgb(232,177,13) 1px solid; PADDING-RIGHT: 0px; = BORDER-TOP: rgb(232,177,13) 1px solid; PADDING-LEFT: 0px; = PADDING-BOTTOM: 10px; MARGIN: 0px 0px 2.5em; BORDER-LEFT: = rgb(232,177,13) 1px solid; WIDTH: 183px; PADDING-TOP: 0px; = BORDER-BOTTOM: rgb(232,177,13) 1px solid; BACKGROUND-COLOR: = rgb(248,224,150) } .subcontent-unit-noborder { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; BACKGROUND: rgb(235,235,235); = PADDING-BOTTOM: 10px; MARGIN: 0px 0px 2.5em; WIDTH: 185px; PADDING-TOP: = 0px } .subcontent-unit-noborder-green { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 10px; MARGIN: = 0px 0px 2.5em; WIDTH: 185px; PADDING-TOP: 0px; BACKGROUND-COLOR: = rgb(217,239,185) } .subcontent-unit-noborder-blue { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 10px; MARGIN: = 0px 0px 2.5em; WIDTH: 185px; PADDING-TOP: 0px; BACKGROUND-COLOR: = rgb(213,225,240) } .subcontent-unit-noborder-orange { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 10px; MARGIN: = 0px 0px 2.5em; WIDTH: 185px; PADDING-TOP: 0px; BACKGROUND-COLOR: = rgb(248,224,150) } .round-border-topleft { MARGIN-TOP: -1px; Z-INDEX: 100; BACKGROUND: = url(../images/bg_corner_topleft.gif) no-repeat; MARGIN-LEFT: -1px; = WIDTH: 10px; POSITION: absolute; HEIGHT: 10px } .round-border-topright { MARGIN-TOP: -1px; Z-INDEX: 100; BACKGROUND: = url(../images/bg_corner_topright.gif) no-repeat; MARGIN-LEFT: 174px; = WIDTH: 10px; POSITION: absolute; HEIGHT: 10px } .round-noborder-topleft { MARGIN-TOP: 0px; Z-INDEX: 100; BACKGROUND: = url(../images/bg_corner_topleft.gif) no-repeat; MARGIN-LEFT: 0px; WIDTH: = 10px; POSITION: absolute; HEIGHT: 10px } .round-noborder-topright { MARGIN-TOP: 0px; Z-INDEX: 100; BACKGROUND: = url(../images/bg_corner_topright.gif) no-repeat; MARGIN-LEFT: 175px; = WIDTH: 10px; POSITION: absolute; HEIGHT: 10px } .round-border-topright-profile { MARGIN-TOP: -1px; Z-INDEX: 100; BACKGROUND: = url(../images/bg_corner_topright.gif) no-repeat; MARGIN-LEFT: 630px; = WIDTH: 10px; POSITION: absolute; HEIGHT: 10px } .footer P { PADDING-RIGHT: 5px; PADDING-LEFT: 5px; FONT-WEIGHT: bold; FONT-SIZE: = 110%; PADDING-BOTTOM: 5px; COLOR: white; LINE-HEIGHT: 1.3em; = PADDING-TOP: 5px; TEXT-ALIGN: center } .footer P.credits { FONT-WEIGHT: normal } .footer A { COLOR: white; TEXT-DECORATION: underline } .footer A:hover { COLOR: rgb(0,0,0); TEXT-DECORATION: none } .footer A:visited { COLOR: white } .page-container:unknown { CLEAR: both; DISPLAY: block; VISIBILITY: hidden; HEIGHT: 0px; content: = "." } .header:unknown { CLEAR: both; DISPLAY: block; VISIBILITY: hidden; HEIGHT: 0px; content: = "." } .header-breadcrumbs:unknown { CLEAR: both; DISPLAY: block; VISIBILITY: hidden; HEIGHT: 0px; content: = "." } .main:unknown { CLEAR: both; DISPLAY: block; VISIBILITY: hidden; HEIGHT: 0px; content: = "." } .main-navigation:unknown { CLEAR: both; DISPLAY: block; VISIBILITY: hidden; HEIGHT: 0px; content: = "." } .main-content:unknown { CLEAR: both; DISPLAY: block; VISIBILITY: hidden; HEIGHT: 0px; content: = "." } .main-content DIV:unknown { CLEAR: both; DISPLAY: block; VISIBILITY: hidden; HEIGHT: 0px; content: = "." } .main-subcontent:unknown { CLEAR: both; DISPLAY: block; VISIBILITY: hidden; HEIGHT: 0px; content: = "." } .column1-unit:unknown { CLEAR: both; DISPLAY: block; VISIBILITY: hidden; HEIGHT: 0px; content: = "." } .column2-unit-left:unknown { CLEAR: both; DISPLAY: block; VISIBILITY: hidden; HEIGHT: 0px; content: = "." } .column2-unit-right:unknown { CLEAR: both; DISPLAY: block; VISIBILITY: hidden; HEIGHT: 0px; content: = "." } .column3-unit-left:unknown { CLEAR: both; DISPLAY: block; VISIBILITY: hidden; HEIGHT: 0px; content: = "." } .column3-unit-middle:unknown { CLEAR: both; DISPLAY: block; VISIBILITY: hidden; HEIGHT: 0px; content: = "." } .column3-unit-right:unknown { CLEAR: both; DISPLAY: block; VISIBILITY: hidden; HEIGHT: 0px; content: = "." } .subcontent-unit-border:unknown { CLEAR: both; DISPLAY: block; VISIBILITY: hidden; HEIGHT: 0px; content: = "." } .subcontent-unit-noborder:unknown { CLEAR: both; DISPLAY: block; VISIBILITY: hidden; HEIGHT: 0px; content: = "." } .subcontent-unit-border-blue:unknown { CLEAR: both; DISPLAY: block; VISIBILITY: hidden; HEIGHT: 0px; content: = "." } .subcontent-unit-border-green:unknown { CLEAR: both; DISPLAY: block; VISIBILITY: hidden; HEIGHT: 0px; content: = "." } .subcontent-unit-border-orange:unknown { CLEAR: both; DISPLAY: block; VISIBILITY: hidden; HEIGHT: 0px; content: = "." } .subcontent-unit-noborder-blue:unknown { CLEAR: both; DISPLAY: block; VISIBILITY: hidden; HEIGHT: 0px; content: = "." } .subcontent-unit-noborder-green:unknown { CLEAR: both; DISPLAY: block; VISIBILITY: hidden; HEIGHT: 0px; content: = "." } .subcontent-unit-noborder-orange:unknown { CLEAR: both; DISPLAY: block; VISIBILITY: hidden; HEIGHT: 0px; content: = "." } .footer:unknown { CLEAR: both; DISPLAY: block; VISIBILITY: hidden; HEIGHT: 0px; content: = "." } P:unknown { CLEAR: both; DISPLAY: block; VISIBILITY: hidden; HEIGHT: 0px; content: = "." } .clear-contentunit { CLEAR: both; BACKGROUND: rgb(210,210,210); WIDTH: 440px; COLOR: = rgb(210,210,210); BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: none; = BORDER-LEFT-STYLE: none; HEIGHT: 0.1em; BORDER-BOTTOM-STYLE: none } @media Print =20 { .header-top { BACKGROUND: rgb(240,240,240); OVERFLOW: visible! important; WIDTH: = 900px; HEIGHT: 80px } .header-breadcrumbs { BACKGROUND: none transparent scroll repeat 0% 0%; WIDTH: 900px } .nav2 { FONT-SIZE: 130%; BACKGROUND: rgb(240,240,240); FLOAT: left; WIDTH: = 900px; COLOR: rgb(75,75,75); BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: = none; BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: none } .main { CLEAR: both; BACKGROUND: none transparent scroll repeat 0% 0%; = PADDING-BOTTOM: 30px; WIDTH: 900px } .main-navigation { BORDER-RIGHT: rgb(200,200,200) 1px solid; DISPLAY: inline; FLOAT: left; = OVERFLOW: visible! important; WIDTH: 199px; BORDER-BOTTOM: = rgb(200,200,200) 1px solid; BACKGROUND-COLOR: rgb(240,240,240) } .footer { CLEAR: both; PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-SIZE: 1em; = BACKGROUND: rgb(240,240,240); PADDING-BOTTOM: 0px; OVERFLOW: visible! = important; WIDTH: 900px; PADDING-TOP: 1.1em; HEIGHT: 3.7em } } HTML { =09 } ------=_NextPart_000_0000_01C9046D.463CB5E0 Content-Type: application/octet-stream Content-Transfer-Encoding: quoted-printable Content-Location: http://www.graduatejunction.com/stylesheets/layout_3_column_text.css?1218552501 .nav3-grid { WIDTH: 199px; BORDER-BOTTOM: rgb(200,200,200) 1px solid } .nav3-grid DT A { PADDING-RIGHT: 10px; BORDER-TOP: rgb(200,200,200) 1px solid; DISPLAY: = block; PADDING-LEFT: 20px; FONT-WEIGHT: bold; FONT-SIZE: 120%; = MIN-HEIGHT: 2em; PADDING-BOTTOM: 0px; COLOR: rgb(70,122,167); = LINE-HEIGHT: 2em; PADDING-TOP: 0px; HEIGHT: auto! important; = TEXT-DECORATION: none } .nav3-grid DT A:visited { PADDING-RIGHT: 10px; BORDER-TOP: rgb(200,200,200) 1px solid; DISPLAY: = block; PADDING-LEFT: 20px; FONT-WEIGHT: bold; FONT-SIZE: 120%; = MIN-HEIGHT: 2em; PADDING-BOTTOM: 0px; COLOR: rgb(70,122,167); = LINE-HEIGHT: 2em; PADDING-TOP: 0px; HEIGHT: auto! important; = TEXT-DECORATION: none } .nav3-grid DD A { PADDING-RIGHT: 10px; DISPLAY: block; PADDING-LEFT: 40px; FONT-WEIGHT: = normal; FONT-SIZE: 120%; MIN-HEIGHT: 1.7em; PADDING-BOTTOM: 0px; COLOR: = rgb(70,122,167); BORDER-TOP-STYLE: none; LINE-HEIGHT: 1.7em; = PADDING-TOP: 0px; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none; = HEIGHT: auto! important; TEXT-DECORATION: none; BORDER-BOTTOM-STYLE: = none } .nav3-grid DD A:visited { PADDING-RIGHT: 10px; DISPLAY: block; PADDING-LEFT: 40px; FONT-WEIGHT: = normal; FONT-SIZE: 120%; MIN-HEIGHT: 1.7em; PADDING-BOTTOM: 0px; COLOR: = rgb(70,122,167); BORDER-TOP-STYLE: none; LINE-HEIGHT: 1.7em; = PADDING-TOP: 0px; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none; = HEIGHT: auto! important; TEXT-DECORATION: none; BORDER-BOTTOM-STYLE: = none } .nav3-grid DT A:hover { COLOR: rgb(42,90,138); BACKGROUND-COLOR: rgb(225,225,225); = TEXT-DECORATION: none } .nav3-grid DD A:hover { COLOR: rgb(42,90,138); BACKGROUND-COLOR: rgb(225,225,225); = TEXT-DECORATION: none } .nav3-bullet { MARGIN: 10px 0px 0px 20px; WIDTH: 170px } .nav3-bullet DT A { PADDING-RIGHT: 0px; PADDING-LEFT: 10px; FONT-WEIGHT: bold; FONT-SIZE: = 120%; BACKGROUND: url(../images/bg_bullet_full_1.gif) no-repeat 0px 50%; = PADDING-BOTTOM: 0px; COLOR: rgb(70,122,167); LINE-HEIGHT: 2em; = PADDING-TOP: 0px; TEXT-DECORATION: none } .nav3-bullet DT A:visited { PADDING-RIGHT: 0px; PADDING-LEFT: 10px; FONT-WEIGHT: bold; FONT-SIZE: = 120%; BACKGROUND: url(../images/bg_bullet_full_1.gif) no-repeat 0px 50%; = PADDING-BOTTOM: 0px; COLOR: rgb(70,122,167); LINE-HEIGHT: 2em; = PADDING-TOP: 0px; TEXT-DECORATION: none } .nav3-bullet DD A { PADDING-RIGHT: 0px; PADDING-LEFT: 10px; FONT-WEIGHT: normal; FONT-SIZE: = 120%; BACKGROUND: url(../images/bg_bullet_half_1.gif) no-repeat 0px 50%; = PADDING-BOTTOM: 0px; MARGIN: 0px 0px 0px 15px; COLOR: rgb(70,122,167); = LINE-HEIGHT: 1.7em; PADDING-TOP: 0px; TEXT-DECORATION: none } .nav3-bullet DD A:visited { PADDING-RIGHT: 0px; PADDING-LEFT: 10px; FONT-WEIGHT: normal; FONT-SIZE: = 120%; BACKGROUND: url(../images/bg_bullet_half_1.gif) no-repeat 0px 50%; = PADDING-BOTTOM: 0px; MARGIN: 0px 0px 0px 15px; COLOR: rgb(70,122,167); = LINE-HEIGHT: 1.7em; PADDING-TOP: 0px; TEXT-DECORATION: none } .nav3-bullet DT A:hover { BACKGROUND: url(../images/bg_bullet_full_2.gif) no-repeat 0px 50%; = COLOR: rgb(42,90,138); TEXT-DECORATION: underline } .nav3-bullet DD A:hover { BACKGROUND: url(../images/bg_bullet_half_2.gif) no-repeat 0px 50%; = COLOR: rgb(42,90,138); TEXT-DECORATION: underline } .nav3-nobullet { MARGIN: 10px 0px 0px 20px; WIDTH: 170px } .nav3-nobullet DT A { FONT-WEIGHT: bold; FONT-SIZE: 120%; COLOR: rgb(70,122,167); = LINE-HEIGHT: 2em; TEXT-DECORATION: none } .nav3-nobullet DT A:visited { FONT-WEIGHT: bold; FONT-SIZE: 120%; COLOR: rgb(70,122,167); = LINE-HEIGHT: 2em; TEXT-DECORATION: none } .nav3-nobullet DD A { FONT-WEIGHT: normal; FONT-SIZE: 120%; MARGIN: 0px 0px 0px 15px; COLOR: = rgb(70,122,167); LINE-HEIGHT: 1.7em; TEXT-DECORATION: none } .nav3-nobullet DD A:visited { FONT-WEIGHT: normal; FONT-SIZE: 120%; MARGIN: 0px 0px 0px 15px; COLOR: = rgb(70,122,167); LINE-HEIGHT: 1.7em; TEXT-DECORATION: none } .nav3-nobullet DT A:hover { COLOR: rgb(42,90,138); TEXT-DECORATION: underline } .nav3-nobullet DD A:hover { COLOR: rgb(42,90,138); TEXT-DECORATION: underline } .main-navigation .loginform { MARGIN: -10px 20px 0px; WIDTH: 160px } .main-navigation .loginform P { CLEAR: both; PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: = 0px; MARGIN: 0px; PADDING-TOP: 0px } .main-navigation .loginform FIELDSET { WIDTH: 160px; BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: none; = BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: none } .main-navigation .loginform LABEL.top { FONT-SIZE: 110%; FLOAT: left; MARGIN: 0px 0px 2px; WIDTH: 125px } .main-navigation .loginform LABEL.right { PADDING-RIGHT: 0px; PADDING-LEFT: 3px; FONT-SIZE: 110%; FLOAT: left; = PADDING-BOTTOM: 0px; MARGIN: 5px 0px 0px; WIDTH: 125px; PADDING-TOP: 0px } .main-navigation .loginform INPUT.field { BORDER-RIGHT: rgb(200,200,200) 1px solid; PADDING-RIGHT: 0px! = important; BORDER-TOP: rgb(200,200,200) 1px solid; PADDING-LEFT: 0px! = important; FONT-SIZE: 110%; PADDING-BOTTOM: 0.2em! important; MARGIN: = 0px 0px 5px; BORDER-LEFT: rgb(200,200,200) 1px solid; WIDTH: 158px; = PADDING-TOP: 0.1em! important; BORDER-BOTTOM: rgb(200,200,200) 1px = solid; FONT-FAMILY: verdana,arial,sans-serif } .main-navigation .loginform INPUT.checkbox { FLOAT: left; MARGIN: 5px 0px 0px; BORDER-TOP-STYLE: none; = BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: = none } .main-navigation .loginform INPUT.button { BORDER-RIGHT: rgb(150,150,150) 1px solid; PADDING-RIGHT: 1px; = BORDER-TOP: rgb(150,150,150) 1px solid; PADDING-LEFT: 1px; FONT-SIZE: = 110%; BACKGROUND: rgb(230,230,230); FLOAT: left; PADDING-BOTTOM: 1px; = MARGIN: 10px 0px 5px; BORDER-LEFT: rgb(150,150,150) 1px solid; WIDTH: = 5em; COLOR: rgb(150,150,150); PADDING-TOP: 1px; BORDER-BOTTOM: = rgb(150,150,150) 1px solid; FONT-FAMILY: verdana,arial,sans-serif; = TEXT-ALIGN: center } .main-navigation .loginform INPUT.button:hover { BORDER-RIGHT: rgb(80,80,80) 1px solid; BORDER-TOP: rgb(80,80,80) 1px = solid; BACKGROUND: rgb(220,220,220); BORDER-LEFT: rgb(80,80,80) 1px = solid; CURSOR: pointer; COLOR: rgb(80,80,80); BORDER-BOTTOM: = rgb(80,80,80) 1px solid } .main-navigation .searchform { MARGIN: 0px 20px; WIDTH: 160px } .main-navigation .searchform FIELDSET { BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: = none; BORDER-BOTTOM-STYLE: none } .main-navigation .searchform INPUT.field { BORDER-RIGHT: rgb(200,200,200) 1px solid; PADDING-RIGHT: 0px! = important; BORDER-TOP: rgb(200,200,200) 1px solid; PADDING-LEFT: 0px! = important; FONT-SIZE: 120%; FLOAT: left; PADDING-BOTTOM: 0.2em! = important; BORDER-LEFT: rgb(200,200,200) 1px solid; WIDTH: 158px; = PADDING-TOP: 0.1em! important; BORDER-BOTTOM: rgb(200,200,200) 1px = solid; FONT-FAMILY: verdana,arial,sans-serif } .main-navigation .searchform INPUT.button { BORDER-RIGHT: rgb(150,150,150) 1px solid; PADDING-RIGHT: 1px; = BORDER-TOP: rgb(150,150,150) 1px solid; MARGIN-TOP: 0.5em; PADDING-LEFT: = 1px; FONT-SIZE: 120%; BACKGROUND: rgb(230,230,230); FLOAT: left; = PADDING-BOTTOM: 1px; BORDER-LEFT: rgb(150,150,150) 1px solid; WIDTH: = 3em; COLOR: rgb(150,150,150); PADDING-TOP: 1px; BORDER-BOTTOM: = rgb(150,150,150) 1px solid; FONT-FAMILY: verdana,arial,sans-serif; = TEXT-ALIGN: center } .main-navigation .searchform INPUT.button:hover { BORDER-RIGHT: rgb(80,80,80) 1px solid; BORDER-TOP: rgb(80,80,80) 1px = solid; BACKGROUND: rgb(220,220,220); BORDER-LEFT: rgb(80,80,80) 1px = solid; CURSOR: pointer; COLOR: rgb(80,80,80); BORDER-BOTTOM: = rgb(80,80,80) 1px solid } .main-navigation H1.first { CLEAR: both; PADDING-RIGHT: 20px; PADDING-LEFT: 20px; FONT-WEIGHT: = bold; FONT-SIZE: 150%; PADDING-BOTTOM: 3px; MARGIN: 0px; COLOR: = rgb(255,255,255); PADDING-TOP: 4px; FONT-FAMILY: "trebuchet = ms",arial,sans-serif; BACKGROUND-COLOR: rgb(190,190,190) } .main-navigation H1 { CLEAR: both; PADDING-RIGHT: 20px; PADDING-LEFT: 20px; FONT-WEIGHT: = bold; FONT-SIZE: 150%; BACKGROUND: rgb(190,190,190); PADDING-BOTTOM: = 3px; MARGIN: 30px 0px 20px; COLOR: rgb(255,255,255); PADDING-TOP: 0px; = FONT-FAMILY: "trebuchet ms",arial,sans-serif } .main-navigation H2 { CLEAR: both; FONT-WEIGHT: bold; FONT-SIZE: 150%; MARGIN: 0px 10px 0px = 20px; COLOR: rgb(100,100,100); FONT-FAMILY: "trebuchet = ms",arial,sans-serif } .main-navigation H3 { CLEAR: both; FONT-WEIGHT: bold; FONT-SIZE: 110%; MARGIN: 10px 10px 5px = 20px; COLOR: rgb(80,80,80) } .main-navigation P { CLEAR: both; FONT-SIZE: 110%; MARGIN: 0px 10px 10px 20px; COLOR: = rgb(80,80,80); LINE-HEIGHT: 1.3em } .main-navigation P.center { TEXT-ALIGN: center } .main-navigation P.right { TEXT-ALIGN: right } .main-navigation UL { MARGIN: 0em 10px 0px 20px; LIST-STYLE-TYPE: none } .main-navigation UL LI { PADDING-RIGHT: 0px; PADDING-LEFT: 11px; FONT-SIZE: 110%; BACKGROUND: = url(../images/bg_bullet_full_1.gif) no-repeat 0px 0.4em; PADDING-BOTTOM: = 0px; MARGIN: 5px 0px 0.2em 2px; LINE-HEIGHT: 1.2em; PADDING-TOP: 0px } .main-navigation OL { MARGIN: 0.5em 10px 1em 40px } .main-navigation OL LI { LIST-STYLE-POSITION: outside; FONT-SIZE: 110%; MARGIN: 0px 0px 0.4em } .main-content H1.pagetitle { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-WEIGHT: bold; FONT-SIZE: = 170%; PADDING-BOTTOM: 2px; MARGIN: 0px 0px 0.4em; COLOR: = rgb(100,100,100); PADDING-TOP: 0px; BORDER-BOTTOM: rgb(225,225,225) 7px = solid; FONT-FAMILY: "trebuchet ms",arial,sans-serif } .main-content H1.block { CLEAR: both; PADDING-RIGHT: 0px; PADDING-LEFT: 2px; FONT-WEIGHT: bold; = FONT-SIZE: 170%; BACKGROUND: rgb(190,190,190); PADDING-BOTTOM: 2px; = MARGIN: 1em 0px 0em; COLOR: rgb(255,255,255); PADDING-TOP: 2px; = FONT-FAMILY: "trebuchet ms",arial,sans-serif } .main-content H1 { CLEAR: both; FONT-WEIGHT: normal; FONT-SIZE: 210%; MARGIN: 0em 0px = 0.5em; COLOR: rgb(80,80,80); FONT-FAMILY: "trebuchet = ms",arial,sans-serif } .main-content H2 { CLEAR: both; FONT-WEIGHT: normal; FONT-SIZE: 170%; MARGIN: 0.3em 0px = 0.2em; COLOR: rgb(80,80,80); FONT-FAMILY: "trebuchet = ms",arial,sans-serif } .main-content H3 { CLEAR: both; FONT-WEIGHT: normal; FONT-SIZE: 150%; MARGIN: -1em 0px = 0.5em; COLOR: rgb(125,125,125); FONT-FAMILY: "trebuchet = ms",arial,sans-serif } .main-content H1.side { CLEAR: none } .main-content H2.side { CLEAR: none } .main-content H3.side { CLEAR: none } .main-content H4 { FONT-WEIGHT: normal; FONT-SIZE: 170%; MARGIN: 1.5em 0px 1em; COLOR: = rgb(80,80,80); FONT-FAMILY: "trebuchet ms",arial,sans-serif } .main-content H5 { FONT-SIZE: 140%; MARGIN: 1.5em 0px 1em; COLOR: rgb(80,80,80); = FONT-FAMILY: "trebuchet ms",arial,sans-serif } .main-content H6 { FONT-WEIGHT: normal; FONT-SIZE: 140%; MARGIN: 1.5em 0px 1em; COLOR: = rgb(80,80,80); FONT-FAMILY: "trebuchet ms",verdana,arial,sans-serif } .main-content P { FONT-SIZE: 115%; MARGIN: 0px 0px 1em; COLOR: #2e2e2e; LINE-HEIGHT: = 1.5em } .main-content P.center { TEXT-ALIGN: center } .main-content P.right { TEXT-ALIGN: right } .main-content P.details { CLEAR: both; FONT-SIZE: 110%; MARGIN: -0.25em 0px 1em; LINE-HEIGHT: 1em } .main-content BLOCKQUOTE { CLEAR: both; FONT-SIZE: 90%; MARGIN: 0px 30px 0.6em } P.caption { CLEAR: both; FONT-SIZE: 110%; MARGIN: 0.5em 0px 2em 20px; COLOR: = rgb(80,80,80); TEXT-ALIGN: left } .main-content .showlist { MARGIN: 0.5em 0px 1em; COLOR: #2e2e2e } .main-content .showlist LI { FONT-SIZE: 110%; MARGIN-LEFT: 3em; LINE-HEIGHT: 1.4em } .main-content OL { MARGIN: 0.5em 0px 1em 20px } .main-content OL LI { LIST-STYLE-POSITION: outside; FONT-SIZE: 120%; MARGIN: 0px 0px 0.2em; = LINE-HEIGHT: 1.4em } .contactform { BORDER-RIGHT: rgb(200,200,200) 1px solid; PADDING-RIGHT: 10px; = BORDER-TOP: rgb(200,200,200) 1px solid; PADDING-LEFT: 10px; = PADDING-BOTTOM: 0px; MARGIN: 2em 0px 0px; BORDER-LEFT: rgb(200,200,200) = 1px solid; WIDTH: 500px; PADDING-TOP: 10px; BORDER-BOTTOM: = rgb(200,200,200) 1px solid; BACKGROUND-COLOR: rgb(240,240,240) } .contactform FIELDSET { BORDER-RIGHT: rgb(220,220,220) 1px solid; PADDING-RIGHT: 0px! = important; BORDER-TOP: rgb(220,220,220) 1px solid; PADDING-LEFT: 0px! = important; PADDING-BOTTOM: 0px! important; MARGIN: 0px 0px 20px; = BORDER-LEFT: rgb(220,220,220) 1px solid; PADDING-TOP: 20px! important; = BORDER-BOTTOM: rgb(220,220,220) 1px solid } .contactform FIELDSET LEGEND { PADDING-RIGHT: 2px; PADDING-LEFT: 2px; FONT-WEIGHT: bold; FONT-SIZE: = 130%; PADDING-BOTTOM: 0px; MARGIN: 0px 0px 0px 5px; COLOR: = rgb(80,80,80); PADDING-TOP: 0px } .contactform LABEL.left { PADDING-RIGHT: 2px; PADDING-LEFT: 2px; FONT-SIZE: 110%; FLOAT: left; = PADDING-BOTTOM: 2px; MARGIN: 0px 0px 0px 10px; WIDTH: 150px; = PADDING-TOP: 2px } .contactform SELECT.combo { BORDER-RIGHT: rgb(200,200,200) 1px solid; PADDING-RIGHT: 2px; = BORDER-TOP: rgb(200,200,200) 1px solid; PADDING-LEFT: 2px; FONT-SIZE: = 110%; PADDING-BOTTOM: 2px; BORDER-LEFT: rgb(200,200,200) 1px solid; = WIDTH: 175px; PADDING-TOP: 2px; BORDER-BOTTOM: rgb(200,200,200) 1px = solid; FONT-FAMILY: verdana,arial,sans-serif } .contactform INPUT.field { BORDER-RIGHT: rgb(200,200,200) 1px solid; PADDING-RIGHT: 2px; = BORDER-TOP: rgb(200,200,200) 1px solid; PADDING-LEFT: 2px; FONT-SIZE: = 110%; PADDING-BOTTOM: 2px; BORDER-LEFT: rgb(200,200,200) 1px solid; = WIDTH: 275px; PADDING-TOP: 2px; BORDER-BOTTOM: rgb(200,200,200) 1px = solid; FONT-FAMILY: verdana,arial,sans-serif } .contactform TEXTAREA { BORDER-RIGHT: rgb(200,200,200) 1px solid; PADDING-RIGHT: 2px; = BORDER-TOP: rgb(200,200,200) 1px solid; PADDING-LEFT: 2px; FONT-SIZE: = 110%; PADDING-BOTTOM: 2px; BORDER-LEFT: rgb(200,200,200) 1px solid; = WIDTH: 275px; PADDING-TOP: 2px; BORDER-BOTTOM: rgb(200,200,200) 1px = solid; FONT-FAMILY: verdana,arial,sans-serif } .contactform INPUT.button { BORDER-RIGHT: rgb(150,150,150) 1px solid; PADDING-RIGHT: 1px! = important; BORDER-TOP: rgb(150,150,150) 1px solid; PADDING-LEFT: 1px! = important; FONT-SIZE: 110%; BACKGROUND: rgb(230,230,230); FLOAT: right; = PADDING-BOTTOM: 1px! important; BORDER-LEFT: rgb(150,150,150) 1px solid; = WIDTH: 9em; COLOR: rgb(150,150,150); MARGIN-RIGHT: 20px; PADDING-TOP: = 1px! important; BORDER-BOTTOM: rgb(150,150,150) 1px solid; FONT-FAMILY: = verdana,arial,sans-serif; TEXT-ALIGN: center } .contactform INPUT.button:hover { BORDER-RIGHT: rgb(80,80,80) 1px solid; BORDER-TOP: rgb(80,80,80) 1px = solid; BACKGROUND: rgb(220,220,220); BORDER-LEFT: rgb(80,80,80) 1px = solid; CURSOR: pointer; COLOR: rgb(80,80,80); BORDER-BOTTOM: = rgb(80,80,80) 1px solid } .largeform { BORDER-RIGHT: rgb(200,200,200) 1px solid; PADDING-RIGHT: 10px; = BORDER-TOP: rgb(200,200,200) 1px solid; PADDING-LEFT: 10px; = PADDING-BOTTOM: 0px; MARGIN: 2em 0px 0px; BORDER-LEFT: rgb(200,200,200) = 1px solid; WIDTH: 600px; PADDING-TOP: 10px; BORDER-BOTTOM: = rgb(200,200,200) 1px solid; BACKGROUND-COLOR: rgb(240,240,240) } .largeform FIELDSET { BORDER-RIGHT: rgb(220,220,220) 1px solid; PADDING-RIGHT: 0px! = important; BORDER-TOP: rgb(220,220,220) 1px solid; PADDING-LEFT: 0px! = important; PADDING-BOTTOM: 0px! important; MARGIN: 0px 0px 20px; = BORDER-LEFT: rgb(220,220,220) 1px solid; PADDING-TOP: 20px! important; = BORDER-BOTTOM: rgb(220,220,220) 1px solid } .largeform FIELDSET LEGEND { PADDING-RIGHT: 2px; PADDING-LEFT: 2px; FONT-WEIGHT: bold; FONT-SIZE: = 130%; PADDING-BOTTOM: 0px; MARGIN: 0px 0px 0px 5px; COLOR: = rgb(80,80,80); PADDING-TOP: 0px } .largeform LABEL.left { PADDING-RIGHT: 2px; PADDING-LEFT: 2px; FONT-SIZE: 110%; FLOAT: left; = PADDING-BOTTOM: 2px; MARGIN: 0px 0px 0px 10px; WIDTH: 100px; = PADDING-TOP: 2px } .largeform SELECT.combo { BORDER-RIGHT: rgb(200,200,200) 1px solid; PADDING-RIGHT: 2px; = BORDER-TOP: rgb(200,200,200) 1px solid; PADDING-LEFT: 2px; FONT-SIZE: = 110%; PADDING-BOTTOM: 2px; BORDER-LEFT: rgb(200,200,200) 1px solid; = WIDTH: 175px; PADDING-TOP: 2px; BORDER-BOTTOM: rgb(200,200,200) 1px = solid; FONT-FAMILY: verdana,arial,sans-serif } .largeform INPUT.field { BORDER-RIGHT: rgb(200,200,200) 1px solid; PADDING-RIGHT: 2px; = BORDER-TOP: rgb(200,200,200) 1px solid; PADDING-LEFT: 2px; FONT-SIZE: = 110%; PADDING-BOTTOM: 2px; BORDER-LEFT: rgb(200,200,200) 1px solid; = WIDTH: 275px; PADDING-TOP: 2px; BORDER-BOTTOM: rgb(200,200,200) 1px = solid; FONT-FAMILY: verdana,arial,sans-serif } .largeform TEXTAREA { BORDER-RIGHT: rgb(200,200,200) 1px solid; PADDING-RIGHT: 2px; = BORDER-TOP: rgb(200,200,200) 1px solid; PADDING-LEFT: 2px; FONT-SIZE: = 110%; PADDING-BOTTOM: 2px; BORDER-LEFT: rgb(200,200,200) 1px solid; = WIDTH: 450px; PADDING-TOP: 2px; BORDER-BOTTOM: rgb(200,200,200) 1px = solid; FONT-FAMILY: verdana,arial,sans-serif } .largeform INPUT.button { BORDER-RIGHT: rgb(150,150,150) 1px solid; PADDING-RIGHT: 1px! = important; BORDER-TOP: rgb(150,150,150) 1px solid; PADDING-LEFT: 1px! = important; FONT-SIZE: 110%; BACKGROUND: rgb(230,230,230); FLOAT: right; = PADDING-BOTTOM: 1px! important; BORDER-LEFT: rgb(150,150,150) 1px solid; = WIDTH: 9em; COLOR: rgb(150,150,150); MARGIN-RIGHT: 20px; PADDING-TOP: = 1px! important; BORDER-BOTTOM: rgb(150,150,150) 1px solid; FONT-FAMILY: = verdana,arial,sans-serif; TEXT-ALIGN: center } .largeform INPUT.button:hover { BORDER-RIGHT: rgb(80,80,80) 1px solid; BORDER-TOP: rgb(80,80,80) 1px = solid; BACKGROUND: rgb(220,220,220); BORDER-LEFT: rgb(80,80,80) 1px = solid; CURSOR: pointer; COLOR: rgb(80,80,80); BORDER-BOTTOM: = rgb(80,80,80) 1px solid } .main-subcontent H1 { CLEAR: both; PADDING-RIGHT: 10px; PADDING-LEFT: 10px; FONT-WEIGHT: = bold; FONT-SIZE: 140%; PADDING-BOTTOM: 3px; MARGIN: 0px 0px 10px; COLOR: = rgb(255,255,255); PADDING-TOP: 4px; FONT-FAMILY: "trebuchet = ms",arial,sans-serif; BACKGROUND-COLOR: rgb(190,190,190) } .main-subcontent H1.green { CLEAR: both; PADDING-RIGHT: 10px; PADDING-LEFT: 10px; FONT-WEIGHT: = bold; FONT-SIZE: 140%; PADDING-BOTTOM: 3px; MARGIN: 0px 0px 5px; COLOR: = rgb(255,255,255); PADDING-TOP: 4px; FONT-FAMILY: "trebuchet = ms",verdana,arial,sans-serif; BACKGROUND-COLOR: rgb(160,214,81) } .main-subcontent H1.blue { CLEAR: both; PADDING-RIGHT: 10px; PADDING-LEFT: 10px; FONT-WEIGHT: = bold; FONT-SIZE: 140%; PADDING-BOTTOM: 3px; MARGIN: 0px 0px 5px; COLOR: = rgb(255,255,255); PADDING-TOP: 4px; FONT-FAMILY: "trebuchet = ms",verdana,arial,sans-serif; BACKGROUND-COLOR: #5b59ba } .main-subcontent H1.orange { CLEAR: both; PADDING-RIGHT: 10px; PADDING-LEFT: 10px; FONT-WEIGHT: = bold; FONT-SIZE: 140%; PADDING-BOTTOM: 3px; MARGIN: 0px 0px 5px; COLOR: = rgb(255,255,255); PADDING-TOP: 4px; FONT-FAMILY: "trebuchet = ms",verdana,arial,sans-serif; BACKGROUND-COLOR: rgb(232,177,13) } .main-subcontent H3 { CLEAR: both; FONT-WEIGHT: bold; FONT-SIZE: 110%; MARGIN: 1em 10px = 0.5em; COLOR: rgb(80,80,80) } .main-subcontent P { CLEAR: both; FONT-SIZE: 110%; MARGIN: 0px 10px 1em; COLOR: = rgb(80,80,80); LINE-HEIGHT: 1.3em } .main-subcontent P.center { TEXT-ALIGN: center } .main-subcontent P.right { TEXT-ALIGN: right } .main-subcontent UL { MARGIN: 0.5em 10px 1em; LIST-STYLE-TYPE: none } .main-subcontent UL LI { PADDING-RIGHT: 0px; PADDING-LEFT: 11px; FONT-SIZE: 110%; BACKGROUND: = url(../images/bg_bullet_full_1.gif) no-repeat 0px 0.4em; PADDING-BOTTOM: = 0px; MARGIN: 5px 0px 0.2em 2px; LINE-HEIGHT: 1.2em; PADDING-TOP: 0px } .xmain-subcontent OL { MARGIN: 0.5em 10px 1em 30px } .main-subcontent OL { MARGIN: 0.5em 10px 1em 30px } .main-subcontent OL LI { LIST-STYLE-POSITION: outside; FONT-SIZE: 110%; MARGIN: 0px 0px 0.4em } .main-subcontent .loginform { MARGIN: 0px 10px; WIDTH: 160px } .main-subcontent .loginform P { CLEAR: both; PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: = 0px; MARGIN: 0px; PADDING-TOP: 0px } .main-subcontent .loginform FIELDSET { WIDTH: 160px; BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: none; = BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: none } .main-subcontent .loginform LABEL.top { FONT-SIZE: 110%; FLOAT: left; MARGIN: 0px 0px 2px; WIDTH: 125px } .main-subcontent .loginform LABEL.right { PADDING-RIGHT: 0px; PADDING-LEFT: 3px; FONT-SIZE: 110%; FLOAT: left; = PADDING-BOTTOM: 0px; MARGIN: 5px 0px 0px; WIDTH: 125px; PADDING-TOP: 0px } .main-subcontent .loginform INPUT.field { BORDER-RIGHT: rgb(200,200,200) 1px solid; PADDING-RIGHT: 0px! = important; BORDER-TOP: rgb(200,200,200) 1px solid; PADDING-LEFT: 0px! = important; FONT-SIZE: 110%; PADDING-BOTTOM: 0.2em! important; MARGIN: = 0px 0px 5px; BORDER-LEFT: rgb(200,200,200) 1px solid; WIDTH: 158px; = PADDING-TOP: 0.1em! important; BORDER-BOTTOM: rgb(200,200,200) 1px = solid; FONT-FAMILY: verdana,arial,sans-serif } .main-subcontent .loginform INPUT.checkbox { FLOAT: left; MARGIN: 5px 0px 0px; BORDER-TOP-STYLE: none; = BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: = none } .main-subcontent .loginform INPUT.button { BORDER-RIGHT: rgb(150,150,150) 1px solid; PADDING-RIGHT: 1px; = BORDER-TOP: rgb(150,150,150) 1px solid; PADDING-LEFT: 1px; FONT-SIZE: = 110%; BACKGROUND: rgb(230,230,230); FLOAT: left; PADDING-BOTTOM: 1px; = MARGIN: 10px 0px 5px; BORDER-LEFT: rgb(150,150,150) 1px solid; WIDTH: = 5em; COLOR: rgb(150,150,150); PADDING-TOP: 1px; BORDER-BOTTOM: = rgb(150,150,150) 1px solid; FONT-FAMILY: verdana,arial,sans-serif; = TEXT-ALIGN: center } .main-subcontent .loginform INPUT.button:hover { BORDER-RIGHT: rgb(80,80,80) 1px solid; BORDER-TOP: rgb(80,80,80) 1px = solid; BACKGROUND: rgb(220,220,220); BORDER-LEFT: rgb(80,80,80) 1px = solid; CURSOR: pointer; COLOR: rgb(80,80,80); BORDER-BOTTOM: = rgb(80,80,80) 1px solid } .main-subcontent .searchform { MARGIN: 0px 10px; WIDTH: 160px } .main-subcontent .searchform FIELDSET { BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: = none; BORDER-BOTTOM-STYLE: none } .main-subcontent .searchform INPUT.field { BORDER-RIGHT: rgb(200,200,200) 1px solid; PADDING-RIGHT: 0px! = important; BORDER-TOP: rgb(200,200,200) 1px solid; PADDING-LEFT: 0px! = important; FONT-SIZE: 120%; FLOAT: left; PADDING-BOTTOM: 0.2em! = important; BORDER-LEFT: rgb(200,200,200) 1px solid; WIDTH: 158px; = PADDING-TOP: 0.1em! important; BORDER-BOTTOM: rgb(200,200,200) 1px = solid; FONT-FAMILY: verdana,arial,sans-serif } .main-subcontent .searchform INPUT.button { BORDER-RIGHT: rgb(150,150,150) 1px solid; PADDING-RIGHT: 1px; = BORDER-TOP: rgb(150,150,150) 1px solid; MARGIN-TOP: 0.5em; PADDING-LEFT: = 1px; FONT-SIZE: 120%; BACKGROUND: rgb(230,230,230); FLOAT: left; = PADDING-BOTTOM: 1px; BORDER-LEFT: rgb(150,150,150) 1px solid; WIDTH: = 3em; COLOR: rgb(150,150,150); PADDING-TOP: 1px; BORDER-BOTTOM: = rgb(150,150,150) 1px solid; FONT-FAMILY: verdana,arial,sans-serif; = TEXT-ALIGN: center } .main-subcontent .searchform INPUT.button:hover { BORDER-RIGHT: rgb(80,80,80) 1px solid; BORDER-TOP: rgb(80,80,80) 1px = solid; BACKGROUND: rgb(220,220,220); BORDER-LEFT: rgb(80,80,80) 1px = solid; CURSOR: pointer; COLOR: rgb(80,80,80); BORDER-BOTTOM: = rgb(80,80,80) 1px solid } .main IMG.center { CLEAR: both; PADDING-RIGHT: 1px; PADDING-LEFT: 1px; FLOAT: none; = PADDING-BOTTOM: 1px; MARGIN: 0px; PADDING-TOP: 1px } .main IMG.right { CLEAR: both; PADDING-RIGHT: 1px; PADDING-LEFT: 1px; FLOAT: right; = PADDING-BOTTOM: 1px; MARGIN: 3px 0px 7px 10px; PADDING-TOP: 1px } .main A { FONT-WEIGHT: bold; COLOR: rgb(70,122,167); TEXT-DECORATION: none } .main-content H1 A { FONT-WEIGHT: normal; COLOR: rgb(70,122,167); TEXT-DECORATION: none } .main A:hover { COLOR: rgb(42,90,138); TEXT-DECORATION: underline } .main A:visited { COLOR: rgb(42,90,138) } .main A IMG { =09 } .main A:hover IMG { =09 } .main-content TABLE.forum { BACKGROUND: #3a66a7; FONT: 10px 'Verdana', Arial, Helvetica, = sans-serif; COLOR: #666666; border-spacing: 1px } .main-content TABLE.forum CAPTION { PADDING-RIGHT: 10px; PADDING-LEFT: 10px; BORDER-LEFT-COLOR: #666666; = BACKGROUND: url(../images/TableCaption.jpg); PADDING-BOTTOM: 10px; FONT: = bold italic 15px 'Verdana', Arial, Helvetica, sans-serif; = TEXT-TRANSFORM: uppercase; BORDER-TOP-COLOR: #666666; PADDING-TOP: 10px; = BORDER-BOTTOM: #666666 2px solid; BORDER-RIGHT-COLOR: #666666 } .main-content TABLE.forum TD { PADDING-RIGHT: 4px; PADDING-LEFT: 4px; PADDING-BOTTOM: 4px; = PADDING-TOP: 4px } TH { PADDING-RIGHT: 4px; PADDING-LEFT: 4px; PADDING-BOTTOM: 4px; = PADDING-TOP: 4px } .main-content TABLE.forum THEAD TH { BORDER-RIGHT: #ffffff 1px solid; BORDER-TOP: #ffffff 1px solid; = BACKGROUND: #f5f5f5; TEXT-TRANSFORM: uppercase; BORDER-LEFT: #ffffff 1px = solid; COLOR: #666666; BORDER-BOTTOM: #ffffff 1px solid; TEXT-ALIGN: = center } .main-content TABLE.forum TBODY TH { FONT-WEIGHT: bold; BACKGROUND: url(../images/Top Option 2.jpg) = rgb(240,240,240); OVERFLOW: visible! important; COLOR: white } .main-content TABLE.forum TBODY TR { BACKGROUND: #ebf8fe; TEXT-ALIGN: left } .main-content TABLE.forum TBODY TR.odd { BORDER-TOP: #ffffff 1px solid; BACKGROUND: #cae1ff } .main-content TABLE.forum TBODY TH A:link { PADDING-RIGHT: 0px; PADDING-LEFT: 18px; BACKGROUND: = url(../images/ico_novajanela.gif) no-repeat; PADDING-BOTTOM: 0px; COLOR: = #666666; PADDING-TOP: 3px } TBODY TH A:visited { PADDING-RIGHT: 0px; PADDING-LEFT: 18px; BACKGROUND: = url(../images/ico_novajanela.gif) no-repeat; PADDING-BOTTOM: 0px; COLOR: = #666666; PADDING-TOP: 3px } .main-content TABLE.forum TBODY TH A:hover { COLOR: #009900 } .main-content TABLE.forum TBODY TR TD { BORDER-RIGHT: #ffffff 1px solid; BORDER-TOP: #ffffff 1px solid; = BACKGROUND: #ebf8fe; BORDER-LEFT: #ffffff 1px solid; BORDER-BOTTOM: = #ffffff 1px solid; HEIGHT: 50px } .main-content TABLE.forum TBODY TR.odd TD { BORDER-TOP: #ffffff 1px solid; BACKGROUND: #cae1ff } .main-content TABLE.forum TABLE TD A:link { FONT-WEIGHT: bold; COLOR: #666666; TEXT-DECORATION: none } TABLE TD A:visited { FONT-WEIGHT: bold; COLOR: #666666; TEXT-DECORATION: none } .main-content TABLE.forum TABLE TD A:hover { FONT-WEIGHT: bold; COLOR: #009900; TEXT-DECORATION: underline } .main-content TABLE.forum TABLE A[title^=3D'Download'] { PADDING-RIGHT: 0px; PADDING-LEFT: 15px; BACKGROUND: = url(http://www.leandropessoa.com.br/table/img/icPADRAO.gif) no-repeat = center 50%; PADDING-BOTTOM: 0px; PADDING-TOP: 20px } .main-content TABLE.forum TBODY TD = A[href=3D'http://www.leandropessoa.com.br'] { PADDING-RIGHT: 0px; PADDING-LEFT: 18px; FONT-WEIGHT: bold; BACKGROUND: = url(http://www.leandropessoa.com.br/table/img/check.gif) no-repeat; = BORDER-BOTTOM-WIDTH: 0px; PADDING-BOTTOM: 0px; MARGIN: 0px auto; COLOR: = #ff8601; PADDING-TOP: 3px; HEIGHT: 15px } .main-content TABLE.forum TFOOT TH { PADDING-RIGHT: 10px; BORDER-TOP: #dfdfdf 1px solid; PADDING-LEFT: 10px; = BACKGROUND: = url(http://www.leandropessoa.com.br/table/img/TableCaption.jpg); = PADDING-BOTTOM: 10px; FONT: bold italic 15px 'Verdana', Arial, = Helvetica, sans-serif; PADDING-TOP: 10px; BORDER-BOTTOM: #cccccc 3px = solid; TEXT-ALIGN: center } TFOOT TD { PADDING-RIGHT: 10px; BORDER-TOP: #dfdfdf 1px solid; PADDING-LEFT: 10px; = BACKGROUND: = url(http://www.leandropessoa.com.br/table/img/TableCaption.jpg); = PADDING-BOTTOM: 10px; FONT: bold italic 15px 'Verdana', Arial, = Helvetica, sans-serif; PADDING-TOP: 10px; BORDER-BOTTOM: #cccccc 3px = solid; TEXT-ALIGN: center } ------=_NextPart_000_0000_01C9046D.463CB5E0 Content-Type: application/octet-stream Content-Transfer-Encoding: quoted-printable Content-Location: http://www.graduatejunction.com/stylesheets/application.css?1218231958 TABLE.form_edit { BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: = none; BORDER-BOTTOM-STYLE: none } TABLE.form_edit TD { PADDING-RIGHT: 2px; PADDING-LEFT: 2px; PADDING-BOTTOM: 2px; = BORDER-TOP-STYLE: none; PADDING-TOP: 2px; BORDER-RIGHT-STYLE: none; = BORDER-LEFT-STYLE: none; BORDER-BOTTOM-STYLE: none } TABLE.form_edit TH { VERTICAL-ALIGN: top; COLOR: #666; TEXT-ALIGN: left } TABLE.keyword_search_form { BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: = none; BORDER-BOTTOM-STYLE: none } TABLE.keyword_search_form TD { BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: = none; BORDER-BOTTOM-STYLE: none } TABLE.unified_search_form { BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: = none; BORDER-BOTTOM-STYLE: none } TABLE.unified_search_form TD { BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: = none; BORDER-BOTTOM-STYLE: none } .auto_drop_down UL { LIST-STYLE-TYPE: none } #map_div { BORDER-RIGHT: #ccc 1px solid; BORDER-TOP: #ccc 1px solid; BORDER-LEFT: = #ccc 1px solid; WIDTH: 100%; BORDER-BOTTOM: #ccc 1px solid; HEIGHT: = 300px } .search_form { BORDER-RIGHT: #ccc 1px solid; PADDING-RIGHT: 3px; BORDER-TOP: #ccc 1px = solid; PADDING-LEFT: 3px; PADDING-BOTTOM: 3px; BORDER-LEFT: #ccc 1px = solid; WIDTH: 100%; PADDING-TOP: 3px; BORDER-BOTTOM: #ccc 1px solid; = BACKGROUND-COLOR: #f2f2f2 } .multipleSelect { BORDER-RIGHT: #aaa 1px solid; PADDING-RIGHT: 2px; BORDER-TOP: #aaa 1px = solid; PADDING-LEFT: 2px; PADDING-BOTTOM: 2px; MARGIN: 1em; OVERFLOW: = auto; BORDER-LEFT: #aaa 1px solid; WIDTH: 250px; PADDING-TOP: 2px; = BORDER-BOTTOM: #aaa 1px solid; HEIGHT: 200px } .multipleSelect LABEL { FONT-WEIGHT: normal } .multipleSelect { LIST-STYLE-TYPE: none } .multipleSelect UL { LIST-STYLE-TYPE: none } .multipleSelectCheckbox { BACKGROUND: #fff } INPUT.checkbox { BORDER-TOP-WIDTH: 0px; BORDER-LEFT-WIDTH: 0px; BORDER-BOTTOM-WIDTH: = 0px; BORDER-RIGHT-WIDTH: 0px } INPUT.radio { BORDER-TOP-WIDTH: 0px; BORDER-LEFT-WIDTH: 0px; BORDER-BOTTOM-WIDTH: = 0px; BORDER-RIGHT-WIDTH: 0px } #members { MARGIN-LEFT: 20px } .status_button { FONT-SIZE: 14px; WIDTH: 200px } #flash { BORDER-RIGHT: red 2px solid; PADDING-RIGHT: 10px; BORDER-TOP: red 2px = solid; PADDING-LEFT: 10px; FONT-WEIGHT: bold; PADDING-BOTTOM: 10px; = BORDER-LEFT: red 2px solid; COLOR: #666; PADDING-TOP: 10px; = BORDER-BOTTOM: red 2px solid; BACKGROUND-COLOR: #f0f0f0 } #flash { FONT-SIZE: 125% } .box { BORDER-RIGHT: #5282c6 1px solid; BORDER-TOP: #5282c6 1px solid; = BACKGROUND: #ffffff; MARGIN-BOTTOM: 10px; BORDER-LEFT: #5282c6 1px = solid; BORDER-BOTTOM: #5282c6 1px solid } .box_title { PADDING-RIGHT: 3px; PADDING-LEFT: 3px; FONT-SIZE: 12px; BACKGROUND: = #283a90; PADDING-BOTTOM: 3px; COLOR: white; PADDING-TOP: 3px } .box_content { PADDING-RIGHT: 3px; PADDING-LEFT: 3px; PADDING-BOTTOM: 3px; = PADDING-TOP: 3px } .small_link A { FONT-SIZE: 12px; FLOAT: right } .fieldWithErrors { BACKGROUND-COLOR: red } #errorExplanation { BORDER-RIGHT: red 2px solid; PADDING-RIGHT: 7px; BORDER-TOP: red 2px = solid; PADDING-LEFT: 7px; MARGIN-BOTTOM: 20px; PADDING-BOTTOM: 12px; = BORDER-LEFT: red 2px solid; WIDTH: 100%; PADDING-TOP: 7px; = BORDER-BOTTOM: red 2px solid; BACKGROUND-COLOR: #f0f0f0 } #errorExplanation H2 { PADDING-RIGHT: 5px; PADDING-LEFT: 15px; FONT-WEIGHT: bold; FONT-SIZE: = 12px; PADDING-BOTTOM: 5px; MARGIN: -7px; COLOR: #fff; PADDING-TOP: 5px; = BACKGROUND-COLOR: #c00; TEXT-ALIGN: left } #errorExplanation P { PADDING-RIGHT: 5px; PADDING-LEFT: 5px; MARGIN-BOTTOM: 0px; = PADDING-BOTTOM: 5px; COLOR: #333; PADDING-TOP: 5px } #errorExplanation UL LI { FONT-SIZE: 12px; MARGIN-LEFT: 1em; LIST-STYLE-TYPE: square } H3.box_heading { CLEAR: both; FONT-WEIGHT: normal; FONT-SIZE: 270%; MARGIN: 8em 0px 1em; = COLOR: rgb(80,80,80); FONT-FAMILY: "trebuchet ms",arial,sans-serif } ------=_NextPart_000_0000_01C9046D.463CB5E0 Content-Type: application/octet-stream Content-Transfer-Encoding: quoted-printable Content-Location: http://www.graduatejunction.com/stylesheets/pagination.css?1218551973 .digg_pagination { BACKGROUND: white } .digg_pagination A { PADDING-RIGHT: 0.5em; DISPLAY: block; PADDING-LEFT: 0.5em; FLOAT: left; = PADDING-BOTTOM: 0.2em; MARGIN-RIGHT: 1px; PADDING-TOP: 0.2em } .digg_pagination SPAN { PADDING-RIGHT: 0.5em; DISPLAY: block; PADDING-LEFT: 0.5em; FLOAT: left; = PADDING-BOTTOM: 0.2em; MARGIN-RIGHT: 1px; PADDING-TOP: 0.2em } .digg_pagination SPAN.disabled { BORDER-RIGHT: #ddd 1px solid; BORDER-TOP: #ddd 1px solid; BORDER-LEFT: = #ddd 1px solid; COLOR: #999; BORDER-BOTTOM: #ddd 1px solid } .digg_pagination SPAN.current { BORDER-RIGHT: #2e6ab1 1px solid; BORDER-TOP: #2e6ab1 1px solid; = FONT-WEIGHT: bold; BACKGROUND: #2e6ab1; BORDER-LEFT: #2e6ab1 1px solid; = COLOR: white; BORDER-BOTTOM: #2e6ab1 1px solid } .digg_pagination A { BORDER-RIGHT: #9aafe5 1px solid; BORDER-TOP: #9aafe5 1px solid; = BORDER-LEFT: #9aafe5 1px solid; COLOR: #105cb6; BORDER-BOTTOM: #9aafe5 = 1px solid; TEXT-DECORATION: none } .digg_pagination A:hover { BORDER-LEFT-COLOR: #003; BORDER-BOTTOM-COLOR: #003; COLOR: #003; = BORDER-TOP-COLOR: #003; BORDER-RIGHT-COLOR: #003 } .digg_pagination A:focus { BORDER-LEFT-COLOR: #003; BORDER-BOTTOM-COLOR: #003; COLOR: #003; = BORDER-TOP-COLOR: #003; BORDER-RIGHT-COLOR: #003 } .digg_pagination .page_info { PADDING-RIGHT: 0.6em; PADDING-LEFT: 0.6em; BACKGROUND: = rgb(225,225,225); MARGIN-BOTTOM: 0.3em; PADDING-BOTTOM: 0.4em; WIDTH: = 22em; COLOR: #2e2e2e; PADDING-TOP: 0.4em; TEXT-ALIGN: center } .digg_pagination .page_info B { PADDING-RIGHT: 0.25em; PADDING-LEFT: 0.25em; BACKGROUND: #6aa6ed; = PADDING-BOTTOM: 0.1em; COLOR: #003; PADDING-TOP: 0.1em } .digg_pagination:unknown { CLEAR: both; DISPLAY: block; VISIBILITY: hidden; HEIGHT: 0px; content: = "." } * HTML .digg_pagination { HEIGHT: 1% } *:first-child + HTML .digg_pagination { OVERFLOW: hidden } .apple_pagination { BORDER-RIGHT: #e5e5e5 1px solid; PADDING-RIGHT: 1em; BORDER-TOP: = #e5e5e5 1px solid; PADDING-LEFT: 1em; BACKGROUND: #f1f1f1; = PADDING-BOTTOM: 1em; BORDER-LEFT: #e5e5e5 1px solid; PADDING-TOP: 1em; = BORDER-BOTTOM: #e5e5e5 1px solid; TEXT-ALIGN: center } .apple_pagination A { PADDING-RIGHT: 0.3em; PADDING-LEFT: 0.3em; PADDING-BOTTOM: 0.2em; = PADDING-TOP: 0.2em } .apple_pagination SPAN { PADDING-RIGHT: 0.3em; PADDING-LEFT: 0.3em; PADDING-BOTTOM: 0.2em; = PADDING-TOP: 0.2em } .apple_pagination SPAN.disabled { COLOR: #aaa } .apple_pagination SPAN.current { FONT-WEIGHT: bold; BACKGROUND: url(apple-circle.gif) no-repeat 50% 50% } .apple_pagination A { COLOR: black; TEXT-DECORATION: none } .apple_pagination A:hover { TEXT-DECORATION: underline } .apple_pagination A:focus { TEXT-DECORATION: underline } .flickr_pagination { PADDING-RIGHT: 0.3em; PADDING-LEFT: 0.3em; PADDING-BOTTOM: 0.3em; = PADDING-TOP: 0.3em; TEXT-ALIGN: center } .flickr_pagination A { PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; PADDING-BOTTOM: 0.2em; = PADDING-TOP: 0.2em } .flickr_pagination SPAN { PADDING-RIGHT: 0.5em; PADDING-LEFT: 0.5em; PADDING-BOTTOM: 0.2em; = PADDING-TOP: 0.2em } .flickr_pagination SPAN.disabled { COLOR: #aaa } .flickr_pagination SPAN.current { FONT-WEIGHT: bold; COLOR: #ff0084 } .flickr_pagination A { BORDER-RIGHT: #dddddd 1px solid; BORDER-TOP: #dddddd 1px solid; = BORDER-LEFT: #dddddd 1px solid; COLOR: #0063dc; BORDER-BOTTOM: #dddddd = 1px solid; TEXT-DECORATION: none } .flickr_pagination A:hover { BORDER-LEFT-COLOR: #003366; BACKGROUND: #0063dc; BORDER-BOTTOM-COLOR: = #003366; COLOR: white; BORDER-TOP-COLOR: #003366; BORDER-RIGHT-COLOR: = #003366 } .flickr_pagination A:focus { BORDER-LEFT-COLOR: #003366; BACKGROUND: #0063dc; BORDER-BOTTOM-COLOR: = #003366; COLOR: white; BORDER-TOP-COLOR: #003366; BORDER-RIGHT-COLOR: = #003366 } .flickr_pagination .page_info { COLOR: #aaa; PADDING-TOP: 0.8em } .flickr_pagination .prev_page { BORDER-TOP-WIDTH: 2px; BORDER-LEFT-WIDTH: 2px; BORDER-BOTTOM-WIDTH: = 2px; BORDER-RIGHT-WIDTH: 2px } .flickr_pagination .next_page { BORDER-TOP-WIDTH: 2px; BORDER-LEFT-WIDTH: 2px; BORDER-BOTTOM-WIDTH: = 2px; BORDER-RIGHT-WIDTH: 2px } .flickr_pagination .prev_page { MARGIN-RIGHT: 1em } .flickr_pagination .next_page { MARGIN-LEFT: 1em } ------=_NextPart_000_0000_01C9046D.463CB5E0 Content-Type: application/octet-stream Content-Transfer-Encoding: quoted-printable Content-Location: http://www.graduatejunction.com/stylesheets/table.css?1218191513 TABLE.grid { BORDER-RIGHT: #ccc 1px solid; BORDER-TOP: #ccc 1px solid; BORDER-LEFT: = #ccc 1px solid; BORDER-BOTTOM: #ccc 1px solid; BORDER-COLLAPSE: collapse } TD { BORDER-RIGHT: #ccc 1px solid; BORDER-TOP: #ccc 1px solid; BORDER-LEFT: = #ccc 1px solid; BORDER-BOTTOM: #ccc 1px solid; BORDER-COLLAPSE: collapse } TABLE.grid { BORDER-RIGHT: #ccc 1px solid; BORDER-TOP: #ccc 1px solid; BORDER-LEFT: = #ccc 1px solid; WIDTH: 100%; BORDER-BOTTOM: #ccc 1px solid } TABLE.grid THEAD TH { PADDING-RIGHT: 10px; PADDING-LEFT: 10px; BACKGROUND: = url(../images/th_bck.gif) #fff repeat-x; PADDING-BOTTOM: 5px; = BORDER-LEFT: #ccc 1px solid; COLOR: #666; PADDING-TOP: 5px } TABLE.grid TBODY TH { BORDER-TOP: #ccc 1px solid; BACKGROUND: url(../images/th_bck.gif) #fff = repeat-x; WIDTH: 30%; COLOR: #666; TEXT-ALIGN: left } TABLE.grid TBODY TR TD { PADDING-RIGHT: 10px; PADDING-LEFT: 10px; PADDING-BOTTOM: 5px; COLOR: = #666; PADDING-TOP: 5px } TABLE.grid TBODY TR:hover { BACKGROUND: url(../images/tr_bck.gif) #fff } TABLE.grid TBODY TR:hover TD { COLOR: #454545 } TABLE.grid TFOOT TD { PADDING-RIGHT: 4px; BORDER-TOP: #ccc 1px solid; PADDING-LEFT: 4px; = BACKGROUND: url(../images/foot_bck.gif) #fff; PADDING-BOTTOM: 4px; = COLOR: #666; PADDING-TOP: 4px; BORDER-LEFT-STYLE: none } TABLE.grid TFOOT TH { PADDING-RIGHT: 4px; BORDER-TOP: #ccc 1px solid; PADDING-LEFT: 4px; = BACKGROUND: url(../images/foot_bck.gif) #fff; PADDING-BOTTOM: 4px; = COLOR: #666; PADDING-TOP: 4px; BORDER-LEFT-STYLE: none } TABLE.grid CAPTION { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-SIZE: 150%; PADDING-BOTTOM: = 0px; COLOR: #666; PADDING-TOP: 0px; TEXT-ALIGN: left } TABLE.grid TABLE A:link { COLOR: #666 } TABLE.grid TABLE A:visited { COLOR: #666 } TABLE.grid TABLE A:hover { COLOR: #003366; TEXT-DECORATION: none } TABLE.grid TABLE A:active { COLOR: #003366 } ------=_NextPart_000_0000_01C9046D.463CB5E0 Content-Type: application/octet-stream Content-Transfer-Encoding: quoted-printable Content-Location: http://www.graduatejunction.com/stylesheets/2_column.css?1217418098 .main-content { DISPLAY: inline; FLOAT: left; MARGIN: 0px 0px 0px 30px; OVERFLOW: = visible! important; WIDTH: 640px } ------=_NextPart_000_0000_01C9046D.463CB5E0 Content-Type: application/octet-stream Content-Transfer-Encoding: quoted-printable Content-Location: http://www.graduatejunction.com/stylesheets/calendar_date_select/blue.css?1216218072 .calendar_date_select { BORDER-RIGHT: #777 1px solid; BORDER-TOP: #777 1px solid; DISPLAY: = block; Z-INDEX: 1000; BORDER-LEFT: #777 1px solid; WIDTH: 195px; COLOR: = white; BORDER-BOTTOM: #777 1px solid } IFRAME.ie6_blocker { Z-INDEX: 999; POSITION: absolute } .calendar_date_select THEAD TH { BORDER-TOP: #777 1px solid; FONT-WEIGHT: bold; COLOR: white! important; = BORDER-BOTTOM: #334 2px solid; BACKGROUND-COLOR: #000 } .calendar_date_select .cds_buttons { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 5px; = PADDING-TOP: 5px; BACKGROUND-COLOR: #000055; TEXT-ALIGN: center } .calendar_date_select .cds_footer { PADDING-RIGHT: 3px; PADDING-LEFT: 3px; FONT-SIZE: 12px; PADDING-BOTTOM: = 3px; PADDING-TOP: 3px; BACKGROUND-COLOR: black; TEXT-ALIGN: center } .calendar_date_select TABLE { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: = 0px; PADDING-TOP: 0px } .calendar_date_select .cds_header { BORDER-BOTTOM: #aaa 2px solid; BACKGROUND-COLOR: #ccc; TEXT-ALIGN: = center } .calendar_date_select .cds_header SPAN { FONT-WEIGHT: bold; FONT-SIZE: 15px; COLOR: black } .calendar_date_select SELECT { FONT-SIZE: 11px } .calendar_date_select .cds_header A:hover { COLOR: white } .calendar_date_select .cds_header A { FONT-SIZE: 14px; WIDTH: 22px; COLOR: black! important; HEIGHT: 20px; = TEXT-DECORATION: none } .calendar_date_select .cds_header A.prev { FLOAT: left } .calendar_date_select .cds_header A.next { FLOAT: right } .calendar_date_select .cds_header A.close { DISPLAY: none; FLOAT: right } .calendar_date_select .cds_header SELECT.month { WIDTH: 90px } .calendar_date_select .cds_header SELECT.year { WIDTH: 61px } .calendar_date_select .cds_buttons A { FONT-SIZE: 9px; COLOR: white } .calendar_date_select TD { FONT-SIZE: 12px; VERTICAL-ALIGN: middle; WIDTH: 24px; HEIGHT: 21px; = BACKGROUND-COLOR: #000066; TEXT-ALIGN: center } .calendar_date_select TD.weekend { BACKGROUND-COLOR: #00005a } .calendar_date_select TD DIV.other { COLOR: #4c5593 } .calendar_date_select TBODY TD { BORDER-BOTTOM: #000044 1px solid } .calendar_date_select TD.selected { COLOR: black; BACKGROUND-COLOR: white } .calendar_date_select TD:hover { BACKGROUND-COLOR: #ccc } .calendar_date_select TD.disabled DIV { COLOR: #000044 } .calendar_date_select TD.today { BORDER-RIGHT: blue 1px dashed; BORDER-TOP: blue 1px dashed; = BORDER-LEFT: blue 1px dashed; BORDER-BOTTOM: blue 1px dashed } .fieldWithErrors .calendar_date_select { BORDER-RIGHT: red 2px solid; BORDER-TOP: red 2px solid; BORDER-LEFT: = red 2px solid; BORDER-BOTTOM: red 2px solid } ------=_NextPart_000_0000_01C9046D.463CB5E0 Content-Type: application/octet-stream Content-Transfer-Encoding: quoted-printable Content-Location: http://www.graduatejunction.com/javascripts/prototype.js?1216850030 /* Prototype JavaScript framework, version 1.6.0=0A= * (c) 2005-2007 Sam Stephenson=0A= *=0A= * Prototype is freely distributable under the terms of an MIT-style = license.=0A= * For details, see the Prototype web site: http://www.prototypejs.org/=0A= *=0A= = *------------------------------------------------------------------------= --*/=0A= =0A= var Prototype =3D {=0A= Version: '1.6.0',=0A= =0A= Browser: {=0A= IE: !!(window.attachEvent && !window.opera),=0A= Opera: !!window.opera,=0A= WebKit: navigator.userAgent.indexOf('AppleWebKit/') > -1,=0A= Gecko: navigator.userAgent.indexOf('Gecko') > -1 && = navigator.userAgent.indexOf('KHTML') =3D=3D -1,=0A= MobileSafari: !!navigator.userAgent.match(/Apple.*Mobile.*Safari/)=0A= },=0A= =0A= BrowserFeatures: {=0A= XPath: !!document.evaluate,=0A= ElementExtensions: !!window.HTMLElement,=0A= SpecificElementExtensions:=0A= document.createElement('div').__proto__ &&=0A= document.createElement('div').__proto__ !=3D=3D=0A= document.createElement('form').__proto__=0A= },=0A= =0A= ScriptFragment: ']*>([\\S\\s]*?)<\/script>',=0A= JSONFilter: /^\/\*-secure-([\s\S]*)\*\/\s*$/,=0A= =0A= emptyFunction: function() { },=0A= K: function(x) { return x }=0A= };=0A= =0A= if (Prototype.Browser.MobileSafari)=0A= Prototype.BrowserFeatures.SpecificElementExtensions =3D false;=0A= =0A= if (Prototype.Browser.WebKit)=0A= Prototype.BrowserFeatures.XPath =3D false;=0A= =0A= /* Based on Alex Arnell's inheritance implementation. */=0A= var Class =3D {=0A= create: function() {=0A= var parent =3D null, properties =3D $A(arguments);=0A= if (Object.isFunction(properties[0]))=0A= parent =3D properties.shift();=0A= =0A= function klass() {=0A= this.initialize.apply(this, arguments);=0A= }=0A= =0A= Object.extend(klass, Class.Methods);=0A= klass.superclass =3D parent;=0A= klass.subclasses =3D [];=0A= =0A= if (parent) {=0A= var subclass =3D function() { };=0A= subclass.prototype =3D parent.prototype;=0A= klass.prototype =3D new subclass;=0A= parent.subclasses.push(klass);=0A= }=0A= =0A= for (var i =3D 0; i < properties.length; i++)=0A= klass.addMethods(properties[i]);=0A= =0A= if (!klass.prototype.initialize)=0A= klass.prototype.initialize =3D Prototype.emptyFunction;=0A= =0A= klass.prototype.constructor =3D klass;=0A= =0A= return klass;=0A= }=0A= };=0A= =0A= Class.Methods =3D {=0A= addMethods: function(source) {=0A= var ancestor =3D this.superclass && this.superclass.prototype;=0A= var properties =3D Object.keys(source);=0A= =0A= if (!Object.keys({ toString: true }).length)=0A= properties.push("toString", "valueOf");=0A= =0A= for (var i =3D 0, length =3D properties.length; i < length; i++) {=0A= var property =3D properties[i], value =3D source[property];=0A= if (ancestor && Object.isFunction(value) &&=0A= value.argumentNames().first() =3D=3D "$super") {=0A= var method =3D value, value =3D Object.extend((function(m) {=0A= return function() { return ancestor[m].apply(this, arguments) = };=0A= })(property).wrap(method), {=0A= valueOf: function() { return method },=0A= toString: function() { return method.toString() }=0A= });=0A= }=0A= this.prototype[property] =3D value;=0A= }=0A= =0A= return this;=0A= }=0A= };=0A= =0A= var Abstract =3D { };=0A= =0A= Object.extend =3D function(destination, source) {=0A= for (var property in source)=0A= destination[property] =3D source[property];=0A= return destination;=0A= };=0A= =0A= Object.extend(Object, {=0A= inspect: function(object) {=0A= try {=0A= if (object =3D=3D=3D undefined) return 'undefined';=0A= if (object =3D=3D=3D null) return 'null';=0A= return object.inspect ? object.inspect() : object.toString();=0A= } catch (e) {=0A= if (e instanceof RangeError) return '...';=0A= throw e;=0A= }=0A= },=0A= =0A= toJSON: function(object) {=0A= var type =3D typeof object;=0A= switch (type) {=0A= case 'undefined':=0A= case 'function':=0A= case 'unknown': return;=0A= case 'boolean': return object.toString();=0A= }=0A= =0A= if (object =3D=3D=3D null) return 'null';=0A= if (object.toJSON) return object.toJSON();=0A= if (Object.isElement(object)) return;=0A= =0A= var results =3D [];=0A= for (var property in object) {=0A= var value =3D Object.toJSON(object[property]);=0A= if (value !=3D=3D undefined)=0A= results.push(property.toJSON() + ': ' + value);=0A= }=0A= =0A= return '{' + results.join(', ') + '}';=0A= },=0A= =0A= toQueryString: function(object) {=0A= return $H(object).toQueryString();=0A= },=0A= =0A= toHTML: function(object) {=0A= return object && object.toHTML ? object.toHTML() : = String.interpret(object);=0A= },=0A= =0A= keys: function(object) {=0A= var keys =3D [];=0A= for (var property in object)=0A= keys.push(property);=0A= return keys;=0A= },=0A= =0A= values: function(object) {=0A= var values =3D [];=0A= for (var property in object)=0A= values.push(object[property]);=0A= return values;=0A= },=0A= =0A= clone: function(object) {=0A= return Object.extend({ }, object);=0A= },=0A= =0A= isElement: function(object) {=0A= return object && object.nodeType =3D=3D 1;=0A= },=0A= =0A= isArray: function(object) {=0A= return object && object.constructor =3D=3D=3D Array;=0A= },=0A= =0A= isHash: function(object) {=0A= return object instanceof Hash;=0A= },=0A= =0A= isFunction: function(object) {=0A= return typeof object =3D=3D "function";=0A= },=0A= =0A= isString: function(object) {=0A= return typeof object =3D=3D "string";=0A= },=0A= =0A= isNumber: function(object) {=0A= return typeof object =3D=3D "number";=0A= },=0A= =0A= isUndefined: function(object) {=0A= return typeof object =3D=3D "undefined";=0A= }=0A= });=0A= =0A= Object.extend(Function.prototype, {=0A= argumentNames: function() {=0A= var names =3D = this.toString().match(/^[\s\(]*function[^(]*\((.*?)\)/)[1].split(",").inv= oke("strip");=0A= return names.length =3D=3D 1 && !names[0] ? [] : names;=0A= },=0A= =0A= bind: function() {=0A= if (arguments.length < 2 && arguments[0] =3D=3D=3D undefined) return = this;=0A= var __method =3D this, args =3D $A(arguments), object =3D = args.shift();=0A= return function() {=0A= return __method.apply(object, args.concat($A(arguments)));=0A= }=0A= },=0A= =0A= bindAsEventListener: function() {=0A= var __method =3D this, args =3D $A(arguments), object =3D = args.shift();=0A= return function(event) {=0A= return __method.apply(object, [event || = window.event].concat(args));=0A= }=0A= },=0A= =0A= curry: function() {=0A= if (!arguments.length) return this;=0A= var __method =3D this, args =3D $A(arguments);=0A= return function() {=0A= return __method.apply(this, args.concat($A(arguments)));=0A= }=0A= },=0A= =0A= delay: function() {=0A= var __method =3D this, args =3D $A(arguments), timeout =3D = args.shift() * 1000;=0A= return window.setTimeout(function() {=0A= return __method.apply(__method, args);=0A= }, timeout);=0A= },=0A= =0A= wrap: function(wrapper) {=0A= var __method =3D this;=0A= return function() {=0A= return wrapper.apply(this, = [__method.bind(this)].concat($A(arguments)));=0A= }=0A= },=0A= =0A= methodize: function() {=0A= if (this._methodized) return this._methodized;=0A= var __method =3D this;=0A= return this._methodized =3D function() {=0A= return __method.apply(null, [this].concat($A(arguments)));=0A= };=0A= }=0A= });=0A= =0A= Function.prototype.defer =3D Function.prototype.delay.curry(0.01);=0A= =0A= Date.prototype.toJSON =3D function() {=0A= return '"' + this.getUTCFullYear() + '-' +=0A= (this.getUTCMonth() + 1).toPaddedString(2) + '-' +=0A= this.getUTCDate().toPaddedString(2) + 'T' +=0A= this.getUTCHours().toPaddedString(2) + ':' +=0A= this.getUTCMinutes().toPaddedString(2) + ':' +=0A= this.getUTCSeconds().toPaddedString(2) + 'Z"';=0A= };=0A= =0A= var Try =3D {=0A= these: function() {=0A= var returnValue;=0A= =0A= for (var i =3D 0, length =3D arguments.length; i < length; i++) {=0A= var lambda =3D arguments[i];=0A= try {=0A= returnValue =3D lambda();=0A= break;=0A= } catch (e) { }=0A= }=0A= =0A= return returnValue;=0A= }=0A= };=0A= =0A= RegExp.prototype.match =3D RegExp.prototype.test;=0A= =0A= RegExp.escape =3D function(str) {=0A= return String(str).replace(/([.*+?^=3D!:${}()|[\]\/\\])/g, '\\$1');=0A= };=0A= =0A= /*-----------------------------------------------------------------------= ---*/=0A= =0A= var PeriodicalExecuter =3D Class.create({=0A= initialize: function(callback, frequency) {=0A= this.callback =3D callback;=0A= this.frequency =3D frequency;=0A= this.currentlyExecuting =3D false;=0A= =0A= this.registerCallback();=0A= },=0A= =0A= registerCallback: function() {=0A= this.timer =3D setInterval(this.onTimerEvent.bind(this), = this.frequency * 1000);=0A= },=0A= =0A= execute: function() {=0A= this.callback(this);=0A= },=0A= =0A= stop: function() {=0A= if (!this.timer) return;=0A= clearInterval(this.timer);=0A= this.timer =3D null;=0A= },=0A= =0A= onTimerEvent: function() {=0A= if (!this.currentlyExecuting) {=0A= try {=0A= this.currentlyExecuting =3D true;=0A= this.execute();=0A= } finally {=0A= this.currentlyExecuting =3D false;=0A= }=0A= }=0A= }=0A= });=0A= Object.extend(String, {=0A= interpret: function(value) {=0A= return value =3D=3D null ? '' : String(value);=0A= },=0A= specialChar: {=0A= '\b': '\\b',=0A= '\t': '\\t',=0A= '\n': '\\n',=0A= '\f': '\\f',=0A= '\r': '\\r',=0A= '\\': '\\\\'=0A= }=0A= });=0A= =0A= Object.extend(String.prototype, {=0A= gsub: function(pattern, replacement) {=0A= var result =3D '', source =3D this, match;=0A= replacement =3D arguments.callee.prepareReplacement(replacement);=0A= =0A= while (source.length > 0) {=0A= if (match =3D source.match(pattern)) {=0A= result +=3D source.slice(0, match.index);=0A= result +=3D String.interpret(replacement(match));=0A= source =3D source.slice(match.index + match[0].length);=0A= } else {=0A= result +=3D source, source =3D '';=0A= }=0A= }=0A= return result;=0A= },=0A= =0A= sub: function(pattern, replacement, count) {=0A= replacement =3D this.gsub.prepareReplacement(replacement);=0A= count =3D count =3D=3D=3D undefined ? 1 : count;=0A= =0A= return this.gsub(pattern, function(match) {=0A= if (--count < 0) return match[0];=0A= return replacement(match);=0A= });=0A= },=0A= =0A= scan: function(pattern, iterator) {=0A= this.gsub(pattern, iterator);=0A= return String(this);=0A= },=0A= =0A= truncate: function(length, truncation) {=0A= length =3D length || 30;=0A= truncation =3D truncation =3D=3D=3D undefined ? '...' : truncation;=0A= return this.length > length ?=0A= this.slice(0, length - truncation.length) + truncation : = String(this);=0A= },=0A= =0A= strip: function() {=0A= return this.replace(/^\s+/, '').replace(/\s+$/, '');=0A= },=0A= =0A= stripTags: function() {=0A= return this.replace(/<\/?[^>]+>/gi, '');=0A= },=0A= =0A= stripScripts: function() {=0A= return this.replace(new RegExp(Prototype.ScriptFragment, 'img'), '');=0A= },=0A= =0A= extractScripts: function() {=0A= var matchAll =3D new RegExp(Prototype.ScriptFragment, 'img');=0A= var matchOne =3D new RegExp(Prototype.ScriptFragment, 'im');=0A= return (this.match(matchAll) || []).map(function(scriptTag) {=0A= return (scriptTag.match(matchOne) || ['', ''])[1];=0A= });=0A= },=0A= =0A= evalScripts: function() {=0A= return this.extractScripts().map(function(script) { return = eval(script) });=0A= },=0A= =0A= escapeHTML: function() {=0A= var self =3D arguments.callee;=0A= self.text.data =3D this;=0A= return self.div.innerHTML;=0A= },=0A= =0A= unescapeHTML: function() {=0A= var div =3D new Element('div');=0A= div.innerHTML =3D this.stripTags();=0A= return div.childNodes[0] ? (div.childNodes.length > 1 ?=0A= $A(div.childNodes).inject('', function(memo, node) { return = memo+node.nodeValue }) :=0A= div.childNodes[0].nodeValue) : '';=0A= },=0A= =0A= toQueryParams: function(separator) {=0A= var match =3D this.strip().match(/([^?#]*)(#.*)?$/);=0A= if (!match) return { };=0A= =0A= return match[1].split(separator || '&').inject({ }, function(hash, = pair) {=0A= if ((pair =3D pair.split('=3D'))[0]) {=0A= var key =3D decodeURIComponent(pair.shift());=0A= var value =3D pair.length > 1 ? pair.join('=3D') : pair[0];=0A= if (value !=3D undefined) value =3D decodeURIComponent(value);=0A= =0A= if (key in hash) {=0A= if (!Object.isArray(hash[key])) hash[key] =3D [hash[key]];=0A= hash[key].push(value);=0A= }=0A= else hash[key] =3D value;=0A= }=0A= return hash;=0A= });=0A= },=0A= =0A= toArray: function() {=0A= return this.split('');=0A= },=0A= =0A= succ: function() {=0A= return this.slice(0, this.length - 1) +=0A= String.fromCharCode(this.charCodeAt(this.length - 1) + 1);=0A= },=0A= =0A= times: function(count) {=0A= return count < 1 ? '' : new Array(count + 1).join(this);=0A= },=0A= =0A= camelize: function() {=0A= var parts =3D this.split('-'), len =3D parts.length;=0A= if (len =3D=3D 1) return parts[0];=0A= =0A= var camelized =3D this.charAt(0) =3D=3D '-'=0A= ? parts[0].charAt(0).toUpperCase() + parts[0].substring(1)=0A= : parts[0];=0A= =0A= for (var i =3D 1; i < len; i++)=0A= camelized +=3D parts[i].charAt(0).toUpperCase() + = parts[i].substring(1);=0A= =0A= return camelized;=0A= },=0A= =0A= capitalize: function() {=0A= return this.charAt(0).toUpperCase() + = this.substring(1).toLowerCase();=0A= },=0A= =0A= underscore: function() {=0A= return this.gsub(/::/, = '/').gsub(/([A-Z]+)([A-Z][a-z])/,'#{1}_#{2}').gsub(/([a-z\d])([A-Z])/,'#{= 1}_#{2}').gsub(/-/,'_').toLowerCase();=0A= },=0A= =0A= dasherize: function() {=0A= return this.gsub(/_/,'-');=0A= },=0A= =0A= inspect: function(useDoubleQuotes) {=0A= var escapedString =3D this.gsub(/[\x00-\x1f\\]/, function(match) {=0A= var character =3D String.specialChar[match[0]];=0A= return character ? character : '\\u00' + = match[0].charCodeAt().toPaddedString(2, 16);=0A= });=0A= if (useDoubleQuotes) return '"' + escapedString.replace(/"/g, '\\"') = + '"';=0A= return "'" + escapedString.replace(/'/g, '\\\'') + "'";=0A= },=0A= =0A= toJSON: function() {=0A= return this.inspect(true);=0A= },=0A= =0A= unfilterJSON: function(filter) {=0A= return this.sub(filter || Prototype.JSONFilter, '#{1}');=0A= },=0A= =0A= isJSON: function() {=0A= var str =3D this.replace(/\\./g, '@').replace(/"[^"\\\n\r]*"/g, '');=0A= return (/^[,:{}\[\]0-9.\-+Eaeflnr-u \n\r\t]*$/).test(str);=0A= },=0A= =0A= evalJSON: function(sanitize) {=0A= var json =3D this.unfilterJSON();=0A= try {=0A= if (!sanitize || json.isJSON()) return eval('(' + json + ')');=0A= } catch (e) { }=0A= throw new SyntaxError('Badly formed JSON string: ' + this.inspect());=0A= },=0A= =0A= include: function(pattern) {=0A= return this.indexOf(pattern) > -1;=0A= },=0A= =0A= startsWith: function(pattern) {=0A= return this.indexOf(pattern) =3D=3D=3D 0;=0A= },=0A= =0A= endsWith: function(pattern) {=0A= var d =3D this.length - pattern.length;=0A= return d >=3D 0 && this.lastIndexOf(pattern) =3D=3D=3D d;=0A= },=0A= =0A= empty: function() {=0A= return this =3D=3D '';=0A= },=0A= =0A= blank: function() {=0A= return /^\s*$/.test(this);=0A= },=0A= =0A= interpolate: function(object, pattern) {=0A= return new Template(this, pattern).evaluate(object);=0A= }=0A= });=0A= =0A= if (Prototype.Browser.WebKit || Prototype.Browser.IE) = Object.extend(String.prototype, {=0A= escapeHTML: function() {=0A= return = this.replace(/&/g,'&').replace(//g,'>');=0A= },=0A= unescapeHTML: function() {=0A= return = this.replace(/&/g,'&').replace(/</g,'<').replace(/>/g,'>');=0A= }=0A= });=0A= =0A= String.prototype.gsub.prepareReplacement =3D function(replacement) {=0A= if (Object.isFunction(replacement)) return replacement;=0A= var template =3D new Template(replacement);=0A= return function(match) { return template.evaluate(match) };=0A= };=0A= =0A= String.prototype.parseQuery =3D String.prototype.toQueryParams;=0A= =0A= Object.extend(String.prototype.escapeHTML, {=0A= div: document.createElement('div'),=0A= text: document.createTextNode('')=0A= });=0A= =0A= with (String.prototype.escapeHTML) div.appendChild(text);=0A= =0A= var Template =3D Class.create({=0A= initialize: function(template, pattern) {=0A= this.template =3D template.toString();=0A= this.pattern =3D pattern || Template.Pattern;=0A= },=0A= =0A= evaluate: function(object) {=0A= if (Object.isFunction(object.toTemplateReplacements))=0A= object =3D object.toTemplateReplacements();=0A= =0A= return this.template.gsub(this.pattern, function(match) {=0A= if (object =3D=3D null) return '';=0A= =0A= var before =3D match[1] || '';=0A= if (before =3D=3D '\\') return match[2];=0A= =0A= var ctx =3D object, expr =3D match[3];=0A= var pattern =3D /^([^.[]+|\[((?:.*?[^\\])?)\])(\.|\[|$)/, match = =3D pattern.exec(expr);=0A= if (match =3D=3D null) return before;=0A= =0A= while (match !=3D null) {=0A= var comp =3D match[1].startsWith('[') ? match[2].gsub('\\\\]', = ']') : match[1];=0A= ctx =3D ctx[comp];=0A= if (null =3D=3D ctx || '' =3D=3D match[3]) break;=0A= expr =3D expr.substring('[' =3D=3D match[3] ? match[1].length : = match[0].length);=0A= match =3D pattern.exec(expr);=0A= }=0A= =0A= return before + String.interpret(ctx);=0A= }.bind(this));=0A= }=0A= });=0A= Template.Pattern =3D /(^|.|\r|\n)(#\{(.*?)\})/;=0A= =0A= var $break =3D { };=0A= =0A= var Enumerable =3D {=0A= each: function(iterator, context) {=0A= var index =3D 0;=0A= iterator =3D iterator.bind(context);=0A= try {=0A= this._each(function(value) {=0A= iterator(value, index++);=0A= });=0A= } catch (e) {=0A= if (e !=3D $break) throw e;=0A= }=0A= return this;=0A= },=0A= =0A= eachSlice: function(number, iterator, context) {=0A= iterator =3D iterator ? iterator.bind(context) : Prototype.K;=0A= var index =3D -number, slices =3D [], array =3D this.toArray();=0A= while ((index +=3D number) < array.length)=0A= slices.push(array.slice(index, index+number));=0A= return slices.collect(iterator, context);=0A= },=0A= =0A= all: function(iterator, context) {=0A= iterator =3D iterator ? iterator.bind(context) : Prototype.K;=0A= var result =3D true;=0A= this.each(function(value, index) {=0A= result =3D result && !!iterator(value, index);=0A= if (!result) throw $break;=0A= });=0A= return result;=0A= },=0A= =0A= any: function(iterator, context) {=0A= iterator =3D iterator ? iterator.bind(context) : Prototype.K;=0A= var result =3D false;=0A= this.each(function(value, index) {=0A= if (result =3D !!iterator(value, index))=0A= throw $break;=0A= });=0A= return result;=0A= },=0A= =0A= collect: function(iterator, context) {=0A= iterator =3D iterator ? iterator.bind(context) : Prototype.K;=0A= var results =3D [];=0A= this.each(function(value, index) {=0A= results.push(iterator(value, index));=0A= });=0A= return results;=0A= },=0A= =0A= detect: function(iterator, context) {=0A= iterator =3D iterator.bind(context);=0A= var result;=0A= this.each(function(value, index) {=0A= if (iterator(value, index)) {=0A= result =3D value;=0A= throw $break;=0A= }=0A= });=0A= return result;=0A= },=0A= =0A= findAll: function(iterator, context) {=0A= iterator =3D iterator.bind(context);=0A= var results =3D [];=0A= this.each(function(value, index) {=0A= if (iterator(value, index))=0A= results.push(value);=0A= });=0A= return results;=0A= },=0A= =0A= grep: function(filter, iterator, context) {=0A= iterator =3D iterator ? iterator.bind(context) : Prototype.K;=0A= var results =3D [];=0A= =0A= if (Object.isString(filter))=0A= filter =3D new RegExp(filter);=0A= =0A= this.each(function(value, index) {=0A= if (filter.match(value))=0A= results.push(iterator(value, index));=0A= });=0A= return results;=0A= },=0A= =0A= include: function(object) {=0A= if (Object.isFunction(this.indexOf))=0A= if (this.indexOf(object) !=3D -1) return true;=0A= =0A= var found =3D false;=0A= this.each(function(value) {=0A= if (value =3D=3D object) {=0A= found =3D true;=0A= throw $break;=0A= }=0A= });=0A= return found;=0A= },=0A= =0A= inGroupsOf: function(number, fillWith) {=0A= fillWith =3D fillWith =3D=3D=3D undefined ? null : fillWith;=0A= return this.eachSlice(number, function(slice) {=0A= while(slice.length < number) slice.push(fillWith);=0A= return slice;=0A= });=0A= },=0A= =0A= inject: function(memo, iterator, context) {=0A= iterator =3D iterator.bind(context);=0A= this.each(function(value, index) {=0A= memo =3D iterator(memo, value, index);=0A= });=0A= return memo;=0A= },=0A= =0A= invoke: function(method) {=0A= var args =3D $A(arguments).slice(1);=0A= return this.map(function(value) {=0A= return value[method].apply(value, args);=0A= });=0A= },=0A= =0A= max: function(iterator, context) {=0A= iterator =3D iterator ? iterator.bind(context) : Prototype.K;=0A= var result;=0A= this.each(function(value, index) {=0A= value =3D iterator(value, index);=0A= if (result =3D=3D undefined || value >=3D result)=0A= result =3D value;=0A= });=0A= return result;=0A= },=0A= =0A= min: function(iterator, context) {=0A= iterator =3D iterator ? iterator.bind(context) : Prototype.K;=0A= var result;=0A= this.each(function(value, index) {=0A= value =3D iterator(value, index);=0A= if (result =3D=3D undefined || value < result)=0A= result =3D value;=0A= });=0A= return result;=0A= },=0A= =0A= partition: function(iterator, context) {=0A= iterator =3D iterator ? iterator.bind(context) : Prototype.K;=0A= var trues =3D [], falses =3D [];=0A= this.each(function(value, index) {=0A= (iterator(value, index) ?=0A= trues : falses).push(value);=0A= });=0A= return [trues, falses];=0A= },=0A= =0A= pluck: function(property) {=0A= var results =3D [];=0A= this.each(function(value) {=0A= results.push(value[property]);=0A= });=0A= return results;=0A= },=0A= =0A= reject: function(iterator, context) {=0A= iterator =3D iterator.bind(context);=0A= var results =3D [];=0A= this.each(function(value, index) {=0A= if (!iterator(value, index))=0A= results.push(value);=0A= });=0A= return results;=0A= },=0A= =0A= sortBy: function(iterator, context) {=0A= iterator =3D iterator.bind(context);=0A= return this.map(function(value, index) {=0A= return {value: value, criteria: iterator(value, index)};=0A= }).sort(function(left, right) {=0A= var a =3D left.criteria, b =3D right.criteria;=0A= return a < b ? -1 : a > b ? 1 : 0;=0A= }).pluck('value');=0A= },=0A= =0A= toArray: function() {=0A= return this.map();=0A= },=0A= =0A= zip: function() {=0A= var iterator =3D Prototype.K, args =3D $A(arguments);=0A= if (Object.isFunction(args.last()))=0A= iterator =3D args.pop();=0A= =0A= var collections =3D [this].concat(args).map($A);=0A= return this.map(function(value, index) {=0A= return iterator(collections.pluck(index));=0A= });=0A= },=0A= =0A= size: function() {=0A= return this.toArray().length;=0A= },=0A= =0A= inspect: function() {=0A= return '#';=0A= }=0A= };=0A= =0A= Object.extend(Enumerable, {=0A= map: Enumerable.collect,=0A= find: Enumerable.detect,=0A= select: Enumerable.findAll,=0A= filter: Enumerable.findAll,=0A= member: Enumerable.include,=0A= entries: Enumerable.toArray,=0A= every: Enumerable.all,=0A= some: Enumerable.any=0A= });=0A= function $A(iterable) {=0A= if (!iterable) return [];=0A= if (iterable.toArray) return iterable.toArray();=0A= var length =3D iterable.length, results =3D new Array(length);=0A= while (length--) results[length] =3D iterable[length];=0A= return results;=0A= }=0A= =0A= if (Prototype.Browser.WebKit) {=0A= function $A(iterable) {=0A= if (!iterable) return [];=0A= if (!(Object.isFunction(iterable) && iterable =3D=3D '[object = NodeList]') &&=0A= iterable.toArray) return iterable.toArray();=0A= var length =3D iterable.length, results =3D new Array(length);=0A= while (length--) results[length] =3D iterable[length];=0A= return results;=0A= }=0A= }=0A= =0A= Array.from =3D $A;=0A= =0A= Object.extend(Array.prototype, Enumerable);=0A= =0A= if (!Array.prototype._reverse) Array.prototype._reverse =3D = Array.prototype.reverse;=0A= =0A= Object.extend(Array.prototype, {=0A= _each: function(iterator) {=0A= for (var i =3D 0, length =3D this.length; i < length; i++)=0A= iterator(this[i]);=0A= },=0A= =0A= clear: function() {=0A= this.length =3D 0;=0A= return this;=0A= },=0A= =0A= first: function() {=0A= return this[0];=0A= },=0A= =0A= last: function() {=0A= return this[this.length - 1];=0A= },=0A= =0A= compact: function() {=0A= return this.select(function(value) {=0A= return value !=3D null;=0A= });=0A= },=0A= =0A= flatten: function() {=0A= return this.inject([], function(array, value) {=0A= return array.concat(Object.isArray(value) ?=0A= value.flatten() : [value]);=0A= });=0A= },=0A= =0A= without: function() {=0A= var values =3D $A(arguments);=0A= return this.select(function(value) {=0A= return !values.include(value);=0A= });=0A= },=0A= =0A= reverse: function(inline) {=0A= return (inline !=3D=3D false ? this : this.toArray())._reverse();=0A= },=0A= =0A= reduce: function() {=0A= return this.length > 1 ? this : this[0];=0A= },=0A= =0A= uniq: function(sorted) {=0A= return this.inject([], function(array, value, index) {=0A= if (0 =3D=3D index || (sorted ? array.last() !=3D value : = !array.include(value)))=0A= array.push(value);=0A= return array;=0A= });=0A= },=0A= =0A= intersect: function(array) {=0A= return this.uniq().findAll(function(item) {=0A= return array.detect(function(value) { return item =3D=3D=3D value = });=0A= });=0A= },=0A= =0A= clone: function() {=0A= return [].concat(this);=0A= },=0A= =0A= size: function() {=0A= return this.length;=0A= },=0A= =0A= inspect: function() {=0A= return '[' + this.map(Object.inspect).join(', ') + ']';=0A= },=0A= =0A= toJSON: function() {=0A= var results =3D [];=0A= this.each(function(object) {=0A= var value =3D Object.toJSON(object);=0A= if (value !=3D=3D undefined) results.push(value);=0A= });=0A= return '[' + results.join(', ') + ']';=0A= }=0A= });=0A= =0A= // use native browser JS 1.6 implementation if available=0A= if (Object.isFunction(Array.prototype.forEach))=0A= Array.prototype._each =3D Array.prototype.forEach;=0A= =0A= if (!Array.prototype.indexOf) Array.prototype.indexOf =3D function(item, = i) {=0A= i || (i =3D 0);=0A= var length =3D this.length;=0A= if (i < 0) i =3D length + i;=0A= for (; i < length; i++)=0A= if (this[i] =3D=3D=3D item) return i;=0A= return -1;=0A= };=0A= =0A= if (!Array.prototype.lastIndexOf) Array.prototype.lastIndexOf =3D = function(item, i) {=0A= i =3D isNaN(i) ? this.length : (i < 0 ? this.length + i : i) + 1;=0A= var n =3D this.slice(0, i).reverse().indexOf(item);=0A= return (n < 0) ? n : i - n - 1;=0A= };=0A= =0A= Array.prototype.toArray =3D Array.prototype.clone;=0A= =0A= function $w(string) {=0A= if (!Object.isString(string)) return [];=0A= string =3D string.strip();=0A= return string ? string.split(/\s+/) : [];=0A= }=0A= =0A= if (Prototype.Browser.Opera){=0A= Array.prototype.concat =3D function() {=0A= var array =3D [];=0A= for (var i =3D 0, length =3D this.length; i < length; i++) = array.push(this[i]);=0A= for (var i =3D 0, length =3D arguments.length; i < length; i++) {=0A= if (Object.isArray(arguments[i])) {=0A= for (var j =3D 0, arrayLength =3D arguments[i].length; j < = arrayLength; j++)=0A= array.push(arguments[i][j]);=0A= } else {=0A= array.push(arguments[i]);=0A= }=0A= }=0A= return array;=0A= };=0A= }=0A= Object.extend(Number.prototype, {=0A= toColorPart: function() {=0A= return this.toPaddedString(2, 16);=0A= },=0A= =0A= succ: function() {=0A= return this + 1;=0A= },=0A= =0A= times: function(iterator) {=0A= $R(0, this, true).each(iterator);=0A= return this;=0A= },=0A= =0A= toPaddedString: function(length, radix) {=0A= var string =3D this.toString(radix || 10);=0A= return '0'.times(length - string.length) + string;=0A= },=0A= =0A= toJSON: function() {=0A= return isFinite(this) ? this.toString() : 'null';=0A= }=0A= });=0A= =0A= $w('abs round ceil floor').each(function(method){=0A= Number.prototype[method] =3D Math[method].methodize();=0A= });=0A= function $H(object) {=0A= return new Hash(object);=0A= };=0A= =0A= var Hash =3D Class.create(Enumerable, (function() {=0A= if (function() {=0A= var i =3D 0, Test =3D function(value) { this.key =3D value };=0A= Test.prototype.key =3D 'foo';=0A= for (var property in new Test('bar')) i++;=0A= return i > 1;=0A= }()) {=0A= function each(iterator) {=0A= var cache =3D [];=0A= for (var key in this._object) {=0A= var value =3D this._object[key];=0A= if (cache.include(key)) continue;=0A= cache.push(key);=0A= var pair =3D [key, value];=0A= pair.key =3D key;=0A= pair.value =3D value;=0A= iterator(pair);=0A= }=0A= }=0A= } else {=0A= function each(iterator) {=0A= for (var key in this._object) {=0A= var value =3D this._object[key], pair =3D [key, value];=0A= pair.key =3D key;=0A= pair.value =3D value;=0A= iterator(pair);=0A= }=0A= }=0A= }=0A= =0A= function toQueryPair(key, value) {=0A= if (Object.isUndefined(value)) return key;=0A= return key + '=3D' + encodeURIComponent(String.interpret(value));=0A= }=0A= =0A= return {=0A= initialize: function(object) {=0A= this._object =3D Object.isHash(object) ? object.toObject() : = Object.clone(object);=0A= },=0A= =0A= _each: each,=0A= =0A= set: function(key, value) {=0A= return this._object[key] =3D value;=0A= },=0A= =0A= get: function(key) {=0A= return this._object[key];=0A= },=0A= =0A= unset: function(key) {=0A= var value =3D this._object[key];=0A= delete this._object[key];=0A= return value;=0A= },=0A= =0A= toObject: function() {=0A= return Object.clone(this._object);=0A= },=0A= =0A= keys: function() {=0A= return this.pluck('key');=0A= },=0A= =0A= values: function() {=0A= return this.pluck('value');=0A= },=0A= =0A= index: function(value) {=0A= var match =3D this.detect(function(pair) {=0A= return pair.value =3D=3D=3D value;=0A= });=0A= return match && match.key;=0A= },=0A= =0A= merge: function(object) {=0A= return this.clone().update(object);=0A= },=0A= =0A= update: function(object) {=0A= return new Hash(object).inject(this, function(result, pair) {=0A= result.set(pair.key, pair.value);=0A= return result;=0A= });=0A= },=0A= =0A= toQueryString: function() {=0A= return this.map(function(pair) {=0A= var key =3D encodeURIComponent(pair.key), values =3D pair.value;=0A= =0A= if (values && typeof values =3D=3D 'object') {=0A= if (Object.isArray(values))=0A= return values.map(toQueryPair.curry(key)).join('&');=0A= }=0A= return toQueryPair(key, values);=0A= }).join('&');=0A= },=0A= =0A= inspect: function() {=0A= return '#';=0A= },=0A= =0A= toJSON: function() {=0A= return Object.toJSON(this.toObject());=0A= },=0A= =0A= clone: function() {=0A= return new Hash(this);=0A= }=0A= }=0A= })());=0A= =0A= Hash.prototype.toTemplateReplacements =3D Hash.prototype.toObject;=0A= Hash.from =3D $H;=0A= var ObjectRange =3D Class.create(Enumerable, {=0A= initialize: function(start, end, exclusive) {=0A= this.start =3D start;=0A= this.end =3D end;=0A= this.exclusive =3D exclusive;=0A= },=0A= =0A= _each: function(iterator) {=0A= var value =3D this.start;=0A= while (this.include(value)) {=0A= iterator(value);=0A= value =3D value.succ();=0A= }=0A= },=0A= =0A= include: function(value) {=0A= if (value < this.start)=0A= return false;=0A= if (this.exclusive)=0A= return value < this.end;=0A= return value <=3D this.end;=0A= }=0A= });=0A= =0A= var $R =3D function(start, end, exclusive) {=0A= return new ObjectRange(start, end, exclusive);=0A= };=0A= =0A= var Ajax =3D {=0A= getTransport: function() {=0A= return Try.these(=0A= function() {return new XMLHttpRequest()},=0A= function() {return new ActiveXObject('Msxml2.XMLHTTP')},=0A= function() {return new ActiveXObject('Microsoft.XMLHTTP')}=0A= ) || false;=0A= },=0A= =0A= activeRequestCount: 0=0A= };=0A= =0A= Ajax.Responders =3D {=0A= responders: [],=0A= =0A= _each: function(iterator) {=0A= this.responders._each(iterator);=0A= },=0A= =0A= register: function(responder) {=0A= if (!this.include(responder))=0A= this.responders.push(responder);=0A= },=0A= =0A= unregister: function(responder) {=0A= this.responders =3D this.responders.without(responder);=0A= },=0A= =0A= dispatch: function(callback, request, transport, json) {=0A= this.each(function(responder) {=0A= if (Object.isFunction(responder[callback])) {=0A= try {=0A= responder[callback].apply(responder, [request, transport, = json]);=0A= } catch (e) { }=0A= }=0A= });=0A= }=0A= };=0A= =0A= Object.extend(Ajax.Responders, Enumerable);=0A= =0A= Ajax.Responders.register({=0A= onCreate: function() { Ajax.activeRequestCount++ },=0A= onComplete: function() { Ajax.activeRequestCount-- }=0A= });=0A= =0A= Ajax.Base =3D Class.create({=0A= initialize: function(options) {=0A= this.options =3D {=0A= method: 'post',=0A= asynchronous: true,=0A= contentType: 'application/x-www-form-urlencoded',=0A= encoding: 'UTF-8',=0A= parameters: '',=0A= evalJSON: true,=0A= evalJS: true=0A= };=0A= Object.extend(this.options, options || { });=0A= =0A= this.options.method =3D this.options.method.toLowerCase();=0A= if (Object.isString(this.options.parameters))=0A= this.options.parameters =3D = this.options.parameters.toQueryParams();=0A= }=0A= });=0A= =0A= Ajax.Request =3D Class.create(Ajax.Base, {=0A= _complete: false,=0A= =0A= initialize: function($super, url, options) {=0A= $super(options);=0A= this.transport =3D Ajax.getTransport();=0A= this.request(url);=0A= },=0A= =0A= request: function(url) {=0A= this.url =3D url;=0A= this.method =3D this.options.method;=0A= var params =3D Object.clone(this.options.parameters);=0A= =0A= if (!['get', 'post'].include(this.method)) {=0A= // simulate other verbs over post=0A= params['_method'] =3D this.method;=0A= this.method =3D 'post';=0A= }=0A= =0A= this.parameters =3D params;=0A= =0A= if (params =3D Object.toQueryString(params)) {=0A= // when GET, append parameters to URL=0A= if (this.method =3D=3D 'get')=0A= this.url +=3D (this.url.include('?') ? '&' : '?') + params;=0A= else if (/Konqueror|Safari|KHTML/.test(navigator.userAgent))=0A= params +=3D '&_=3D';=0A= }=0A= =0A= try {=0A= var response =3D new Ajax.Response(this);=0A= if (this.options.onCreate) this.options.onCreate(response);=0A= Ajax.Responders.dispatch('onCreate', this, response);=0A= =0A= this.transport.open(this.method.toUpperCase(), this.url,=0A= this.options.asynchronous);=0A= =0A= if (this.options.asynchronous) = this.respondToReadyState.bind(this).defer(1);=0A= =0A= this.transport.onreadystatechange =3D = this.onStateChange.bind(this);=0A= this.setRequestHeaders();=0A= =0A= this.body =3D this.method =3D=3D 'post' ? (this.options.postBody = || params) : null;=0A= this.transport.send(this.body);=0A= =0A= /* Force Firefox to handle ready state 4 for synchronous requests = */=0A= if (!this.options.asynchronous && this.transport.overrideMimeType)=0A= this.onStateChange();=0A= =0A= }=0A= catch (e) {=0A= this.dispatchException(e);=0A= }=0A= },=0A= =0A= onStateChange: function() {=0A= var readyState =3D this.transport.readyState;=0A= if (readyState > 1 && !((readyState =3D=3D 4) && this._complete))=0A= this.respondToReadyState(this.transport.readyState);=0A= },=0A= =0A= setRequestHeaders: function() {=0A= var headers =3D {=0A= 'X-Requested-With': 'XMLHttpRequest',=0A= 'X-Prototype-Version': Prototype.Version,=0A= 'Accept': 'text/javascript, text/html, application/xml, text/xml, = */*'=0A= };=0A= =0A= if (this.method =3D=3D 'post') {=0A= headers['Content-type'] =3D this.options.contentType +=0A= (this.options.encoding ? '; charset=3D' + this.options.encoding = : '');=0A= =0A= /* Force "Connection: close" for older Mozilla browsers to work=0A= * around a bug where XMLHttpRequest sends an incorrect=0A= * Content-length header. See Mozilla Bugzilla #246651.=0A= */=0A= if (this.transport.overrideMimeType &&=0A= (navigator.userAgent.match(/Gecko\/(\d{4})/) || [0,2005])[1] < = 2005)=0A= headers['Connection'] =3D 'close';=0A= }=0A= =0A= // user-defined headers=0A= if (typeof this.options.requestHeaders =3D=3D 'object') {=0A= var extras =3D this.options.requestHeaders;=0A= =0A= if (Object.isFunction(extras.push))=0A= for (var i =3D 0, length =3D extras.length; i < length; i +=3D 2)=0A= headers[extras[i]] =3D extras[i+1];=0A= else=0A= $H(extras).each(function(pair) { headers[pair.key] =3D = pair.value });=0A= }=0A= =0A= for (var name in headers)=0A= this.transport.setRequestHeader(name, headers[name]);=0A= },=0A= =0A= success: function() {=0A= var status =3D this.getStatus();=0A= return !status || (status >=3D 200 && status < 300);=0A= },=0A= =0A= getStatus: function() {=0A= try {=0A= return this.transport.status || 0;=0A= } catch (e) { return 0 }=0A= },=0A= =0A= respondToReadyState: function(readyState) {=0A= var state =3D Ajax.Request.Events[readyState], response =3D new = Ajax.Response(this);=0A= =0A= if (state =3D=3D 'Complete') {=0A= try {=0A= this._complete =3D true;=0A= (this.options['on' + response.status]=0A= || this.options['on' + (this.success() ? 'Success' : 'Failure')]=0A= || Prototype.emptyFunction)(response, response.headerJSON);=0A= } catch (e) {=0A= this.dispatchException(e);=0A= }=0A= =0A= var contentType =3D response.getHeader('Content-type');=0A= if (this.options.evalJS =3D=3D 'force'=0A= || (this.options.evalJS && contentType=0A= && = contentType.match(/^\s*(text|application)\/(x-)?(java|ecma)script(;.*)?\s= *$/i)))=0A= this.evalResponse();=0A= }=0A= =0A= try {=0A= (this.options['on' + state] || Prototype.emptyFunction)(response, = response.headerJSON);=0A= Ajax.Responders.dispatch('on' + state, this, response, = response.headerJSON);=0A= } catch (e) {=0A= this.dispatchException(e);=0A= }=0A= =0A= if (state =3D=3D 'Complete') {=0A= // avoid memory leak in MSIE: clean up=0A= this.transport.onreadystatechange =3D Prototype.emptyFunction;=0A= }=0A= },=0A= =0A= getHeader: function(name) {=0A= try {=0A= return this.transport.getResponseHeader(name);=0A= } catch (e) { return null }=0A= },=0A= =0A= evalResponse: function() {=0A= try {=0A= return eval((this.transport.responseText || '').unfilterJSON());=0A= } catch (e) {=0A= this.dispatchException(e);=0A= }=0A= },=0A= =0A= dispatchException: function(exception) {=0A= (this.options.onException || Prototype.emptyFunction)(this, = exception);=0A= Ajax.Responders.dispatch('onException', this, exception);=0A= }=0A= });=0A= =0A= Ajax.Request.Events =3D=0A= ['Uninitialized', 'Loading', 'Loaded', 'Interactive', 'Complete'];=0A= =0A= Ajax.Response =3D Class.create({=0A= initialize: function(request){=0A= this.request =3D request;=0A= var transport =3D this.transport =3D request.transport,=0A= readyState =3D this.readyState =3D transport.readyState;=0A= =0A= if((readyState > 2 && !Prototype.Browser.IE) || readyState =3D=3D 4) = {=0A= this.status =3D this.getStatus();=0A= this.statusText =3D this.getStatusText();=0A= this.responseText =3D String.interpret(transport.responseText);=0A= this.headerJSON =3D this._getHeaderJSON();=0A= }=0A= =0A= if(readyState =3D=3D 4) {=0A= var xml =3D transport.responseXML;=0A= this.responseXML =3D xml =3D=3D=3D undefined ? null : xml;=0A= this.responseJSON =3D this._getResponseJSON();=0A= }=0A= },=0A= =0A= status: 0,=0A= statusText: '',=0A= =0A= getStatus: Ajax.Request.prototype.getStatus,=0A= =0A= getStatusText: function() {=0A= try {=0A= return this.transport.statusText || '';=0A= } catch (e) { return '' }=0A= },=0A= =0A= getHeader: Ajax.Request.prototype.getHeader,=0A= =0A= getAllHeaders: function() {=0A= try {=0A= return this.getAllResponseHeaders();=0A= } catch (e) { return null }=0A= },=0A= =0A= getResponseHeader: function(name) {=0A= return this.transport.getResponseHeader(name);=0A= },=0A= =0A= getAllResponseHeaders: function() {=0A= return this.transport.getAllResponseHeaders();=0A= },=0A= =0A= _getHeaderJSON: function() {=0A= var json =3D this.getHeader('X-JSON');=0A= if (!json) return null;=0A= json =3D decodeURIComponent(escape(json));=0A= try {=0A= return json.evalJSON(this.request.options.sanitizeJSON);=0A= } catch (e) {=0A= this.request.dispatchException(e);=0A= }=0A= },=0A= =0A= _getResponseJSON: function() {=0A= var options =3D this.request.options;=0A= if (!options.evalJSON || (options.evalJSON !=3D 'force' &&=0A= !(this.getHeader('Content-type') || = '').include('application/json')))=0A= return null;=0A= try {=0A= return this.transport.responseText.evalJSON(options.sanitizeJSON);=0A= } catch (e) {=0A= this.request.dispatchException(e);=0A= }=0A= }=0A= });=0A= =0A= Ajax.Updater =3D Class.create(Ajax.Request, {=0A= initialize: function($super, container, url, options) {=0A= this.container =3D {=0A= success: (container.success || container),=0A= failure: (container.failure || (container.success ? null : = container))=0A= };=0A= =0A= options =3D options || { };=0A= var onComplete =3D options.onComplete;=0A= options.onComplete =3D (function(response, param) {=0A= this.updateContent(response.responseText);=0A= if (Object.isFunction(onComplete)) onComplete(response, param);=0A= }).bind(this);=0A= =0A= $super(url, options);=0A= },=0A= =0A= updateContent: function(responseText) {=0A= var receiver =3D this.container[this.success() ? 'success' : = 'failure'],=0A= options =3D this.options;=0A= =0A= if (!options.evalScripts) responseText =3D = responseText.stripScripts();=0A= =0A= if (receiver =3D $(receiver)) {=0A= if (options.insertion) {=0A= if (Object.isString(options.insertion)) {=0A= var insertion =3D { }; insertion[options.insertion] =3D = responseText;=0A= receiver.insert(insertion);=0A= }=0A= else options.insertion(receiver, responseText);=0A= }=0A= else receiver.update(responseText);=0A= }=0A= =0A= if (this.success()) {=0A= if (this.onComplete) this.onComplete.bind(this).defer();=0A= }=0A= }=0A= });=0A= =0A= Ajax.PeriodicalUpdater =3D Class.create(Ajax.Base, {=0A= initialize: function($super, container, url, options) {=0A= $super(options);=0A= this.onComplete =3D this.options.onComplete;=0A= =0A= this.frequency =3D (this.options.frequency || 2);=0A= this.decay =3D (this.options.decay || 1);=0A= =0A= this.updater =3D { };=0A= this.container =3D container;=0A= this.url =3D url;=0A= =0A= this.start();=0A= },=0A= =0A= start: function() {=0A= this.options.onComplete =3D this.updateComplete.bind(this);=0A= this.onTimerEvent();=0A= },=0A= =0A= stop: function() {=0A= this.updater.options.onComplete =3D undefined;=0A= clearTimeout(this.timer);=0A= (this.onComplete || Prototype.emptyFunction).apply(this, arguments);=0A= },=0A= =0A= updateComplete: function(response) {=0A= if (this.options.decay) {=0A= this.decay =3D (response.responseText =3D=3D this.lastText ?=0A= this.decay * this.options.decay : 1);=0A= =0A= this.lastText =3D response.responseText;=0A= }=0A= this.timer =3D this.onTimerEvent.bind(this).delay(this.decay * = this.frequency);=0A= },=0A= =0A= onTimerEvent: function() {=0A= this.updater =3D new Ajax.Updater(this.container, this.url, = this.options);=0A= }=0A= });=0A= function $(element) {=0A= if (arguments.length > 1) {=0A= for (var i =3D 0, elements =3D [], length =3D arguments.length; i < = length; i++)=0A= elements.push($(arguments[i]));=0A= return elements;=0A= }=0A= if (Object.isString(element))=0A= element =3D document.getElementById(element);=0A= return Element.extend(element);=0A= }=0A= =0A= if (Prototype.BrowserFeatures.XPath) {=0A= document._getElementsByXPath =3D function(expression, parentElement) {=0A= var results =3D [];=0A= var query =3D document.evaluate(expression, $(parentElement) || = document,=0A= null, XPathResult.ORDERED_NODE_SNAPSHOT_TYPE, null);=0A= for (var i =3D 0, length =3D query.snapshotLength; i < length; i++)=0A= results.push(Element.extend(query.snapshotItem(i)));=0A= return results;=0A= };=0A= }=0A= =0A= /*-----------------------------------------------------------------------= ---*/=0A= =0A= if (!window.Node) var Node =3D { };=0A= =0A= if (!Node.ELEMENT_NODE) {=0A= // DOM level 2 ECMAScript Language Binding=0A= Object.extend(Node, {=0A= ELEMENT_NODE: 1,=0A= ATTRIBUTE_NODE: 2,=0A= TEXT_NODE: 3,=0A= CDATA_SECTION_NODE: 4,=0A= ENTITY_REFERENCE_NODE: 5,=0A= ENTITY_NODE: 6,=0A= PROCESSING_INSTRUCTION_NODE: 7,=0A= COMMENT_NODE: 8,=0A= DOCUMENT_NODE: 9,=0A= DOCUMENT_TYPE_NODE: 10,=0A= DOCUMENT_FRAGMENT_NODE: 11,=0A= NOTATION_NODE: 12=0A= });=0A= }=0A= =0A= (function() {=0A= var element =3D this.Element;=0A= this.Element =3D function(tagName, attributes) {=0A= attributes =3D attributes || { };=0A= tagName =3D tagName.toLowerCase();=0A= var cache =3D Element.cache;=0A= if (Prototype.Browser.IE && attributes.name) {=0A= tagName =3D '<' + tagName + ' name=3D"' + attributes.name + '">';=0A= delete attributes.name;=0A= return Element.writeAttribute(document.createElement(tagName), = attributes);=0A= }=0A= if (!cache[tagName]) cache[tagName] =3D = Element.extend(document.createElement(tagName));=0A= return Element.writeAttribute(cache[tagName].cloneNode(false), = attributes);=0A= };=0A= Object.extend(this.Element, element || { });=0A= }).call(window);=0A= =0A= Element.cache =3D { };=0A= =0A= Element.Methods =3D {=0A= visible: function(element) {=0A= return $(element).style.display !=3D 'none';=0A= },=0A= =0A= toggle: function(element) {=0A= element =3D $(element);=0A= Element[Element.visible(element) ? 'hide' : 'show'](element);=0A= return element;=0A= },=0A= =0A= hide: function(element) {=0A= $(element).style.display =3D 'none';=0A= return element;=0A= },=0A= =0A= show: function(element) {=0A= $(element).style.display =3D '';=0A= return element;=0A= },=0A= =0A= remove: function(element) {=0A= element =3D $(element);=0A= element.parentNode.removeChild(element);=0A= return element;=0A= },=0A= =0A= update: function(element, content) {=0A= element =3D $(element);=0A= if (content && content.toElement) content =3D content.toElement();=0A= if (Object.isElement(content)) return = element.update().insert(content);=0A= content =3D Object.toHTML(content);=0A= element.innerHTML =3D content.stripScripts();=0A= content.evalScripts.bind(content).defer();=0A= return element;=0A= },=0A= =0A= replace: function(element, content) {=0A= element =3D $(element);=0A= if (content && content.toElement) content =3D content.toElement();=0A= else if (!Object.isElement(content)) {=0A= content =3D Object.toHTML(content);=0A= var range =3D element.ownerDocument.createRange();=0A= range.selectNode(element);=0A= content.evalScripts.bind(content).defer();=0A= content =3D range.createContextualFragment(content.stripScripts());=0A= }=0A= element.parentNode.replaceChild(content, element);=0A= return element;=0A= },=0A= =0A= insert: function(element, insertions) {=0A= element =3D $(element);=0A= =0A= if (Object.isString(insertions) || Object.isNumber(insertions) ||=0A= Object.isElement(insertions) || (insertions && = (insertions.toElement || insertions.toHTML)))=0A= insertions =3D {bottom:insertions};=0A= =0A= var content, t, range;=0A= =0A= for (position in insertions) {=0A= content =3D insertions[position];=0A= position =3D position.toLowerCase();=0A= t =3D Element._insertionTranslations[position];=0A= =0A= if (content && content.toElement) content =3D content.toElement();=0A= if (Object.isElement(content)) {=0A= t.insert(element, content);=0A= continue;=0A= }=0A= =0A= content =3D Object.toHTML(content);=0A= =0A= range =3D element.ownerDocument.createRange();=0A= t.initializeRange(element, range);=0A= t.insert(element, = range.createContextualFragment(content.stripScripts()));=0A= =0A= content.evalScripts.bind(content).defer();=0A= }=0A= =0A= return element;=0A= },=0A= =0A= wrap: function(element, wrapper, attributes) {=0A= element =3D $(element);=0A= if (Object.isElement(wrapper))=0A= $(wrapper).writeAttribute(attributes || { });=0A= else if (Object.isString(wrapper)) wrapper =3D new Element(wrapper, = attributes);=0A= else wrapper =3D new Element('div', wrapper);=0A= if (element.parentNode)=0A= element.parentNode.replaceChild(wrapper, element);=0A= wrapper.appendChild(element);=0A= return wrapper;=0A= },=0A= =0A= inspect: function(element) {=0A= element =3D $(element);=0A= var result =3D '<' + element.tagName.toLowerCase();=0A= $H({'id': 'id', 'className': 'class'}).each(function(pair) {=0A= var property =3D pair.first(), attribute =3D pair.last();=0A= var value =3D (element[property] || '').toString();=0A= if (value) result +=3D ' ' + attribute + '=3D' + = value.inspect(true);=0A= });=0A= return result + '>';=0A= },=0A= =0A= recursivelyCollect: function(element, property) {=0A= element =3D $(element);=0A= var elements =3D [];=0A= while (element =3D element[property])=0A= if (element.nodeType =3D=3D 1)=0A= elements.push(Element.extend(element));=0A= return elements;=0A= },=0A= =0A= ancestors: function(element) {=0A= return $(element).recursivelyCollect('parentNode');=0A= },=0A= =0A= descendants: function(element) {=0A= return $A($(element).getElementsByTagName('*')).each(Element.extend);=0A= },=0A= =0A= firstDescendant: function(element) {=0A= element =3D $(element).firstChild;=0A= while (element && element.nodeType !=3D 1) element =3D = element.nextSibling;=0A= return $(element);=0A= },=0A= =0A= immediateDescendants: function(element) {=0A= if (!(element =3D $(element).firstChild)) return [];=0A= while (element && element.nodeType !=3D 1) element =3D = element.nextSibling;=0A= if (element) return [element].concat($(element).nextSiblings());=0A= return [];=0A= },=0A= =0A= previousSiblings: function(element) {=0A= return $(element).recursivelyCollect('previousSibling');=0A= },=0A= =0A= nextSiblings: function(element) {=0A= return $(element).recursivelyCollect('nextSibling');=0A= },=0A= =0A= siblings: function(element) {=0A= element =3D $(element);=0A= return = element.previousSiblings().reverse().concat(element.nextSiblings());=0A= },=0A= =0A= match: function(element, selector) {=0A= if (Object.isString(selector))=0A= selector =3D new Selector(selector);=0A= return selector.match($(element));=0A= },=0A= =0A= up: function(element, expression, index) {=0A= element =3D $(element);=0A= if (arguments.length =3D=3D 1) return $(element.parentNode);=0A= var ancestors =3D element.ancestors();=0A= return expression ? Selector.findElement(ancestors, expression, = index) :=0A= ancestors[index || 0];=0A= },=0A= =0A= down: function(element, expression, index) {=0A= element =3D $(element);=0A= if (arguments.length =3D=3D 1) return element.firstDescendant();=0A= var descendants =3D element.descendants();=0A= return expression ? Selector.findElement(descendants, expression, = index) :=0A= descendants[index || 0];=0A= },=0A= =0A= previous: function(element, expression, index) {=0A= element =3D $(element);=0A= if (arguments.length =3D=3D 1) return = $(Selector.handlers.previousElementSibling(element));=0A= var previousSiblings =3D element.previousSiblings();=0A= return expression ? Selector.findElement(previousSiblings, = expression, index) :=0A= previousSiblings[index || 0];=0A= },=0A= =0A= next: function(element, expression, index) {=0A= element =3D $(element);=0A= if (arguments.length =3D=3D 1) return = $(Selector.handlers.nextElementSibling(element));=0A= var nextSiblings =3D element.nextSiblings();=0A= return expression ? Selector.findElement(nextSiblings, expression, = index) :=0A= nextSiblings[index || 0];=0A= },=0A= =0A= select: function() {=0A= var args =3D $A(arguments), element =3D $(args.shift());=0A= return Selector.findChildElements(element, args);=0A= },=0A= =0A= adjacent: function() {=0A= var args =3D $A(arguments), element =3D $(args.shift());=0A= return Selector.findChildElements(element.parentNode, = args).without(element);=0A= },=0A= =0A= identify: function(element) {=0A= element =3D $(element);=0A= var id =3D element.readAttribute('id'), self =3D arguments.callee;=0A= if (id) return id;=0A= do { id =3D 'anonymous_element_' + self.counter++ } while ($(id));=0A= element.writeAttribute('id', id);=0A= return id;=0A= },=0A= =0A= readAttribute: function(element, name) {=0A= element =3D $(element);=0A= if (Prototype.Browser.IE) {=0A= var t =3D Element._attributeTranslations.read;=0A= if (t.values[name]) return t.values[name](element, name);=0A= if (t.names[name]) name =3D t.names[name];=0A= if (name.include(':')) {=0A= return (!element.attributes || !element.attributes[name]) ? null = :=0A= element.attributes[name].value;=0A= }=0A= }=0A= return element.getAttribute(name);=0A= },=0A= =0A= writeAttribute: function(element, name, value) {=0A= element =3D $(element);=0A= var attributes =3D { }, t =3D Element._attributeTranslations.write;=0A= =0A= if (typeof name =3D=3D 'object') attributes =3D name;=0A= else attributes[name] =3D value =3D=3D=3D undefined ? true : value;=0A= =0A= for (var attr in attributes) {=0A= var name =3D t.names[attr] || attr, value =3D attributes[attr];=0A= if (t.values[attr]) name =3D t.values[attr](element, value);=0A= if (value =3D=3D=3D false || value =3D=3D=3D null)=0A= element.removeAttribute(name);=0A= else if (value =3D=3D=3D true)=0A= element.setAttribute(name, name);=0A= else element.setAttribute(name, value);=0A= }=0A= return element;=0A= },=0A= =0A= getHeight: function(element) {=0A= return $(element).getDimensions().height;=0A= },=0A= =0A= getWidth: function(element) {=0A= return $(element).getDimensions().width;=0A= },=0A= =0A= classNames: function(element) {=0A= return new Element.ClassNames(element);=0A= },=0A= =0A= hasClassName: function(element, className) {=0A= if (!(element =3D $(element))) return;=0A= var elementClassName =3D element.className;=0A= return (elementClassName.length > 0 && (elementClassName =3D=3D = className ||=0A= new RegExp("(^|\\s)" + className + = "(\\s|$)").test(elementClassName)));=0A= },=0A= =0A= addClassName: function(element, className) {=0A= if (!(element =3D $(element))) return;=0A= if (!element.hasClassName(className))=0A= element.className +=3D (element.className ? ' ' : '') + className;=0A= return element;=0A= },=0A= =0A= removeClassName: function(element, className) {=0A= if (!(element =3D $(element))) return;=0A= element.className =3D element.className.replace(=0A= new RegExp("(^|\\s+)" + className + "(\\s+|$)"), ' ').strip();=0A= return element;=0A= },=0A= =0A= toggleClassName: function(element, className) {=0A= if (!(element =3D $(element))) return;=0A= return element[element.hasClassName(className) ?=0A= 'removeClassName' : 'addClassName'](className);=0A= },=0A= =0A= // removes whitespace-only text node children=0A= cleanWhitespace: function(element) {=0A= element =3D $(element);=0A= var node =3D element.firstChild;=0A= while (node) {=0A= var nextNode =3D node.nextSibling;=0A= if (node.nodeType =3D=3D 3 && !/\S/.test(node.nodeValue))=0A= element.removeChild(node);=0A= node =3D nextNode;=0A= }=0A= return element;=0A= },=0A= =0A= empty: function(element) {=0A= return $(element).innerHTML.blank();=0A= },=0A= =0A= descendantOf: function(element, ancestor) {=0A= element =3D $(element), ancestor =3D $(ancestor);=0A= =0A= if (element.compareDocumentPosition)=0A= return (element.compareDocumentPosition(ancestor) & 8) =3D=3D=3D 8;=0A= =0A= if (element.sourceIndex && !Prototype.Browser.Opera) {=0A= var e =3D element.sourceIndex, a =3D ancestor.sourceIndex,=0A= nextAncestor =3D ancestor.nextSibling;=0A= if (!nextAncestor) {=0A= do { ancestor =3D ancestor.parentNode; }=0A= while (!(nextAncestor =3D ancestor.nextSibling) && = ancestor.parentNode);=0A= }=0A= if (nextAncestor) return (e > a && e < nextAncestor.sourceIndex);=0A= }=0A= =0A= while (element =3D element.parentNode)=0A= if (element =3D=3D ancestor) return true;=0A= return false;=0A= },=0A= =0A= scrollTo: function(element) {=0A= element =3D $(element);=0A= var pos =3D element.cumulativeOffset();=0A= window.scrollTo(pos[0], pos[1]);=0A= return element;=0A= },=0A= =0A= getStyle: function(element, style) {=0A= element =3D $(element);=0A= style =3D style =3D=3D 'float' ? 'cssFloat' : style.camelize();=0A= var value =3D element.style[style];=0A= if (!value) {=0A= var css =3D document.defaultView.getComputedStyle(element, null);=0A= value =3D css ? css[style] : null;=0A= }=0A= if (style =3D=3D 'opacity') return value ? parseFloat(value) : 1.0;=0A= return value =3D=3D 'auto' ? null : value;=0A= },=0A= =0A= getOpacity: function(element) {=0A= return $(element).getStyle('opacity');=0A= },=0A= =0A= setStyle: function(element, styles) {=0A= element =3D $(element);=0A= var elementStyle =3D element.style, match;=0A= if (Object.isString(styles)) {=0A= element.style.cssText +=3D ';' + styles;=0A= return styles.include('opacity') ?=0A= element.setOpacity(styles.match(/opacity:\s*(\d?\.?\d*)/)[1]) : = element;=0A= }=0A= for (var property in styles)=0A= if (property =3D=3D 'opacity') = element.setOpacity(styles[property]);=0A= else=0A= elementStyle[(property =3D=3D 'float' || property =3D=3D = 'cssFloat') ?=0A= (elementStyle.styleFloat =3D=3D=3D undefined ? 'cssFloat' : = 'styleFloat') :=0A= property] =3D styles[property];=0A= =0A= return element;=0A= },=0A= =0A= setOpacity: function(element, value) {=0A= element =3D $(element);=0A= element.style.opacity =3D (value =3D=3D 1 || value =3D=3D=3D '') ? = '' :=0A= (value < 0.00001) ? 0 : value;=0A= return element;=0A= },=0A= =0A= getDimensions: function(element) {=0A= element =3D $(element);=0A= var display =3D $(element).getStyle('display');=0A= if (display !=3D 'none' && display !=3D null) // Safari bug=0A= return {width: element.offsetWidth, height: element.offsetHeight};=0A= =0A= // All *Width and *Height properties give 0 on elements with display = none,=0A= // so enable the element temporarily=0A= var els =3D element.style;=0A= var originalVisibility =3D els.visibility;=0A= var originalPosition =3D els.position;=0A= var originalDisplay =3D els.display;=0A= els.visibility =3D 'hidden';=0A= els.position =3D 'absolute';=0A= els.display =3D 'block';=0A= var originalWidth =3D element.clientWidth;=0A= var originalHeight =3D element.clientHeight;=0A= els.display =3D originalDisplay;=0A= els.position =3D originalPosition;=0A= els.visibility =3D originalVisibility;=0A= return {width: originalWidth, height: originalHeight};=0A= },=0A= =0A= makePositioned: function(element) {=0A= element =3D $(element);=0A= var pos =3D Element.getStyle(element, 'position');=0A= if (pos =3D=3D 'static' || !pos) {=0A= element._madePositioned =3D true;=0A= element.style.position =3D 'relative';=0A= // Opera returns the offset relative to the positioning context, = when an=0A= // element is position relative but top and left have not been = defined=0A= if (window.opera) {=0A= element.style.top =3D 0;=0A= element.style.left =3D 0;=0A= }=0A= }=0A= return element;=0A= },=0A= =0A= undoPositioned: function(element) {=0A= element =3D $(element);=0A= if (element._madePositioned) {=0A= element._madePositioned =3D undefined;=0A= element.style.position =3D=0A= element.style.top =3D=0A= element.style.left =3D=0A= element.style.bottom =3D=0A= element.style.right =3D '';=0A= }=0A= return element;=0A= },=0A= =0A= makeClipping: function(element) {=0A= element =3D $(element);=0A= if (element._overflow) return element;=0A= element._overflow =3D Element.getStyle(element, 'overflow') || = 'auto';=0A= if (element._overflow !=3D=3D 'hidden')=0A= element.style.overflow =3D 'hidden';=0A= return element;=0A= },=0A= =0A= undoClipping: function(element) {=0A= element =3D $(element);=0A= if (!element._overflow) return element;=0A= element.style.overflow =3D element._overflow =3D=3D 'auto' ? '' : = element._overflow;=0A= element._overflow =3D null;=0A= return element;=0A= },=0A= =0A= cumulativeOffset: function(element) {=0A= var valueT =3D 0, valueL =3D 0;=0A= do {=0A= valueT +=3D element.offsetTop || 0;=0A= valueL +=3D element.offsetLeft || 0;=0A= element =3D element.offsetParent;=0A= } while (element);=0A= return Element._returnOffset(valueL, valueT);=0A= },=0A= =0A= positionedOffset: function(element) {=0A= var valueT =3D 0, valueL =3D 0;=0A= do {=0A= valueT +=3D element.offsetTop || 0;=0A= valueL +=3D element.offsetLeft || 0;=0A= element =3D element.offsetParent;=0A= if (element) {=0A= if (element.tagName =3D=3D 'BODY') break;=0A= var p =3D Element.getStyle(element, 'position');=0A= if (p =3D=3D 'relative' || p =3D=3D 'absolute') break;=0A= }=0A= } while (element);=0A= return Element._returnOffset(valueL, valueT);=0A= },=0A= =0A= absolutize: function(element) {=0A= element =3D $(element);=0A= if (element.getStyle('position') =3D=3D 'absolute') return;=0A= // Position.prepare(); // To be done manually by Scripty when it = needs it.=0A= =0A= var offsets =3D element.positionedOffset();=0A= var top =3D offsets[1];=0A= var left =3D offsets[0];=0A= var width =3D element.clientWidth;=0A= var height =3D element.clientHeight;=0A= =0A= element._originalLeft =3D left - parseFloat(element.style.left || = 0);=0A= element._originalTop =3D top - parseFloat(element.style.top || = 0);=0A= element._originalWidth =3D element.style.width;=0A= element._originalHeight =3D element.style.height;=0A= =0A= element.style.position =3D 'absolute';=0A= element.style.top =3D top + 'px';=0A= element.style.left =3D left + 'px';=0A= element.style.width =3D width + 'px';=0A= element.style.height =3D height + 'px';=0A= return element;=0A= },=0A= =0A= relativize: function(element) {=0A= element =3D $(element);=0A= if (element.getStyle('position') =3D=3D 'relative') return;=0A= // Position.prepare(); // To be done manually by Scripty when it = needs it.=0A= =0A= element.style.position =3D 'relative';=0A= var top =3D parseFloat(element.style.top || 0) - = (element._originalTop || 0);=0A= var left =3D parseFloat(element.style.left || 0) - = (element._originalLeft || 0);=0A= =0A= element.style.top =3D top + 'px';=0A= element.style.left =3D left + 'px';=0A= element.style.height =3D element._originalHeight;=0A= element.style.width =3D element._originalWidth;=0A= return element;=0A= },=0A= =0A= cumulativeScrollOffset: function(element) {=0A= var valueT =3D 0, valueL =3D 0;=0A= do {=0A= valueT +=3D element.scrollTop || 0;=0A= valueL +=3D element.scrollLeft || 0;=0A= element =3D element.parentNode;=0A= } while (element);=0A= return Element._returnOffset(valueL, valueT);=0A= },=0A= =0A= getOffsetParent: function(element) {=0A= if (element.offsetParent) return $(element.offsetParent);=0A= if (element =3D=3D document.body) return $(element);=0A= =0A= while ((element =3D element.parentNode) && element !=3D = document.body)=0A= if (Element.getStyle(element, 'position') !=3D 'static')=0A= return $(element);=0A= =0A= return $(document.body);=0A= },=0A= =0A= viewportOffset: function(forElement) {=0A= var valueT =3D 0, valueL =3D 0;=0A= =0A= var element =3D forElement;=0A= do {=0A= valueT +=3D element.offsetTop || 0;=0A= valueL +=3D element.offsetLeft || 0;=0A= =0A= // Safari fix=0A= if (element.offsetParent =3D=3D document.body &&=0A= Element.getStyle(element, 'position') =3D=3D 'absolute') break;=0A= =0A= } while (element =3D element.offsetParent);=0A= =0A= element =3D forElement;=0A= do {=0A= if (!Prototype.Browser.Opera || element.tagName =3D=3D 'BODY') {=0A= valueT -=3D element.scrollTop || 0;=0A= valueL -=3D element.scrollLeft || 0;=0A= }=0A= } while (element =3D element.parentNode);=0A= =0A= return Element._returnOffset(valueL, valueT);=0A= },=0A= =0A= clonePosition: function(element, source) {=0A= var options =3D Object.extend({=0A= setLeft: true,=0A= setTop: true,=0A= setWidth: true,=0A= setHeight: true,=0A= offsetTop: 0,=0A= offsetLeft: 0=0A= }, arguments[2] || { });=0A= =0A= // find page position of source=0A= source =3D $(source);=0A= var p =3D source.viewportOffset();=0A= =0A= // find coordinate system to use=0A= element =3D $(element);=0A= var delta =3D [0, 0];=0A= var parent =3D null;=0A= // delta [0,0] will do fine with position: fixed elements,=0A= // position:absolute needs offsetParent deltas=0A= if (Element.getStyle(element, 'position') =3D=3D 'absolute') {=0A= parent =3D element.getOffsetParent();=0A= delta =3D parent.viewportOffset();=0A= }=0A= =0A= // correct by body offsets (fixes Safari)=0A= if (parent =3D=3D document.body) {=0A= delta[0] -=3D document.body.offsetLeft;=0A= delta[1] -=3D document.body.offsetTop;=0A= }=0A= =0A= // set position=0A= if (options.setLeft) element.style.left =3D (p[0] - delta[0] + = options.offsetLeft) + 'px';=0A= if (options.setTop) element.style.top =3D (p[1] - delta[1] + = options.offsetTop) + 'px';=0A= if (options.setWidth) element.style.width =3D source.offsetWidth + = 'px';=0A= if (options.setHeight) element.style.height =3D source.offsetHeight = + 'px';=0A= return element;=0A= }=0A= };=0A= =0A= Element.Methods.identify.counter =3D 1;=0A= =0A= Object.extend(Element.Methods, {=0A= getElementsBySelector: Element.Methods.select,=0A= childElements: Element.Methods.immediateDescendants=0A= });=0A= =0A= Element._attributeTranslations =3D {=0A= write: {=0A= names: {=0A= className: 'class',=0A= htmlFor: 'for'=0A= },=0A= values: { }=0A= }=0A= };=0A= =0A= =0A= if (!document.createRange || Prototype.Browser.Opera) {=0A= Element.Methods.insert =3D function(element, insertions) {=0A= element =3D $(element);=0A= =0A= if (Object.isString(insertions) || Object.isNumber(insertions) ||=0A= Object.isElement(insertions) || (insertions && = (insertions.toElement || insertions.toHTML)))=0A= insertions =3D { bottom: insertions };=0A= =0A= var t =3D Element._insertionTranslations, content, position, pos, = tagName;=0A= =0A= for (position in insertions) {=0A= content =3D insertions[position];=0A= position =3D position.toLowerCase();=0A= pos =3D t[position];=0A= =0A= if (content && content.toElement) content =3D content.toElement();=0A= if (Object.isElement(content)) {=0A= pos.insert(element, content);=0A= continue;=0A= }=0A= =0A= content =3D Object.toHTML(content);=0A= tagName =3D ((position =3D=3D 'before' || position =3D=3D 'after')=0A= ? element.parentNode : element).tagName.toUpperCase();=0A= =0A= if (t.tags[tagName]) {=0A= var fragments =3D = Element._getContentFromAnonymousElement(tagName, content.stripScripts());=0A= if (position =3D=3D 'top' || position =3D=3D 'after') = fragments.reverse();=0A= fragments.each(pos.insert.curry(element));=0A= }=0A= else element.insertAdjacentHTML(pos.adjacency, = content.stripScripts());=0A= =0A= content.evalScripts.bind(content).defer();=0A= }=0A= =0A= return element;=0A= };=0A= }=0A= =0A= if (Prototype.Browser.Opera) {=0A= Element.Methods._getStyle =3D Element.Methods.getStyle;=0A= Element.Methods.getStyle =3D function(element, style) {=0A= switch(style) {=0A= case 'left':=0A= case 'top':=0A= case 'right':=0A= case 'bottom':=0A= if (Element._getStyle(element, 'position') =3D=3D 'static') = return null;=0A= default: return Element._getStyle(element, style);=0A= }=0A= };=0A= Element.Methods._readAttribute =3D Element.Methods.readAttribute;=0A= Element.Methods.readAttribute =3D function(element, attribute) {=0A= if (attribute =3D=3D 'title') return element.title;=0A= return Element._readAttribute(element, attribute);=0A= };=0A= }=0A= =0A= else if (Prototype.Browser.IE) {=0A= $w('positionedOffset getOffsetParent = viewportOffset').each(function(method) {=0A= Element.Methods[method] =3D Element.Methods[method].wrap(=0A= function(proceed, element) {=0A= element =3D $(element);=0A= var position =3D element.getStyle('position');=0A= if (position !=3D 'static') return proceed(element);=0A= element.setStyle({ position: 'relative' });=0A= var value =3D proceed(element);=0A= element.setStyle({ position: position });=0A= return value;=0A= }=0A= );=0A= });=0A= =0A= Element.Methods.getStyle =3D function(element, style) {=0A= element =3D $(element);=0A= style =3D (style =3D=3D 'float' || style =3D=3D 'cssFloat') ? = 'styleFloat' : style.camelize();=0A= var value =3D element.style[style];=0A= if (!value && element.currentStyle) value =3D = element.currentStyle[style];=0A= =0A= if (style =3D=3D 'opacity') {=0A= if (value =3D (element.getStyle('filter') || = '').match(/alpha\(opacity=3D(.*)\)/))=0A= if (value[1]) return parseFloat(value[1]) / 100;=0A= return 1.0;=0A= }=0A= =0A= if (value =3D=3D 'auto') {=0A= if ((style =3D=3D 'width' || style =3D=3D 'height') && = (element.getStyle('display') !=3D 'none'))=0A= return element['offset' + style.capitalize()] + 'px';=0A= return null;=0A= }=0A= return value;=0A= };=0A= =0A= Element.Methods.setOpacity =3D function(element, value) {=0A= function stripAlpha(filter){=0A= return filter.replace(/alpha\([^\)]*\)/gi,'');=0A= }=0A= element =3D $(element);=0A= var currentStyle =3D element.currentStyle;=0A= if ((currentStyle && !currentStyle.hasLayout) ||=0A= (!currentStyle && element.style.zoom =3D=3D 'normal'))=0A= element.style.zoom =3D 1;=0A= =0A= var filter =3D element.getStyle('filter'), style =3D element.style;=0A= if (value =3D=3D 1 || value =3D=3D=3D '') {=0A= (filter =3D stripAlpha(filter)) ?=0A= style.filter =3D filter : style.removeAttribute('filter');=0A= return element;=0A= } else if (value < 0.00001) value =3D 0;=0A= style.filter =3D stripAlpha(filter) +=0A= 'alpha(opacity=3D' + (value * 100) + ')';=0A= return element;=0A= };=0A= =0A= Element._attributeTranslations =3D {=0A= read: {=0A= names: {=0A= 'class': 'className',=0A= 'for': 'htmlFor'=0A= },=0A= values: {=0A= _getAttr: function(element, attribute) {=0A= return element.getAttribute(attribute, 2);=0A= },=0A= _getAttrNode: function(element, attribute) {=0A= var node =3D element.getAttributeNode(attribute);=0A= return node ? node.value : "";=0A= },=0A= _getEv: function(element, attribute) {=0A= var attribute =3D element.getAttribute(attribute);=0A= return attribute ? attribute.toString().slice(23, -2) : null;=0A= },=0A= _flag: function(element, attribute) {=0A= return $(element).hasAttribute(attribute) ? attribute : null;=0A= },=0A= style: function(element) {=0A= return element.style.cssText.toLowerCase();=0A= },=0A= title: function(element) {=0A= return element.title;=0A= }=0A= }=0A= }=0A= };=0A= =0A= Element._attributeTranslations.write =3D {=0A= names: Object.clone(Element._attributeTranslations.read.names),=0A= values: {=0A= checked: function(element, value) {=0A= element.checked =3D !!value;=0A= },=0A= =0A= style: function(element, value) {=0A= element.style.cssText =3D value ? value : '';=0A= }=0A= }=0A= };=0A= =0A= Element._attributeTranslations.has =3D {};=0A= =0A= $w('colSpan rowSpan vAlign dateTime accessKey tabIndex ' +=0A= 'encType maxLength readOnly longDesc').each(function(attr) {=0A= Element._attributeTranslations.write.names[attr.toLowerCase()] =3D = attr;=0A= Element._attributeTranslations.has[attr.toLowerCase()] =3D attr;=0A= });=0A= =0A= (function(v) {=0A= Object.extend(v, {=0A= href: v._getAttr,=0A= src: v._getAttr,=0A= type: v._getAttr,=0A= action: v._getAttrNode,=0A= disabled: v._flag,=0A= checked: v._flag,=0A= readonly: v._flag,=0A= multiple: v._flag,=0A= onload: v._getEv,=0A= onunload: v._getEv,=0A= onclick: v._getEv,=0A= ondblclick: v._getEv,=0A= onmousedown: v._getEv,=0A= onmouseup: v._getEv,=0A= onmouseover: v._getEv,=0A= onmousemove: v._getEv,=0A= onmouseout: v._getEv,=0A= onfocus: v._getEv,=0A= onblur: v._getEv,=0A= onkeypress: v._getEv,=0A= onkeydown: v._getEv,=0A= onkeyup: v._getEv,=0A= onsubmit: v._getEv,=0A= onreset: v._getEv,=0A= onselect: v._getEv,=0A= onchange: v._getEv=0A= });=0A= })(Element._attributeTranslations.read.values);=0A= }=0A= =0A= else if (Prototype.Browser.Gecko && = /rv:1\.8\.0/.test(navigator.userAgent)) {=0A= Element.Methods.setOpacity =3D function(element, value) {=0A= element =3D $(element);=0A= element.style.opacity =3D (value =3D=3D 1) ? 0.999999 :=0A= (value =3D=3D=3D '') ? '' : (value < 0.00001) ? 0 : value;=0A= return element;=0A= };=0A= }=0A= =0A= else if (Prototype.Browser.WebKit) {=0A= Element.Methods.setOpacity =3D function(element, value) {=0A= element =3D $(element);=0A= element.style.opacity =3D (value =3D=3D 1 || value =3D=3D=3D '') ? = '' :=0A= (value < 0.00001) ? 0 : value;=0A= =0A= if (value =3D=3D 1)=0A= if(element.tagName =3D=3D 'IMG' && element.width) {=0A= element.width++; element.width--;=0A= } else try {=0A= var n =3D document.createTextNode(' ');=0A= element.appendChild(n);=0A= element.removeChild(n);=0A= } catch (e) { }=0A= =0A= return element;=0A= };=0A= =0A= // Safari returns margins on body which is incorrect if the child is = absolutely=0A= // positioned. For performance reasons, redefine = Position.cumulativeOffset for=0A= // KHTML/WebKit only.=0A= Element.Methods.cumulativeOffset =3D function(element) {=0A= var valueT =3D 0, valueL =3D 0;=0A= do {=0A= valueT +=3D element.offsetTop || 0;=0A= valueL +=3D element.offsetLeft || 0;=0A= if (element.offsetParent =3D=3D document.body)=0A= if (Element.getStyle(element, 'position') =3D=3D 'absolute') = break;=0A= =0A= element =3D element.offsetParent;=0A= } while (element);=0A= =0A= return Element._returnOffset(valueL, valueT);=0A= };=0A= }=0A= =0A= if (Prototype.Browser.IE || Prototype.Browser.Opera) {=0A= // IE and Opera are missing .innerHTML support for TABLE-related and = SELECT elements=0A= Element.Methods.update =3D function(element, content) {=0A= element =3D $(element);=0A= =0A= if (content && content.toElement) content =3D content.toElement();=0A= if (Object.isElement(content)) return = element.update().insert(content);=0A= =0A= content =3D Object.toHTML(content);=0A= var tagName =3D element.tagName.toUpperCase();=0A= =0A= if (tagName in Element._insertionTranslations.tags) {=0A= $A(element.childNodes).each(function(node) { = element.removeChild(node) });=0A= Element._getContentFromAnonymousElement(tagName, = content.stripScripts())=0A= .each(function(node) { element.appendChild(node) });=0A= }=0A= else element.innerHTML =3D content.stripScripts();=0A= =0A= content.evalScripts.bind(content).defer();=0A= return element;=0A= };=0A= }=0A= =0A= if (document.createElement('div').outerHTML) {=0A= Element.Methods.replace =3D function(element, content) {=0A= element =3D $(element);=0A= =0A= if (content && content.toElement) content =3D content.toElement();=0A= if (Object.isElement(content)) {=0A= element.parentNode.replaceChild(content, element);=0A= return element;=0A= }=0A= =0A= content =3D Object.toHTML(content);=0A= var parent =3D element.parentNode, tagName =3D = parent.tagName.toUpperCase();=0A= =0A= if (Element._insertionTranslations.tags[tagName]) {=0A= var nextSibling =3D element.next();=0A= var fragments =3D Element._getContentFromAnonymousElement(tagName, = content.stripScripts());=0A= parent.removeChild(element);=0A= if (nextSibling)=0A= fragments.each(function(node) { parent.insertBefore(node, = nextSibling) });=0A= else=0A= fragments.each(function(node) { parent.appendChild(node) });=0A= }=0A= else element.outerHTML =3D content.stripScripts();=0A= =0A= content.evalScripts.bind(content).defer();=0A= return element;=0A= };=0A= }=0A= =0A= Element._returnOffset =3D function(l, t) {=0A= var result =3D [l, t];=0A= result.left =3D l;=0A= result.top =3D t;=0A= return result;=0A= };=0A= =0A= Element._getContentFromAnonymousElement =3D function(tagName, html) {=0A= var div =3D new Element('div'), t =3D = Element._insertionTranslations.tags[tagName];=0A= div.innerHTML =3D t[0] + html + t[1];=0A= t[2].times(function() { div =3D div.firstChild });=0A= return $A(div.childNodes);=0A= };=0A= =0A= Element._insertionTranslations =3D {=0A= before: {=0A= adjacency: 'beforeBegin',=0A= insert: function(element, node) {=0A= element.parentNode.insertBefore(node, element);=0A= },=0A= initializeRange: function(element, range) {=0A= range.setStartBefore(element);=0A= }=0A= },=0A= top: {=0A= adjacency: 'afterBegin',=0A= insert: function(element, node) {=0A= element.insertBefore(node, element.firstChild);=0A= },=0A= initializeRange: function(element, range) {=0A= range.selectNodeContents(element);=0A= range.collapse(true);=0A= }=0A= },=0A= bottom: {=0A= adjacency: 'beforeEnd',=0A= insert: function(element, node) {=0A= element.appendChild(node);=0A= }=0A= },=0A= after: {=0A= adjacency: 'afterEnd',=0A= insert: function(element, node) {=0A= element.parentNode.insertBefore(node, element.nextSibling);=0A= },=0A= initializeRange: function(element, range) {=0A= range.setStartAfter(element);=0A= }=0A= },=0A= tags: {=0A= TABLE: ['', '
', 1],=0A= TBODY: ['', '
', 2],=0A= TR: ['', '
', 3],=0A= TD: ['
', '
', 4],=0A= SELECT: ['', 1]=0A= }=0A= };=0A= =0A= (function() {=0A= this.bottom.initializeRange =3D this.top.initializeRange;=0A= Object.extend(this.tags, {=0A= THEAD: this.tags.TBODY,=0A= TFOOT: this.tags.TBODY,=0A= TH: this.tags.TD=0A= });=0A= }).call(Element._insertionTranslations);=0A= =0A= Element.Methods.Simulated =3D {=0A= hasAttribute: function(element, attribute) {=0A= attribute =3D Element._attributeTranslations.has[attribute] || = attribute;=0A= var node =3D $(element).getAttributeNode(attribute);=0A= return node && node.specified;=0A= }=0A= };=0A= =0A= Element.Methods.ByTag =3D { };=0A= =0A= Object.extend(Element, Element.Methods);=0A= =0A= if (!Prototype.BrowserFeatures.ElementExtensions &&=0A= document.createElement('div').__proto__) {=0A= window.HTMLElement =3D { };=0A= window.HTMLElement.prototype =3D = document.createElement('div').__proto__;=0A= Prototype.BrowserFeatures.ElementExtensions =3D true;=0A= }=0A= =0A= Element.extend =3D (function() {=0A= if (Prototype.BrowserFeatures.SpecificElementExtensions)=0A= return Prototype.K;=0A= =0A= var Methods =3D { }, ByTag =3D Element.Methods.ByTag;=0A= =0A= var extend =3D Object.extend(function(element) {=0A= if (!element || element._extendedByPrototype ||=0A= element.nodeType !=3D 1 || element =3D=3D window) return element;=0A= =0A= var methods =3D Object.clone(Methods),=0A= tagName =3D element.tagName, property, value;=0A= =0A= // extend methods for specific tags=0A= if (ByTag[tagName]) Object.extend(methods, ByTag[tagName]);=0A= =0A= for (property in methods) {=0A= value =3D methods[property];=0A= if (Object.isFunction(value) && !(property in element))=0A= element[property] =3D value.methodize();=0A= }=0A= =0A= element._extendedByPrototype =3D Prototype.emptyFunction;=0A= return element;=0A= =0A= }, {=0A= refresh: function() {=0A= // extend methods for all tags (Safari doesn't need this)=0A= if (!Prototype.BrowserFeatures.ElementExtensions) {=0A= Object.extend(Methods, Element.Methods);=0A= Object.extend(Methods, Element.Methods.Simulated);=0A= }=0A= }=0A= });=0A= =0A= extend.refresh();=0A= return extend;=0A= })();=0A= =0A= Element.hasAttribute =3D function(element, attribute) {=0A= if (element.hasAttribute) return element.hasAttribute(attribute);=0A= return Element.Methods.Simulated.hasAttribute(element, attribute);=0A= };=0A= =0A= Element.addMethods =3D function(methods) {=0A= var F =3D Prototype.BrowserFeatures, T =3D Element.Methods.ByTag;=0A= =0A= if (!methods) {=0A= Object.extend(Form, Form.Methods);=0A= Object.extend(Form.Element, Form.Element.Methods);=0A= Object.extend(Element.Methods.ByTag, {=0A= "FORM": Object.clone(Form.Methods),=0A= "INPUT": Object.clone(Form.Element.Methods),=0A= "SELECT": Object.clone(Form.Element.Methods),=0A= "TEXTAREA": Object.clone(Form.Element.Methods)=0A= });=0A= }=0A= =0A= if (arguments.length =3D=3D 2) {=0A= var tagName =3D methods;=0A= methods =3D arguments[1];=0A= }=0A= =0A= if (!tagName) Object.extend(Element.Methods, methods || { });=0A= else {=0A= if (Object.isArray(tagName)) tagName.each(extend);=0A= else extend(tagName);=0A= }=0A= =0A= function extend(tagName) {=0A= tagName =3D tagName.toUpperCase();=0A= if (!Element.Methods.ByTag[tagName])=0A= Element.Methods.ByTag[tagName] =3D { };=0A= Object.extend(Element.Methods.ByTag[tagName], methods);=0A= }=0A= =0A= function copy(methods, destination, onlyIfAbsent) {=0A= onlyIfAbsent =3D onlyIfAbsent || false;=0A= for (var property in methods) {=0A= var value =3D methods[property];=0A= if (!Object.isFunction(value)) continue;=0A= if (!onlyIfAbsent || !(property in destination))=0A= destination[property] =3D value.methodize();=0A= }=0A= }=0A= =0A= function findDOMClass(tagName) {=0A= var klass;=0A= var trans =3D {=0A= "OPTGROUP": "OptGroup", "TEXTAREA": "TextArea", "P": "Paragraph",=0A= "FIELDSET": "FieldSet", "UL": "UList", "OL": "OList", "DL": = "DList",=0A= "DIR": "Directory", "H1": "Heading", "H2": "Heading", "H3": = "Heading",=0A= "H4": "Heading", "H5": "Heading", "H6": "Heading", "Q": "Quote",=0A= "INS": "Mod", "DEL": "Mod", "A": "Anchor", "IMG": "Image", = "CAPTION":=0A= "TableCaption", "COL": "TableCol", "COLGROUP": "TableCol", "THEAD":=0A= "TableSection", "TFOOT": "TableSection", "TBODY": "TableSection", = "TR":=0A= "TableRow", "TH": "TableCell", "TD": "TableCell", "FRAMESET":=0A= "FrameSet", "IFRAME": "IFrame"=0A= };=0A= if (trans[tagName]) klass =3D 'HTML' + trans[tagName] + 'Element';=0A= if (window[klass]) return window[klass];=0A= klass =3D 'HTML' + tagName + 'Element';=0A= if (window[klass]) return window[klass];=0A= klass =3D 'HTML' + tagName.capitalize() + 'Element';=0A= if (window[klass]) return window[klass];=0A= =0A= window[klass] =3D { };=0A= window[klass].prototype =3D = document.createElement(tagName).__proto__;=0A= return window[klass];=0A= }=0A= =0A= if (F.ElementExtensions) {=0A= copy(Element.Methods, HTMLElement.prototype);=0A= copy(Element.Methods.Simulated, HTMLElement.prototype, true);=0A= }=0A= =0A= if (F.SpecificElementExtensions) {=0A= for (var tag in Element.Methods.ByTag) {=0A= var klass =3D findDOMClass(tag);=0A= if (Object.isUndefined(klass)) continue;=0A= copy(T[tag], klass.prototype);=0A= }=0A= }=0A= =0A= Object.extend(Element, Element.Methods);=0A= delete Element.ByTag;=0A= =0A= if (Element.extend.refresh) Element.extend.refresh();=0A= Element.cache =3D { };=0A= };=0A= =0A= document.viewport =3D {=0A= getDimensions: function() {=0A= var dimensions =3D { };=0A= $w('width height').each(function(d) {=0A= var D =3D d.capitalize();=0A= dimensions[d] =3D self['inner' + D] ||=0A= (document.documentElement['client' + D] || document.body['client' = + D]);=0A= });=0A= return dimensions;=0A= },=0A= =0A= getWidth: function() {=0A= return this.getDimensions().width;=0A= },=0A= =0A= getHeight: function() {=0A= return this.getDimensions().height;=0A= },=0A= =0A= getScrollOffsets: function() {=0A= return Element._returnOffset(=0A= window.pageXOffset || document.documentElement.scrollLeft || = document.body.scrollLeft,=0A= window.pageYOffset || document.documentElement.scrollTop || = document.body.scrollTop);=0A= }=0A= };=0A= /* Portions of the Selector class are derived from Jack Slocum=E2=80=99s = DomQuery,=0A= * part of YUI-Ext version 0.40, distributed under the terms of an = MIT-style=0A= * license. Please see http://www.yui-ext.com/ for more information. */=0A= =0A= var Selector =3D Class.create({=0A= initialize: function(expression) {=0A= this.expression =3D expression.strip();=0A= this.compileMatcher();=0A= },=0A= =0A= compileMatcher: function() {=0A= // Selectors with namespaced attributes can't use the XPath version=0A= if (Prototype.BrowserFeatures.XPath && = !(/(\[[\w-]*?:|:checked)/).test(this.expression))=0A= return this.compileXPathMatcher();=0A= =0A= var e =3D this.expression, ps =3D Selector.patterns, h =3D = Selector.handlers,=0A= c =3D Selector.criteria, le, p, m;=0A= =0A= if (Selector._cache[e]) {=0A= this.matcher =3D Selector._cache[e];=0A= return;=0A= }=0A= =0A= this.matcher =3D ["this.matcher =3D function(root) {",=0A= "var r =3D root, h =3D Selector.handlers, c =3D = false, n;"];=0A= =0A= while (e && le !=3D e && (/\S/).test(e)) {=0A= le =3D e;=0A= for (var i in ps) {=0A= p =3D ps[i];=0A= if (m =3D e.match(p)) {=0A= this.matcher.push(Object.isFunction(c[i]) ? c[i](m) :=0A= new Template(c[i]).evaluate(m));=0A= e =3D e.replace(m[0], '');=0A= break;=0A= }=0A= }=0A= }=0A= =0A= this.matcher.push("return h.unique(n);\n}");=0A= eval(this.matcher.join('\n'));=0A= Selector._cache[this.expression] =3D this.matcher;=0A= },=0A= =0A= compileXPathMatcher: function() {=0A= var e =3D this.expression, ps =3D Selector.patterns,=0A= x =3D Selector.xpath, le, m;=0A= =0A= if (Selector._cache[e]) {=0A= this.xpath =3D Selector._cache[e]; return;=0A= }=0A= =0A= this.matcher =3D ['.//*'];=0A= while (e && le !=3D e && (/\S/).test(e)) {=0A= le =3D e;=0A= for (var i in ps) {=0A= if (m =3D e.match(ps[i])) {=0A= this.matcher.push(Object.isFunction(x[i]) ? x[i](m) :=0A= new Template(x[i]).evaluate(m));=0A= e =3D e.replace(m[0], '');=0A= break;=0A= }=0A= }=0A= }=0A= =0A= this.xpath =3D this.matcher.join('');=0A= Selector._cache[this.expression] =3D this.xpath;=0A= },=0A= =0A= findElements: function(root) {=0A= root =3D root || document;=0A= if (this.xpath) return document._getElementsByXPath(this.xpath, = root);=0A= return this.matcher(root);=0A= },=0A= =0A= match: function(element) {=0A= this.tokens =3D [];=0A= =0A= var e =3D this.expression, ps =3D Selector.patterns, as =3D = Selector.assertions;=0A= var le, p, m;=0A= =0A= while (e && le !=3D=3D e && (/\S/).test(e)) {=0A= le =3D e;=0A= for (var i in ps) {=0A= p =3D ps[i];=0A= if (m =3D e.match(p)) {=0A= // use the Selector.assertions methods unless the selector=0A= // is too complex.=0A= if (as[i]) {=0A= this.tokens.push([i, Object.clone(m)]);=0A= e =3D e.replace(m[0], '');=0A= } else {=0A= // reluctantly do a document-wide search=0A= // and look for a match in the array=0A= return this.findElements(document).include(element);=0A= }=0A= }=0A= }=0A= }=0A= =0A= var match =3D true, name, matches;=0A= for (var i =3D 0, token; token =3D this.tokens[i]; i++) {=0A= name =3D token[0], matches =3D token[1];=0A= if (!Selector.assertions[name](element, matches)) {=0A= match =3D false; break;=0A= }=0A= }=0A= =0A= return match;=0A= },=0A= =0A= toString: function() {=0A= return this.expression;=0A= },=0A= =0A= inspect: function() {=0A= return "#";=0A= }=0A= });=0A= =0A= Object.extend(Selector, {=0A= _cache: { },=0A= =0A= xpath: {=0A= descendant: "//*",=0A= child: "/*",=0A= adjacent: "/following-sibling::*[1]",=0A= laterSibling: '/following-sibling::*',=0A= tagName: function(m) {=0A= if (m[1] =3D=3D '*') return '';=0A= return "[local-name()=3D'" + m[1].toLowerCase() +=0A= "' or local-name()=3D'" + m[1].toUpperCase() + "']";=0A= },=0A= className: "[contains(concat(' ', @class, ' '), ' #{1} ')]",=0A= id: "[@id=3D'#{1}']",=0A= attrPresence: "[@#{1}]",=0A= attr: function(m) {=0A= m[3] =3D m[5] || m[6];=0A= return new Template(Selector.xpath.operators[m[2]]).evaluate(m);=0A= },=0A= pseudo: function(m) {=0A= var h =3D Selector.xpath.pseudos[m[1]];=0A= if (!h) return '';=0A= if (Object.isFunction(h)) return h(m);=0A= return new Template(Selector.xpath.pseudos[m[1]]).evaluate(m);=0A= },=0A= operators: {=0A= '=3D': "[@#{1}=3D'#{3}']",=0A= '!=3D': "[@#{1}!=3D'#{3}']",=0A= '^=3D': "[starts-with(@#{1}, '#{3}')]",=0A= '$=3D': "[substring(@#{1}, (string-length(@#{1}) - = string-length('#{3}') + 1))=3D'#{3}']",=0A= '*=3D': "[contains(@#{1}, '#{3}')]",=0A= '~=3D': "[contains(concat(' ', @#{1}, ' '), ' #{3} ')]",=0A= '|=3D': "[contains(concat('-', @#{1}, '-'), '-#{3}-')]"=0A= },=0A= pseudos: {=0A= 'first-child': '[not(preceding-sibling::*)]',=0A= 'last-child': '[not(following-sibling::*)]',=0A= 'only-child': '[not(preceding-sibling::* or = following-sibling::*)]',=0A= 'empty': "[count(*) =3D 0 and (count(text()) =3D 0 or = translate(text(), ' \t\r\n', '') =3D '')]",=0A= 'checked': "[@checked]",=0A= 'disabled': "[@disabled]",=0A= 'enabled': "[not(@disabled)]",=0A= 'not': function(m) {=0A= var e =3D m[6], p =3D Selector.patterns,=0A= x =3D Selector.xpath, le, m, v;=0A= =0A= var exclusion =3D [];=0A= while (e && le !=3D e && (/\S/).test(e)) {=0A= le =3D e;=0A= for (var i in p) {=0A= if (m =3D e.match(p[i])) {=0A= v =3D Object.isFunction(x[i]) ? x[i](m) : new = Template(x[i]).evaluate(m);=0A= exclusion.push("(" + v.substring(1, v.length - 1) + ")");=0A= e =3D e.replace(m[0], '');=0A= break;=0A= }=0A= }=0A= }=0A= return "[not(" + exclusion.join(" and ") + ")]";=0A= },=0A= 'nth-child': function(m) {=0A= return = Selector.xpath.pseudos.nth("(count(./preceding-sibling::*) + 1) ", m);=0A= },=0A= 'nth-last-child': function(m) {=0A= return = Selector.xpath.pseudos.nth("(count(./following-sibling::*) + 1) ", m);=0A= },=0A= 'nth-of-type': function(m) {=0A= return Selector.xpath.pseudos.nth("position() ", m);=0A= },=0A= 'nth-last-of-type': function(m) {=0A= return Selector.xpath.pseudos.nth("(last() + 1 - position()) ", = m);=0A= },=0A= 'first-of-type': function(m) {=0A= m[6] =3D "1"; return Selector.xpath.pseudos['nth-of-type'](m);=0A= },=0A= 'last-of-type': function(m) {=0A= m[6] =3D "1"; return = Selector.xpath.pseudos['nth-last-of-type'](m);=0A= },=0A= 'only-of-type': function(m) {=0A= var p =3D Selector.xpath.pseudos; return p['first-of-type'](m) + = p['last-of-type'](m);=0A= },=0A= nth: function(fragment, m) {=0A= var mm, formula =3D m[6], predicate;=0A= if (formula =3D=3D 'even') formula =3D '2n+0';=0A= if (formula =3D=3D 'odd') formula =3D '2n+1';=0A= if (mm =3D formula.match(/^(\d+)$/)) // digit only=0A= return '[' + fragment + "=3D " + mm[1] + ']';=0A= if (mm =3D formula.match(/^(-?\d*)?n(([+-])(\d+))?/)) { // an+b=0A= if (mm[1] =3D=3D "-") mm[1] =3D -1;=0A= var a =3D mm[1] ? Number(mm[1]) : 1;=0A= var b =3D mm[2] ? Number(mm[2]) : 0;=0A= predicate =3D "[((#{fragment} - #{b}) mod #{a} =3D 0) and " +=0A= "((#{fragment} - #{b}) div #{a} >=3D 0)]";=0A= return new Template(predicate).evaluate({=0A= fragment: fragment, a: a, b: b });=0A= }=0A= }=0A= }=0A= },=0A= =0A= criteria: {=0A= tagName: 'n =3D h.tagName(n, r, "#{1}", c); c =3D false;',=0A= className: 'n =3D h.className(n, r, "#{1}", c); c =3D false;',=0A= id: 'n =3D h.id(n, r, "#{1}", c); c =3D false;',=0A= attrPresence: 'n =3D h.attrPresence(n, r, "#{1}"); c =3D false;',=0A= attr: function(m) {=0A= m[3] =3D (m[5] || m[6]);=0A= return new Template('n =3D h.attr(n, r, "#{1}", "#{3}", "#{2}"); c = =3D false;').evaluate(m);=0A= },=0A= pseudo: function(m) {=0A= if (m[6]) m[6] =3D m[6].replace(/"/g, '\\"');=0A= return new Template('n =3D h.pseudo(n, "#{1}", "#{6}", r, c); c = =3D false;').evaluate(m);=0A= },=0A= descendant: 'c =3D "descendant";',=0A= child: 'c =3D "child";',=0A= adjacent: 'c =3D "adjacent";',=0A= laterSibling: 'c =3D "laterSibling";'=0A= },=0A= =0A= patterns: {=0A= // combinators must be listed first=0A= // (and descendant needs to be last combinator)=0A= laterSibling: /^\s*~\s*/,=0A= child: /^\s*>\s*/,=0A= adjacent: /^\s*\+\s*/,=0A= descendant: /^\s/,=0A= =0A= // selectors follow=0A= tagName: /^\s*(\*|[\w\-]+)(\b|$)?/,=0A= id: /^#([\w\-\*]+)(\b|$)/,=0A= className: /^\.([\w\-\*]+)(\b|$)/,=0A= pseudo: = /^:((first|last|nth|nth-last|only)(-child|-of-type)|empty|checked|(en|dis= )abled|not)(\((.*?)\))?(\b|$|(?=3D\s)|(?=3D:))/,=0A= attrPresence: /^\[([\w]+)\]/,=0A= attr: = /\[((?:[\w-]*:)?[\w-]+)\s*(?:([!^$*~|]?=3D)\s*((['"])([^\4]*?)\4|([^'"][^= \]]*?)))?\]/=0A= },=0A= =0A= // for Selector.match and Element#match=0A= assertions: {=0A= tagName: function(element, matches) {=0A= return matches[1].toUpperCase() =3D=3D = element.tagName.toUpperCase();=0A= },=0A= =0A= className: function(element, matches) {=0A= return Element.hasClassName(element, matches[1]);=0A= },=0A= =0A= id: function(element, matches) {=0A= return element.id =3D=3D=3D matches[1];=0A= },=0A= =0A= attrPresence: function(element, matches) {=0A= return Element.hasAttribute(element, matches[1]);=0A= },=0A= =0A= attr: function(element, matches) {=0A= var nodeValue =3D Element.readAttribute(element, matches[1]);=0A= return Selector.operators[matches[2]](nodeValue, matches[3]);=0A= }=0A= },=0A= =0A= handlers: {=0A= // UTILITY FUNCTIONS=0A= // joins two collections=0A= concat: function(a, b) {=0A= for (var i =3D 0, node; node =3D b[i]; i++)=0A= a.push(node);=0A= return a;=0A= },=0A= =0A= // marks an array of nodes for counting=0A= mark: function(nodes) {=0A= for (var i =3D 0, node; node =3D nodes[i]; i++)=0A= node._counted =3D true;=0A= return nodes;=0A= },=0A= =0A= unmark: function(nodes) {=0A= for (var i =3D 0, node; node =3D nodes[i]; i++)=0A= node._counted =3D undefined;=0A= return nodes;=0A= },=0A= =0A= // mark each child node with its position (for nth calls)=0A= // "ofType" flag indicates whether we're indexing for nth-of-type=0A= // rather than nth-child=0A= index: function(parentNode, reverse, ofType) {=0A= parentNode._counted =3D true;=0A= if (reverse) {=0A= for (var nodes =3D parentNode.childNodes, i =3D nodes.length - = 1, j =3D 1; i >=3D 0; i--) {=0A= var node =3D nodes[i];=0A= if (node.nodeType =3D=3D 1 && (!ofType || node._counted)) = node.nodeIndex =3D j++;=0A= }=0A= } else {=0A= for (var i =3D 0, j =3D 1, nodes =3D parentNode.childNodes; node = =3D nodes[i]; i++)=0A= if (node.nodeType =3D=3D 1 && (!ofType || node._counted)) = node.nodeIndex =3D j++;=0A= }=0A= },=0A= =0A= // filters out duplicates and extends all nodes=0A= unique: function(nodes) {=0A= if (nodes.length =3D=3D 0) return nodes;=0A= var results =3D [], n;=0A= for (var i =3D 0, l =3D nodes.length; i < l; i++)=0A= if (!(n =3D nodes[i])._counted) {=0A= n._counted =3D true;=0A= results.push(Element.extend(n));=0A= }=0A= return Selector.handlers.unmark(results);=0A= },=0A= =0A= // COMBINATOR FUNCTIONS=0A= descendant: function(nodes) {=0A= var h =3D Selector.handlers;=0A= for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++)=0A= h.concat(results, node.getElementsByTagName('*'));=0A= return results;=0A= },=0A= =0A= child: function(nodes) {=0A= var h =3D Selector.handlers;=0A= for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++) {=0A= for (var j =3D 0, children =3D [], child; child =3D = node.childNodes[j]; j++)=0A= if (child.nodeType =3D=3D 1 && child.tagName !=3D '!') = results.push(child);=0A= }=0A= return results;=0A= },=0A= =0A= adjacent: function(nodes) {=0A= for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++) {=0A= var next =3D this.nextElementSibling(node);=0A= if (next) results.push(next);=0A= }=0A= return results;=0A= },=0A= =0A= laterSibling: function(nodes) {=0A= var h =3D Selector.handlers;=0A= for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++)=0A= h.concat(results, Element.nextSiblings(node));=0A= return results;=0A= },=0A= =0A= nextElementSibling: function(node) {=0A= while (node =3D node.nextSibling)=0A= if (node.nodeType =3D=3D 1) return node;=0A= return null;=0A= },=0A= =0A= previousElementSibling: function(node) {=0A= while (node =3D node.previousSibling)=0A= if (node.nodeType =3D=3D 1) return node;=0A= return null;=0A= },=0A= =0A= // TOKEN FUNCTIONS=0A= tagName: function(nodes, root, tagName, combinator) {=0A= tagName =3D tagName.toUpperCase();=0A= var results =3D [], h =3D Selector.handlers;=0A= if (nodes) {=0A= if (combinator) {=0A= // fastlane for ordinary descendant combinators=0A= if (combinator =3D=3D "descendant") {=0A= for (var i =3D 0, node; node =3D nodes[i]; i++)=0A= h.concat(results, node.getElementsByTagName(tagName));=0A= return results;=0A= } else nodes =3D this[combinator](nodes);=0A= if (tagName =3D=3D "*") return nodes;=0A= }=0A= for (var i =3D 0, node; node =3D nodes[i]; i++)=0A= if (node.tagName.toUpperCase() =3D=3D tagName) = results.push(node);=0A= return results;=0A= } else return root.getElementsByTagName(tagName);=0A= },=0A= =0A= id: function(nodes, root, id, combinator) {=0A= var targetNode =3D $(id), h =3D Selector.handlers;=0A= if (!targetNode) return [];=0A= if (!nodes && root =3D=3D document) return [targetNode];=0A= if (nodes) {=0A= if (combinator) {=0A= if (combinator =3D=3D 'child') {=0A= for (var i =3D 0, node; node =3D nodes[i]; i++)=0A= if (targetNode.parentNode =3D=3D node) return [targetNode];=0A= } else if (combinator =3D=3D 'descendant') {=0A= for (var i =3D 0, node; node =3D nodes[i]; i++)=0A= if (Element.descendantOf(targetNode, node)) return = [targetNode];=0A= } else if (combinator =3D=3D 'adjacent') {=0A= for (var i =3D 0, node; node =3D nodes[i]; i++)=0A= if (Selector.handlers.previousElementSibling(targetNode) = =3D=3D node)=0A= return [targetNode];=0A= } else nodes =3D h[combinator](nodes);=0A= }=0A= for (var i =3D 0, node; node =3D nodes[i]; i++)=0A= if (node =3D=3D targetNode) return [targetNode];=0A= return [];=0A= }=0A= return (targetNode && Element.descendantOf(targetNode, root)) ? = [targetNode] : [];=0A= },=0A= =0A= className: function(nodes, root, className, combinator) {=0A= if (nodes && combinator) nodes =3D this[combinator](nodes);=0A= return Selector.handlers.byClassName(nodes, root, className);=0A= },=0A= =0A= byClassName: function(nodes, root, className) {=0A= if (!nodes) nodes =3D Selector.handlers.descendant([root]);=0A= var needle =3D ' ' + className + ' ';=0A= for (var i =3D 0, results =3D [], node, nodeClassName; node =3D = nodes[i]; i++) {=0A= nodeClassName =3D node.className;=0A= if (nodeClassName.length =3D=3D 0) continue;=0A= if (nodeClassName =3D=3D className || (' ' + nodeClassName + ' = ').include(needle))=0A= results.push(node);=0A= }=0A= return results;=0A= },=0A= =0A= attrPresence: function(nodes, root, attr) {=0A= if (!nodes) nodes =3D root.getElementsByTagName("*");=0A= var results =3D [];=0A= for (var i =3D 0, node; node =3D nodes[i]; i++)=0A= if (Element.hasAttribute(node, attr)) results.push(node);=0A= return results;=0A= },=0A= =0A= attr: function(nodes, root, attr, value, operator) {=0A= if (!nodes) nodes =3D root.getElementsByTagName("*");=0A= var handler =3D Selector.operators[operator], results =3D [];=0A= for (var i =3D 0, node; node =3D nodes[i]; i++) {=0A= var nodeValue =3D Element.readAttribute(node, attr);=0A= if (nodeValue =3D=3D=3D null) continue;=0A= if (handler(nodeValue, value)) results.push(node);=0A= }=0A= return results;=0A= },=0A= =0A= pseudo: function(nodes, name, value, root, combinator) {=0A= if (nodes && combinator) nodes =3D this[combinator](nodes);=0A= if (!nodes) nodes =3D root.getElementsByTagName("*");=0A= return Selector.pseudos[name](nodes, value, root);=0A= }=0A= },=0A= =0A= pseudos: {=0A= 'first-child': function(nodes, value, root) {=0A= for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++) {=0A= if (Selector.handlers.previousElementSibling(node)) continue;=0A= results.push(node);=0A= }=0A= return results;=0A= },=0A= 'last-child': function(nodes, value, root) {=0A= for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++) {=0A= if (Selector.handlers.nextElementSibling(node)) continue;=0A= results.push(node);=0A= }=0A= return results;=0A= },=0A= 'only-child': function(nodes, value, root) {=0A= var h =3D Selector.handlers;=0A= for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++)=0A= if (!h.previousElementSibling(node) && = !h.nextElementSibling(node))=0A= results.push(node);=0A= return results;=0A= },=0A= 'nth-child': function(nodes, formula, root) {=0A= return Selector.pseudos.nth(nodes, formula, root);=0A= },=0A= 'nth-last-child': function(nodes, formula, root) {=0A= return Selector.pseudos.nth(nodes, formula, root, true);=0A= },=0A= 'nth-of-type': function(nodes, formula, root) {=0A= return Selector.pseudos.nth(nodes, formula, root, false, true);=0A= },=0A= 'nth-last-of-type': function(nodes, formula, root) {=0A= return Selector.pseudos.nth(nodes, formula, root, true, true);=0A= },=0A= 'first-of-type': function(nodes, formula, root) {=0A= return Selector.pseudos.nth(nodes, "1", root, false, true);=0A= },=0A= 'last-of-type': function(nodes, formula, root) {=0A= return Selector.pseudos.nth(nodes, "1", root, true, true);=0A= },=0A= 'only-of-type': function(nodes, formula, root) {=0A= var p =3D Selector.pseudos;=0A= return p['last-of-type'](p['first-of-type'](nodes, formula, root), = formula, root);=0A= },=0A= =0A= // handles the an+b logic=0A= getIndices: function(a, b, total) {=0A= if (a =3D=3D 0) return b > 0 ? [b] : [];=0A= return $R(1, total).inject([], function(memo, i) {=0A= if (0 =3D=3D (i - b) % a && (i - b) / a >=3D 0) memo.push(i);=0A= return memo;=0A= });=0A= },=0A= =0A= // handles nth(-last)-child, nth(-last)-of-type, and = (first|last)-of-type=0A= nth: function(nodes, formula, root, reverse, ofType) {=0A= if (nodes.length =3D=3D 0) return [];=0A= if (formula =3D=3D 'even') formula =3D '2n+0';=0A= if (formula =3D=3D 'odd') formula =3D '2n+1';=0A= var h =3D Selector.handlers, results =3D [], indexed =3D [], m;=0A= h.mark(nodes);=0A= for (var i =3D 0, node; node =3D nodes[i]; i++) {=0A= if (!node.parentNode._counted) {=0A= h.index(node.parentNode, reverse, ofType);=0A= indexed.push(node.parentNode);=0A= }=0A= }=0A= if (formula.match(/^\d+$/)) { // just a number=0A= formula =3D Number(formula);=0A= for (var i =3D 0, node; node =3D nodes[i]; i++)=0A= if (node.nodeIndex =3D=3D formula) results.push(node);=0A= } else if (m =3D formula.match(/^(-?\d*)?n(([+-])(\d+))?/)) { // = an+b=0A= if (m[1] =3D=3D "-") m[1] =3D -1;=0A= var a =3D m[1] ? Number(m[1]) : 1;=0A= var b =3D m[2] ? Number(m[2]) : 0;=0A= var indices =3D Selector.pseudos.getIndices(a, b, nodes.length);=0A= for (var i =3D 0, node, l =3D indices.length; node =3D nodes[i]; = i++) {=0A= for (var j =3D 0; j < l; j++)=0A= if (node.nodeIndex =3D=3D indices[j]) results.push(node);=0A= }=0A= }=0A= h.unmark(nodes);=0A= h.unmark(indexed);=0A= return results;=0A= },=0A= =0A= 'empty': function(nodes, value, root) {=0A= for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++) {=0A= // IE treats comments as element nodes=0A= if (node.tagName =3D=3D '!' || (node.firstChild && = !node.innerHTML.match(/^\s*$/))) continue;=0A= results.push(node);=0A= }=0A= return results;=0A= },=0A= =0A= 'not': function(nodes, selector, root) {=0A= var h =3D Selector.handlers, selectorType, m;=0A= var exclusions =3D new Selector(selector).findElements(root);=0A= h.mark(exclusions);=0A= for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++)=0A= if (!node._counted) results.push(node);=0A= h.unmark(exclusions);=0A= return results;=0A= },=0A= =0A= 'enabled': function(nodes, value, root) {=0A= for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++)=0A= if (!node.disabled) results.push(node);=0A= return results;=0A= },=0A= =0A= 'disabled': function(nodes, value, root) {=0A= for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++)=0A= if (node.disabled) results.push(node);=0A= return results;=0A= },=0A= =0A= 'checked': function(nodes, value, root) {=0A= for (var i =3D 0, results =3D [], node; node =3D nodes[i]; i++)=0A= if (node.checked) results.push(node);=0A= return results;=0A= }=0A= },=0A= =0A= operators: {=0A= '=3D': function(nv, v) { return nv =3D=3D v; },=0A= '!=3D': function(nv, v) { return nv !=3D v; },=0A= '^=3D': function(nv, v) { return nv.startsWith(v); },=0A= '$=3D': function(nv, v) { return nv.endsWith(v); },=0A= '*=3D': function(nv, v) { return nv.include(v); },=0A= '~=3D': function(nv, v) { return (' ' + nv + ' ').include(' ' + v + = ' '); },=0A= '|=3D': function(nv, v) { return ('-' + nv.toUpperCase() + = '-').include('-' + v.toUpperCase() + '-'); }=0A= },=0A= =0A= matchElements: function(elements, expression) {=0A= var matches =3D new Selector(expression).findElements(), h =3D = Selector.handlers;=0A= h.mark(matches);=0A= for (var i =3D 0, results =3D [], element; element =3D elements[i]; = i++)=0A= if (element._counted) results.push(element);=0A= h.unmark(matches);=0A= return results;=0A= },=0A= =0A= findElement: function(elements, expression, index) {=0A= if (Object.isNumber(expression)) {=0A= index =3D expression; expression =3D false;=0A= }=0A= return Selector.matchElements(elements, expression || '*')[index || = 0];=0A= },=0A= =0A= findChildElements: function(element, expressions) {=0A= var exprs =3D expressions.join(','), expressions =3D [];=0A= exprs.scan(/(([\w#:.~>+()\s-]+|\*|\[.*?\])+)\s*(,|$)/, function(m) {=0A= expressions.push(m[1].strip());=0A= });=0A= var results =3D [], h =3D Selector.handlers;=0A= for (var i =3D 0, l =3D expressions.length, selector; i < l; i++) {=0A= selector =3D new Selector(expressions[i].strip());=0A= h.concat(results, selector.findElements(element));=0A= }=0A= return (l > 1) ? h.unique(results) : results;=0A= }=0A= });=0A= =0A= function $$() {=0A= return Selector.findChildElements(document, $A(arguments));=0A= }=0A= var Form =3D {=0A= reset: function(form) {=0A= $(form).reset();=0A= return form;=0A= },=0A= =0A= serializeElements: function(elements, options) {=0A= if (typeof options !=3D 'object') options =3D { hash: !!options };=0A= else if (options.hash =3D=3D=3D undefined) options.hash =3D true;=0A= var key, value, submitted =3D false, submit =3D options.submit;=0A= =0A= var data =3D elements.inject({ }, function(result, element) {=0A= if (!element.disabled && element.name) {=0A= key =3D element.name; value =3D $(element).getValue();=0A= if (value !=3D null && (element.type !=3D 'submit' || = (!submitted &&=0A= submit !=3D=3D false && (!submit || key =3D=3D submit) && = (submitted =3D true)))) {=0A= if (key in result) {=0A= // a key is already present; construct an array of values=0A= if (!Object.isArray(result[key])) result[key] =3D = [result[key]];=0A= result[key].push(value);=0A= }=0A= else result[key] =3D value;=0A= }=0A= }=0A= return result;=0A= });=0A= =0A= return options.hash ? data : Object.toQueryString(data);=0A= }=0A= };=0A= =0A= Form.Methods =3D {=0A= serialize: function(form, options) {=0A= return Form.serializeElements(Form.getElements(form), options);=0A= },=0A= =0A= getElements: function(form) {=0A= return $A($(form).getElementsByTagName('*')).inject([],=0A= function(elements, child) {=0A= if (Form.Element.Serializers[child.tagName.toLowerCase()])=0A= elements.push(Element.extend(child));=0A= return elements;=0A= }=0A= );=0A= },=0A= =0A= getInputs: function(form, typeName, name) {=0A= form =3D $(form);=0A= var inputs =3D form.getElementsByTagName('input');=0A= =0A= if (!typeName && !name) return $A(inputs).map(Element.extend);=0A= =0A= for (var i =3D 0, matchingInputs =3D [], length =3D inputs.length; i = < length; i++) {=0A= var input =3D inputs[i];=0A= if ((typeName && input.type !=3D typeName) || (name && input.name = !=3D name))=0A= continue;=0A= matchingInputs.push(Element.extend(input));=0A= }=0A= =0A= return matchingInputs;=0A= },=0A= =0A= disable: function(form) {=0A= form =3D $(form);=0A= Form.getElements(form).invoke('disable');=0A= return form;=0A= },=0A= =0A= enable: function(form) {=0A= form =3D $(form);=0A= Form.getElements(form).invoke('enable');=0A= return form;=0A= },=0A= =0A= findFirstElement: function(form) {=0A= var elements =3D $(form).getElements().findAll(function(element) {=0A= return 'hidden' !=3D element.type && !element.disabled;=0A= });=0A= var firstByIndex =3D elements.findAll(function(element) {=0A= return element.hasAttribute('tabIndex') && element.tabIndex >=3D 0;=0A= }).sortBy(function(element) { return element.tabIndex }).first();=0A= =0A= return firstByIndex ? firstByIndex : elements.find(function(element) = {=0A= return ['input', 'select', = 'textarea'].include(element.tagName.toLowerCase());=0A= });=0A= },=0A= =0A= focusFirstElement: function(form) {=0A= form =3D $(form);=0A= form.findFirstElement().activate();=0A= return form;=0A= },=0A= =0A= request: function(form, options) {=0A= form =3D $(form), options =3D Object.clone(options || { });=0A= =0A= var params =3D options.parameters, action =3D = form.readAttribute('action') || '';=0A= if (action.blank()) action =3D window.location.href;=0A= options.parameters =3D form.serialize(true);=0A= =0A= if (params) {=0A= if (Object.isString(params)) params =3D params.toQueryParams();=0A= Object.extend(options.parameters, params);=0A= }=0A= =0A= if (form.hasAttribute('method') && !options.method)=0A= options.method =3D form.method;=0A= =0A= return new Ajax.Request(action, options);=0A= }=0A= };=0A= =0A= /*-----------------------------------------------------------------------= ---*/=0A= =0A= Form.Element =3D {=0A= focus: function(element) {=0A= $(element).focus();=0A= return element;=0A= },=0A= =0A= select: function(element) {=0A= $(element).select();=0A= return element;=0A= }=0A= };=0A= =0A= Form.Element.Methods =3D {=0A= serialize: function(element) {=0A= element =3D $(element);=0A= if (!element.disabled && element.name) {=0A= var value =3D element.getValue();=0A= if (value !=3D undefined) {=0A= var pair =3D { };=0A= pair[element.name] =3D value;=0A= return Object.toQueryString(pair);=0A= }=0A= }=0A= return '';=0A= },=0A= =0A= getValue: function(element) {=0A= element =3D $(element);=0A= var method =3D element.tagName.toLowerCase();=0A= return Form.Element.Serializers[method](element);=0A= },=0A= =0A= setValue: function(element, value) {=0A= element =3D $(element);=0A= var method =3D element.tagName.toLowerCase();=0A= Form.Element.Serializers[method](element, value);=0A= return element;=0A= },=0A= =0A= clear: function(element) {=0A= $(element).value =3D '';=0A= return element;=0A= },=0A= =0A= present: function(element) {=0A= return $(element).value !=3D '';=0A= },=0A= =0A= activate: function(element) {=0A= element =3D $(element);=0A= try {=0A= element.focus();=0A= if (element.select && (element.tagName.toLowerCase() !=3D 'input' = ||=0A= !['button', 'reset', 'submit'].include(element.type)))=0A= element.select();=0A= } catch (e) { }=0A= return element;=0A= },=0A= =0A= disable: function(element) {=0A= element =3D $(element);=0A= element.blur();=0A= element.disabled =3D true;=0A= return element;=0A= },=0A= =0A= enable: function(element) {=0A= element =3D $(element);=0A= element.disabled =3D false;=0A= return element;=0A= }=0A= };=0A= =0A= /*-----------------------------------------------------------------------= ---*/=0A= =0A= var Field =3D Form.Element;=0A= var $F =3D Form.Element.Methods.getValue;=0A= =0A= /*-----------------------------------------------------------------------= ---*/=0A= =0A= Form.Element.Serializers =3D {=0A= input: function(element, value) {=0A= switch (element.type.toLowerCase()) {=0A= case 'checkbox':=0A= case 'radio':=0A= return Form.Element.Serializers.inputSelector(element, value);=0A= default:=0A= return Form.Element.Serializers.textarea(element, value);=0A= }=0A= },=0A= =0A= inputSelector: function(element, value) {=0A= if (value =3D=3D=3D undefined) return element.checked ? = element.value : null;=0A= else element.checked =3D !!value;=0A= },=0A= =0A= textarea: function(element, value) {=0A= if (value =3D=3D=3D undefined) return element.value;=0A= else element.value =3D value;=0A= },=0A= =0A= select: function(element, index) {=0A= if (index =3D=3D=3D undefined)=0A= return this[element.type =3D=3D 'select-one' ?=0A= 'selectOne' : 'selectMany'](element);=0A= else {=0A= var opt, value, single =3D !Object.isArray(index);=0A= for (var i =3D 0, length =3D element.length; i < length; i++) {=0A= opt =3D element.options[i];=0A= value =3D this.optionValue(opt);=0A= if (single) {=0A= if (value =3D=3D index) {=0A= opt.selected =3D true;=0A= return;=0A= }=0A= }=0A= else opt.selected =3D index.include(value);=0A= }=0A= }=0A= },=0A= =0A= selectOne: function(element) {=0A= var index =3D element.selectedIndex;=0A= return index >=3D 0 ? this.optionValue(element.options[index]) : = null;=0A= },=0A= =0A= selectMany: function(element) {=0A= var values, length =3D element.length;=0A= if (!length) return null;=0A= =0A= for (var i =3D 0, values =3D []; i < length; i++) {=0A= var opt =3D element.options[i];=0A= if (opt.selected) values.push(this.optionValue(opt));=0A= }=0A= return values;=0A= },=0A= =0A= optionValue: function(opt) {=0A= // extend element because hasAttribute may not be native=0A= return Element.extend(opt).hasAttribute('value') ? opt.value : = opt.text;=0A= }=0A= };=0A= =0A= /*-----------------------------------------------------------------------= ---*/=0A= =0A= Abstract.TimedObserver =3D Class.create(PeriodicalExecuter, {=0A= initialize: function($super, element, frequency, callback) {=0A= $super(callback, frequency);=0A= this.element =3D $(element);=0A= this.lastValue =3D this.getValue();=0A= },=0A= =0A= execute: function() {=0A= var value =3D this.getValue();=0A= if (Object.isString(this.lastValue) && Object.isString(value) ?=0A= this.lastValue !=3D value : String(this.lastValue) !=3D = String(value)) {=0A= this.callback(this.element, value);=0A= this.lastValue =3D value;=0A= }=0A= }=0A= });=0A= =0A= Form.Element.Observer =3D Class.create(Abstract.TimedObserver, {=0A= getValue: function() {=0A= return Form.Element.getValue(this.element);=0A= }=0A= });=0A= =0A= Form.Observer =3D Class.create(Abstract.TimedObserver, {=0A= getValue: function() {=0A= return Form.serialize(this.element);=0A= }=0A= });=0A= =0A= /*-----------------------------------------------------------------------= ---*/=0A= =0A= Abstract.EventObserver =3D Class.create({=0A= initialize: function(element, callback) {=0A= this.element =3D $(element);=0A= this.callback =3D callback;=0A= =0A= this.lastValue =3D this.getValue();=0A= if (this.element.tagName.toLowerCase() =3D=3D 'form')=0A= this.registerFormCallbacks();=0A= else=0A= this.registerCallback(this.element);=0A= },=0A= =0A= onElementEvent: function() {=0A= var value =3D this.getValue();=0A= if (this.lastValue !=3D value) {=0A= this.callback(this.element, value);=0A= this.lastValue =3D value;=0A= }=0A= },=0A= =0A= registerFormCallbacks: function() {=0A= Form.getElements(this.element).each(this.registerCallback, this);=0A= },=0A= =0A= registerCallback: function(element) {=0A= if (element.type) {=0A= switch (element.type.toLowerCase()) {=0A= case 'checkbox':=0A= case 'radio':=0A= Event.observe(element, 'click', = this.onElementEvent.bind(this));=0A= break;=0A= default:=0A= Event.observe(element, 'change', = this.onElementEvent.bind(this));=0A= break;=0A= }=0A= }=0A= }=0A= });=0A= =0A= Form.Element.EventObserver =3D Class.create(Abstract.EventObserver, {=0A= getValue: function() {=0A= return Form.Element.getValue(this.element);=0A= }=0A= });=0A= =0A= Form.EventObserver =3D Class.create(Abstract.EventObserver, {=0A= getValue: function() {=0A= return Form.serialize(this.element);=0A= }=0A= });=0A= if (!window.Event) var Event =3D { };=0A= =0A= Object.extend(Event, {=0A= KEY_BACKSPACE: 8,=0A= KEY_TAB: 9,=0A= KEY_RETURN: 13,=0A= KEY_ESC: 27,=0A= KEY_LEFT: 37,=0A= KEY_UP: 38,=0A= KEY_RIGHT: 39,=0A= KEY_DOWN: 40,=0A= KEY_DELETE: 46,=0A= KEY_HOME: 36,=0A= KEY_END: 35,=0A= KEY_PAGEUP: 33,=0A= KEY_PAGEDOWN: 34,=0A= KEY_INSERT: 45,=0A= =0A= cache: { },=0A= =0A= relatedTarget: function(event) {=0A= var element;=0A= switch(event.type) {=0A= case 'mouseover': element =3D event.fromElement; break;=0A= case 'mouseout': element =3D event.toElement; break;=0A= default: return null;=0A= }=0A= return Element.extend(element);=0A= }=0A= });=0A= =0A= Event.Methods =3D (function() {=0A= var isButton;=0A= =0A= if (Prototype.Browser.IE) {=0A= var buttonMap =3D { 0: 1, 1: 4, 2: 2 };=0A= isButton =3D function(event, code) {=0A= return event.button =3D=3D buttonMap[code];=0A= };=0A= =0A= } else if (Prototype.Browser.WebKit) {=0A= isButton =3D function(event, code) {=0A= switch (code) {=0A= case 0: return event.which =3D=3D 1 && !event.metaKey;=0A= case 1: return event.which =3D=3D 1 && event.metaKey;=0A= default: return false;=0A= }=0A= };=0A= =0A= } else {=0A= isButton =3D function(event, code) {=0A= return event.which ? (event.which =3D=3D=3D code + 1) : = (event.button =3D=3D=3D code);=0A= };=0A= }=0A= =0A= return {=0A= isLeftClick: function(event) { return isButton(event, 0) },=0A= isMiddleClick: function(event) { return isButton(event, 1) },=0A= isRightClick: function(event) { return isButton(event, 2) },=0A= =0A= element: function(event) {=0A= var node =3D Event.extend(event).target;=0A= return Element.extend(node.nodeType =3D=3D Node.TEXT_NODE ? = node.parentNode : node);=0A= },=0A= =0A= findElement: function(event, expression) {=0A= var element =3D Event.element(event);=0A= return element.match(expression) ? element : = element.up(expression);=0A= },=0A= =0A= pointer: function(event) {=0A= return {=0A= x: event.pageX || (event.clientX +=0A= (document.documentElement.scrollLeft || = document.body.scrollLeft)),=0A= y: event.pageY || (event.clientY +=0A= (document.documentElement.scrollTop || = document.body.scrollTop))=0A= };=0A= },=0A= =0A= pointerX: function(event) { return Event.pointer(event).x },=0A= pointerY: function(event) { return Event.pointer(event).y },=0A= =0A= stop: function(event) {=0A= Event.extend(event);=0A= event.preventDefault();=0A= event.stopPropagation();=0A= event.stopped =3D true;=0A= }=0A= };=0A= })();=0A= =0A= Event.extend =3D (function() {=0A= var methods =3D Object.keys(Event.Methods).inject({ }, function(m, = name) {=0A= m[name] =3D Event.Methods[name].methodize();=0A= return m;=0A= });=0A= =0A= if (Prototype.Browser.IE) {=0A= Object.extend(methods, {=0A= stopPropagation: function() { this.cancelBubble =3D true },=0A= preventDefault: function() { this.returnValue =3D false },=0A= inspect: function() { return "[object Event]" }=0A= });=0A= =0A= return function(event) {=0A= if (!event) return false;=0A= if (event._extendedByPrototype) return event;=0A= =0A= event._extendedByPrototype =3D Prototype.emptyFunction;=0A= var pointer =3D Event.pointer(event);=0A= Object.extend(event, {=0A= target: event.srcElement,=0A= relatedTarget: Event.relatedTarget(event),=0A= pageX: pointer.x,=0A= pageY: pointer.y=0A= });=0A= return Object.extend(event, methods);=0A= };=0A= =0A= } else {=0A= Event.prototype =3D Event.prototype || = document.createEvent("HTMLEvents").__proto__;=0A= Object.extend(Event.prototype, methods);=0A= return Prototype.K;=0A= }=0A= })();=0A= =0A= Object.extend(Event, (function() {=0A= var cache =3D Event.cache;=0A= =0A= function getEventID(element) {=0A= if (element._eventID) return element._eventID;=0A= arguments.callee.id =3D arguments.callee.id || 1;=0A= return element._eventID =3D ++arguments.callee.id;=0A= }=0A= =0A= function getDOMEventName(eventName) {=0A= if (eventName && eventName.include(':')) return "dataavailable";=0A= return eventName;=0A= }=0A= =0A= function getCacheForID(id) {=0A= return cache[id] =3D cache[id] || { };=0A= }=0A= =0A= function getWrappersForEventName(id, eventName) {=0A= var c =3D getCacheForID(id);=0A= return c[eventName] =3D c[eventName] || [];=0A= }=0A= =0A= function createWrapper(element, eventName, handler) {=0A= var id =3D getEventID(element);=0A= var c =3D getWrappersForEventName(id, eventName);=0A= if (c.pluck("handler").include(handler)) return false;=0A= =0A= var wrapper =3D function(event) {=0A= if (!Event || !Event.extend ||=0A= (event.eventName && event.eventName !=3D eventName))=0A= return false;=0A= =0A= Event.extend(event);=0A= handler.call(element, event)=0A= };=0A= =0A= wrapper.handler =3D handler;=0A= c.push(wrapper);=0A= return wrapper;=0A= }=0A= =0A= function findWrapper(id, eventName, handler) {=0A= var c =3D getWrappersForEventName(id, eventName);=0A= return c.find(function(wrapper) { return wrapper.handler =3D=3D = handler });=0A= }=0A= =0A= function destroyWrapper(id, eventName, handler) {=0A= var c =3D getCacheForID(id);=0A= if (!c[eventName]) return false;=0A= c[eventName] =3D c[eventName].without(findWrapper(id, eventName, = handler));=0A= }=0A= =0A= function destroyCache() {=0A= for (var id in cache)=0A= for (var eventName in cache[id])=0A= cache[id][eventName] =3D null;=0A= }=0A= =0A= if (window.attachEvent) {=0A= window.attachEvent("onunload", destroyCache);=0A= }=0A= =0A= return {=0A= observe: function(element, eventName, handler) {=0A= element =3D $(element);=0A= var name =3D getDOMEventName(eventName);=0A= =0A= var wrapper =3D createWrapper(element, eventName, handler);=0A= if (!wrapper) return element;=0A= =0A= if (element.addEventListener) {=0A= element.addEventListener(name, wrapper, false);=0A= } else {=0A= element.attachEvent("on" + name, wrapper);=0A= }=0A= =0A= return element;=0A= },=0A= =0A= stopObserving: function(element, eventName, handler) {=0A= element =3D $(element);=0A= var id =3D getEventID(element), name =3D = getDOMEventName(eventName);=0A= =0A= if (!handler && eventName) {=0A= getWrappersForEventName(id, eventName).each(function(wrapper) {=0A= element.stopObserving(eventName, wrapper.handler);=0A= });=0A= return element;=0A= =0A= } else if (!eventName) {=0A= Object.keys(getCacheForID(id)).each(function(eventName) {=0A= element.stopObserving(eventName);=0A= });=0A= return element;=0A= }=0A= =0A= var wrapper =3D findWrapper(id, eventName, handler);=0A= if (!wrapper) return element;=0A= =0A= if (element.removeEventListener) {=0A= element.removeEventListener(name, wrapper, false);=0A= } else {=0A= element.detachEvent("on" + name, wrapper);=0A= }=0A= =0A= destroyWrapper(id, eventName, handler);=0A= =0A= return element;=0A= },=0A= =0A= fire: function(element, eventName, memo) {=0A= element =3D $(element);=0A= if (element =3D=3D document && document.createEvent && = !element.dispatchEvent)=0A= element =3D document.documentElement;=0A= =0A= if (document.createEvent) {=0A= var event =3D document.createEvent("HTMLEvents");=0A= event.initEvent("dataavailable", true, true);=0A= } else {=0A= var event =3D document.createEventObject();=0A= event.eventType =3D "ondataavailable";=0A= }=0A= =0A= event.eventName =3D eventName;=0A= event.memo =3D memo || { };=0A= =0A= if (document.createEvent) {=0A= element.dispatchEvent(event);=0A= } else {=0A= element.fireEvent(event.eventType, event);=0A= }=0A= =0A= return event;=0A= }=0A= };=0A= })());=0A= =0A= Object.extend(Event, Event.Methods);=0A= =0A= Element.addMethods({=0A= fire: Event.fire,=0A= observe: Event.observe,=0A= stopObserving: Event.stopObserving=0A= });=0A= =0A= Object.extend(document, {=0A= fire: Element.Methods.fire.methodize(),=0A= observe: Element.Methods.observe.methodize(),=0A= stopObserving: Element.Methods.stopObserving.methodize()=0A= });=0A= =0A= (function() {=0A= /* Support for the DOMContentLoaded event is based on work by Dan Webb,=0A= Matthias Miller, Dean Edwards and John Resig. */=0A= =0A= var timer, fired =3D false;=0A= =0A= function fireContentLoadedEvent() {=0A= if (fired) return;=0A= if (timer) window.clearInterval(timer);=0A= document.fire("dom:loaded");=0A= fired =3D true;=0A= }=0A= =0A= if (document.addEventListener) {=0A= if (Prototype.Browser.WebKit) {=0A= timer =3D window.setInterval(function() {=0A= if (/loaded|complete/.test(document.readyState))=0A= fireContentLoadedEvent();=0A= }, 0);=0A= =0A= Event.observe(window, "load", fireContentLoadedEvent);=0A= =0A= } else {=0A= document.addEventListener("DOMContentLoaded",=0A= fireContentLoadedEvent, false);=0A= }=0A= =0A= } else {=0A= document.write("