if(typeof(PEARLTREES) == "undefined" || typeof(PEARLTREES.getVersion) == "undefined") {

/**
 * PEARLTREES Global Object 
 * It provides a single global namespace within which 
 * all Pearltrees Library code resides.
 * version: 1.0.9
 */
if(typeof(PEARLTREES) == "undefined") PEARLTREES = {};
PEARLTREES.getVersion = function() { return '1.0.9'; };

/**
 * PEARLTREES.config
 * Common constants.
 */
PEARLTREES.config = {
   DOMAIN : 'http://www.pearltrees.com/',
   SERVICE_URL : 'http://www.pearltrees.com/s/embed/',
   SOURCE_URL : 'http://www.pearltrees.com/embed/',
   STATIC_URL : 'http://cdn.pearltrees.com/embed/',
   TRACE_DEBUG : false,
   ENABLE_EMBED_WINDOW : false
}


/**
* PEARLTREES.embedWindow
* Related to the window displayed next to the embed
* The window object is shared with the overlay.
*/ 
PEARLTREES.embedWindow = {
   
   IFRAME_ID : 'pt-pearltreesWindowIframe',
   EMBED_MARGIN : 24,
   WINDOW_WIDTH : 376,
   WINDOW_HEIGHT : 319,
   WINDOW_MODE_PEARL : 1,
   WINDOW_MODE_TREE : 2,
   WINDOW_INIT_TIMEOUT : 10000,
   COMMAND_POLL: 200,
   HIDE_DELAY : 2500,
   CLOSE_WINDOW_AND_OPEN_OVERLAY: 'cwoo',
   WINDOW_INITIALIZED: 'wi',
   OPEN_EFFECT_SPEED: 400,
   CLOSE_EFFECT_SPEED: 400,
   
   KEEP_SIZE_ON_ZOOM:false,
   
   _window:null,
   _iframe:null,
   _closeButton:null,
   _dragButton:null,
   _embedShowingWindow:null,
   _isOverWindow:false,
   _isOverEmbed:false,
   _closeWindowTimeoutId:null,
   _dragZonesForPearl:null,
   _dragZonesForTree:null,
   _fullDragZone:null,
   _lastUrlIFrameUpdate:null,
   _hasAlreadyOpenedWindow:null,
   _crossDomainIframe:null, // used by IE
   _openWindowEffectTarget:null,
   _isOpenEffectPlaying:false,
   _lastWindowPosition:null, // {top, left}
   _skipOpenEffectAndBackupLastPosition:false,
   _isWindowInitialized:false,
   _isWindowLoading:false,
   _showRequestPending:null, // {url, compId, localX, localY, isPearl, compInnerWidth}
   _openOverlayOnOpenEffectEnd:false,
   _windowPercentWidth:0,
   _windowPercentHeight:0,
   _zoomFactor:1,
   
   init : function(lang) {
      if(this._window) return;
      
      var $j = PEARLTREES.libs.jQuery;
   
      var embedWindow = PEARLTREES.embedWindow;
      this._window = $j('<div id="pt-window"></div>');
      // Detect rollOver and rollOut to hide the window on mouse out
      this._window.hover(this.onRollOverWindow, this.onRollOutWindow);
      
      // Add CC3 shadow to the window
      this._window.addClass('pt-shadow');
      
      // Preload pearltrees in the window
      var iframePreloadUrl = PEARLTREES.config.DOMAIN+'#/embedWindow=1';
      if(lang) {
         iframePreloadUrl = iframePreloadUrl + "&lang=" + lang;
      }
      this._iframe = $j('<iframe id="'+embedWindow.IFRAME_ID+'" name="'+embedWindow.IFRAME_ID+'" src="'+iframePreloadUrl+'" style="border:none;position:absolute;width:100%;height:100%;left:0px;top:0px;" frameborder="0" vspace="0" hspace="0" marginwidth="0" marginheight="0"></iframe>');      
      
      // Prepare the open effect
      this._openWindowEffectTarget = $j('<div id="pt-window-openEffect"></div>');
      this._openWindowEffectTarget.hide();
      $j('body').append(this._openWindowEffectTarget);
      
      // The window is preloaded at the top-left of the screen (avoid page scroll)
      var scrollTop = document.documentElement.scrollTop;
      if(!scrollTop) { scrollTop = document.body.scrollTop; }
      var scrollLeft = document.documentElement.scrollLeft;
      if(!scrollLeft) { scrollLeft = document.body.scrollLeft; }      
      this._window.css({left:scrollLeft});
      this._window.css({top:scrollTop});      
      
      // Create close button
      this._closeButton = $j('<div id="pt-window-closeButton" style="background-image: url('+PEARLTREES.utils.getEmbedAssetUrl("window/close.png")+')"></div>');
      this._closeButton.hover(this.onRollOverCloseButton, this.onRollOutCloseButton); 
      this._closeButton.click(function(){ PEARLTREES.embedWindow.hide(true); });
      // Create drag button
      this._dragButton = $j('<div id="pt-window-dragButton" style="background-image: url('+PEARLTREES.utils.getEmbedAssetUrl("window/dragHand.png")+')"></div>');
      this._dragButton.hover(this.onRollOverDragButton, this.onRollOutDragButton);
      // Create HTML zones over the iframe where the window is draggable
      this._dragZonesForPearl = new Array(this.createDragZone(0,0,'100%','10%'),
                                          this.createDragZone('35%','91%','65%','9%'));

      this._dragZonesForTree = new Array(this.createDragZone(0,0,'100%','15%'),
                                         this.createDragZone('35%','86%','65%','14%'),
                                         this.createDragZone(0,0,'21%','86%'),
                                         this.createDragZone('82%',0,'17%','100%'));
      // Append elements to the window
      this._window.append(this._iframe);
      for(i=0; i < this._dragZonesForPearl.length; i++) {
         this._window.append(this._dragZonesForPearl[i]);
      }
      for(i=0; i < this._dragZonesForTree.length; i++) {
         this._window.append(this._dragZonesForTree[i]);
      }
      // Create an HTML zone that cover all the window when the drag start
      this._fullDragZone = this.createDragZone(0,0,'100%','100%');
      this._fullDragZone.hide();
      this._window.append(this._fullDragZone);     
      this._window.append(this._closeButton);
      this._window.append(this._dragButton);
      
      // Make the window draggable thanks to jQuery
      this.makeWindowDraggable();     
      // The window is hidden by default
      this.hide(false, null, true);
      
      // Everything is created when the window is added to the body of the document
      $j('body').append(this._window);
      
      this._isWindowLoading = true;
      setTimeout("PEARLTREES.embedWindow.onWindowInitialized()", this.WINDOW_INIT_TIMEOUT);
   }, 
   
   onWindowInitialized : function () {
      if(!this._isWindowInitialized) {
         this._isWindowInitialized = true;
         if(this._showRequestPending) {
            if(this._isOverWindow || this._isOverEmbed) {              
               this.showFromComp(this._showRequestPending.url,
                                 this._showRequestPending.compId,
                                 this._showRequestPending.localX,
                                 this._showRequestPending.localY,
                                 this._showRequestPending.isPearl,
                                 this._showRequestPending.compInnerWidth,
                                 this._showRequestPending.lang);
            }else{
               this.hide(false);
            }
         }
      }
      this._isWindowLoading = false;
      this._showRequestPending = null;
   },
   
   // Called by embeds
   showFromComp : function(url, compId, localX, localY, isPearl, compInnerWidth, lang) {
      if(!PEARLTREES.config.ENABLE_EMBED_WINDOW) {
         return true;
      }
      
      var embedWindow = PEARLTREES.embedWindow;
      var $j = PEARLTREES.libs.jQuery;
      if(!embedWindow._window) {
         embedWindow.init(lang);
      }
      
      if(PEARLTREES.overlay.isOverlayOpened()) {
         return false;
      }
      
      // Add params to the URL sent by the embed
      if(PEARLTREES.utils.isPearltreesUrl(url)) {
         if(url.indexOf("embedWindow") == -1) {
            url = url + "&embedWindow=1"
         }
         if(url.indexOf("embedWindow-parent") == -1) {
            url = url + "&embedWindow-parent=" + encodeURIComponent(window.location.href);
         }
         if(url.indexOf("N-play") == -1) {
            url = url + "&N-play=0";
         }
         if(url.indexOf("lang") == -1 && lang) {
            url = url + "&lang=" + lang;
         }
      }
      
      // Update iframe url
      embedWindow.updateIFrameURL(url);
      
      var embedType = PEARLTREES.embed.getEmbedType(compId);
      var isSuperEmbed = (embedType == PEARLTREES.embed.SUPER_EMBED);
      var isPearlEmbed = (embedType == PEARLTREES.embed.PEARL_EMBED);
      
      // Link the window to its embed
      var comp = PEARLTREES.embed.getHtmlCompFromId(compId);
      if(comp) {
         $j(comp).hover(this.onRollOverEmbed, this.onRollOutEmbed);
      }
      var embedChanged = false;
      if(this._embedShowingWindow != comp) {
         // Notify the embed that his window is now closed
         if(this._embedShowingWindow && this._embedShowingWindow.setWindowOpened) {
            try {
               this._embedShowingWindow.setWindowOpened(false);
            }catch(e) {
               PEARLTREES.utils.log("Error calling flash from JS");
            }
         }
         // Make sure the embed is no more freezed
         this.setEmbedSelectionFreezed(false);
         this._embedShowingWindow = comp;
         embedChanged = true;
      }
      // Will check if the mouse is over the embed
      $j(document).one('mousemove', this.onMouseMove);
      // We refresh the window size
      PEARLTREES.embed.refreshCachedPosition(compId); 
      if(compInnerWidth && comp) {
         this._zoomFactor = comp.ptCompWidth / compInnerWidth;
      }
      this.refreshWindowPercentSize();
      
      var windowMode = (isPearl)?this.WINDOW_MODE_PEARL:this.WINDOW_MODE_TREE;
      
      // If the window is not yet initialized, we will open it later
      if(!this._isWindowInitialized) {
         var iframePreloadUrl = PEARLTREES.config.DOMAIN+'#/embedWindow=1';
         iframePreloadUrl += '&embedWindow-notifyInit=1';
         iframePreloadUrl += '&embedWindow-parent='+encodeURIComponent(window.location.href);
         this.updateIFrameURL(iframePreloadUrl);
         this.listenForCommand();
         this._showRequestPending = {url:url, compId:compId, localX:localX, localY:localY, isPearl:isPearl, compInnerWidth:compInnerWidth, lang:lang};
      }
      // We may want to skip the open effect
      else if(this._skipOpenEffectAndBackupLastPosition && comp) {
         this._skipOpenEffectAndBackupLastPosition = false;
         if(!this._lastWindowPosition) {
            this._lastWindowPosition = this.getDefaultPosition(comp);
         }
         this._window.css({top:this._lastWindowPosition.top, left:this._lastWindowPosition.left});
         this.show(windowMode);
      }
      // If the window was hidden, we show it at its default position with an effect
      else if((!this.isWindowOpened() || embedChanged) && !this._isOpenEffectPlaying && comp) {              
         if(!localX) localX = Math.round(comp.ptCompWidth / 2);
         if(!localY) localY = Math.round(comp.ptCompHeight / 2);        
         var effectStartX = Math.round(comp.ptCompX + (localX * this._zoomFactor));
         var effectStartY = Math.round(comp.ptCompY + (localY * this._zoomFactor));         
         
         var defaultPosition = this.getDefaultPosition(comp);
         var windowY = defaultPosition.top;
         var windowX = defaultPosition.left;
         
         // Prepare and play the effect
         if(!this.isWindowOpened()) {
            this._isOpenEffectPlaying = true;
            this._openWindowEffectTarget.css({top:effectStartY, 
                                              left:effectStartX,
                                              height:0,
                                              width:0});
            this._openWindowEffectTarget.show();
            var targetWidth = this.getWindowWidth() - 2;
            var targetHeight = this.getWindowHeight() - 2;
            this._openWindowEffectTarget.animate({top:windowY, 
                                                  left:windowX, 
                                                  width:targetWidth, 
                                                  height:targetHeight}, 
                                                  this.OPEN_EFFECT_SPEED,
                                                  'linear',
                                                  embedWindow.onOpenWindowEffectEnd);         
   
            // When the animation end, we show the window at the right position
            setTimeout('PEARLTREES.embedWindow.show('+windowMode+','+windowY+','+windowX+')', this.OPEN_EFFECT_SPEED); 
         }
         // If the embed has changed while the window was open, we directly move the window without effect
         else if(embedChanged) {
            this._window.css({top:windowY, left:windowX});
            this.show(windowMode);
         }
      }
      // Else we only show it without any effect
      else if(!this._isOpenEffectPlaying) {
         this.show(windowMode);
      }
       
      // PEARLTREES.utils.log("url:"+url);      
      return true;      
   },   
   
   // @param comp Embed component
   // @return {top, left} position
   getDefaultPosition : function(comp) {
      var $j = PEARLTREES.libs.jQuery;
      
      var browserWindowHeight = $j(window).height();
      var browserWindowWidth = $j(window).width();         
      var windowWidth = this.getWindowWidth();
      var windowHeight = this.getWindowHeight();
      var windowLeft = comp.ptCompX;
      var windowRight = browserWindowWidth - (comp.ptCompX + comp.ptCompWidth);
      var widthNeededByWindow = windowWidth + this.EMBED_MARGIN * 2;
      
      var windowX = null;
      // Horizontally: we prefer to show the window on the right side
      if(windowRight > widthNeededByWindow || windowLeft < widthNeededByWindow) {
         if(windowRight > widthNeededByWindow) {
            windowX = comp.ptCompX + comp.ptCompWidth + this.EMBED_MARGIN;               
         }else{
            windowX = browserWindowWidth - (windowWidth + this.EMBED_MARGIN);
         }
      }else{
         if(windowLeft > widthNeededByWindow) {
            windowX = comp.ptCompX - (windowWidth + this.EMBED_MARGIN);
         }else{
            windowX = this.EMBED_MARGIN;
         }
      }   
      // Vertically: we center the window on embed height
      var windowY = comp.ptCompY + Math.round((comp.ptCompHeight - this.getWindowHeight()) / 2); 
      
      return {top:windowY, left:windowX};
   },
   
   onOpenWindowEffectEnd : function() {
      var embedWindow = PEARLTREES.embedWindow;
      embedWindow._openWindowEffectTarget.hide();
      embedWindow._isOpenEffectPlaying = false;
      if(embedWindow._openOverlayOnOpenEffectEnd) {
         embedWindow.hide();   
         PEARLTREES.overlay._forceNextOpenFromWindowPosition = true;      
         if(embedWindow._embedShowingWindow.setOverlayOpened) {
            embedWindow._embedShowingWindow.setOverlayOpened(true);
         }
      }
   },
   
   // Called each time the the user roll over/out the window or the embed
   refreshWindowVisibility : function() {
      if(this.isWindowOpened() && !this._isOverWindow && !this._isOverEmbed && !PEARLTREES.overlay.isOverlayOpened()) {
         clearTimeout(this._closeWindowTimeoutId);
         this._closeWindowTimeoutId = setTimeout("PEARLTREES.embedWindow.onTimeToHideWindowAfterRollOut()", this.HIDE_DELAY);
      }
      else if(this._closeWindowTimeoutId) {
         clearTimeout(this._closeWindowTimeoutId);
         this._closeWindowTimeoutId = null;
      }
   },
   
   // If the user does not roll over during the HIDE_DELAY, we hide the window.
   onTimeToHideWindowAfterRollOut : function() {
      if(this.isWindowOpened() && !this._isOverWindow && !this._isOverEmbed) {
         this.hide(true);
      }
   },
   
   // Only refresh percent values based on zoom factor, it does not show the window
   refreshWindowPercentSize : function () {
      var $j = PEARLTREES.libs.jQuery;
      
      if(!this.KEEP_SIZE_ON_ZOOM) return;
      if(!this._zoomFactor) this._zoomFactor = 1;
      var parentWidth = $j(document).width();
      this._windowPercentWidth = (this.WINDOW_WIDTH / parentWidth) * 100 * this._zoomFactor;
      var parentHeight = $j(window).height();
      this._windowPercentHeight = (this.WINDOW_HEIGHT / parentHeight) * 100 * this._zoomFactor;      
   },
   
   getWindowWidth : function () {
      var $j = PEARLTREES.libs.jQuery;
   
      if(this.isWindowOpened()) {
         return Math.round(this._window.width());
      }
      else if(this._windowPercentWidth > 0) {
         var parentWidth = $j(window).width();
         return Math.round(parentWidth * (this._windowPercentWidth / 100));
      }
      else {
         return this.WINDOW_WIDTH;
      }
   },
   
   getWindowHeight : function () {
      var $j = PEARLTREES.libs.jQuery;
      
      if(this.isWindowOpened()) {
         return Math.round(this._window.height());
      }
      else if(this._windowPercentHeight > 0) {
         var parentHeight = $j(window).height();
         return Math.round(parentHeight * (this._windowPercentHeight / 100));
      }      
      else {
         return this.WINDOW_HEIGHT;
      }   
   },   
   
   // Show the window in its default state (as a pearl window)
   show : function(windowMode, top, left) {
      if(!this._window) {
         this.init();
      }
      // Set size
      if(this._windowPercentWidth > 0 && this._windowPercentHeight > 0) {
         this._window.css({width:this._windowPercentWidth+"%", height:this._windowPercentHeight+"%"});
      }else{
         this._window.css({width:this.getWindowWidth(), height:this.getWindowHeight()});
      }
      
      // Set position if specified
      if(top) this._window.css({top:top});
      if(left) this._window.css({left:left});
      // Make it draggable
      this.makeWindowDraggable();
      // Add drop shadow
      this._window.addClass('pt-shadow');
      // Show HTML buttons
      this._closeButton.show();
      this._dragButton.show();
      
      // Restore drag zones based on the windowMode (pearl or tree)
      for(i=0; i < this._dragZonesForPearl.length; i++) {
         if(windowMode == this.WINDOW_MODE_PEARL) {
            this._dragZonesForPearl[i].show();
         }else {
            this._dragZonesForPearl[i].hide();
         }
      }
      for(j=0; j < this._dragZonesForTree.length; j++) {
         if(windowMode == this.WINDOW_MODE_PEARL) {
            this._dragZonesForTree[j].hide();
         }else {
            this._dragZonesForTree[j].show();
         }
      }
      
      // Listen to commands comming from the iframe
      this.listenForCommand();
      
      // In order to hide it after delay if the mouse is not over it
      this.refreshWindowVisibility();
   },
   
   // Hide the window by setting his size to 1px.
   hide : function(playEffect, targetCompId, keepPosition) {
      if(!this._window) return;
      // We ignore calls from embed not showing the window
      if(targetCompId) {
         var targetComp = PEARLTREES.embed.getHtmlCompFromId(targetCompId);
         if(this._embedShowingWindow && this._embedShowingWindow != targetComp) {
            return;
         }
      }
      
      // Save window position and hide
      if(this.isWindowOpened()) {
         this.saveWindowPosition();
      }
      var windowTop = this._window.offset().top;
      var windowLeft = this._window.offset().left;
      this._window.css({width:1, height:1});
      if(!keepPosition) {
         this._window.css({top:0, left:0});
      }

      // Remove its shadow
      this._window.removeClass('pt-shadow');
      // Hide also HTML buttons
      if(this._closeButton) {
         this._closeButton.hide();
      }  
      if(this._dragButton) {
         this._dragButton.hide();
      }
      // Notify the embed that his window is now closed
      if(this._embedShowingWindow && this._embedShowingWindow.setWindowOpened) {
         try {
            this._embedShowingWindow.setWindowOpened(false);
         }catch(e) {
            PEARLTREES.utils.log("Error calling flash from JS");
         }
      }
      // Make sure the embed is no more freezed
      this.setEmbedSelectionFreezed(false);      
      // Clean commands which might be in the URL
      this.removeAllCommand();
      // Reset overlay effect sync
      this._openOverlayOnOpenEffectEnd = false;
      
      if(playEffect) {
         var embed = this.getEmbedShowingWindow();
         
         if(embed && embed.getSelectedNodeLocalPoint) {
            var result = embed.getSelectedNodeLocalPoint();
            if(result.innerWidth) {
               this._zoomFactor = embed.ptCompWidth / result.innerWidth;
            }
                  
            var effectEndY = embed.ptCompY + (result.localY * this._zoomFactor);
            var effectEndX = embed.ptCompX + (result.localX * this._zoomFactor);
            
            this._openWindowEffectTarget.css({top:windowTop, 
                                              left:windowLeft,
                                              height:this.getWindowHeight()-2,
                                              width:this.getWindowWidth()-2});
            this._openWindowEffectTarget.show();
            this._openWindowEffectTarget.animate({top:effectEndY, 
                                                  left:effectEndX, 
                                                  width:0, 
                                                  height:0}, 
                                                  this.CLOSE_EFFECT_SPEED,
                                                  'linear');
            setTimeout('PEARLTREES.embedWindow.hideWindowEffect()', this.CLOSE_EFFECT_SPEED-20); 
         }      
      }
   },
   
   // Called by the embed
   closeEmbedWindow : function(playEffect, targetCompId, keepPosition) {
      if(!PEARLTREES.overlay.isOverlayOpened()) {
         PEARLTREES.embedWindow.hide(playEffect, targetCompId, keepPosition);
      }
   },
   
   hideWindowEffect: function() {
      PEARLTREES.embedWindow._openWindowEffectTarget.stop();
      PEARLTREES.embedWindow._openWindowEffectTarget.hide();
   },
     
   saveWindowPosition : function() {
      if(!this._window) return;
      this._lastWindowPosition = {top:this._window.offset().top,
                                  left:this._window.offset().left};       
   },   
   
   isWindowLoading : function () {
      return this._isWindowLoading;
   },
   
   isWindowOpened : function() {
      var windowWidth = parseInt(this._window.css('width'));
      return (this._window && windowWidth > 1 && !PEARLTREES.overlay.isOverlayOpened());
   },  

   getEmbedShowingWindow : function() {
      return this._embedShowingWindow;
   },    
   
   updateIFrameURL : function(url) {
      var $j = PEARLTREES.libs.jQuery;
      
      var iframeComp = this._iframe.get(0);
      if ($j.browser.safari && !this._lastUrlIFrameUpdate) {
         iframeComp.src = url;
      }
      else if ($j.browser.msie) {
         // @TODO check it does work with a quick window init
         if (this._hasAlreadyOpenedWindow) {
            if (this._crossDomainIframe) {
               document.body.removeChild(this._crossDomainIframe);
               this._crossDomainIframe = null;
            }
            this._crossDomainIframe = document.createElement("iframe");
            this._crossDomainIframe.style.display = "none";
            var i = url.indexOf('#');
            this._crossDomainIframe.src = PEARLTREES.config.SOURCE_URL + "cross.html?" + (i < 0 ? "" : url.substring(i + 1));
            document.body.appendChild(this._crossDomainIframe);
         } 
         else {
            iframeComp.src = url;
            this._hasAlreadyOpenedWindow = true;
         }
      }else{
         iframeComp.src = url;
      }
      this._lastUrlIFrameUpdate = url;      
   },
   
   listenForCommand : function() {
      var overlay = PEARLTREES.overlay;
      var embedWindow = PEARLTREES.embedWindow;
      if(!embedWindow.isWindowOpened() && !embedWindow._isWindowLoading) return;
      var isCloseCommandFired = false;
      
      if(overlay.isCommandFired(embedWindow.CLOSE_WINDOW_AND_OPEN_OVERLAY)) {
         isCloseCommandFired = true;
         
         embedWindow.hide();
         overlay._forceNextOpenFromWindowPosition = true;
         
         if(embedWindow._embedShowingWindow.setOverlayOpened) {
            try {
               embedWindow._embedShowingWindow.setOverlayOpened(true);
            }catch(e) {
               PEARLTREES.utils.log("Error calling flash from JS");
            }
         }
      }
      else if(overlay.isCommandFired(embedWindow.WINDOW_INITIALIZED)) {
         embedWindow.onWindowInitialized();
         embedWindow.removeAllCommand();
      }

      if(!isCloseCommandFired) {
         setTimeout('PEARLTREES.embedWindow.listenForCommand()', embedWindow.COMMAND_POLL);
      }      
   },
      
   removeAllCommand : function() {
      var overlay = PEARLTREES.overlay;
      var embedWindow = PEARLTREES.embedWindow;
      var currentUrl = window.location.href;
      var cleanUrl = currentUrl;
      cleanUrl = overlay.removeCommandFromUrl(embedWindow.CLOSE_WINDOW_AND_OPEN_OVERLAY, cleanUrl);
      cleanUrl = overlay.removeCommandFromUrl(embedWindow.WINDOW_INITIALIZED, cleanUrl);
      if(currentUrl != cleanUrl) {
         window.location.href = cleanUrl;
      }
   },     
   
   // Helper for drag zones
   createDragZone : function(x, y, width, height) {
      var $j = PEARLTREES.libs.jQuery;
      var dragZone = $j('<div class="pt-window-dragZone"></div>');
      dragZone.css('background-image', 'url('+PEARLTREES.utils.getEmbedAssetUrl("window/transparent.gif")+')');
      dragZone.css('width', width);
      dragZone.css('height', height);
      dragZone.css('top', y);
      dragZone.css('left', x);
      return dragZone;
   },
   
   onDragStart : function() {
      PEARLTREES.embedWindow._fullDragZone.show();
   },

   onDragStop : function() {
      PEARLTREES.embedWindow._fullDragZone.hide();
   },
      
   // Helper for drag zones
   hideDragZones : function() {
      //this._window.draggable("option", "disabled", true);
      this._window.trigger('mouseup');      
      this._window.draggable("destroy");      
      for(i=0; i < this._dragZonesForPearl.length; i++) {
         this._dragZonesForPearl[i].hide();
      }
      for(j=0; j < this._dragZonesForTree.length; j++) {
         this._dragZonesForTree[j].hide();
      }      
   },   
   
   makeWindowDraggable : function () {
      this._window.draggable({iframeFix:true, 
                              scroll:false, 
                              containment:'document',
                              start: this.onDragStart,
                              stop: this.onDragStop,
                              addClasses: false});   
   },
   
   onRollOverWindow : function() {
      PEARLTREES.embedWindow._isOverWindow = true;
      PEARLTREES.embedWindow.refreshWindowVisibility();
      PEARLTREES.embedWindow.setEmbedSelectionFreezed(true);
   },  
   onRollOutWindow : function() {
      PEARLTREES.embedWindow._isOverWindow = false;
      PEARLTREES.embedWindow.refreshWindowVisibility();
      PEARLTREES.embedWindow.setEmbedSelectionFreezed(false);
   },
   
   onRollOverEmbed : function() {
      if(this == PEARLTREES.embedWindow._embedShowingWindow) {
         PEARLTREES.embedWindow._isOverEmbed = true;
         PEARLTREES.embedWindow.refreshWindowVisibility();
      }
   },
   onRollOutEmbed : function() {
      if(this == PEARLTREES.embedWindow._embedShowingWindow) {
         PEARLTREES.embedWindow._isOverEmbed = false;
         PEARLTREES.embedWindow.refreshWindowVisibility();
      }
   },
   
   setEmbedSelectionFreezed : function(value) {
      if(this._embedShowingWindow && this._embedShowingWindow.setSelectionFreezed) {
         try {
            this._embedShowingWindow.setSelectionFreezed(value);
         }catch(e) {
            PEARLTREES.utils.log("Error calling flash from JS");
         }
      }
   },
   
   onMouseMove : function(event) {
      var $j = PEARLTREES.libs.jQuery;
      var embedWindow = PEARLTREES.embedWindow;
      var embed = $j(embedWindow._embedShowingWindow);
      var embedLeft = embed.offset().left;
      var embedRight = embedLeft + embed.width();
      var embedTop = embed.offset().top;
      var embedBottom = embedTop + embed.height();
      
      if(event.pageX > embedLeft && event.pageX < embedRight &&
         event.pageY > embedTop && event.pageY < embedBottom) {
         embedWindow._isOverEmbed = true;
      }else{
         embedWindow._isOverEmbed = false;
      }
   },
   
   onRollOverCloseButton : function() {
      var $j = PEARLTREES.libs.jQuery;
      $j(this).css('background-image', 'url('+PEARLTREES.utils.getEmbedAssetUrl("window/closeOver.png")+')');
   },
   onRollOutCloseButton : function() {
      var $j = PEARLTREES.libs.jQuery;
      $j(this).css('background-image', 'url('+PEARLTREES.utils.getEmbedAssetUrl("window/close.png")+')');
   },
   
   onRollOverDragButton : function() {
      var $j = PEARLTREES.libs.jQuery;
      $j(this).css('background-image', 'url('+PEARLTREES.utils.getEmbedAssetUrl("window/dragHandOver.png")+')');
   },   
   onRollOutDragButton : function() {
      var $j = PEARLTREES.libs.jQuery;
      $j(this).css('background-image', 'url('+PEARLTREES.utils.getEmbedAssetUrl("window/dragHand.png")+')');
   }   
}


/**
 * PEARLTREES.overlay 
 * It contains functions related to overlays.
 */
PEARLTREES.overlay = {
   
   TIME_TO_OPEN : 600,
   TIME_TO_CLOSE : 600,
   COMMAND_PREFIX : '#/pts/',
   ENCODED_COMMAND_PREFIX : '%23/pts/',
   CLOSE_COMMAND : 'co',
   CLOSE_AND_SHARE_COMMAND : 'coas',
   CLOSE_AND_SELECT_NODE_COMMAND : 'cosn',   
   SELECT_NODE_COMMAND : 'sn',   
   END_COMMAND_CHAR : '/', 
   PARAM_COMMAND_CHAR : '-',
   COMMAND_POLL: 200,
   
   _jQueryOverlay:null, // http://flowplayer.org/tools/overlay.html     
   _iframeContainer:null,
   _isPlayingOpenEffect:false,
   _isPlayingCloseEffect:false,
   _closeEffectFocusOnEmbed:false, // by default it focused on window
   _forceNextOpenFromWindowPosition:false, // When opening overlay from embedWindow
   
   getJQueryOverlay : function() {
      var $j = PEARLTREES.libs.jQuery;
      if(!this._jQueryOverlay) {
         
         // Create the overlay. It is only the iframe location and the command to close it.
         var overlayContainer = $j('<div id="pt-overlay"></div>');
         var closeButton = $j('<div id="pt-closeButtonContainer"><a href="javascript:PEARLTREES.overlay.hide()"><img src="'+PEARLTREES.utils.getEmbedAssetUrl("close.png")+'" onmouseout="this.src=\''+PEARLTREES.utils.getEmbedAssetUrl("close.png")+'\'" onmouseover="this.src=\''+PEARLTREES.utils.getEmbedAssetUrl("closeOver.png")+'\'" alt="" /></a></div>');
         this._iframeContainer = $j('<div id="pt-iframeContainer"></div>');

         overlayContainer.append(closeButton);
         overlayContainer.append(this._iframeContainer);
         $j('body').append(overlayContainer);
         $j(window).resize(this.onWindowResize);
                  
         // Turn it into a jQuery overlay
         this._jQueryOverlay = overlayContainer.overlay({
            top: "center",
            left: "center",
            
            expose: {
                color: '#505050',
                loadSpeed: PEARLTREES.overlay.TIME_TO_OPEN,
                opacity: 0
            },
            
            effect: 'pearltrees',
            start: {absolute:true},
            openSpeed: PEARLTREES.overlay.TIME_TO_OPEN,
            closeSpeed: PEARLTREES.overlay.TIME_TO_CLOSE,
            
            onClose:PEARLTREES.overlay.onOverlayClose,
            onBeforeClose:PEARLTREES.overlay.onOverlayBeforeClose,
            onLoad:PEARLTREES.overlay.onOverlayOpened,
            
            closeOnClick: true,
            api: true
         });
      }
      return this._jQueryOverlay;
   },
   
   // Called by embeds or embed window
   showFromComp : function(url, compId, localX, localY, forceToOpenFromWindowPosition, lang) {
      // If we are into an Iframe, we won't show the overlay
      // @todo do this only if a parent is a pearltrees browser
      if(top != self) {
         return false;
      }
      
      var $j = PEARLTREES.libs.jQuery;
      var overlay = PEARLTREES.overlay;
      var embedWindow = PEARLTREES.embedWindow;
      if(!embedWindow._window) {
         embedWindow.init(lang);
      }
      
      if(embedWindow._isOpenEffectPlaying) {
         embedWindow._openOverlayOnOpenEffectEnd = true;
         return true;
      }
      if(overlay._isPlayingCloseEffect || overlay._isPlayingOpenEffect) {
         return true;
      }
      
      var embedType = PEARLTREES.embed.getEmbedType(compId);
      var isSuperEmbed = (embedType == PEARLTREES.embed.SUPER_EMBED);
      var isPearlEmbed = (embedType == PEARLTREES.embed.PEARL_EMBED);
      
      // Add the lang to the URL
      if(lang) {
         url = url + "&lang=" + lang;
      }
      
      // Get the embed componenet
      var comp = PEARLTREES.embed.getHtmlCompFromId(compId);
      
      // The default effect start position is the middle of the screen
      var startX = screen.width / 2;
      var startY = screen.height / 2;
      var startWidth = 0;
      var startHeight = 0;
      
      // Set open effect start location based on embed position
      if(comp) {
         // Actually we always open the overlay with an effect from the window
         if(embedWindow._isWindowInitialized && (embedWindow.isWindowOpened() || overlay._forceNextOpenFromWindowPosition)) {
            if(embedWindow.isWindowOpened()) {
               embedWindow.saveWindowPosition();
            }
            startX = embedWindow._lastWindowPosition.left;
            startY = embedWindow._lastWindowPosition.top;
            startWidth = embedWindow.getWindowWidth() - 3;
            startHeight = embedWindow.getWindowHeight() - 3;
            
            overlay.show(url, startX, startY, startWidth, startHeight, embedType); 
         }
         else{
            PEARLTREES.embed.refreshCachedPosition(compId);    
            if(!localX) localX = Math.round(comp.ptCompWidth / 2);
            if(!localY) localY = Math.round(comp.ptCompHeight / 2);        
            startX = Math.round(comp.ptCompX + localX);
            startY = Math.round(comp.ptCompY + localY);
            
            overlay.show(url, startX, startY, startWidth, startHeight, embedType); 
            
            if(!embedWindow._lastWindowPosition) {
               var embedWindowComp = embedWindow.getEmbedShowingWindow();
               if(!embedWindowComp) {
                  embedWindowComp = comp;
                  embedWindow._embedShowingWindow = comp;
               }
               embedWindow._lastWindowPosition = embedWindow.getDefaultPosition(embedWindowComp);
            }
            
            // Set close position to the embed window
            if(PEARLTREES.config.ENABLE_EMBED_WINDOW) {
               var conf = overlay.getJQueryOverlay().getConf();
               conf.start.left = embedWindow._lastWindowPosition.left;
               conf.start.top = embedWindow._lastWindowPosition.top;
               conf.start.width = embedWindow.getWindowWidth() - 3;
               conf.start.height = embedWindow.getWindowHeight() - 3;  
            } 
            
            overlay._closeEffectFocusOnEmbed = false;          
         }
         
         //PEARLTREES.utils.log("[Show] compX: "+compX+" localX: "+localX+" compY: "+compY+" localY: "+localY);         
      }
      else {      
         overlay.show(url, startX, startY, startWidth, startHeight, embedType);
      }
      
      overlay._forceNextOpenFromWindowPosition = false;
      
      return true;
   }, 
   
   show : function(url, startX, startY, startWidth, startHeight, embedType) {
      var $j = PEARLTREES.libs.jQuery;
      var overlay = PEARLTREES.overlay;
      var conf = overlay.getJQueryOverlay().getConf();
      conf.start.top = startY;
      conf.start.left = startX;
      conf.start.width = startWidth;
      conf.start.height = startHeight;
      
      // Fix bug when body is relative instead of static
      var body = $j('body');          
      if(body && body.css('position') == "relative") {
         var documentHeight = $j(window).height();
         var overlayHeight = Math.round(documentHeight - (documentHeight * 0.15));
         var documentWidth = $j(window).width();
         var overlayWidth = Math.round(documentWidth - (documentWidth * 0.15));
         $j("#pt-overlay").css({width:overlayWidth, height:overlayHeight});
      }
      
      // Remove remaining drag zones from the window
      PEARLTREES.embedWindow.hideDragZones();      
      // We hide the embed window if it was visible
      PEARLTREES.embedWindow.hide();      
      // Update iframe URL
      overlay.updateOverlayUrl(url, embedType);
      // Start open effect
      overlay._isPlayingOpenEffect = true;      
      overlay.getJQueryOverlay().load();
      // Listen to iframe commands
      overlay.listenForCommand();
   },
   
   onOverlayOpened : function() {
      PEARLTREES.overlay.displayIFrameInOverlay();
      PEARLTREES.overlay._isPlayingOpenEffect = false;
      PEARLTREES.overlay._isPlayingCloseEffect = false;
      
      // Make sure the window is at the right place
      setTimeout('PEARLTREES.overlay.displayIFrameInOverlay()', 50);
      
      // On the overlay opened, we consider the window initialized
      if(!PEARLTREES.embedWindow._isWindowInitialized) {
         PEARLTREES.embedWindow._isWindowInitialized = true;
      }
   },
   
   displayIFrameInOverlay : function() {
      var $j = PEARLTREES.libs.jQuery;
      // We use the iframe window
      var window = PEARLTREES.embedWindow._window;

      // Because the overlay is in percent, we have to parseInt first in order to have a round value
      var overlayComp = this.getJQueryOverlay().getOverlay();
      overlayComp.css('top', parseInt(overlayComp.css('top')));
      overlayComp.css('left', parseInt(overlayComp.css('left')));
      overlayComp.css('right', 0);
      overlayComp.css('bottom', 0);
            
      // Adjust window size on overlay size
      var width = this._iframeContainer.width();
      var height = this._iframeContainer.height();
      var containerOffsetTop = this._iframeContainer.offset().top;
      var containerOffsetLeft = this._iframeContainer.offset().left;
      var top = parseInt(containerOffsetTop) + 1;
      var left = parseInt(containerOffsetLeft) + 1;
      
      // Fix bug when body is relative instead of static
      var body = $j('body');          
      if(body && body.css('position') == "relative") {
         top = parseInt(overlayComp.css('top')) + parseInt(this._iframeContainer.css('top')) + 1;
      }
      
      // On IE we may have a negative value
      if(width < 0) width = 0;
      if(height < 0) height = 0;         
      if(top < 0) top = 0;
      if(left < 0) left = 0;
      
      window.css({width:width, height:height, top:top, left:left});         
   },

   isOverlayOpened : function() {
      return this.getJQueryOverlay().isOpened();
   },
     
   updateOverlayUrl : function(url, embedType) {
      var $j = PEARLTREES.libs.jQuery;

      if(PEARLTREES.utils.isPearltreesUrl(url)) {
         if(url.indexOf("N-play") == -1) {
            url = url + "&N-play=1";
         }
         if(url.indexOf("overlay-url") == -1) {
            url = url + "&overlay-url="
         }
         if(url.indexOf("overlay-parent") == -1) {
            url = url + "&overlay-parent=" + encodeURIComponent(window.location.href);
         }
         if(url.indexOf("overlay-embedType") == -1) {
            if(!embedType) embedType = PEARLTREES.embed.PEARL_EMBED;
            url = url + "&overlay-embedType=" + embedType;
         }
      }     
      PEARLTREES.embedWindow.updateIFrameURL(url);
   },
   
   hide : function(focusOnEmbed) {
      var overlay = PEARLTREES.overlay;
      if(focusOnEmbed) {
         overlay._closeEffectFocusOnEmbed = true;
         
         var comp = PEARLTREES.embedWindow.getEmbedShowingWindow();
         var conf = overlay.getJQueryOverlay().getConf();
         conf.start.top = comp.ptCompY;
         conf.start.left = comp.ptCompX;
         conf.start.width = comp.ptCompWidth;
         conf.start.height = comp.ptCompHeight;         
      }else{
         overlay._closeEffectFocusOnEmbed = false;
      }
      overlay.getJQueryOverlay().close();      
   },
   
   onOverlayClose : function() {
      var embedWindow = PEARLTREES.embedWindow;
      if(!PEARLTREES.overlay._closeEffectFocusOnEmbed && embedWindow.getEmbedShowingWindow() && embedWindow.getEmbedShowingWindow().setWindowOpened) {
         embedWindow._skipOpenEffectAndBackupLastPosition = true;
         try {
            embedWindow.getEmbedShowingWindow().setWindowOpened(true);
         }catch(e) {
            PEARLTREES.utils.log("Error calling flash from JS");
         }
      }
      PEARLTREES.overlay._isPlayingCloseEffect = false;
      PEARLTREES.overlay._isPlayingOpenEffect = false;
      PEARLTREES.overlay._closeEffectFocusOnEmbed = false;
   },
   
   onOverlayBeforeClose : function() {
      PEARLTREES.overlay.resetOverlayPlayer();
      PEARLTREES.embedWindow.hide();
      PEARLTREES.overlay.removeAllCommand();
      PEARLTREES.overlay._isPlayingCloseEffect = true;
   },
   
   resetOverlayPlayer : function() {
      var overlay = PEARLTREES.overlay;
      var embedWindow = PEARLTREES.embedWindow;
      var $j = PEARLTREES.libs.jQuery;
      var url = embedWindow._lastUrlIFrameUpdate;
      if(url) {
         // Close the player
         url = url.replace("N-play=1", "N-play=0");
         // Remove overlay-url param
         var anchorParams = PEARLTREES.overlay.getUrlAnchorParams(url);
         if(anchorParams["overlay-url"]) {
            url = url.replace(anchorParams["overlay-url"], "");
         }

         overlay.updateOverlayUrl(url);
      }
   },
   
   onWindowResize : function() {
      if(PEARLTREES.overlay.isOverlayOpened()) {
         PEARLTREES.overlay.displayIFrameInOverlay();
      }
   }, 
   
   listenForCommand : function() {
      var overlay = PEARLTREES.overlay;
      var embedWindow = PEARLTREES.embedWindow;
      if(!overlay.isOverlayOpened()) return;
      var isCloseCommandFired = false;
      var embedShowingWindow = embedWindow.getEmbedShowingWindow();
      
      if(overlay.isCommandFired(overlay.CLOSE_COMMAND)) {
         isCloseCommandFired = true;
         overlay.hide();
      }
      else if(overlay.isCommandFired(overlay.CLOSE_AND_SHARE_COMMAND)) {
         isCloseCommandFired = true;         
         if(embedShowingWindow && embedShowingWindow.displayShareWindow) {
            try {
               embedShowingWindow.displayShareWindow();
            }catch(e) {
               PEARLTREES.utils.log("Error calling flash from JS");
            }                
         }
         overlay.hide(true);         
      }
      else if(overlay.isCommandFired(overlay.CLOSE_AND_SELECT_NODE_COMMAND)) {
         isCloseCommandFired = true;
         var params = overlay.getCommandParams(overlay.CLOSE_AND_SELECT_NODE_COMMAND);
         if(params.length == 4) {
            var assoId = params[0];
            var focusedTreeId = params[1];
            var selectedTreeId = params[2];
            var pearlId = params[3];
            if(embedShowingWindow && embedShowingWindow.navigateTo) {
               try {
                  embedShowingWindow.navigateTo(assoId, focusedTreeId, selectedTreeId, pearlId);
               }catch(e) {
                  PEARLTREES.utils.log("Error calling flash from JS");
               }               
            }
         }
         //PEARLTREES.utils.log("assoId: "+assoId+" treeId: "+treeId+" pearlId: "+pearlId);
         overlay.hide();
      }
      else if(overlay.isCommandFired(overlay.SELECT_NODE_COMMAND)) {
         var params = overlay.getCommandParams(overlay.SELECT_NODE_COMMAND);
         if(params.length == 4) {
            var assoId = params[0];
            var focusedTreeId = params[1];
            var selectedTreeId = params[2];
            var pearlId = params[3];
            if(embedShowingWindow && embedShowingWindow.navigateTo) {
               try {
                  embedShowingWindow.navigateTo(assoId, focusedTreeId, selectedTreeId, pearlId);
               }catch(e) {
                  PEARLTREES.utils.log("Error calling flash from JS");
               }
            }
         }
         //PEARLTREES.utils.log("assoId: "+assoId+" treeId: "+treeId+" pearlId: "+pearlId);
      }

      if(!isCloseCommandFired) {
         setTimeout('PEARLTREES.overlay.listenForCommand()', overlay.COMMAND_POLL);
      }
   },
   
   removeAllCommand : function() {
      var overlay = PEARLTREES.overlay;
      var currentUrl = window.location.href;
      var cleanUrl = currentUrl;      
      cleanUrl = overlay.removeCommandFromUrl(overlay.CLOSE_COMMAND, cleanUrl);
      cleanUrl = overlay.removeCommandFromUrl(overlay.CLOSE_AND_SHARE_COMMAND, cleanUrl);
      cleanUrl = overlay.removeCommandFromUrl(overlay.CLOSE_AND_SELECT_NODE_COMMAND, cleanUrl);
      cleanUrl = overlay.removeCommandFromUrl(overlay.SELECT_NODE_COMMAND, cleanUrl);
      if(cleanUrl != currentUrl) {
         window.location.href = cleanUrl;
      }
   },
   
   removeCommandFromUrl : function(commandName, url) {
      var overlay = PEARLTREES.overlay;
      
      // Clean both command and encoded command 
      var commandInUrl = overlay.getCommandInUrl(commandName, url);
      if(commandInUrl) {
         url = url.replace(commandInUrl, "");
         // If the last char is a # we will replace it by our COMMAND_PREFIX
         if(url.indexOf("#")+1 == url.length) {
            url = url.substr(0, url.length-1);
         }
         if(url.indexOf("#") == -1) {
            url += overlay.COMMAND_PREFIX;
         }
      }
      return url;
   },
   
   isCommandFired : function(commandName) {
      var overlay = PEARLTREES.overlay;
      var url = window.location.href;
      
      // Search command
      if(overlay.getCommandInUrl(commandName, url)) {
         return true;
      }else{
         return false;
      }           
   },
   
   getCommandParams : function(commandName) {
      var overlay = PEARLTREES.overlay;
      var url = window.location.href;
      var commandInUrl = overlay.getCommandInUrl(commandName, url);
      commandInUrl = commandInUrl.substr(0, commandInUrl.length - 1);
      var params = commandInUrl.split(overlay.PARAM_COMMAND_CHAR);
      if(params && params.length > 0) {
         params.splice(0,1);
      }else{
         params = [];
      }
      
      return params;
   },
   
   getCommandInUrl : function(commandName, url) {
      var overlay = PEARLTREES.overlay;
      var prefixedCommand = overlay.COMMAND_PREFIX + commandName;
      var commandInUrl = null;
      if(url.indexOf(prefixedCommand + overlay.END_COMMAND_CHAR) != -1 || url.indexOf(prefixedCommand + overlay.PARAM_COMMAND_CHAR) != -1) {
         var splitedUrl = url.split(prefixedCommand);
         var leftPart = splitedUrl[0]
         var rightPart = splitedUrl[1];
         var prefixedCommandIndex = url.indexOf(prefixedCommand);
         var endOfCommandIndex = leftPart.length + prefixedCommand.length + rightPart.indexOf(overlay.END_COMMAND_CHAR);
         commandInUrl = url.substring(prefixedCommandIndex, endOfCommandIndex + 1);
      }
      // If we don't find the command, we try check if it is url encoded
      if(!commandInUrl) {
         //var encodedPrefixedCommand = encodeURIComponent(overlay.COMMAND_PREFIX + commandName);
         var encodedPrefixedCommand = overlay.ENCODED_COMMAND_PREFIX + commandName;
         if(url.indexOf(encodedPrefixedCommand + overlay.END_COMMAND_CHAR) != -1 || url.indexOf(encodedPrefixedCommand + overlay.PARAM_COMMAND_CHAR) != -1) {
            var splitedUrl = url.split(encodedPrefixedCommand);
            var leftPart = splitedUrl[0]
            var rightPart = splitedUrl[1];
            var prefixedCommandIndex = url.indexOf(encodedPrefixedCommand);
            var endOfCommandIndex = leftPart.length + encodedPrefixedCommand.length + rightPart.indexOf(overlay.END_COMMAND_CHAR);
            commandInUrl = url.substring(prefixedCommandIndex, endOfCommandIndex + 1);
         }
      }
      return commandInUrl;
   }, 
   
   getUrlAnchorParams : function(url) {
      var params = [];
      var paramsString = url.substr(url.indexOf('#')+1,url.length);     
      if(paramsString.length==0) {
         return params;
      }
      else if(paramsString.indexOf('&') != -1) {
         var nvPairs = paramsString.split("&");
         for (i = 0; i < nvPairs.length; i++) {
              var nvPair = nvPairs[i].split("=");
              var name = nvPair[0];
              var value = nvPair[1];
              params[name] = value;
         }     
      }
      else {
         var nvPair = paramsString.split("=");
          var name = nvPair[0];
          var value = nvPair[1];
          params[name] = value;
      }
      return params;    
   }
}

/**
 * PEARLTREES.embed 
 * It contains functions related to embeds.
 */
PEARLTREES.embed = {    
   
   TIME_TO_FADE_IN : 300.0,
   TIME_TO_FADE_OUT : 300.0,
   TITLE_LINE_LENGTH : 16,
   TITLE_MAX_LINES : 2,
   DISPLAY_LABEL : 1,
   MIN_PEARL_HEIGHT : 43,
   MAX_PEARL_WIDTH : 100,
   LINE_HEIGHT : 12,   
   
   SUPER_EMBED : 1,
   PEARL_EMBED : 2,
   
   init : function() {
      this.loadCss();
   },
   
   loadCss : function() {
      var $j = PEARLTREES.libs.jQuery;
      var htmlHead = document.getElementsByTagName("head")[0];
      
      var cssNode = document.createElement('link');
      cssNode.type = 'text/css';
      cssNode.rel = 'stylesheet';
      cssNode.href = PEARLTREES.utils.getEmbedAssetUrl("pt-embed.css");
      cssNode.media = 'all';
      htmlHead.appendChild(cssNode);
      
      if($j.browser.msie) {
         var cssNode = document.createElement('link');
         cssNode.type = 'text/css';
         cssNode.rel = 'stylesheet';
         cssNode.href = PEARLTREES.utils.getEmbedAssetUrl("pt-embed-ie.css");
         cssNode.media = 'all';
         htmlHead.appendChild(cssNode);
      }
   },
   
   getEmbedType : function (embedId) {
      if(embedId.substring(0,8) == "pt-embed") {
         return this.SUPER_EMBED;
      }else{
         return this.PEARL_EMBED;
      }
   },
   
   getHtmlCompFromId : function(compId) {
      var $j = PEARLTREES.libs.jQuery;
      
      var embedType = this.getEmbedType(compId);      
      var comp = null;
      
      // If it is a super sembed we get the real DOM element id.
      if(this.getEmbedType(compId) == this.SUPER_EMBED) {
         var embedContainer = null;
         var objectContainer = null;
         if ($j.browser.msie) {
            objectContainer = window[compId+"-object"];
            if(!objectContainer) objectContainer = this.findObjectContainerInPage(compId);
            comp = objectContainer;
         }
         else{
            objectContainer = document.getElementById(compId+"-object");
            if(!objectContainer) objectContainer = this.findObjectContainerInPage(compId);
            embedContainer = document.getElementById(compId+"-embed");
            if(!embedContainer) embedContainer = this.findEmbedContainerInPage(compId);
             
            if(!embedContainer && objectContainer) {
               comp = objectContainer;
            }else {
               comp = embedContainer;
            }
         }
         
         if(comp) {
            if(embedContainer && objectContainer) {
               comp.ptIsOldEmbedCode = true;
            }
            comp.ptObjectContainer = objectContainer;
            comp.ptEmbedContainer = embedContainer;
         }
      }else{
         if($j.browser.msie) {
            comp = window[compId];
         }else{
            comp = document.getElementById(compId);
         }
      }
      
      return comp;
   },
   
   refreshCachedPosition : function (compId) {
      var $j = PEARLTREES.libs.jQuery;    
      var comp = PEARLTREES.embed.getHtmlCompFromId(compId);
      if(!comp) return;
      
      // Positions are retreived thanks to jQuery
      var jQueryComp = $j(comp);
      var compX = Math.round(jQueryComp.offset().left);
      var compY = Math.round(jQueryComp.offset().top);
      var compWidth = Math.round(jQueryComp.width());
      var compHeight = Math.round(jQueryComp.height());      
      //PEARLTREES.utils.log("[jQuery] compX: "+compX+" compY: "+compY+" compWidth: "+compWidth+" compHeight: "+compHeight); 
      
      // In some cases we have to set special values
      var embedType = this.getEmbedType(compId);
      if(embedType == this.PEARL_EMBED) {
         compWidth = this.MAX_PEARL_WIDTH;
         // We set compHeight to 0 because compY is already in the middle of the pearl
         compHeight = 0;
      }
      // In webkit old embeds using the embedContainer must use the objectContainer
      // note: some plateform still transform the new embed code in the old one
      else if(embedType == this.SUPER_EMBED && comp.ptIsOldEmbedCode && ($j.browser.webkit || $j.browser.safari)) {
         jQueryComp = $j(comp.ptObjectContainer);
         if(compX == 0 || compY == 0) {
            compX = Math.round(jQueryComp.offset().left);
            compY = Math.round(jQueryComp.offset().top);
         }
         if(compWidth == 0 || compHeight == 0) {
            compWidth = Math.round(jQueryComp.width());
            compHeight = Math.round(jQueryComp.height());
         }         
         if((compX == 0 || compY == 0) && comp.parentNode) {
            jQueryComp = $j(comp.parentNode);
            compX = Math.round(jQueryComp.offset().left);
            compY = Math.round(jQueryComp.offset().top);
            //PEARLTREES.utils.log("[old webkit fix] use parent node");                
         }
         //PEARLTREES.utils.log("[old webkit fix] compX: "+compX+" compY: "+compY+" compWidth: "+compWidth+" compHeight: "+compHeight); 
      }
      
      // Save values
      comp.ptCompX = compX;
      comp.ptCompY = compY;
      comp.ptCompWidth = compWidth;
      comp.ptCompHeight = compHeight;
   },
   
   findEmbedContainerInPage : function (embedId) {
      var embeds = document.getElementsByTagName('embed');
      for(var i in embeds) {
         var embed = embeds[i];
         
         if(embed && embed.getAttribute) {         
            var flashvars = embed.getAttribute('flashvars');
            if(flashvars) {
               var flashvarsEmbedId = flashvars.split("embedId=");
               if(flashvarsEmbedId.length > 1) {
                  flashvarsEmbedId = flashvarsEmbedId[1];
                  var nextParamIndex = flashvarsEmbedId.indexOf("&");
                  if(nextParamIndex != -1) {
                     flashvarsEmbedId = flashvarsEmbedId.substr(0, nextParamIndex);
                  }
                  if(flashvarsEmbedId == embedId) {
                     return embed;
                  }
               }
            }
         }
      }
      return null;
   },
   
   findObjectContainerInPage : function(embedId) {
      var objects = document.getElementsByTagName('object');
      for(var i in objects) {
         var object = objects[i];
         var flashvars = null;
         
         if(object && object.childNodes && object.childNodes.length > 0) {    
            for(var j in object.childNodes) {
               var param = object.childNodes[j];
               var paramName = param.name;
               var paramValue = param.value;
               //PEARLTREES.utils.log("paramName: "+paramName);
               if(paramName && paramName == "flashvars") {
                  flashvars = paramValue;
               }
            }

            if(flashvars) {
               var flashvarsEmbedId = flashvars.split("embedId=");
               if(flashvarsEmbedId.length > 1) {
                  flashvarsEmbedId = flashvarsEmbedId[1];
                  var nextParamIndex = flashvarsEmbedId.indexOf("&");
                  if(nextParamIndex != -1) {
                     flashvarsEmbedId = flashvarsEmbedId.substr(0, nextParamIndex);
                  }
                  if(flashvarsEmbedId == embedId) {
                     return object;
                  }
               }
            }
         }
      }
      return null;
   },    
   
   initPearl : function(pearlLinkId,pearlDB,pearlID,displayLabel) {
      pearlDB = 1; // deprecated and not used
      
      var $j = PEARLTREES.libs.jQuery;
      var embed = PEARLTREES.embed;
      var config = PEARLTREES.config;
      var pearlLink = document.getElementById(pearlLinkId); 
      var pearlTitle = embed.getPearlTitle(pearlLink);
      
      if(displayLabel != embed.DISPLAY_LABEL) pearlTitle = null;
      
      var divContainer = document.createElement('div');
      divContainer.className = 'pt-pearlContent';
      embed.setElementStyleAsString(divContainer, 'height:'+embed.getPearlHeight(pearlTitle)+'px !important');
      var containerHTML = 
         '<p>' +
         '   <img src="'+ PEARLTREES.utils.getEmbedAssetUrl("pearl-background.png")+'" width="38" height="38" class="pt-background" />' +
         '   <img src="'+ config.SERVICE_URL +'logo?pearlID=' + pearlID + '" width="16" height="16" class="pt-logo" />' +
         '   <img src="'+ PEARLTREES.utils.getEmbedAssetUrl("maskPearl.png")+'" width="38" height="38" class="pt-background" name="mask" />';
      if(displayLabel == embed.DISPLAY_LABEL) containerHTML += embed.getLabelCode(pearlLink);
      containerHTML += '</p>';
      
      divContainer.innerHTML = containerHTML;   
         
       pearlLink.innerHTML='';
      pearlLink.appendChild(divContainer);   
      pearlLink.className = 'pt-pearlLink';
      
      // Uncomment to use overlay
      //pearlLink.pearlURL = pearlLink.href;
      //pearlLink.href = 'javascript:;';
      //pearlLink.target = '_top';
      //pearlLink.onclick = embed.onClickPearl;
      
      // On IE. Open pearltrees in current window.
      if($j.browser.msie) {
         pearlLink.onclick = embed.onClickPearl;
         pearlLink.setAttribute('target','_top');
      }
      pearlLink.onmouseover = embed.onMouseOverPearl;
      pearlLink.onmouseout = embed.onMouseOutPearl;
   },
   
   initTree : function(pearlLinkId, userDB, userID, treeDB, treeID, displayLabel) {
      userDB = 1; // deprecated and not used
      userID = -1; // deprecated and not used
      treeDB = -1; // deprecated and not used
   
      var $j = PEARLTREES.libs.jQuery;
      var embed = PEARLTREES.embed;
      var config = PEARLTREES.config;
      var pearlLink = document.getElementById(pearlLinkId);
      var pearlTitle = embed.getPearlTitle(pearlLink);
      
      if(displayLabel != embed.DISPLAY_LABEL) pearlTitle = null;
      
      var divContainer = document.createElement('div');
      divContainer.className = 'pt-pearlContent';
      embed.setElementStyleAsString(divContainer, 'height:'+embed.getPearlHeight(pearlTitle)+'px !important');
      var containerHTML = 
         '<p>' +
         '   <img src="'+ PEARLTREES.utils.getEmbedAssetUrl("pearl-background.png")+'" width="38" height="38" class="pt-background" />' +
         '   <img src="'+ config.SERVICE_URL +'avatar?treeID=' + treeID + '" width="36" height="36" class="pt-avatar" />' +
         '   <img src="'+ PEARLTREES.utils.getEmbedAssetUrl("maskTree.png")+'" width="38" height="38" class="pt-mask" name="mask" />' +    
         '   <img src="'+ PEARLTREES.utils.getEmbedAssetUrl("border.png")+'" width="38" height="38" class="pt-background" />' +
         '   <img src="'+ PEARLTREES.utils.getEmbedAssetUrl("treeArrow.png")+'" width="14" height="15" class="pt-arrow" name="arrow" />';
      if(displayLabel == embed.DISPLAY_LABEL) containerHTML += embed.getLabelCode(pearlLink);
      containerHTML += '</p>';
      
      divContainer.innerHTML = containerHTML;
         
       pearlLink.innerHTML='';
      pearlLink.appendChild(divContainer);   
      pearlLink.className = 'pt-pearlLink';
      
      // Uncomment to use overlay
      //pearlLink.pearlURL = PEARLTREES.config.DOMAIN+"#/N-u=1_"+userID+"&N-f=1_"+treeID+"&N-s=1_"+treeID;
      //pearlLink.href = 'javascript:;';
      //pearlLink.target = '_top';
      //pearlLink.onclick = embed.onClickPearl;
      
      // On IE. Open pearltrees in current window.
      if($j.browser.msie) {
         pearlLink.onclick = embed.onClickPearl;
         pearlLink.setAttribute('target','_top');
      }     
      
      pearlLink.onmouseover = embed.onMouseOverTree;
      pearlLink.onmouseout = embed.onMouseOutTree;
   },
   
   getPearlHeight : function(pearlTitle) {
      var height = this.MIN_PEARL_HEIGHT;
      if(!pearlTitle || pearlTitle == '') return height;
      var numLines = this.getPearlTitleLines(pearlTitle).length;
      if(numLines > this.TITLE_MAX_LINES) numLines = this.TITLE_MAX_LINES;
      height += numLines * this.LINE_HEIGHT;
      return height;
   },
   
   getLabelCode : function (pearlLink) {
      var pearlTitle = this.getPearlTitle(pearlLink);
      
      var lines = this.getPearlTitleLines(pearlTitle);
      var numLines = lines.length;
      if(numLines > this.TITLE_MAX_LINES) numLines = this.TITLE_MAX_LINES;
      var pearlTitleCode = "";
      
      for(var i=0; i < numLines; i++) {
         pearlTitleCode += lines[i];
         if(i+1 < numLines) pearlTitleCode += "<br />";
      }
      if(lines.length > this.TITLE_MAX_LINES) {
         pearlTitleCode += '<span class="pt-more">..</span>';
      }
      
      var labelCode =
         '   <p style="' + this.getElementStyleAsString(pearlLink) + '" class="pt-title">' +
         '   ' + pearlTitleCode +
         '   </p>';
      return labelCode;
   },
   
   getPearlTitleLines : function(pearlTitle) {
      var lines = [];
      var titleToSplit = pearlTitle;
      
      for(var i=0; titleToSplit.length > 0; i++) {
         
         if(titleToSplit.length > this.TITLE_LINE_LENGTH) {
            var splitPos = this.TITLE_LINE_LENGTH;
            var currentLine = titleToSplit.substr(0,splitPos);
            var spacePos = currentLine.lastIndexOf(' ');
            if(spacePos > 1) {
               splitPos = spacePos;
            }
            currentLine = titleToSplit.substr(0, splitPos);
            lines[i] = currentLine;
            titleToSplit = titleToSplit.substring(splitPos, titleToSplit.length);
         }
         else{
            lines[i] = titleToSplit;
            titleToSplit = "";
         }  
      }
      return lines;
   },
   
   getPearlTitle : function(pearlLink) {
      var pearlTitle = null;
      var defaultImage = pearlLink.getElementsByTagName('img')[0];   
      if(defaultImage) {
         pearlTitle = defaultImage.getAttribute('alt');
      }else{
         pearlTitle = pearlLink.innerHTML;
      }
      return pearlTitle;
   },
   
   onMouseOverPearl : function() {
      PEARLTREES.embed.hideMask(this);
   },
   
   onMouseOutPearl : function() {
      PEARLTREES.embed.showMask(this);
   },
   
   onMouseOverTree : function() {
      PEARLTREES.embed.hideMask(this);
      PEARLTREES.embed.showArrow(this);
   },
   
   onMouseOutTree : function() {
      PEARLTREES.embed.showMask(this);
      PEARLTREES.embed.hideArrow(this);
   },
   
   onClickPearl : function() {
      if(this.href == 'javascript:;') {
         PEARLTREES.overlay.showFromComp(this.pearlURL, this.id);
      }else{
         document.location = this.href;
      }
   },
   
   getElementStyleAsString : function(element) {
      if(!element) return '';
      var styleValue = element.getAttribute('style');
      if (styleValue && typeof styleValue == 'object') {
         return styleValue.cssText;
      }
      else {
         return styleValue;
      }
   },
   
   setElementStyleAsString : function(element, style) {
      var $j = PEARLTREES.libs.jQuery;
      if(!element) return;
   
      if($j.support.style) {
         element.setAttribute('style', style);
      }else {
         element.cssText = style;
      }
   },
   
   onClick : function(pearlLinkId){
      var pearlLink = document.getElementById(pearlLinkId);
      document.location = pearlLink.href;
   },
   
   showMask : function(pearlLink) {
      var $j = PEARLTREES.libs.jQuery;
      var mask = this.getMask(pearlLink);
      
      // We don't play the fade effect with IE
      if($j.browser.msie) {
         mask.style.visibility = 'visible';
      }else{
         this.fade(mask.id);
      }
   },
   
   hideMask : function(pearlLink) {
      var $j = PEARLTREES.libs.jQuery; 
      var mask = this.getMask(pearlLink);
      
      // We don't play the fade effect with IE
      if($j.browser.msie) {
         mask.style.visibility = 'hidden';
      }else{
         this.fade(mask.id);
      }
   },
   
   showArrow : function(pearlLink) {
      var arrow = this.getArrow(pearlLink);
      arrow.style.visibility = 'visible';
   },
   
   hideArrow : function(pearlLink) {
      var arrow = this.getArrow(pearlLink);
      arrow.style.visibility = 'hidden';
   },
   
   getMask : function(pearlLink){
      var children = pearlLink.getElementsByTagName('img');
      var i=0;
      var mask;
      while(children[i]) {
         if(children[i].name == 'mask'){
            mask = children[i];
            mask.id = pearlLink.id+'mask';
            break;
         }
         i++;
      }
      return mask;
   },
   
   getArrow : function(pearlLink){
      var children = pearlLink.getElementsByTagName('img');
      var i=0;
      var arrow;
      while(children[i]) {
         if(children[i].name == 'arrow'){
            arrow = children[i];
            arrow.id = pearlLink.id+'arrow';
            break;
         }
         i++;
      }
      return arrow;
   },

   fade : function(elementId) {
     var element = document.getElementById(elementId);
     if(element == null)
      return;
      
     if(element.FadeState == null)
     {
      if(element.style.opacity == null
         || element.style.opacity == ''
         || element.style.opacity == '1')
      {
        element.FadeState = 2;
      }
      else
      {
        element.FadeState = -2;
      }
     }
      
     if(element.FadeState == 1 || element.FadeState == -1)
     {
      element.FadeState = element.FadeState == 1 ? -1 : 1;
      element.FadeTimeLeft = this.TIME_TO_FADE_OUT - element.FadeTimeLeft;
     }
     else
     {
      element.FadeState = element.FadeState == 2 ? -1 : 1;
      element.FadeTimeLeft = this.TIME_TO_FADE_IN;
      setTimeout("PEARLTREES.embed.animateFade(" + new Date().getTime() + ",'" + elementId + "')", 33);
     }  
   }, 
   
   animateFade : function(lastTick, elementId) {  
     var element = document.getElementById(elementId);
     
     var curTick = new Date().getTime();
     var elapsedTicks = curTick - lastTick;
    
     if(element.FadeTimeLeft <= elapsedTicks)
     {
      element.style.opacity = element.FadeState == 1 ? '1' : '0';
      element.style.filter = 'alpha(opacity = '
         + (element.FadeState == 1 ? '100' : '0') + ')';
      element.FadeState = element.FadeState == 1 ? 2 : -2;
      return;
     }
    
     element.FadeTimeLeft -= elapsedTicks;
     var newOpVal = element.FadeTimeLeft/this.TIME_TO_FADE_IN;
     if(element.FadeState == 1)
      newOpVal = 1 - newOpVal;
   
     element.style.opacity = newOpVal;
     element.style.filter = 'alpha(opacity = ' + (newOpVal*100) + ')';
    
     setTimeout("PEARLTREES.embed.animateFade(" + curTick + ",'" + elementId + "')", 33);
   }
}

/**
 * PEARLTREES.utls 
 * It contains common functions
 */
PEARLTREES.utils = {

   BROWSER_NAME_CHROME : "Chrome",
   BROWSER_NAME_FIREFOX : "Firefox",
   BROWSER_NAME_MSIE : "Explorer",
   BROWSER_NAME_OPERA : "Opera",
   BROWSER_NAME_SAFARI : "Safari",

   EMBED_SCRIPT_ID : 'pt-embed-js',
   
   scriptVersion : null,
   
   getBrowserName : function() {
      var $j = PEARLTREES.libs.jQuery;
      if($j.browser.msie) {
         return this.BROWSER_NAME_MSIE;
      }
      else if($j.browser.mozilla) {
         return this.BROWSER_NAME_FIREFOX;
      }
      else if($j.browser.opera) {
         return this.BROWSER_NAME_OPERA;
      }
      else if(navigator.userAgent.toLowerCase().indexOf('chrome') > -1) {
         return this.BROWSER_NAME_CHROME;
      }
      else {
         return this.BROWSER_NAME_SAFARI;
      }
   },
   
   getBrowserVersion : function() {
      var $j = PEARLTREES.libs.jQuery;
      return $j.browser.version;
   },
   
   log : function() {
      if(PEARLTREES.config.TRACE_DEBUG) {
         if(window.console) {
            window.console.log(message);
         } else {
            alert(message);
         }
      }
   },
      
   isPearltreesUrl : function(url) {
       if(!url) {
           return false;
       }else{
           return (url.lastIndexOf(PEARLTREES.config.DOMAIN) == 0);
       }
   },
   
   getEmbedAssetUrl : function(fileName) {
      // Get real script version in the .js file querystring
      if(!this.scriptVersion) {
         var script = document.getElementById(this.EMBED_SCRIPT_ID);
         this.scriptVersion = "undefined";
         if(script) {
            var scriptUrl = script.src;     
            this.scriptVersion = scriptUrl.substr(scriptUrl.indexOf("?v=")+3);
         }
      }
      
      return PEARLTREES.config.STATIC_URL + fileName + "?v=" + this.scriptVersion;
   },
   
   openWindow : function(url, target) {
      window.open(url, target);
   }
}

/**
 * PEARLTREES.libs
 * It contains javascript libraries
 */
PEARLTREES.libs = {
   
   jQuery : null,

   globalFunctionsInConflict : [],
   externalLibraries: [],
   
   LIBRARY_NAME_JQUERY : "jquery",
   LIBRARY_NAME_PROTOTYPE : "prototype",
   
   init : function() {
      this.detectExternalLibraries();
      this.initJQuery();
   },
   
   isExternalLibraryRunning : function (libraryName, version) {
      var libraryVersion = this.externalLibraries[libraryName];
      if(typeof(libraryVersion) != "undefined") {
         if(typeof(version) == "undefined") {
            return true;
         }else{
            var libraryVersion = this.externalLibraries[libraryName];
            return (libraryVersion.indexOf(version) == 0);
         }
      }else{
         return false;
      }
   },
   
   detectExternalLibraries : function () {
      if(typeof(Prototype) != "undefined" && typeof(Prototype.Version) != "undefined") {
         this.externalLibraries[this.LIBRARY_NAME_PROTOTYPE] = Prototype.Version;
      }
      if(typeof(jQuery) != "undefined" && typeof(jQuery.fn.jquery) != "undefined") {
         this.externalLibraries[this.LIBRARY_NAME_JQUERY] = jQuery.fn.jquery;
      }
   },
   
   saveAndDestroyGlobalFunctionsInConflict : function() {
      if(this.isExternalLibraryRunning(this.LIBRARY_NAME_PROTOTYPE, '1.5')) {
         this.globalFunctionsInConflict['document.getElementsByClassName'] = document.getElementsByClassName;
         document.getElementsByClassName = null;
      }  
   },
   
   backupGlobalFunctionsInConflict : function() {
      if(this.globalFunctionsInConflict['document.getElementsByClassName']) {
         document.getElementsByClassName = this.globalFunctionsInConflict['document.getElementsByClassName'];
      }
   }, 
   
   initJQuery : function () {
      this.saveAndDestroyGlobalFunctionsInConflict();
      
      /**
       * jquery.tools 1.1.2 - The missing UI library for the Web
       * 
       * [tools.overlay-1.1.2, tools.overlay.apple-1.0.1, tools.expose-1.0.5]
       * 
       * Copyright (c) 2009 Tero Piirainen
       * http://flowplayer.org/tools/
       *
       * Dual licensed under MIT and GPL 2+ licenses
       * http://www.opensource.org/licenses
       * 
       * -----
       * 
       * jQuery JavaScript Library v1.3.2
       * http://jquery.com/
       *
       * Copyright (c) 2009 John Resig
       * Dual licensed under the MIT and GPL licenses.
       * http://docs.jquery.com/License
       *
       * Sizzle CSS Selector Engine - v0.9.3
       * Copyright 2009, The Dojo Foundation
       * Released under the MIT, BSD, and GPL Licenses.
       * More information: http://sizzlejs.com/
       * 
       * -----
       * 
       * File generated: Fri Mar 12 07:37:55 GMT 2010
       */
      (function(){var l=this,g,y=l.jQuery,p=l.$,o=l.jQuery=l.$=function(E,F){return new o.fn.init(E,F)},D=/^[^<]*(<(.|\s)+>)[^>]*$|^#([\w-]+)$/,f=/^.[^:#\[\.,]*$/;o.fn=o.prototype={init:function(E,H){E=E||document;if(E.nodeType){this[0]=E;this.length=1;this.context=E;return this}if(typeof E==="string"){var G=D.exec(E);if(G&&(G[1]||!H)){if(G[1]){E=o.clean([G[1]],H)}else{var I=document.getElementById(G[3]);if(I&&I.id!=G[3]){return o().find(E)}var F=o(I||[]);F.context=document;F.selector=E;return F}}else{return o(H).find(E)}}else{if(o.isFunction(E)){return o(document).ready(E)}}if(E.selector&&E.context){this.selector=E.selector;this.context=E.context}return this.setArray(o.isArray(E)?E:o.makeArray(E))},selector:"",jquery:"1.3.2",size:function(){return this.length},get:function(E){return E===g?Array.prototype.slice.call(this):this[E]},pushStack:function(F,H,E){var G=o(F);G.prevObject=this;G.context=this.context;if(H==="find"){G.selector=this.selector+(this.selector?" ":"")+E}else{if(H){G.selector=this.selector+"."+H+"("+E+")"}}return G},setArray:function(E){this.length=0;Array.prototype.push.apply(this,E);return this},each:function(F,E){return o.each(this,F,E)},index:function(E){return o.inArray(E&&E.jquery?E[0]:E,this)},attr:function(F,H,G){var E=F;if(typeof F==="string"){if(H===g){return this[0]&&o[G||"attr"](this[0],F)}else{E={};E[F]=H}}return this.each(function(I){for(F in E){o.attr(G?this.style:this,F,o.prop(this,E[F],G,I,F))}})},css:function(E,F){if((E=="width"||E=="height")&&parseFloat(F)<0){F=g}return this.attr(E,F,"curCSS")},text:function(F){if(typeof F!=="object"&&F!=null){return this.empty().append((this[0]&&this[0].ownerDocument||document).createTextNode(F))}var E="";o.each(F||this,function(){o.each(this.childNodes,function(){if(this.nodeType!=8){E+=this.nodeType!=1?this.nodeValue:o.fn.text([this])}})});return E},wrapAll:function(E){if(this[0]){var F=o(E,this[0].ownerDocument).clone();if(this[0].parentNode){F.insertBefore(this[0])}F.map(function(){var G=this;while(G.firstChild){G=G.firstChild}return G}).append(this)}return this},wrapInner:function(E){return this.each(function(){o(this).contents().wrapAll(E)})},wrap:function(E){return this.each(function(){o(this).wrapAll(E)})},append:function(){return this.domManip(arguments,true,function(E){if(this.nodeType==1){this.appendChild(E)}})},prepend:function(){return this.domManip(arguments,true,function(E){if(this.nodeType==1){this.insertBefore(E,this.firstChild)}})},before:function(){return this.domManip(arguments,false,function(E){this.parentNode.insertBefore(E,this)})},after:function(){return this.domManip(arguments,false,function(E){this.parentNode.insertBefore(E,this.nextSibling)})},end:function(){return this.prevObject||o([])},push:[].push,sort:[].sort,splice:[].splice,find:function(E){if(this.length===1){var F=this.pushStack([],"find",E);F.length=0;o.find(E,this[0],F);return F}else{return this.pushStack(o.unique(o.map(this,function(G){return o.find(E,G)})),"find",E)}},clone:function(G){var E=this.map(function(){if(!o.support.noCloneEvent&&!o.isXMLDoc(this)){var I=this.outerHTML;if(!I){var J=this.ownerDocument.createElement("div");J.appendChild(this.cloneNode(true));I=J.innerHTML}return o.clean([I.replace(/ jQuery\d+="(?:\d+|null)"/g,"").replace(/^\s*/,"")])[0]}else{return this.cloneNode(true)}});if(G===true){var H=this.find("*").andSelf(),F=0;E.find("*").andSelf().each(function(){if(this.nodeName!==H[F].nodeName){return}var I=o.data(H[F],"events");for(var K in I){for(var J in I[K]){o.event.add(this,K,I[K][J],I[K][J].data)}}F++})}return E},filter:function(E){return this.pushStack(o.isFunction(E)&&o.grep(this,function(G,F){return E.call(G,F)})||o.multiFilter(E,o.grep(this,function(F){return F.nodeType===1})),"filter",E)},closest:function(E){var G=o.expr.match.POS.test(E)?o(E):null,F=0;return this.map(function(){var H=this;while(H&&H.ownerDocument){if(G?G.index(H)>-1:o(H).is(E)){o.data(H,"closest",F);return H}H=H.parentNode;F++}})},not:function(E){if(typeof E==="string"){if(f.test(E)){return this.pushStack(o.multiFilter(E,this,true),"not",E)}else{E=o.multiFilter(E,this)}}var F=E.length&&E[E.length-1]!==g&&!E.nodeType;return this.filter(function(){return F?o.inArray(this,E)<0:this!=E})},add:function(E){return this.pushStack(o.unique(o.merge(this.get(),typeof E==="string"?o(E):o.makeArray(E))))},is:function(E){return !!E&&o.multiFilter(E,this).length>0},hasClass:function(E){return !!E&&this.is("."+E)},val:function(K){if(K===g){var E=this[0];if(E){if(o.nodeName(E,"option")){return(E.attributes.value||{}).specified?E.value:E.text}if(o.nodeName(E,"select")){var I=E.selectedIndex,L=[],M=E.options,H=E.type=="select-one";if(I<0){return null}for(var F=H?I:0,J=H?I+1:M.length;F<J;F++){var G=M[F];if(G.selected){K=o(G).val();if(H){return K}L.push(K)}}return L}return(E.value||"").replace(/\r/g,"")}return g}if(typeof K==="number"){K+=""}return this.each(function(){if(this.nodeType!=1){return}if(o.isArray(K)&&/radio|checkbox/.test(this.type)){this.checked=(o.inArray(this.value,K)>=0||o.inArray(this.name,K)>=0)}else{if(o.nodeName(this,"select")){var N=o.makeArray(K);o("option",this).each(function(){this.selected=(o.inArray(this.value,N)>=0||o.inArray(this.text,N)>=0)});if(!N.length){this.selectedIndex=-1}}else{this.value=K}}})},html:function(E){return E===g?(this[0]?this[0].innerHTML.replace(/ jQuery\d+="(?:\d+|null)"/g,""):null):this.empty().append(E)},replaceWith:function(E){return this.after(E).remove()},eq:function(E){return this.slice(E,+E+1)},slice:function(){return this.pushStack(Array.prototype.slice.apply(this,arguments),"slice",Array.prototype.slice.call(arguments).join(","))},map:function(E){return this.pushStack(o.map(this,function(G,F){return E.call(G,F,G)}))},andSelf:function(){return this.add(this.prevObject)},domManip:function(J,M,L){if(this[0]){var I=(this[0].ownerDocument||this[0]).createDocumentFragment(),F=o.clean(J,(this[0].ownerDocument||this[0]),I),H=I.firstChild;if(H){for(var G=0,E=this.length;G<E;G++){L.call(K(this[G],H),this.length>1||G>0?I.cloneNode(true):I)}}if(F){o.each(F,z)}}return this;function K(N,O){return M&&o.nodeName(N,"table")&&o.nodeName(O,"tr")?(N.getElementsByTagName("tbody")[0]||N.appendChild(N.ownerDocument.createElement("tbody"))):N}}};o.fn.init.prototype=o.fn;function z(E,F){if(F.src){o.ajax({url:F.src,async:false,dataType:"script"})}else{o.globalEval(F.text||F.textContent||F.innerHTML||"")}if(F.parentNode){F.parentNode.removeChild(F)}}function e(){return +new Date}o.extend=o.fn.extend=function(){var J=arguments[0]||{},H=1,I=arguments.length,E=false,G;if(typeof J==="boolean"){E=J;J=arguments[1]||{};H=2}if(typeof J!=="object"&&!o.isFunction(J)){J={}}if(I==H){J=this;--H}for(;H<I;H++){if((G=arguments[H])!=null){for(var F in G){var K=J[F],L=G[F];if(J===L){continue}if(E&&L&&typeof L==="object"&&!L.nodeType){J[F]=o.extend(E,K||(L.length!=null?[]:{}),L)}else{if(L!==g){J[F]=L}}}}}return J};var b=/z-?index|font-?weight|opacity|zoom|line-?height/i,q=document.defaultView||{},s=Object.prototype.toString;o.extend({noConflict:function(E){l.$=p;if(E){l.jQuery=y}return o},isFunction:function(E){return s.call(E)==="[object Function]"},isArray:function(E){return s.call(E)==="[object Array]"},isXMLDoc:function(E){return E.nodeType===9&&E.documentElement.nodeName!=="HTML"||!!E.ownerDocument&&o.isXMLDoc(E.ownerDocument)},globalEval:function(G){if(G&&/\S/.test(G)){var F=document.getElementsByTagName("head")[0]||document.documentElement,E=document.createElement("script");E.type="text/javascript";if(o.support.scriptEval){E.appendChild(document.createTextNode(G))}else{E.text=G}F.insertBefore(E,F.firstChild);F.removeChild(E)}},nodeName:function(F,E){return F.nodeName&&F.nodeName.toUpperCase()==E.toUpperCase()},each:function(G,K,F){var E,H=0,I=G.length;if(F){if(I===g){for(E in G){if(K.apply(G[E],F)===false){break}}}else{for(;H<I;){if(K.apply(G[H++],F)===false){break}}}}else{if(I===g){for(E in G){if(K.call(G[E],E,G[E])===false){break}}}else{for(var J=G[0];H<I&&K.call(J,H,J)!==false;J=G[++H]){}}}return G},prop:function(H,I,G,F,E){if(o.isFunction(I)){I=I.call(H,F)}return typeof I==="number"&&G=="curCSS"&&!b.test(E)?I+"px":I},className:{add:function(E,F){o.each((F||"").split(/\s+/),function(G,H){if(E.nodeType==1&&!o.className.has(E.className,H)){E.className+=(E.className?" ":"")+H}})},remove:function(E,F){if(E.nodeType==1){E.className=F!==g?o.grep(E.className.split(/\s+/),function(G){return !o.className.has(F,G)}).join(" "):""}},has:function(F,E){return F&&o.inArray(E,(F.className||F).toString().split(/\s+/))>-1}},swap:function(H,G,I){var E={};for(var F in G){E[F]=H.style[F];H.style[F]=G[F]}I.call(H);for(var F in G){H.style[F]=E[F]}},css:function(H,F,J,E){if(F=="width"||F=="height"){var L,G={position:"absolute",visibility:"hidden",display:"block"},K=F=="width"?["Left","Right"]:["Top","Bottom"];function I(){L=F=="width"?H.offsetWidth:H.offsetHeight;if(E==="border"){return}o.each(K,function(){if(!E){L-=parseFloat(o.curCSS(H,"padding"+this,true))||0}if(E==="margin"){L+=parseFloat(o.curCSS(H,"margin"+this,true))||0}else{L-=parseFloat(o.curCSS(H,"border"+this+"Width",true))||0}})}if(H.offsetWidth!==0){I()}else{o.swap(H,G,I)}return Math.max(0,Math.round(L))}return o.curCSS(H,F,J)},curCSS:function(I,F,G){var L,E=I.style;if(F=="opacity"&&!o.support.opacity){L=o.attr(E,"opacity");return L==""?"1":L}if(F.match(/float/i)){F=w}if(!G&&E&&E[F]){L=E[F]}else{if(q.getComputedStyle){if(F.match(/float/i)){F="float"}F=F.replace(/([A-Z])/g,"-$1").toLowerCase();var M=q.getComputedStyle(I,null);if(M){L=M.getPropertyValue(F)}if(F=="opacity"&&L==""){L="1"}}else{if(I.currentStyle){var J=F.replace(/\-(\w)/g,function(N,O){return O.toUpperCase()});L=I.currentStyle[F]||I.currentStyle[J];if(!/^\d+(px)?$/i.test(L)&&/^\d/.test(L)){var H=E.left,K=I.runtimeStyle.left;I.runtimeStyle.left=I.currentStyle.left;E.left=L||0;L=E.pixelLeft+"px";E.left=H;I.runtimeStyle.left=K}}}}return L},clean:function(F,K,I){K=K||document;if(typeof K.createElement==="undefined"){K=K.ownerDocument||K[0]&&K[0].ownerDocument||document}if(!I&&F.length===1&&typeof F[0]==="string"){var H=/^<(\w+)\s*\/?>$/.exec(F[0]);if(H){return[K.createElement(H[1])]}}var G=[],E=[],L=K.createElement("div");o.each(F,function(P,S){if(typeof S==="number"){S+=""}if(!S){return}if(typeof S==="string"){S=S.replace(/(<(\w+)[^>]*?)\/>/g,function(U,V,T){return T.match(/^(abbr|br|col|img|input|link|meta|param|hr|area|embed)$/i)?U:V+"></"+T+">"});var O=S.replace(/^\s+/,"").substring(0,10).toLowerCase();var Q=!O.indexOf("<opt")&&[1,"<select multiple='multiple'>","</select>"]||!O.indexOf("<leg")&&[1,"<fieldset>","</fieldset>"]||O.match(/^<(thead|tbody|tfoot|colg|cap)/)&&[1,"<table>","</table>"]||!O.indexOf("<tr")&&[2,"<table><tbody>","</tbody></table>"]||(!O.indexOf("<td")||!O.indexOf("<th"))&&[3,"<table><tbody><tr>","</tr></tbody></table>"]||!O.indexOf("<col")&&[2,"<table><tbody></tbody><colgroup>","</colgroup></table>"]||!o.support.htmlSerialize&&[1,"div<div>","</div>"]||[0,"",""];L.innerHTML=Q[1]+S+Q[2];while(Q[0]--){L=L.lastChild}if(!o.support.tbody){var R=/<tbody/i.test(S),N=!O.indexOf("<table")&&!R?L.firstChild&&L.firstChild.childNodes:Q[1]=="<table>"&&!R?L.childNodes:[];for(var M=N.length-1;M>=0;--M){if(o.nodeName(N[M],"tbody")&&!N[M].childNodes.length){N[M].parentNode.removeChild(N[M])}}}if(!o.support.leadingWhitespace&&/^\s/.test(S)){L.insertBefore(K.createTextNode(S.match(/^\s*/)[0]),L.firstChild)}S=o.makeArray(L.childNodes)}if(S.nodeType){G.push(S)}else{G=o.merge(G,S)}});if(I){for(var J=0;G[J];J++){if(o.nodeName(G[J],"script")&&(!G[J].type||G[J].type.toLowerCase()==="text/javascript")){E.push(G[J].parentNode?G[J].parentNode.removeChild(G[J]):G[J])}else{if(G[J].nodeType===1){G.splice.apply(G,[J+1,0].concat(o.makeArray(G[J].getElementsByTagName("script"))))}I.appendChild(G[J])}}return E}return G},attr:function(J,G,K){if(!J||J.nodeType==3||J.nodeType==8){return g}var H=!o.isXMLDoc(J),L=K!==g;G=H&&o.props[G]||G;if(J.tagName){var F=/href|src|style/.test(G);if(G=="selected"&&J.parentNode){J.parentNode.selectedIndex}if(G in J&&H&&!F){if(L){if(G=="type"&&o.nodeName(J,"input")&&J.parentNode){throw"type property can't be changed"}J[G]=K}if(o.nodeName(J,"form")&&J.getAttributeNode(G)){return J.getAttributeNode(G).nodeValue}if(G=="tabIndex"){var I=J.getAttributeNode("tabIndex");return I&&I.specified?I.value:J.nodeName.match(/(button|input|object|select|textarea)/i)?0:J.nodeName.match(/^(a|area)$/i)&&J.href?0:g}return J[G]}if(!o.support.style&&H&&G=="style"){return o.attr(J.style,"cssText",K)}if(L){J.setAttribute(G,""+K)}var E=!o.support.hrefNormalized&&H&&F?J.getAttribute(G,2):J.getAttribute(G);return E===null?g:E}if(!o.support.opacity&&G=="opacity"){if(L){J.zoom=1;J.filter=(J.filter||"").replace(/alpha\([^)]*\)/,"")+(parseInt(K)+""=="NaN"?"":"alpha(opacity="+K*100+")")}return J.filter&&J.filter.indexOf("opacity=")>=0?(parseFloat(J.filter.match(/opacity=([^)]*)/)[1])/100)+"":""}G=G.replace(/-([a-z])/ig,function(M,N){return N.toUpperCase()});if(L){J[G]=K}return J[G]},trim:function(E){return(E||"").replace(/^\s+|\s+$/g,"")},makeArray:function(G){var E=[];if(G!=null){var F=G.length;if(F==null||typeof G==="string"||o.isFunction(G)||G.setInterval){E[0]=G}else{while(F){E[--F]=G[F]}}}return E},inArray:function(G,H){for(var E=0,F=H.length;E<F;E++){if(H[E]===G){return E}}return -1},merge:function(H,E){var F=0,G,I=H.length;if(!o.support.getAll){while((G=E[F++])!=null){if(G.nodeType!=8){H[I++]=G}}}else{while((G=E[F++])!=null){H[I++]=G}}return H},unique:function(K){var F=[],E={};try{for(var G=0,H=K.length;G<H;G++){var J=o.data(K[G]);if(!E[J]){E[J]=true;F.push(K[G])}}}catch(I){F=K}return F},grep:function(F,J,E){var G=[];for(var H=0,I=F.length;H<I;H++){if(!E!=!J(F[H],H)){G.push(F[H])}}return G},map:function(E,J){var F=[];for(var G=0,H=E.length;G<H;G++){var I=J(E[G],G);if(I!=null){F[F.length]=I}}return F.concat.apply([],F)}});var C=navigator.userAgent.toLowerCase();o.browser={version:(C.match(/.+(?:rv|it|ra|ie)[\/: ]([\d.]+)/)||[0,"0"])[1],safari:/webkit/.test(C),opera:/opera/.test(C),msie:/msie/.test(C)&&!/opera/.test(C),mozilla:/mozilla/.test(C)&&!/(compatible|webkit)/.test(C)};o.each({parent:function(E){return E.parentNode},parents:function(E){return o.dir(E,"parentNode")},next:function(E){return o.nth(E,2,"nextSibling")},prev:function(E){return o.nth(E,2,"previousSibling")},nextAll:function(E){return o.dir(E,"nextSibling")},prevAll:function(E){return o.dir(E,"previousSibling")},siblings:function(E){return o.sibling(E.parentNode.firstChild,E)},children:function(E){return o.sibling(E.firstChild)},contents:function(E){return o.nodeName(E,"iframe")?E.contentDocument||E.contentWindow.document:o.makeArray(E.childNodes)}},function(E,F){o.fn[E]=function(G){var H=o.map(this,F);if(G&&typeof G=="string"){H=o.multiFilter(G,H)}return this.pushStack(o.unique(H),E,G)}});o.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(E,F){o.fn[E]=function(G){var J=[],L=o(G);for(var K=0,H=L.length;K<H;K++){var I=(K>0?this.clone(true):this).get();o.fn[F].apply(o(L[K]),I);J=J.concat(I)}return this.pushStack(J,E,G)}});o.each({removeAttr:function(E){o.attr(this,E,"");if(this.nodeType==1){this.removeAttribute(E)}},addClass:function(E){o.className.add(this,E)},removeClass:function(E){o.className.remove(this,E)},toggleClass:function(F,E){if(typeof E!=="boolean"){E=!o.className.has(this,F)}o.className[E?"add":"remove"](this,F)},remove:function(E){if(!E||o.filter(E,[this]).length){o("*",this).add([this]).each(function(){o.event.remove(this);o.removeData(this)});if(this.parentNode){this.parentNode.removeChild(this)}}},empty:function(){o(this).children().remove();while(this.firstChild){this.removeChild(this.firstChild)}}},function(E,F){o.fn[E]=function(){return this.each(F,arguments)}});function j(E,F){return E[0]&&parseInt(o.curCSS(E[0],F,true),10)||0}var h="jQuery"+e(),v=0,A={};o.extend({cache:{},data:function(F,E,G){F=F==l?A:F;var H=F[h];if(!H){H=F[h]=++v}if(E&&!o.cache[H]){o.cache[H]={}}if(G!==g){o.cache[H][E]=G}return E?o.cache[H][E]:H},removeData:function(F,E){F=F==l?A:F;var H=F[h];if(E){if(o.cache[H]){delete o.cache[H][E];E="";for(E in o.cache[H]){break}if(!E){o.removeData(F)}}}else{try{delete F[h]}catch(G){if(F.removeAttribute){F.removeAttribute(h)}}delete o.cache[H]}},queue:function(F,E,H){if(F){E=(E||"fx")+"queue";var G=o.data(F,E);if(!G||o.isArray(H)){G=o.data(F,E,o.makeArray(H))}else{if(H){G.push(H)}}}return G},dequeue:function(H,G){var E=o.queue(H,G),F=E.shift();if(!G||G==="fx"){F=E[0]}if(F!==g){F.call(H)}}});o.fn.extend({data:function(E,G){var H=E.split(".");H[1]=H[1]?"."+H[1]:"";if(G===g){var F=this.triggerHandler("getData"+H[1]+"!",[H[0]]);if(F===g&&this.length){F=o.data(this[0],E)}return F===g&&H[1]?this.data(H[0]):F}else{return this.trigger("setData"+H[1]+"!",[H[0],G]).each(function(){o.data(this,E,G)})}},removeData:function(E){return this.each(function(){o.removeData(this,E)})},queue:function(E,F){if(typeof E!=="string"){F=E;E="fx"}if(F===g){return o.queue(this[0],E)}return this.each(function(){var G=o.queue(this,E,F);if(E=="fx"&&G.length==1){G[0].call(this)}})},dequeue:function(E){return this.each(function(){o.dequeue(this,E)})}});
      (function(){var R=/((?:\((?:\([^()]+\)|[^()]+)+\)|\[(?:\[[^[\]]*\]|['"][^'"]*['"]|[^[\]'"]+)+\]|\\.|[^ >+~,(\[\\]+)+|[>+~])(\s*,\s*)?/g,L=0,H=Object.prototype.toString;var F=function(Y,U,ab,ac){ab=ab||[];U=U||document;if(U.nodeType!==1&&U.nodeType!==9){return[]}if(!Y||typeof Y!=="string"){return ab}var Z=[],W,af,ai,T,ad,V,X=true;R.lastIndex=0;while((W=R.exec(Y))!==null){Z.push(W[1]);if(W[2]){V=RegExp.rightContext;break}}if(Z.length>1&&M.exec(Y)){if(Z.length===2&&I.relative[Z[0]]){af=J(Z[0]+Z[1],U)}else{af=I.relative[Z[0]]?[U]:F(Z.shift(),U);while(Z.length){Y=Z.shift();if(I.relative[Y]){Y+=Z.shift()}af=J(Y,af)}}}else{var ae=ac?{expr:Z.pop(),set:E(ac)}:F.find(Z.pop(),Z.length===1&&U.parentNode?U.parentNode:U,Q(U));af=F.filter(ae.expr,ae.set);if(Z.length>0){ai=E(af)}else{X=false}while(Z.length){var ah=Z.pop(),ag=ah;if(!I.relative[ah]){ah=""}else{ag=Z.pop()}if(ag==null){ag=U}I.relative[ah](ai,ag,Q(U))}}if(!ai){ai=af}if(!ai){throw"Syntax error, unrecognized expression: "+(ah||Y)}if(H.call(ai)==="[object Array]"){if(!X){ab.push.apply(ab,ai)}else{if(U.nodeType===1){for(var aa=0;ai[aa]!=null;aa++){if(ai[aa]&&(ai[aa]===true||ai[aa].nodeType===1&&K(U,ai[aa]))){ab.push(af[aa])}}}else{for(var aa=0;ai[aa]!=null;aa++){if(ai[aa]&&ai[aa].nodeType===1){ab.push(af[aa])}}}}}else{E(ai,ab)}if(V){F(V,U,ab,ac);if(G){hasDuplicate=false;ab.sort(G);if(hasDuplicate){for(var aa=1;aa<ab.length;aa++){if(ab[aa]===ab[aa-1]){ab.splice(aa--,1)}}}}}return ab};F.matches=function(T,U){return F(T,null,null,U)};F.find=function(aa,T,ab){var Z,X;if(!aa){return[]}for(var W=0,V=I.order.length;W<V;W++){var Y=I.order[W],X;if((X=I.match[Y].exec(aa))){var U=RegExp.leftContext;if(U.substr(U.length-1)!=="\\"){X[1]=(X[1]||"").replace(/\\/g,"");Z=I.find[Y](X,T,ab);if(Z!=null){aa=aa.replace(I.match[Y],"");break}}}}if(!Z){Z=T.getElementsByTagName("*")}return{set:Z,expr:aa}};F.filter=function(ad,ac,ag,W){var V=ad,ai=[],aa=ac,Y,T,Z=ac&&ac[0]&&Q(ac[0]);while(ad&&ac.length){for(var ab in I.filter){if((Y=I.match[ab].exec(ad))!=null){var U=I.filter[ab],ah,af;T=false;if(aa==ai){ai=[]}if(I.preFilter[ab]){Y=I.preFilter[ab](Y,aa,ag,ai,W,Z);if(!Y){T=ah=true}else{if(Y===true){continue}}}if(Y){for(var X=0;(af=aa[X])!=null;X++){if(af){ah=U(af,Y,X,aa);var ae=W^!!ah;if(ag&&ah!=null){if(ae){T=true}else{aa[X]=false}}else{if(ae){ai.push(af);T=true}}}}}if(ah!==g){if(!ag){aa=ai}ad=ad.replace(I.match[ab],"");if(!T){return[]}break}}}if(ad==V){if(T==null){throw"Syntax error, unrecognized expression: "+ad}else{break}}V=ad}return aa};var I=F.selectors={order:["ID","NAME","TAG"],match:{ID:/#((?:[\w\u00c0-\uFFFF_-]|\\.)+)/,CLASS:/\.((?:[\w\u00c0-\uFFFF_-]|\\.)+)/,NAME:/\[name=['"]*((?:[\w\u00c0-\uFFFF_-]|\\.)+)['"]*\]/,ATTR:/\[\s*((?:[\w\u00c0-\uFFFF_-]|\\.)+)\s*(?:(\S?=)\s*(['"]*)(.*?)\3|)\s*\]/,TAG:/^((?:[\w\u00c0-\uFFFF\*_-]|\\.)+)/,CHILD:/:(only|nth|last|first)-child(?:\((even|odd|[\dn+-]*)\))?/,POS:/:(nth|eq|gt|lt|first|last|even|odd)(?:\((\d*)\))?(?=[^-]|$)/,PSEUDO:/:((?:[\w\u00c0-\uFFFF_-]|\\.)+)(?:\((['"]*)((?:\([^\)]+\)|[^\2\(\)]*)+)\2\))?/},attrMap:{"class":"className","for":"htmlFor"},attrHandle:{href:function(T){return T.getAttribute("href")}},relative:{"+":function(aa,T,Z){var X=typeof T==="string",ab=X&&!/\W/.test(T),Y=X&&!ab;if(ab&&!Z){T=T.toUpperCase()}for(var W=0,V=aa.length,U;W<V;W++){if((U=aa[W])){while((U=U.previousSibling)&&U.nodeType!==1){}aa[W]=Y||U&&U.nodeName===T?U||false:U===T}}if(Y){F.filter(T,aa,true)}},">":function(Z,U,aa){var X=typeof U==="string";if(X&&!/\W/.test(U)){U=aa?U:U.toUpperCase();for(var V=0,T=Z.length;V<T;V++){var Y=Z[V];if(Y){var W=Y.parentNode;Z[V]=W.nodeName===U?W:false}}}else{for(var V=0,T=Z.length;V<T;V++){var Y=Z[V];if(Y){Z[V]=X?Y.parentNode:Y.parentNode===U}}if(X){F.filter(U,Z,true)}}},"":function(W,U,Y){var V=L++,T=S;if(!U.match(/\W/)){var X=U=Y?U:U.toUpperCase();T=P}T("parentNode",U,V,W,X,Y)},"~":function(W,U,Y){var V=L++,T=S;if(typeof U==="string"&&!U.match(/\W/)){var X=U=Y?U:U.toUpperCase();T=P}T("previousSibling",U,V,W,X,Y)}},find:{ID:function(U,V,W){if(typeof V.getElementById!=="undefined"&&!W){var T=V.getElementById(U[1]);return T?[T]:[]}},NAME:function(V,Y,Z){if(typeof Y.getElementsByName!=="undefined"){var U=[],X=Y.getElementsByName(V[1]);for(var W=0,T=X.length;W<T;W++){if(X[W].getAttribute("name")===V[1]){U.push(X[W])}}return U.length===0?null:U}},TAG:function(T,U){return U.getElementsByTagName(T[1])}},preFilter:{CLASS:function(W,U,V,T,Z,aa){W=" "+W[1].replace(/\\/g,"")+" ";if(aa){return W}for(var X=0,Y;(Y=U[X])!=null;X++){if(Y){if(Z^(Y.className&&(" "+Y.className+" ").indexOf(W)>=0)){if(!V){T.push(Y)}}else{if(V){U[X]=false}}}}return false},ID:function(T){return T[1].replace(/\\/g,"")},TAG:function(U,T){for(var V=0;T[V]===false;V++){}return T[V]&&Q(T[V])?U[1]:U[1].toUpperCase()},CHILD:function(T){if(T[1]=="nth"){var U=/(-?)(\d*)n((?:\+|-)?\d*)/.exec(T[2]=="even"&&"2n"||T[2]=="odd"&&"2n+1"||!/\D/.test(T[2])&&"0n+"+T[2]||T[2]);T[2]=(U[1]+(U[2]||1))-0;T[3]=U[3]-0}T[0]=L++;return T},ATTR:function(X,U,V,T,Y,Z){var W=X[1].replace(/\\/g,"");if(!Z&&I.attrMap[W]){X[1]=I.attrMap[W]}if(X[2]==="~="){X[4]=" "+X[4]+" "}return X},PSEUDO:function(X,U,V,T,Y){if(X[1]==="not"){if(X[3].match(R).length>1||/^\w/.test(X[3])){X[3]=F(X[3],null,null,U)}else{var W=F.filter(X[3],U,V,true^Y);if(!V){T.push.apply(T,W)}return false}}else{if(I.match.POS.test(X[0])||I.match.CHILD.test(X[0])){return true}}return X},POS:function(T){T.unshift(true);return T}},filters:{enabled:function(T){return T.disabled===false&&T.type!=="hidden"},disabled:function(T){return T.disabled===true},checked:function(T){return T.checked===true},selected:function(T){T.parentNode.selectedIndex;return T.selected===true},parent:function(T){return !!T.firstChild},empty:function(T){return !T.firstChild},has:function(V,U,T){return !!F(T[3],V).length},header:function(T){return/h\d/i.test(T.nodeName)},text:function(T){return"text"===T.type},radio:function(T){return"radio"===T.type},checkbox:function(T){return"checkbox"===T.type},file:function(T){return"file"===T.type},password:function(T){return"password"===T.type},submit:function(T){return"submit"===T.type},image:function(T){return"image"===T.type},reset:function(T){return"reset"===T.type},button:function(T){return"button"===T.type||T.nodeName.toUpperCase()==="BUTTON"},input:function(T){return/input|select|textarea|button/i.test(T.nodeName)}},setFilters:{first:function(U,T){return T===0},last:function(V,U,T,W){return U===W.length-1},even:function(U,T){return T%2===0},odd:function(U,T){return T%2===1},lt:function(V,U,T){return U<T[3]-0},gt:function(V,U,T){return U>T[3]-0},nth:function(V,U,T){return T[3]-0==U},eq:function(V,U,T){return T[3]-0==U}},filter:{PSEUDO:function(Z,V,W,aa){var U=V[1],X=I.filters[U];if(X){return X(Z,W,V,aa)}else{if(U==="contains"){return(Z.textContent||Z.innerText||"").indexOf(V[3])>=0}else{if(U==="not"){var Y=V[3];for(var W=0,T=Y.length;W<T;W++){if(Y[W]===Z){return false}}return true}}}},CHILD:function(T,W){var Z=W[1],U=T;switch(Z){case"only":case"first":while(U=U.previousSibling){if(U.nodeType===1){return false}}if(Z=="first"){return true}U=T;case"last":while(U=U.nextSibling){if(U.nodeType===1){return false}}return true;case"nth":var V=W[2],ac=W[3];if(V==1&&ac==0){return true}var Y=W[0],ab=T.parentNode;if(ab&&(ab.sizcache!==Y||!T.nodeIndex)){var X=0;for(U=ab.firstChild;U;U=U.nextSibling){if(U.nodeType===1){U.nodeIndex=++X}}ab.sizcache=Y}var aa=T.nodeIndex-ac;if(V==0){return aa==0}else{return(aa%V==0&&aa/V>=0)}}},ID:function(U,T){return U.nodeType===1&&U.getAttribute("id")===T},TAG:function(U,T){return(T==="*"&&U.nodeType===1)||U.nodeName===T},CLASS:function(U,T){return(" "+(U.className||U.getAttribute("class"))+" ").indexOf(T)>-1},ATTR:function(Y,W){var V=W[1],T=I.attrHandle[V]?I.attrHandle[V](Y):Y[V]!=null?Y[V]:Y.getAttribute(V),Z=T+"",X=W[2],U=W[4];return T==null?X==="!=":X==="="?Z===U:X==="*="?Z.indexOf(U)>=0:X==="~="?(" "+Z+" ").indexOf(U)>=0:!U?Z&&T!==false:X==="!="?Z!=U:X==="^="?Z.indexOf(U)===0:X==="$="?Z.substr(Z.length-U.length)===U:X==="|="?Z===U||Z.substr(0,U.length+1)===U+"-":false},POS:function(X,U,V,Y){var T=U[2],W=I.setFilters[T];if(W){return W(X,V,U,Y)}}}};var M=I.match.POS;for(var O in I.match){I.match[O]=RegExp(I.match[O].source+/(?![^\[]*\])(?![^\(]*\))/.source)}var E=function(U,T){U=Array.prototype.slice.call(U);if(T){T.push.apply(T,U);return T}return U};try{Array.prototype.slice.call(document.documentElement.childNodes)}catch(N){E=function(X,W){var U=W||[];if(H.call(X)==="[object Array]"){Array.prototype.push.apply(U,X)}else{if(typeof X.length==="number"){for(var V=0,T=X.length;V<T;V++){U.push(X[V])}}else{for(var V=0;X[V];V++){U.push(X[V])}}}return U}}var G;if(document.documentElement.compareDocumentPosition){G=function(U,T){var V=U.compareDocumentPosition(T)&4?-1:U===T?0:1;if(V===0){hasDuplicate=true}return V}}else{if("sourceIndex" in document.documentElement){G=function(U,T){var V=U.sourceIndex-T.sourceIndex;if(V===0){hasDuplicate=true}return V}}else{if(document.createRange){G=function(W,U){var V=W.ownerDocument.createRange(),T=U.ownerDocument.createRange();V.selectNode(W);V.collapse(true);T.selectNode(U);T.collapse(true);var X=V.compareBoundaryPoints(Range.START_TO_END,T);if(X===0){hasDuplicate=true}return X}}}}(function(){var U=document.createElement("form"),V="script"+(new Date).getTime();U.innerHTML="<input name='"+V+"'/>";var T=document.documentElement;T.insertBefore(U,T.firstChild);if(!!document.getElementById(V)){I.find.ID=function(X,Y,Z){if(typeof Y.getElementById!=="undefined"&&!Z){var W=Y.getElementById(X[1]);return W?W.id===X[1]||typeof W.getAttributeNode!=="undefined"&&W.getAttributeNode("id").nodeValue===X[1]?[W]:g:[]}};I.filter.ID=function(Y,W){var X=typeof Y.getAttributeNode!=="undefined"&&Y.getAttributeNode("id");return Y.nodeType===1&&X&&X.nodeValue===W}}T.removeChild(U)})();(function(){var T=document.createElement("div");T.appendChild(document.createComment(""));if(T.getElementsByTagName("*").length>0){I.find.TAG=function(U,Y){var X=Y.getElementsByTagName(U[1]);if(U[1]==="*"){var W=[];for(var V=0;X[V];V++){if(X[V].nodeType===1){W.push(X[V])}}X=W}return X}}T.innerHTML="<a href='#'></a>";if(T.firstChild&&typeof T.firstChild.getAttribute!=="undefined"&&T.firstChild.getAttribute("href")!=="#"){I.attrHandle.href=function(U){return U.getAttribute("href",2)}}})();if(document.querySelectorAll){(function(){var T=F,U=document.createElement("div");U.innerHTML="<p class='TEST'></p>";if(U.querySelectorAll&&U.querySelectorAll(".TEST").length===0){return}F=function(Y,X,V,W){X=X||document;if(!W&&X.nodeType===9&&!Q(X)){try{return E(X.querySelectorAll(Y),V)}catch(Z){}}return T(Y,X,V,W)};F.find=T.find;F.filter=T.filter;F.selectors=T.selectors;F.matches=T.matches})()}if(document.getElementsByClassName&&document.documentElement.getElementsByClassName){(function(){var T=document.createElement("div");T.innerHTML="<div class='test e'></div><div class='test'></div>";if(T.getElementsByClassName("e").length===0){return}T.lastChild.className="e";if(T.getElementsByClassName("e").length===1){return}I.order.splice(1,0,"CLASS");I.find.CLASS=function(U,V,W){if(typeof V.getElementsByClassName!=="undefined"&&!W){return V.getElementsByClassName(U[1])}}})()}function P(U,Z,Y,ad,aa,ac){var ab=U=="previousSibling"&&!ac;for(var W=0,V=ad.length;W<V;W++){var T=ad[W];if(T){if(ab&&T.nodeType===1){T.sizcache=Y;T.sizset=W}T=T[U];var X=false;while(T){if(T.sizcache===Y){X=ad[T.sizset];break}if(T.nodeType===1&&!ac){T.sizcache=Y;T.sizset=W}if(T.nodeName===Z){X=T;break}T=T[U]}ad[W]=X}}}function S(U,Z,Y,ad,aa,ac){var ab=U=="previousSibling"&&!ac;for(var W=0,V=ad.length;W<V;W++){var T=ad[W];if(T){if(ab&&T.nodeType===1){T.sizcache=Y;T.sizset=W}T=T[U];var X=false;while(T){if(T.sizcache===Y){X=ad[T.sizset];break}if(T.nodeType===1){if(!ac){T.sizcache=Y;T.sizset=W}if(typeof Z!=="string"){if(T===Z){X=true;break}}else{if(F.filter(Z,[T]).length>0){X=T;break}}}T=T[U]}ad[W]=X}}}var K=document.compareDocumentPosition?function(U,T){return U.compareDocumentPosition(T)&16}:function(U,T){return U!==T&&(U.contains?U.contains(T):true)};var Q=function(T){return T.nodeType===9&&T.documentElement.nodeName!=="HTML"||!!T.ownerDocument&&Q(T.ownerDocument)};var J=function(T,aa){var W=[],X="",Y,V=aa.nodeType?[aa]:aa;while((Y=I.match.PSEUDO.exec(T))){X+=Y[0];T=T.replace(I.match.PSEUDO,"")}T=I.relative[T]?T+"*":T;for(var Z=0,U=V.length;Z<U;Z++){F(T,V[Z],W)}return F.filter(X,W)};o.find=F;o.filter=F.filter;o.expr=F.selectors;o.expr[":"]=o.expr.filters;F.selectors.filters.hidden=function(T){return T.offsetWidth===0||T.offsetHeight===0};F.selectors.filters.visible=function(T){return T.offsetWidth>0||T.offsetHeight>0};F.selectors.filters.animated=function(T){return o.grep(o.timers,function(U){return T===U.elem}).length};o.multiFilter=function(V,T,U){if(U){V=":not("+V+")"}return F.matches(V,T)};o.dir=function(V,U){var T=[],W=V[U];while(W&&W!=document){if(W.nodeType==1){T.push(W)}W=W[U]}return T};o.nth=function(X,T,V,W){T=T||1;var U=0;for(;X;X=X[V]){if(X.nodeType==1&&++U==T){break}}return X};o.sibling=function(V,U){var T=[];for(;V;V=V.nextSibling){if(V.nodeType==1&&V!=U){T.push(V)}}return T};return;l.Sizzle=F})();o.event={add:function(I,F,H,K){if(I.nodeType==3||I.nodeType==8){return}if(I.setInterval&&I!=l){I=l}if(!H.guid){H.guid=this.guid++}if(K!==g){var G=H;H=this.proxy(G);H.data=K}var E=o.data(I,"events")||o.data(I,"events",{}),J=o.data(I,"handle")||o.data(I,"handle",function(){return typeof o!=="undefined"&&!o.event.triggered?o.event.handle.apply(arguments.callee.elem,arguments):g});J.elem=I;o.each(F.split(/\s+/),function(M,N){var O=N.split(".");N=O.shift();H.type=O.slice().sort().join(".");var L=E[N];if(o.event.specialAll[N]){o.event.specialAll[N].setup.call(I,K,O)}if(!L){L=E[N]={};if(!o.event.special[N]||o.event.special[N].setup.call(I,K,O)===false){if(I.addEventListener){I.addEventListener(N,J,false)}else{if(I.attachEvent){I.attachEvent("on"+N,J)}}}}L[H.guid]=H;o.event.global[N]=true});I=null},guid:1,global:{},remove:function(K,H,J){if(K.nodeType==3||K.nodeType==8){return}var G=o.data(K,"events"),F,E;if(G){if(H===g||(typeof H==="string"&&H.charAt(0)==".")){for(var I in G){this.remove(K,I+(H||""))}}else{if(H.type){J=H.handler;H=H.type}o.each(H.split(/\s+/),function(M,O){var Q=O.split(".");O=Q.shift();var N=RegExp("(^|\\.)"+Q.slice().sort().join(".*\\.")+"(\\.|$)");if(G[O]){if(J){delete G[O][J.guid]}else{for(var P in G[O]){if(N.test(G[O][P].type)){delete G[O][P]}}}if(o.event.specialAll[O]){o.event.specialAll[O].teardown.call(K,Q)}for(F in G[O]){break}if(!F){if(!o.event.special[O]||o.event.special[O].teardown.call(K,Q)===false){if(K.removeEventListener){K.removeEventListener(O,o.data(K,"handle"),false)}else{if(K.detachEvent){K.detachEvent("on"+O,o.data(K,"handle"))}}}F=null;delete G[O]}}})}for(F in G){break}if(!F){var L=o.data(K,"handle");if(L){L.elem=null}o.removeData(K,"events");o.removeData(K,"handle")}}},trigger:function(I,K,H,E){var G=I.type||I;if(!E){I=typeof I==="object"?I[h]?I:o.extend(o.Event(G),I):o.Event(G);if(G.indexOf("!")>=0){I.type=G=G.slice(0,-1);I.exclusive=true}if(!H){I.stopPropagation();if(this.global[G]){o.each(o.cache,function(){if(this.events&&this.events[G]){o.event.trigger(I,K,this.handle.elem)}})}}if(!H||H.nodeType==3||H.nodeType==8){return g}I.result=g;I.target=H;K=o.makeArray(K);K.unshift(I)}I.currentTarget=H;var J=o.data(H,"handle");if(J){J.apply(H,K)}if((!H[G]||(o.nodeName(H,"a")&&G=="click"))&&H["on"+G]&&H["on"+G].apply(H,K)===false){I.result=false}if(!E&&H[G]&&!I.isDefaultPrevented()&&!(o.nodeName(H,"a")&&G=="click")){this.triggered=true;try{H[G]()}catch(L){}}this.triggered=false;if(!I.isPropagationStopped()){var F=H.parentNode||H.ownerDocument;if(F){o.event.trigger(I,K,F,true)}}},handle:function(K){var J,E;K=arguments[0]=o.event.fix(K||l.event);K.currentTarget=this;var L=K.type.split(".");K.type=L.shift();J=!L.length&&!K.exclusive;var I=RegExp("(^|\\.)"+L.slice().sort().join(".*\\.")+"(\\.|$)");E=(o.data(this,"events")||{})[K.type];for(var G in E){var H=E[G];if(J||I.test(H.type)){K.handler=H;K.data=H.data;var F=H.apply(this,arguments);if(F!==g){K.result=F;if(F===false){K.preventDefault();K.stopPropagation()}}if(K.isImmediatePropagationStopped()){break}}}},props:"altKey attrChange attrName bubbles button cancelable charCode clientX clientY ctrlKey currentTarget data detail eventPhase fromElement handler keyCode metaKey newValue originalTarget pageX pageY prevValue relatedNode relatedTarget screenX screenY shiftKey srcElement target toElement view wheelDelta which".split(" "),fix:function(H){if(H[h]){return H}var F=H;H=o.Event(F);for(var G=this.props.length,J;G;){J=this.props[--G];H[J]=F[J]}if(!H.target){H.target=H.srcElement||document}if(H.target.nodeType==3){H.target=H.target.parentNode}if(!H.relatedTarget&&H.fromElement){H.relatedTarget=H.fromElement==H.target?H.toElement:H.fromElement}if(H.pageX==null&&H.clientX!=null){var I=document.documentElement,E=document.body;H.pageX=H.clientX+(I&&I.scrollLeft||E&&E.scrollLeft||0)-(I.clientLeft||0);H.pageY=H.clientY+(I&&I.scrollTop||E&&E.scrollTop||0)-(I.clientTop||0)}if(!H.which&&((H.charCode||H.charCode===0)?H.charCode:H.keyCode)){H.which=H.charCode||H.keyCode}if(!H.metaKey&&H.ctrlKey){H.metaKey=H.ctrlKey}if(!H.which&&H.button){H.which=(H.button&1?1:(H.button&2?3:(H.button&4?2:0)))}return H},proxy:function(F,E){E=E||function(){return F.apply(this,arguments)};E.guid=F.guid=F.guid||E.guid||this.guid++;return E},special:{ready:{setup:B,teardown:function(){}}},specialAll:{live:{setup:function(E,F){o.event.add(this,F[0],c)},teardown:function(G){if(G.length){var E=0,F=RegExp("(^|\\.)"+G[0]+"(\\.|$)");o.each((o.data(this,"events").live||{}),function(){if(F.test(this.type)){E++}});if(E<1){o.event.remove(this,G[0],c)}}}}}};o.Event=function(E){if(!this.preventDefault){return new o.Event(E)}if(E&&E.type){this.originalEvent=E;this.type=E.type}else{this.type=E}this.timeStamp=e();this[h]=true};function k(){return false}function u(){return true}o.Event.prototype={preventDefault:function(){this.isDefaultPrevented=u;var E=this.originalEvent;if(!E){return}if(E.preventDefault){E.preventDefault()}E.returnValue=false},stopPropagation:function(){this.isPropagationStopped=u;var E=this.originalEvent;if(!E){return}if(E.stopPropagation){E.stopPropagation()}E.cancelBubble=true},stopImmediatePropagation:function(){this.isImmediatePropagationStopped=u;this.stopPropagation()},isDefaultPrevented:k,isPropagationStopped:k,isImmediatePropagationStopped:k};var a=function(F){var E=F.relatedTarget;while(E&&E!=this){try{E=E.parentNode}catch(G){E=this}}if(E!=this){F.type=F.data;o.event.handle.apply(this,arguments)}};o.each({mouseover:"mouseenter",mouseout:"mouseleave"},function(F,E){o.event.special[E]={setup:function(){o.event.add(this,F,a,E)},teardown:function(){o.event.remove(this,F,a)}}});o.fn.extend({bind:function(F,G,E){return F=="unload"?this.one(F,G,E):this.each(function(){o.event.add(this,F,E||G,E&&G)})},one:function(G,H,F){var E=o.event.proxy(F||H,function(I){o(this).unbind(I,E);return(F||H).apply(this,arguments)});return this.each(function(){o.event.add(this,G,E,F&&H)})},unbind:function(F,E){return this.each(function(){o.event.remove(this,F,E)})},trigger:function(E,F){return this.each(function(){o.event.trigger(E,F,this)})},triggerHandler:function(E,G){if(this[0]){var F=o.Event(E);F.preventDefault();F.stopPropagation();o.event.trigger(F,G,this[0]);return F.result}},toggle:function(G){var E=arguments,F=1;while(F<E.length){o.event.proxy(G,E[F++])}return this.click(o.event.proxy(G,function(H){this.lastToggle=(this.lastToggle||0)%F;H.preventDefault();return E[this.lastToggle++].apply(this,arguments)||false}))},hover:function(E,F){return this.mouseenter(E).mouseleave(F)},ready:function(E){B();if(o.isReady){E.call(document,o)}else{o.readyList.push(E)}return this},live:function(G,F){var E=o.event.proxy(F);E.guid+=this.selector+G;o(document).bind(i(G,this.selector),this.selector,E);return this},die:function(F,E){o(document).unbind(i(F,this.selector),E?{guid:E.guid+this.selector+F}:null);return this}});function c(H){var E=RegExp("(^|\\.)"+H.type+"(\\.|$)"),G=true,F=[];o.each(o.data(this,"events").live||[],function(I,J){if(E.test(J.type)){var K=o(H.target).closest(J.data)[0];if(K){F.push({elem:K,fn:J})}}});F.sort(function(J,I){return o.data(J.elem,"closest")-o.data(I.elem,"closest")});o.each(F,function(){if(this.fn.call(this.elem,H,this.fn.data)===false){return(G=false)}});return G}function i(F,E){return["live",F,E.replace(/\./g,"`").replace(/ /g,"|")].join(".")}o.extend({isReady:false,readyList:[],ready:function(){if(!o.isReady){o.isReady=true;if(o.readyList){o.each(o.readyList,function(){this.call(document,o)});o.readyList=null}o(document).triggerHandler("ready")}}});var x=false;function B(){if(x){return}x=true;if(document.addEventListener){document.addEventListener("DOMContentLoaded",function(){document.removeEventListener("DOMContentLoaded",arguments.callee,false);o.ready()},false)}else{if(document.attachEvent){document.attachEvent("onreadystatechange",function(){if(document.readyState==="complete"){document.detachEvent("onreadystatechange",arguments.callee);o.ready()}});if(document.documentElement.doScroll&&l==l.top){(function(){if(o.isReady){return}try{document.documentElement.doScroll("left")}catch(E){setTimeout(arguments.callee,0);return}o.ready()})()}}}o.event.add(l,"load",o.ready)}o.each(("blur,focus,load,resize,scroll,unload,click,dblclick,mousedown,mouseup,mousemove,mouseover,mouseout,mouseenter,mouseleave,change,select,submit,keydown,keypress,keyup,error").split(","),function(F,E){o.fn[E]=function(G){return G?this.bind(E,G):this.trigger(E)}});o(l).bind("unload",function(){for(var E in o.cache){if(E!=1&&o.cache[E].handle){o.event.remove(o.cache[E].handle.elem)}}});(function(){o.support={};var F=document.documentElement,G=document.createElement("script"),K=document.createElement("div"),J="script"+(new Date).getTime();K.style.display="none";K.innerHTML='   <link/><table></table><a href="/a" style="color:red;float:left;opacity:.5;">a</a><select><option>text</option></select><object><param/></object>';var H=K.getElementsByTagName("*"),E=K.getElementsByTagName("a")[0];if(!H||!H.length||!E){return}o.support={leadingWhitespace:K.firstChild.nodeType==3,tbody:!K.getElementsByTagName("tbody").length,objectAll:!!K.getElementsByTagName("object")[0].getElementsByTagName("*").length,htmlSerialize:!!K.getElementsByTagName("link").length,style:/red/.test(E.getAttribute("style")),hrefNormalized:E.getAttribute("href")==="/a",opacity:E.style.opacity==="0.5",cssFloat:!!E.style.cssFloat,scriptEval:false,noCloneEvent:true,boxModel:null};G.type="text/javascript";try{G.appendChild(document.createTextNode("window."+J+"=1;"))}catch(I){}F.insertBefore(G,F.firstChild);if(l[J]){o.support.scriptEval=true;delete l[J]}F.removeChild(G);if(K.attachEvent&&K.fireEvent){K.attachEvent("onclick",function(){o.support.noCloneEvent=false;K.detachEvent("onclick",arguments.callee)});K.cloneNode(true).fireEvent("onclick")}o(function(){var L=document.createElement("div");L.style.width=L.style.paddingLeft="1px";document.body.appendChild(L);o.boxModel=o.support.boxModel=L.offsetWidth===2;document.body.removeChild(L).style.display="none"})})();var w=o.support.cssFloat?"cssFloat":"styleFloat";o.props={"for":"htmlFor","class":"className","float":w,cssFloat:w,styleFloat:w,readonly:"readOnly",maxlength:"maxLength",cellspacing:"cellSpacing",rowspan:"rowSpan",tabindex:"tabIndex"};o.fn.extend({_load:o.fn.load,load:function(G,J,K){if(typeof G!=="string"){return this._load(G)}var I=G.indexOf(" ");if(I>=0){var E=G.slice(I,G.length);G=G.slice(0,I)}var H="GET";if(J){if(o.isFunction(J)){K=J;J=null}else{if(typeof J==="object"){J=o.param(J);H="POST"}}}var F=this;o.ajax({url:G,type:H,dataType:"html",data:J,complete:function(M,L){if(L=="success"||L=="notmodified"){F.html(E?o("<div/>").append(M.responseText.replace(/<script(.|\s)*?\/script>/g,"")).find(E):M.responseText)}if(K){F.each(K,[M.responseText,L,M])}}});return this},serialize:function(){return o.param(this.serializeArray())},serializeArray:function(){return this.map(function(){return this.elements?o.makeArray(this.elements):this}).filter(function(){return this.name&&!this.disabled&&(this.checked||/select|textarea/i.test(this.nodeName)||/text|hidden|password|search/i.test(this.type))}).map(function(E,F){var G=o(this).val();return G==null?null:o.isArray(G)?o.map(G,function(I,H){return{name:F.name,value:I}}):{name:F.name,value:G}}).get()}});o.each("ajaxStart,ajaxStop,ajaxComplete,ajaxError,ajaxSuccess,ajaxSend".split(","),function(E,F){o.fn[F]=function(G){return this.bind(F,G)}});var r=e();o.extend({get:function(E,G,H,F){if(o.isFunction(G)){H=G;G=null}return o.ajax({type:"GET",url:E,data:G,success:H,dataType:F})},getScript:function(E,F){return o.get(E,null,F,"script")},getJSON:function(E,F,G){return o.get(E,F,G,"json")},post:function(E,G,H,F){if(o.isFunction(G)){H=G;G={}}return o.ajax({type:"POST",url:E,data:G,success:H,dataType:F})},ajaxSetup:function(E){o.extend(o.ajaxSettings,E)},ajaxSettings:{url:location.href,global:true,type:"GET",contentType:"application/x-www-form-urlencoded",processData:true,async:true,xhr:function(){return l.ActiveXObject?new ActiveXObject("Microsoft.XMLHTTP"):new XMLHttpRequest()},accepts:{xml:"application/xml, text/xml",html:"text/html",script:"text/javascript, application/javascript",json:"application/json, text/javascript",text:"text/plain",_default:"*/*"}},lastModified:{},ajax:function(M){M=o.extend(true,M,o.extend(true,{},o.ajaxSettings,M));var W,F=/=\?(&|$)/g,R,V,G=M.type.toUpperCase();if(M.data&&M.processData&&typeof M.data!=="string"){M.data=o.param(M.data)}if(M.dataType=="jsonp"){if(G=="GET"){if(!M.url.match(F)){M.url+=(M.url.match(/\?/)?"&":"?")+(M.jsonp||"callback")+"=?"}}else{if(!M.data||!M.data.match(F)){M.data=(M.data?M.data+"&":"")+(M.jsonp||"callback")+"=?"}}M.dataType="json"}if(M.dataType=="json"&&(M.data&&M.data.match(F)||M.url.match(F))){W="jsonp"+r++;if(M.data){M.data=(M.data+"").replace(F,"="+W+"$1")}M.url=M.url.replace(F,"="+W+"$1");M.dataType="script";l[W]=function(X){V=X;I();L();l[W]=g;try{delete l[W]}catch(Y){}if(H){H.removeChild(T)}}}if(M.dataType=="script"&&M.cache==null){M.cache=false}if(M.cache===false&&G=="GET"){var E=e();var U=M.url.replace(/(\?|&)_=.*?(&|$)/,"$1_="+E+"$2");M.url=U+((U==M.url)?(M.url.match(/\?/)?"&":"?")+"_="+E:"")}if(M.data&&G=="GET"){M.url+=(M.url.match(/\?/)?"&":"?")+M.data;M.data=null}if(M.global&&!o.active++){o.event.trigger("ajaxStart")}var Q=/^(\w+:)?\/\/([^\/?#]+)/.exec(M.url);if(M.dataType=="script"&&G=="GET"&&Q&&(Q[1]&&Q[1]!=location.protocol||Q[2]!=location.host)){var H=document.getElementsByTagName("head")[0];var T=document.createElement("script");T.src=M.url;if(M.scriptCharset){T.charset=M.scriptCharset}if(!W){var O=false;T.onload=T.onreadystatechange=function(){if(!O&&(!this.readyState||this.readyState=="loaded"||this.readyState=="complete")){O=true;I();L();T.onload=T.onreadystatechange=null;H.removeChild(T)}}}H.appendChild(T);return g}var K=false;var J=M.xhr();if(M.username){J.open(G,M.url,M.async,M.username,M.password)}else{J.open(G,M.url,M.async)}try{if(M.data){J.setRequestHeader("Content-Type",M.contentType)}if(M.ifModified){J.setRequestHeader("If-Modified-Since",o.lastModified[M.url]||"Thu, 01 Jan 1970 00:00:00 GMT")}J.setRequestHeader("X-Requested-With","XMLHttpRequest");J.setRequestHeader("Accept",M.dataType&&M.accepts[M.dataType]?M.accepts[M.dataType]+", */*":M.accepts._default)}catch(S){}if(M.beforeSend&&M.beforeSend(J,M)===false){if(M.global&&!--o.active){o.event.trigger("ajaxStop")}J.abort();return false}if(M.global){o.event.trigger("ajaxSend",[J,M])}var N=function(X){if(J.readyState==0){if(P){clearInterval(P);P=null;if(M.global&&!--o.active){o.event.trigger("ajaxStop")}}}else{if(!K&&J&&(J.readyState==4||X=="timeout")){K=true;if(P){clearInterval(P);P=null}R=X=="timeout"?"timeout":!o.httpSuccess(J)?"error":M.ifModified&&o.httpNotModified(J,M.url)?"notmodified":"success";if(R=="success"){try{V=o.httpData(J,M.dataType,M)}catch(Z){R="parsererror"}}if(R=="success"){var Y;try{Y=J.getResponseHeader("Last-Modified")}catch(Z){}if(M.ifModified&&Y){o.lastModified[M.url]=Y}if(!W){I()}}else{o.handleError(M,J,R)}L();if(X){J.abort()}if(M.async){J=null}}}};if(M.async){var P=setInterval(N,13);if(M.timeout>0){setTimeout(function(){if(J&&!K){N("timeout")}},M.timeout)}}try{J.send(M.data)}catch(S){o.handleError(M,J,null,S)}if(!M.async){N()}function I(){if(M.success){M.success(V,R)}if(M.global){o.event.trigger("ajaxSuccess",[J,M])}}function L(){if(M.complete){M.complete(J,R)}if(M.global){o.event.trigger("ajaxComplete",[J,M])}if(M.global&&!--o.active){o.event.trigger("ajaxStop")}}return J},handleError:function(F,H,E,G){if(F.error){F.error(H,E,G)}if(F.global){o.event.trigger("ajaxError",[H,F,G])}},active:0,httpSuccess:function(F){try{return !F.status&&location.protocol=="file:"||(F.status>=200&&F.status<300)||F.status==304||F.status==1223}catch(E){}return false},httpNotModified:function(G,E){try{var H=G.getResponseHeader("Last-Modified");return G.status==304||H==o.lastModified[E]}catch(F){}return false},httpData:function(J,H,G){var F=J.getResponseHeader("content-type"),E=H=="xml"||!H&&F&&F.indexOf("xml")>=0,I=E?J.responseXML:J.responseText;if(E&&I.documentElement.tagName=="parsererror"){throw"parsererror"}if(G&&G.dataFilter){I=G.dataFilter(I,H)}if(typeof I==="string"){if(H=="script"){o.globalEval(I)}if(H=="json"){I=l["eval"]("("+I+")")}}return I},param:function(E){var G=[];function H(I,J){G[G.length]=encodeURIComponent(I)+"="+encodeURIComponent(J)}if(o.isArray(E)||E.jquery){o.each(E,function(){H(this.name,this.value)})}else{for(var F in E){if(o.isArray(E[F])){o.each(E[F],function(){H(F,this)})}else{H(F,o.isFunction(E[F])?E[F]():E[F])}}}return G.join("&").replace(/%20/g,"+")}});var m={},n,d=[["height","marginTop","marginBottom","paddingTop","paddingBottom"],["width","marginLeft","marginRight","paddingLeft","paddingRight"],["opacity"]];function t(F,E){var G={};o.each(d.concat.apply([],d.slice(0,E)),function(){G[this]=F});return G}o.fn.extend({show:function(J,L){if(J){return this.animate(t("show",3),J,L)}else{for(var H=0,F=this.length;H<F;H++){var E=o.data(this[H],"olddisplay");this[H].style.display=E||"";if(o.css(this[H],"display")==="none"){var G=this[H].tagName,K;if(m[G]){K=m[G]}else{var I=o("<"+G+" />").appendTo("body");K=I.css("display");if(K==="none"){K="block"}I.remove();m[G]=K}o.data(this[H],"olddisplay",K)}}for(var H=0,F=this.length;H<F;H++){this[H].style.display=o.data(this[H],"olddisplay")||""}return this}},hide:function(H,I){if(H){return this.animate(t("hide",3),H,I)}else{for(var G=0,F=this.length;G<F;G++){var E=o.data(this[G],"olddisplay");if(!E&&E!=="none"){o.data(this[G],"olddisplay",o.css(this[G],"display"))}}for(var G=0,F=this.length;G<F;G++){this[G].style.display="none"}return this}},_toggle:o.fn.toggle,toggle:function(G,F){var E=typeof G==="boolean";return o.isFunction(G)&&o.isFunction(F)?this._toggle.apply(this,arguments):G==null||E?this.each(function(){var H=E?G:o(this).is(":hidden");o(this)[H?"show":"hide"]()}):this.animate(t("toggle",3),G,F)},fadeTo:function(E,G,F){return this.animate({opacity:G},E,F)},animate:function(I,F,H,G){var E=o.speed(F,H,G);return this[E.queue===false?"each":"queue"](function(){var K=o.extend({},E),M,L=this.nodeType==1&&o(this).is(":hidden"),J=this;for(M in I){if(I[M]=="hide"&&L||I[M]=="show"&&!L){return K.complete.call(this)}if((M=="height"||M=="width")&&this.style){K.display=o.css(this,"display");K.overflow=this.style.overflow}}if(K.overflow!=null){this.style.overflow="hidden"}K.curAnim=o.extend({},I);o.each(I,function(O,S){var R=new o.fx(J,K,O);if(/toggle|show|hide/.test(S)){R[S=="toggle"?L?"show":"hide":S](I)}else{var Q=S.toString().match(/^([+-]=)?([\d+-.]+)(.*)$/),T=R.cur(true)||0;if(Q){var N=parseFloat(Q[2]),P=Q[3]||"px";if(P!="px"){J.style[O]=(N||1)+P;T=((N||1)/R.cur(true))*T;J.style[O]=T+P}if(Q[1]){N=((Q[1]=="-="?-1:1)*N)+T}R.custom(T,N,P)}else{R.custom(T,S,"")}}});return true})},stop:function(F,E){var G=o.timers;if(F){this.queue([])}this.each(function(){for(var H=G.length-1;H>=0;H--){if(G[H].elem==this){if(E){G[H](true)}G.splice(H,1)}}});if(!E){this.dequeue()}return this}});o.each({slideDown:t("show",1),slideUp:t("hide",1),slideToggle:t("toggle",1),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"}},function(E,F){o.fn[E]=function(G,H){return this.animate(F,G,H)}});o.extend({speed:function(G,H,F){var E=typeof G==="object"?G:{complete:F||!F&&H||o.isFunction(G)&&G,duration:G,easing:F&&H||H&&!o.isFunction(H)&&H};E.duration=o.fx.off?0:typeof E.duration==="number"?E.duration:o.fx.speeds[E.duration]||o.fx.speeds._default;E.old=E.complete;E.complete=function(){if(E.queue!==false){o(this).dequeue()}if(o.isFunction(E.old)){E.old.call(this)}};return E},easing:{linear:function(G,H,E,F){return E+F*G},swing:function(G,H,E,F){return((-Math.cos(G*Math.PI)/2)+0.5)*F+E}},timers:[],fx:function(F,E,G){this.options=E;this.elem=F;this.prop=G;if(!E.orig){E.orig={}}}});o.fx.prototype={update:function(){if(this.options.step){this.options.step.call(this.elem,this.now,this)}(o.fx.step[this.prop]||o.fx.step._default)(this);if((this.prop=="height"||this.prop=="width")&&this.elem.style){this.elem.style.display="block"}},cur:function(F){if(this.elem[this.prop]!=null&&(!this.elem.style||this.elem.style[this.prop]==null)){return this.elem[this.prop]}var E=parseFloat(o.css(this.elem,this.prop,F));return E&&E>-10000?E:parseFloat(o.curCSS(this.elem,this.prop))||0},custom:function(I,H,G){this.startTime=e();this.start=I;this.end=H;this.unit=G||this.unit||"px";this.now=this.start;this.pos=this.state=0;var E=this;function F(J){return E.step(J)}F.elem=this.elem;if(F()&&o.timers.push(F)&&!n){n=setInterval(function(){var K=o.timers;for(var J=0;J<K.length;J++){if(!K[J]()){K.splice(J--,1)}}if(!K.length){clearInterval(n);n=g}},13)}},show:function(){this.options.orig[this.prop]=o.attr(this.elem.style,this.prop);this.options.show=true;this.custom(this.prop=="width"||this.prop=="height"?1:0,this.cur());o(this.elem).show()},hide:function(){this.options.orig[this.prop]=o.attr(this.elem.style,this.prop);this.options.hide=true;this.custom(this.cur(),0)},step:function(H){var G=e();if(H||G>=this.options.duration+this.startTime){this.now=this.end;this.pos=this.state=1;this.update();this.options.curAnim[this.prop]=true;var E=true;for(var F in this.options.curAnim){if(this.options.curAnim[F]!==true){E=false}}if(E){if(this.options.display!=null){this.elem.style.overflow=this.options.overflow;this.elem.style.display=this.options.display;if(o.css(this.elem,"display")=="none"){this.elem.style.display="block"}}if(this.options.hide){o(this.elem).hide()}if(this.options.hide||this.options.show){for(var I in this.options.curAnim){o.attr(this.elem.style,I,this.options.orig[I])}}this.options.complete.call(this.elem)}return false}else{var J=G-this.startTime;this.state=J/this.options.duration;this.pos=o.easing[this.options.easing||(o.easing.swing?"swing":"linear")](this.state,J,0,1,this.options.duration);this.now=this.start+((this.end-this.start)*this.pos);this.update()}return true}};o.extend(o.fx,{speeds:{slow:600,fast:200,_default:400},step:{opacity:function(E){o.attr(E.elem.style,"opacity",E.now)},_default:function(E){if(E.elem.style&&E.elem.style[E.prop]!=null){E.elem.style[E.prop]=E.now+E.unit}else{E.elem[E.prop]=E.now}}}});if(document.documentElement.getBoundingClientRect){o.fn.offset=function(){if(!this[0]){return{top:0,left:0}}if(this[0]===this[0].ownerDocument.body){return o.offset.bodyOffset(this[0])}var G=this[0].getBoundingClientRect(),J=this[0].ownerDocument,F=J.body,E=J.documentElement,L=E.clientTop||F.clientTop||0,K=E.clientLeft||F.clientLeft||0,I=G.top+(self.pageYOffset||o.boxModel&&E.scrollTop||F.scrollTop)-L,H=G.left+(self.pageXOffset||o.boxModel&&E.scrollLeft||F.scrollLeft)-K;return{top:I,left:H}}}else{o.fn.offset=function(){if(!this[0]){return{top:0,left:0}}if(this[0]===this[0].ownerDocument.body){return o.offset.bodyOffset(this[0])}o.offset.initialized||o.offset.initialize();var J=this[0],G=J.offsetParent,F=J,O=J.ownerDocument,M,H=O.documentElement,K=O.body,L=O.defaultView,E=L.getComputedStyle(J,null),N=J.offsetTop,I=J.offsetLeft;while((J=J.parentNode)&&J!==K&&J!==H){M=L.getComputedStyle(J,null);N-=J.scrollTop,I-=J.scrollLeft;if(J===G){N+=J.offsetTop,I+=J.offsetLeft;if(o.offset.doesNotAddBorder&&!(o.offset.doesAddBorderForTableAndCells&&/^t(able|d|h)$/i.test(J.tagName))){N+=parseInt(M.borderTopWidth,10)||0,I+=parseInt(M.borderLeftWidth,10)||0}F=G,G=J.offsetParent}if(o.offset.subtractsBorderForOverflowNotVisible&&M.overflow!=="visible"){N+=parseInt(M.borderTopWidth,10)||0,I+=parseInt(M.borderLeftWidth,10)||0}E=M}if(E.position==="relative"||E.position==="static"){N+=K.offsetTop,I+=K.offsetLeft}if(E.position==="fixed"){N+=Math.max(H.scrollTop,K.scrollTop),I+=Math.max(H.scrollLeft,K.scrollLeft)}return{top:N,left:I}}}o.offset={initialize:function(){if(this.initialized){return}var L=document.body,F=document.createElement("div"),H,G,N,I,M,E,J=L.style.marginTop,K='<div style="position:absolute;top:0;left:0;margin:0;border:5px solid #000;padding:0;width:1px;height:1px;"><div></div></div><table style="position:absolute;top:0;left:0;margin:0;border:5px solid #000;padding:0;width:1px;height:1px;" cellpadding="0" cellspacing="0"><tr><td></td></tr></table>';M={position:"absolute",top:0,left:0,margin:0,border:0,width:"1px",height:"1px",visibility:"hidden"};for(E in M){F.style[E]=M[E]}F.innerHTML=K;L.insertBefore(F,L.firstChild);H=F.firstChild,G=H.firstChild,I=H.nextSibling.firstChild.firstChild;this.doesNotAddBorder=(G.offsetTop!==5);this.doesAddBorderForTableAndCells=(I.offsetTop===5);H.style.overflow="hidden",H.style.position="relative";this.subtractsBorderForOverflowNotVisible=(G.offsetTop===-5);L.style.marginTop="1px";this.doesNotIncludeMarginInBodyOffset=(L.offsetTop===0);L.style.marginTop=J;L.removeChild(F);this.initialized=true},bodyOffset:function(E){o.offset.initialized||o.offset.initialize();var G=E.offsetTop,F=E.offsetLeft;if(o.offset.doesNotIncludeMarginInBodyOffset){G+=parseInt(o.curCSS(E,"marginTop",true),10)||0,F+=parseInt(o.curCSS(E,"marginLeft",true),10)||0}return{top:G,left:F}}};o.fn.extend({position:function(){var I=0,H=0,F;if(this[0]){var G=this.offsetParent(),J=this.offset(),E=/^body|html$/i.test(G[0].tagName)?{top:0,left:0}:G.offset();J.top-=j(this,"marginTop");J.left-=j(this,"marginLeft");E.top+=j(G,"borderTopWidth");E.left+=j(G,"borderLeftWidth");F={top:J.top-E.top,left:J.left-E.left}}return F},offsetParent:function(){var E=this[0].offsetParent||document.body;while(E&&(!/^body|html$/i.test(E.tagName)&&o.css(E,"position")=="static")){E=E.offsetParent}return o(E)}});o.each(["Left","Top"],function(F,E){var G="scroll"+E;o.fn[G]=function(H){if(!this[0]){return null}return H!==g?this.each(function(){this==l||this==document?l.scrollTo(!F?H:o(l).scrollLeft(),F?H:o(l).scrollTop()):this[G]=H}):this[0]==l||this[0]==document?self[F?"pageYOffset":"pageXOffset"]||o.boxModel&&document.documentElement[G]||document.body[G]:this[0][G]}});o.each(["Height","Width"],function(I,G){var E=I?"Left":"Top",H=I?"Right":"Bottom",F=G.toLowerCase();o.fn["inner"+G]=function(){return this[0]?o.css(this[0],F,false,"padding"):null};o.fn["outer"+G]=function(K){return this[0]?o.css(this[0],F,false,K?"margin":"border"):null};var J=G.toLowerCase();o.fn[J]=function(K){return this[0]==l?document.compatMode=="CSS1Compat"&&document.documentElement["client"+G]||document.body["client"+G]:this[0]==document?Math.max(document.documentElement["client"+G],document.body["scroll"+G],document.documentElement["scroll"+G],document.body["offset"+G],document.documentElement["offset"+G]):K===g?(this.length?o.css(this[0],J):null):this.css(J,typeof K==="string"?K:K+"px")}})})();
      (function(c){c.tools=c.tools||{};c.tools.overlay={version:"1.1.2",addEffect:function(e,f,g){b[e]=[f,g]},conf:{top:"10%",left:"center",absolute:false,speed:"normal",closeSpeed:"fast",effect:"default",close:null,oneInstance:true,closeOnClick:true,closeOnEsc:true,api:false,expose:null,target:null}};var b={};c.tools.overlay.addEffect("default",function(e){this.getOverlay().fadeIn(this.getConf().speed,e)},function(e){this.getOverlay().fadeOut(this.getConf().closeSpeed,e)});var d=[];function a(g,k){var o=this,m=c(this),n=c(window),j,i,h,e=k.expose&&c.tools.expose.version;var f=k.target||g.attr("rel");i=f?c(f):null||g;if(!i.length){throw"Could not find Overlay: "+f}if(g&&g.index(i)==-1){g.click(function(p){o.load(p);return p.preventDefault()})}c.each(k,function(p,q){if(c.isFunction(q)){m.bind(p,q)}});c.extend(o,{load:function(u){if(o.isOpened()){return o}var r=b[k.effect];if(!r){throw'Overlay: cannot find effect : "'+k.effect+'"'}if(k.oneInstance){c.each(d,function(){this.close(u)})}u=u||c.Event();u.type="onBeforeLoad";m.trigger(u);if(u.isDefaultPrevented()){return o}h=true;if(e){i.expose().load(u)}var t=k.top;var s=k.left;var p=i.outerWidth({margin:true});var q=i.outerHeight({margin:true});if(typeof t=="string"){t=t=="center"?Math.max((n.height()-q)/2,0):parseInt(t,10)/100*n.height()}if(s=="center"){s=Math.max((n.width()-p)/2,0)}if(!k.absolute){t+=n.scrollTop();s+=n.scrollLeft()}i.css({top:t,left:s,position:"absolute"});u.type="onStart";m.trigger(u);r[0].call(o,function(){if(h){u.type="onLoad";m.trigger(u)}});if(k.closeOnClick){c(document).bind("click.overlay",function(w){if(!o.isOpened()){return}var v=c(w.target);if(v.parents(i).length>1){return}c.each(d,function(){this.close(w)})})}if(k.closeOnEsc){c(document).unbind("keydown.overlay").bind("keydown.overlay",function(v){if(v.keyCode==27){c.each(d,function(){this.close(v)})}})}return o},close:function(q){if(!o.isOpened()){return o}q=q||c.Event();q.type="onBeforeClose";m.trigger(q);if(q.isDefaultPrevented()){return}h=false;b[k.effect][1].call(o,function(){q.type="onClose";m.trigger(q)});var p=true;c.each(d,function(){if(this.isOpened()){p=false}});if(p){c(document).unbind("click.overlay").unbind("keydown.overlay")}return o},getContent:function(){return i},getOverlay:function(){return i},getTrigger:function(){return g},getClosers:function(){return j},isOpened:function(){return h},getConf:function(){return k},bind:function(p,q){m.bind(p,q);return o},unbind:function(p){m.unbind(p);return o}});c.each("onBeforeLoad,onStart,onLoad,onBeforeClose,onClose".split(","),function(p,q){o[q]=function(r){return o.bind(q,r)}});if(e){if(typeof k.expose=="string"){k.expose={color:k.expose}}c.extend(k.expose,{api:true,closeOnClick:k.closeOnClick,closeOnEsc:false});var l=i.expose(k.expose);l.onBeforeClose(function(p){o.close(p)});o.onClose(function(p){l.close(p)})}j=i.find(k.close||".close");if(!j.length&&!k.close){j=c('<div class="close"></div>');i.prepend(j)}j.click(function(p){o.close(p)})}c.fn.overlay=function(e){var f=this.eq(typeof e=="number"?e:0).data("overlay");if(f){return f}if(c.isFunction(e)){e={onBeforeLoad:e}}var g=c.extend({},c.tools.overlay.conf);e=c.extend(true,g,e);this.each(function(){f=new a(c(this),e);d.push(f);c(this).data("overlay",f)});return e.api?f:this}})(jQuery);
      (function(d){var b=d.tools.overlay;b.effects=b.effects||{};b.effects.apple={version:"1.0.1"};d.extend(b.conf,{start:{absolute:true,top:null,left:null},fadeInSpeed:"fast",zIndex:9999});function c(f){var g=f.offset();return[g.top+f.height()/2,g.left+f.width()/2]}var e=function(n){var k=this.getOverlay(),f=this.getConf(),i=this.getTrigger(),q=this,r=k.outerWidth({margin:true}),m=k.data("img");if(!m){var l=k.css("backgroundImage");if(!l){throw"background-image CSS property not set for overlay"}l=l.substring(l.indexOf("(")+1,l.indexOf(")")).replace(/\"/g,"");k.css("backgroundImage","none");m=d('<img src="'+l+'"/>');m.css({border:0,position:"absolute",display:"none"}).width(r);d("body").append(m);k.data("img",m)}var o=d(window),j=f.start.top||Math.round(o.height()/2),h=f.start.left||Math.round(o.width()/2);if(i){var g=c(i);j=g[0];h=g[1]}if(!f.start.absolute){j+=o.scrollTop();h+=o.scrollLeft()}m.css({top:j,left:h,width:0,zIndex:f.zIndex}).show();m.animate({top:k.css("top"),left:k.css("left"),width:r},f.speed,function(){k.css("zIndex",f.zIndex+1).fadeIn(f.fadeInSpeed,function(){if(q.isOpened()&&!d(this).index(k)){n.call()}else{k.hide()}})})};var a=function(f){var h=this.getOverlay(),i=this.getConf(),g=this.getTrigger(),l=i.start.top,k=i.start.left;h.hide();if(g){var j=c(g);l=j[0];k=j[1]}h.data("img").animate({top:l,left:k,width:0},i.closeSpeed,f)};b.addEffect("apple",e,a)})(jQuery);
      (function(b){b.tools=b.tools||{};b.tools.expose={version:"1.0.5",conf:{maskId:null,loadSpeed:"slow",closeSpeed:"fast",closeOnClick:true,closeOnEsc:true,zIndex:9998,opacity:0.8,color:"#456",api:false}};function a(){if(b.browser.msie){var f=b(document).height(),e=b(window).height();return[window.innerWidth||document.documentElement.clientWidth||document.body.clientWidth,f-e<20?e:f]}return[b(window).width(),b(document).height()]}function c(h,g){var e=this,j=b(this),d=null,f=false,i=0;b.each(g,function(k,l){if(b.isFunction(l)){j.bind(k,l)}});b(window).resize(function(){e.fit()});b.extend(this,{getMask:function(){return d},getExposed:function(){return h},getConf:function(){return g},isLoaded:function(){return f},load:function(n){if(f){return e}i=h.eq(0).css("zIndex");if(g.maskId){d=b("#"+g.maskId)}if(!d||!d.length){var l=a();d=b("<div/>").css({position:"absolute",top:0,left:0,width:l[0],height:l[1],display:"none",opacity:0,zIndex:g.zIndex});if(g.maskId){d.attr("id",g.maskId)}b("body").append(d);var k=d.css("backgroundColor");if(!k||k=="transparent"||k=="rgba(0, 0, 0, 0)"){d.css("backgroundColor",g.color)}if(g.closeOnEsc){b(document).bind("keydown.unexpose",function(o){if(o.keyCode==27){e.close()}})}if(g.closeOnClick){d.bind("click.unexpose",function(o){e.close(o)})}}n=n||b.Event();n.type="onBeforeLoad";j.trigger(n);if(n.isDefaultPrevented()){return e}b.each(h,function(){var o=b(this);if(!/relative|absolute|fixed/i.test(o.css("position"))){o.css("position","relative")}});h.css({zIndex:Math.max(g.zIndex+1,i=="auto"?0:i)});var m=d.height();if(!this.isLoaded()){d.css({opacity:0,display:"block"}).fadeTo(g.loadSpeed,g.opacity,function(){if(d.height()!=m){d.css("height",m)}n.type="onLoad";j.trigger(n)})}f=true;return e},close:function(k){if(!f){return e}k=k||b.Event();k.type="onBeforeClose";j.trigger(k);if(k.isDefaultPrevented()){return e}d.fadeOut(g.closeSpeed,function(){k.type="onClose";j.trigger(k);h.css({zIndex:b.browser.msie?i:null})});f=false;return e},fit:function(){if(d){var k=a();d.css({width:k[0],height:k[1]})}},bind:function(k,l){j.bind(k,l);return e},unbind:function(k){j.unbind(k);return e}});b.each("onBeforeLoad,onLoad,onBeforeClose,onClose".split(","),function(k,l){e[l]=function(m){return e.bind(l,m)}})}b.fn.expose=function(d){var e=this.eq(typeof d=="number"?d:0).data("expose");if(e){return e}if(typeof d=="string"){d={color:d}}var f=b.extend({},b.tools.expose.conf);d=b.extend(f,d);this.each(function(){e=new c(b(this),d);b(this).data("expose",e)});return d.api?e:this}})(jQuery);
            
      /**
       * jQuery tools.overlay "pearltrees" 1.0.0
       * 
       * (inspired by tools.overlay "Apple Effect" 1.0.1)
       */
      (function($) { 
      
         // version number
         var t = $.tools.overlay;
         t.effects = t.effects || {};
         t.effects.pearltrees = {version: '1.0.0'}; 
            
         // extend global configuragion with effect specific defaults
         $.extend(t.conf, { 
            start: { 
               absolute: true,
               top: null,
               left: null,
               width: null,
               height: null
            },
            
            fadeInSpeed: 0,
            openSpeed: 'fast',
            closeSpeed: 'falst',
            zIndex: 2147483000,
            // close button height
            yOffest:"22px"
         });
      
         // load
         var loadEffect = function(onLoad) {
            
            var overlay = this.getOverlay();
            var opts = this.getConf();
            var trigger = this.getTrigger();
            var self = this;
            var oWidth = overlay.outerWidth({margin:true}) - 4;
            var oHeight = overlay.outerHeight({margin:true}) - opts.yOffest.replace("px", "") + 25;
      
            overlay.css("backgroundImage", "none");
            
            var img = $('#pt-overlay-effect');
            if(img.length == 0) {
               img = $('<div id="pt-overlay-effect" />');
            }
            img.width(oWidth)
               .height(oHeight);
               
            $('body').append(img);
            overlay.data("img", img);
         
            // initial top & left
            var w = $(window);
            var itop = opts.start.top;
            var ileft = opts.start.left;
            var iwidth = opts.start.width;
            var iheight = opts.start.height;
            
            // initialize background image and make it visible
            img.css({
               position:'absolute',
               display:'none',
               top: itop,
               left: ileft,
               width: iwidth,
               height: iheight,
               border:'1px solid #505050',
               backgroundColor:'#FFFFFF',
               zIndex: opts.zIndex
            }).show();
            
              var overlayTop = parseInt(overlay.css("top").replace("px", ""));
              var overlayOffest = parseInt(opts.yOffest.replace("px", ""));
              var newTop = (overlayTop + overlayOffest) + "px";
              
            // begin growing
            img.animate({
               top: newTop, 
               left: overlay.css("left"),
               width: oWidth,
               height: oHeight}, opts.openSpeed, function() { 
      
               // set close button and content over the image
               overlay.css("zIndex", opts.zIndex + 1).fadeIn(opts.fadeInSpeed, function()  { 
                  
                  if (self.isOpened() && !$(this).index(overlay)) {               
                     onLoad.call();
                     overlay.css({visibility:'visible'});
                     img.css({display:'none'});
                  } else { 
                     overlay.css({visibility:'hidden'});
                  }
               });
      
               /* without fadeIn
               overlay.css("zIndex", opts.zIndex + 1);
               
               //PEARLTREES.utils.log("selfOpen: "+self.isOpened());
               
               if (self.isOpened()) {
                  onLoad.call();
                  overlay.css({visibility:'visible'});
                  img.css({display:'none'});
               } else {
                  //overlay.hide();
                   overlay.css({visibility:'hidden'});
               }
               */
               
            });
            
         };
         
         // close
         var closeEffect = function(onClose) {
      
            // variables
            var overlay = this.getOverlay();
            var opts = this.getConf();
            var trigger = this.getTrigger();
            var top = opts.start.top;
            var left = opts.start.left;
            var width = opts.start.width;
            var height = opts.start.height;
            
            // hide overlay & closers
            //overlay.hide();
            overlay.css({visibility:'hidden'});
            
            // shrink image      
            overlay.data("img")
                   .animate({top: top, left: left, width:width, height:height}, 
                            opts.closeSpeed, 
                            onClose);
                            
            // Hide effect image after a little delay
            var hideDelay = (PEARLTREES.config.ENABLE_EMBED_WINDOW)?500:100;
            setTimeout(function() { PEARLTREES.overlay.getJQueryOverlay().getOverlay().data("img").hide(); }, opts.closeSpeed + hideDelay);
         };
         
         // add overlay effect   
         t.addEffect("pearltrees", loadEffect, closeEffect); 
         
      })(jQuery);
      
      /*
       * Extend jQuery with BrowserDetect
       * @see http://www.stoimen.com/blog/2009/07/16/jquery-browser-and-os-detection-plugin/
       */
      (function($){var BrowserDetect={init:function(){this.browser=this.searchString(this.dataBrowser)||"An unknown browser";this.version=this.searchVersion(navigator.userAgent)||this.searchVersion(navigator.appVersion)||"an unknown version";this.OS=this.searchString(this.dataOS)||"an unknown OS";},searchString:function(data){for(var i=0;i<data.length;i++){var dataString=data[i].string;var dataProp=data[i].prop;this.versionSearchString=data[i].versionSearch||data[i].identity;if(dataString){if(dataString.indexOf(data[i].subString)!=-1)return data[i].identity;}else if(dataProp)return data[i].identity;}},searchVersion:function(dataString){var index=dataString.indexOf(this.versionSearchString);if(index==-1)return;return parseFloat(dataString.substring(index+this.versionSearchString.length+1));},dataBrowser:[{string:navigator.userAgent,subString:"Chrome",identity:"Chrome"},{string:navigator.userAgent,subString:"OmniWeb",versionSearch:"OmniWeb/",identity:"OmniWeb"},{string:navigator.vendor,subString:"Apple",identity:"Safari",versionSearch:"Version"},{prop:window.opera,identity:"Opera"},{string:navigator.vendor,subString:"iCab",identity:"iCab"},{string:navigator.vendor,subString:"KDE",identity:"Konqueror"},{string:navigator.userAgent,subString:"Firefox",identity:"Firefox"},{string:navigator.vendor,subString:"Camino",identity:"Camino"},{string:navigator.userAgent,subString:"Netscape",identity:"Netscape"},{string:navigator.userAgent,subString:"MSIE",identity:"Explorer",versionSearch:"MSIE"},{string:navigator.userAgent,subString:"Gecko",identity:"Mozilla",versionSearch:"rv"},{string:navigator.userAgent,subString:"Mozilla",identity:"Netscape",versionSearch:"Mozilla"}],dataOS:[{string:navigator.platform,subString:"Win",identity:"Windows"},{string:navigator.platform,subString:"Mac",identity:"Mac"},{string:navigator.userAgent,subString:"iPhone",identity:"iPhone/iPod"},{string:navigator.platform,subString:"Linux",identity:"Linux"}]};BrowserDetect.init();$.client={os:BrowserDetect.OS,browser:BrowserDetect.browser};})(jQuery);
      
      this.jQuery = jQuery.noConflict(true);
      this.backupGlobalFunctionsInConflict();
      
      /*
       * jQuery UI 1.7.3
       *
       * Copyright (c) 2009 AUTHORS.txt (http://jqueryui.com/about)
       * Dual licensed under the MIT (MIT-LICENSE.txt)
       * and GPL (GPL-LICENSE.txt) licenses.
       *
       * http://docs.jquery.com/UI
       */
      this.jQuery.ui||(function(c){var i=c.fn.remove,d=c.browser.mozilla&&(parseFloat(c.browser.version)<1.9);c.ui={version:"1.7.3",plugin:{add:function(k,l,n){var m=c.ui[k].prototype;for(var j in n){m.plugins[j]=m.plugins[j]||[];m.plugins[j].push([l,n[j]])}},call:function(j,l,k){var n=j.plugins[l];if(!n||!j.element[0].parentNode){return}for(var m=0;m<n.length;m++){if(j.options[n[m][0]]){n[m][1].apply(j.element,k)}}}},contains:function(k,j){return document.compareDocumentPosition?k.compareDocumentPosition(j)&16:k!==j&&k.contains(j)},hasScroll:function(m,k){if(c(m).css("overflow")=="hidden"){return false}var j=(k&&k=="left")?"scrollLeft":"scrollTop",l=false;if(m[j]>0){return true}m[j]=1;l=(m[j]>0);m[j]=0;return l},isOverAxis:function(k,j,l){return(k>j)&&(k<(j+l))},isOver:function(o,k,n,m,j,l){return c.ui.isOverAxis(o,n,j)&&c.ui.isOverAxis(k,m,l)},keyCode:{BACKSPACE:8,CAPS_LOCK:20,COMMA:188,CONTROL:17,DELETE:46,DOWN:40,END:35,ENTER:13,ESCAPE:27,HOME:36,INSERT:45,LEFT:37,NUMPAD_ADD:107,NUMPAD_DECIMAL:110,NUMPAD_DIVIDE:111,NUMPAD_ENTER:108,NUMPAD_MULTIPLY:106,NUMPAD_SUBTRACT:109,PAGE_DOWN:34,PAGE_UP:33,PERIOD:190,RIGHT:39,SHIFT:16,SPACE:32,TAB:9,UP:38}};if(d){var f=c.attr,e=c.fn.removeAttr,h="http://www.w3.org/2005/07/aaa",a=/^aria-/,b=/^wairole:/;c.attr=function(k,j,l){var m=l!==undefined;return(j=="role"?(m?f.call(this,k,j,"wairole:"+l):(f.apply(this,arguments)||"").replace(b,"")):(a.test(j)?(m?k.setAttributeNS(h,j.replace(a,"aaa:"),l):f.call(this,k,j.replace(a,"aaa:"))):f.apply(this,arguments)))};c.fn.removeAttr=function(j){return(a.test(j)?this.each(function(){this.removeAttributeNS(h,j.replace(a,""))}):e.call(this,j))}}c.fn.extend({remove:function(j,k){return this.each(function(){if(!k){if(!j||c.filter(j,[this]).length){c("*",this).add(this).each(function(){c(this).triggerHandler("remove")})}}return i.call(c(this),j,k)})},enableSelection:function(){return this.attr("unselectable","off").css("MozUserSelect","").unbind("selectstart.ui")},disableSelection:function(){return this.attr("unselectable","on").css("MozUserSelect","none").bind("selectstart.ui",function(){return false})},scrollParent:function(){var j;if((c.browser.msie&&(/(static|relative)/).test(this.css("position")))||(/absolute/).test(this.css("position"))){j=this.parents().filter(function(){return(/(relative|absolute|fixed)/).test(c.curCSS(this,"position",1))&&(/(auto|scroll)/).test(c.curCSS(this,"overflow",1)+c.curCSS(this,"overflow-y",1)+c.curCSS(this,"overflow-x",1))}).eq(0)}else{j=this.parents().filter(function(){return(/(auto|scroll)/).test(c.curCSS(this,"overflow",1)+c.curCSS(this,"overflow-y",1)+c.curCSS(this,"overflow-x",1))}).eq(0)}return(/fixed/).test(this.css("position"))||!j.length?c(document):j}});c.extend(c.expr[":"],{data:function(l,k,j){return !!c.data(l,j[3])},focusable:function(k){var l=k.nodeName.toLowerCase(),j=c.attr(k,"tabindex");return(/input|select|textarea|button|object/.test(l)?!k.disabled:"a"==l||"area"==l?k.href||!isNaN(j):!isNaN(j))&&!c(k)["area"==l?"parents":"closest"](":hidden").length},tabbable:function(k){var j=c.attr(k,"tabindex");return(isNaN(j)||j>=0)&&c(k).is(":focusable")}});function g(m,n,o,l){function k(q){var p=c[m][n][q]||[];return(typeof p=="string"?p.split(/,?\s+/):p)}var j=k("getter");if(l.length==1&&typeof l[0]=="string"){j=j.concat(k("getterSetter"))}return(c.inArray(o,j)!=-1)}c.widget=function(k,j){var l=k.split(".")[0];k=k.split(".")[1];c.fn[k]=function(p){var n=(typeof p=="string"),o=Array.prototype.slice.call(arguments,1);if(n&&p.substring(0,1)=="_"){return this}if(n&&g(l,k,p,o)){var m=c.data(this[0],k);return(m?m[p].apply(m,o):undefined)}return this.each(function(){var q=c.data(this,k);(!q&&!n&&c.data(this,k,new c[l][k](this,p))._init());(q&&n&&c.isFunction(q[p])&&q[p].apply(q,o))})};c[l]=c[l]||{};c[l][k]=function(o,n){var m=this;this.namespace=l;this.widgetName=k;this.widgetEventPrefix=c[l][k].eventPrefix||k;this.widgetBaseClass=l+"-"+k;this.options=c.extend({},c.widget.defaults,c[l][k].defaults,c.metadata&&c.metadata.get(o)[k],n);this.element=c(o).bind("setData."+k,function(q,p,r){if(q.target==o){return m._setData(p,r)}}).bind("getData."+k,function(q,p){if(q.target==o){return m._getData(p)}}).bind("remove",function(){return m.destroy()})};c[l][k].prototype=c.extend({},c.widget.prototype,j);c[l][k].getterSetter="option"};c.widget.prototype={_init:function(){},destroy:function(){this.element.removeData(this.widgetName).removeClass(this.widgetBaseClass+"-disabled "+this.namespace+"-state-disabled").removeAttr("aria-disabled")},option:function(l,m){var k=l,j=this;if(typeof l=="string"){if(m===undefined){return this._getData(l)}k={};k[l]=m}c.each(k,function(n,o){j._setData(n,o)})},_getData:function(j){return this.options[j]},_setData:function(j,k){this.options[j]=k;if(j=="disabled"){this.element[k?"addClass":"removeClass"](this.widgetBaseClass+"-disabled "+this.namespace+"-state-disabled").attr("aria-disabled",k)}},enable:function(){this._setData("disabled",false)},disable:function(){this._setData("disabled",true)},_trigger:function(l,m,n){var p=this.options[l],j=(l==this.widgetEventPrefix?l:this.widgetEventPrefix+l);m=c.Event(m);m.type=j;if(m.originalEvent){for(var k=c.event.props.length,o;k;){o=c.event.props[--k];m[o]=m.originalEvent[o]}}this.element.trigger(m,n);return !(c.isFunction(p)&&p.call(this.element[0],m,n)===false||m.isDefaultPrevented())}};c.widget.defaults={disabled:false};c.ui.mouse={_mouseInit:function(){var j=this;this.element.bind("mousedown."+this.widgetName,function(k){return j._mouseDown(k)}).bind("click."+this.widgetName,function(k){if(j._preventClickEvent){j._preventClickEvent=false;k.stopImmediatePropagation();return false}});if(c.browser.msie){this._mouseUnselectable=this.element.attr("unselectable");this.element.attr("unselectable","on")}this.started=false},_mouseDestroy:function(){this.element.unbind("."+this.widgetName);(c.browser.msie&&this.element.attr("unselectable",this._mouseUnselectable))},_mouseDown:function(l){l.originalEvent=l.originalEvent||{};if(l.originalEvent.mouseHandled){return}(this._mouseStarted&&this._mouseUp(l));this._mouseDownEvent=l;var k=this,m=(l.which==1),j=(typeof this.options.cancel=="string"?c(l.target).parents().add(l.target).filter(this.options.cancel).length:false);if(!m||j||!this._mouseCapture(l)){return true}this.mouseDelayMet=!this.options.delay;if(!this.mouseDelayMet){this._mouseDelayTimer=setTimeout(function(){k.mouseDelayMet=true},this.options.delay)}if(this._mouseDistanceMet(l)&&this._mouseDelayMet(l)){this._mouseStarted=(this._mouseStart(l)!==false);if(!this._mouseStarted){l.preventDefault();return true}}this._mouseMoveDelegate=function(n){return k._mouseMove(n)};this._mouseUpDelegate=function(n){return k._mouseUp(n)};c(document).bind("mousemove."+this.widgetName,this._mouseMoveDelegate).bind("mouseup."+this.widgetName,this._mouseUpDelegate);(c.browser.safari||l.preventDefault());l.originalEvent.mouseHandled=true;return true},_mouseMove:function(j){if(c.browser.msie&&!j.button){return this._mouseUp(j)}if(this._mouseStarted){this._mouseDrag(j);return j.preventDefault()}if(this._mouseDistanceMet(j)&&this._mouseDelayMet(j)){this._mouseStarted=(this._mouseStart(this._mouseDownEvent,j)!==false);(this._mouseStarted?this._mouseDrag(j):this._mouseUp(j))}return !this._mouseStarted},_mouseUp:function(j){c(document).unbind("mousemove."+this.widgetName,this._mouseMoveDelegate).unbind("mouseup."+this.widgetName,this._mouseUpDelegate);if(this._mouseStarted){this._mouseStarted=false;this._preventClickEvent=(j.target==this._mouseDownEvent.target);this._mouseStop(j)}return false},_mouseDistanceMet:function(j){return(Math.max(Math.abs(this._mouseDownEvent.pageX-j.pageX),Math.abs(this._mouseDownEvent.pageY-j.pageY))>=this.options.distance)},_mouseDelayMet:function(j){return this.mouseDelayMet},_mouseStart:function(j){},_mouseDrag:function(j){},_mouseStop:function(j){},_mouseCapture:function(j){return true}};c.ui.mouse.defaults={cancel:null,distance:1,delay:0}})(this.jQuery);;
      
      /*       
       * jQuery UI Draggable 1.7.3
       *
       * Copyright (c) 2009 AUTHORS.txt (http://jqueryui.com/about)
       * Dual licensed under the MIT (MIT-LICENSE.txt)
       * and GPL (GPL-LICENSE.txt) licenses.
       *
       * http://docs.jquery.com/UI/Draggables
       *
       * Depends:
       * ui.core.js
       */
      (function(a){a.widget("ui.draggable",a.extend({},a.ui.mouse,{_init:function(){if(this.options.helper=="original"&&!(/^(?:r|a|f)/).test(this.element.css("position"))){this.element[0].style.position="relative"}(this.options.addClasses&&this.element.addClass("ui-draggable"));(this.options.disabled&&this.element.addClass("ui-draggable-disabled"));this._mouseInit()},destroy:function(){if(!this.element.data("draggable")){return}this.element.removeData("draggable").unbind(".draggable").removeClass("ui-draggable ui-draggable-dragging ui-draggable-disabled");this._mouseDestroy()},_mouseCapture:function(b){var c=this.options;if(this.helper||c.disabled||a(b.target).is(".ui-resizable-handle")){return false}this.handle=this._getHandle(b);if(!this.handle){return false}return true},_mouseStart:function(b){var c=this.options;this.helper=this._createHelper(b);this._cacheHelperProportions();if(a.ui.ddmanager){a.ui.ddmanager.current=this}this._cacheMargins();this.cssPosition=this.helper.css("position");this.scrollParent=this.helper.scrollParent();this.offset=this.element.offset();this.offset={top:this.offset.top-this.margins.top,left:this.offset.left-this.margins.left};a.extend(this.offset,{click:{left:b.pageX-this.offset.left,top:b.pageY-this.offset.top},parent:this._getParentOffset(),relative:this._getRelativeOffset()});this.originalPosition=this._generatePosition(b);this.originalPageX=b.pageX;this.originalPageY=b.pageY;if(c.cursorAt){this._adjustOffsetFromHelper(c.cursorAt)}if(c.containment){this._setContainment()}this._trigger("start",b);this._cacheHelperProportions();if(a.ui.ddmanager&&!c.dropBehaviour){a.ui.ddmanager.prepareOffsets(this,b)}this.helper.addClass("ui-draggable-dragging");this._mouseDrag(b,true);return true},_mouseDrag:function(b,d){this.position=this._generatePosition(b);this.positionAbs=this._convertPositionTo("absolute");if(!d){var c=this._uiHash();this._trigger("drag",b,c);this.position=c.position}if(!this.options.axis||this.options.axis!="y"){this.helper[0].style.left=this.position.left+"px"}if(!this.options.axis||this.options.axis!="x"){this.helper[0].style.top=this.position.top+"px"}if(a.ui.ddmanager){a.ui.ddmanager.drag(this,b)}return false},_mouseStop:function(c){var d=false;if(a.ui.ddmanager&&!this.options.dropBehaviour){d=a.ui.ddmanager.drop(this,c)}if(this.dropped){d=this.dropped;this.dropped=false}if((this.options.revert=="invalid"&&!d)||(this.options.revert=="valid"&&d)||this.options.revert===true||(a.isFunction(this.options.revert)&&this.options.revert.call(this.element,d))){var b=this;a(this.helper).animate(this.originalPosition,parseInt(this.options.revertDuration,10),function(){b._trigger("stop",c);b._clear()})}else{this._trigger("stop",c);this._clear()}return false},_getHandle:function(b){var c=!this.options.handle||!a(this.options.handle,this.element).length?true:false;a(this.options.handle,this.element).find("*").andSelf().each(function(){if(this==b.target){c=true}});return c},_createHelper:function(c){var d=this.options;var b=a.isFunction(d.helper)?a(d.helper.apply(this.element[0],[c])):(d.helper=="clone"?this.element.clone():this.element);if(!b.parents("body").length){b.appendTo((d.appendTo=="parent"?this.element[0].parentNode:d.appendTo))}if(b[0]!=this.element[0]&&!(/(fixed|absolute)/).test(b.css("position"))){b.css("position","absolute")}return b},_adjustOffsetFromHelper:function(b){if(b.left!=undefined){this.offset.click.left=b.left+this.margins.left}if(b.right!=undefined){this.offset.click.left=this.helperProportions.width-b.right+this.margins.left}if(b.top!=undefined){this.offset.click.top=b.top+this.margins.top}if(b.bottom!=undefined){this.offset.click.top=this.helperProportions.height-b.bottom+this.margins.top}},_getParentOffset:function(){this.offsetParent=this.helper.offsetParent();var b=this.offsetParent.offset();if(this.cssPosition=="absolute"&&this.scrollParent[0]!=document&&a.ui.contains(this.scrollParent[0],this.offsetParent[0])){b.left+=this.scrollParent.scrollLeft();b.top+=this.scrollParent.scrollTop()}if((this.offsetParent[0]==document.body)||(this.offsetParent[0].tagName&&this.offsetParent[0].tagName.toLowerCase()=="html"&&a.browser.msie)){b={top:0,left:0}}return{top:b.top+(parseInt(this.offsetParent.css("borderTopWidth"),10)||0),left:b.left+(parseInt(this.offsetParent.css("borderLeftWidth"),10)||0)}},_getRelativeOffset:function(){if(this.cssPosition=="relative"){var b=this.element.position();return{top:b.top-(parseInt(this.helper.css("top"),10)||0)+this.scrollParent.scrollTop(),left:b.left-(parseInt(this.helper.css("left"),10)||0)+this.scrollParent.scrollLeft()}}else{return{top:0,left:0}}},_cacheMargins:function(){this.margins={left:(parseInt(this.element.css("marginLeft"),10)||0),top:(parseInt(this.element.css("marginTop"),10)||0)}},_cacheHelperProportions:function(){this.helperProportions={width:this.helper.outerWidth(),height:this.helper.outerHeight()}},_setContainment:function(){var e=this.options;if(e.containment=="parent"){e.containment=this.helper[0].parentNode}if(e.containment=="document"||e.containment=="window"){this.containment=[0-this.offset.relative.left-this.offset.parent.left,0-this.offset.relative.top-this.offset.parent.top,a(e.containment=="document"?document:window).width()-this.helperProportions.width-this.margins.left,(a(e.containment=="document"?document:window).height()||document.body.parentNode.scrollHeight)-this.helperProportions.height-this.margins.top]}if(!(/^(document|window|parent)$/).test(e.containment)&&e.containment.constructor!=Array){var c=a(e.containment)[0];if(!c){return}var d=a(e.containment).offset();var b=(a(c).css("overflow")!="hidden");this.containment=[d.left+(parseInt(a(c).css("borderLeftWidth"),10)||0)+(parseInt(a(c).css("paddingLeft"),10)||0)-this.margins.left,d.top+(parseInt(a(c).css("borderTopWidth"),10)||0)+(parseInt(a(c).css("paddingTop"),10)||0)-this.margins.top,d.left+(b?Math.max(c.scrollWidth,c.offsetWidth):c.offsetWidth)-(parseInt(a(c).css("borderLeftWidth"),10)||0)-(parseInt(a(c).css("paddingRight"),10)||0)-this.helperProportions.width-this.margins.left,d.top+(b?Math.max(c.scrollHeight,c.offsetHeight):c.offsetHeight)-(parseInt(a(c).css("borderTopWidth"),10)||0)-(parseInt(a(c).css("paddingBottom"),10)||0)-this.helperProportions.height-this.margins.top]}else{if(e.containment.constructor==Array){this.containment=e.containment}}},_convertPositionTo:function(f,h){if(!h){h=this.position}var c=f=="absolute"?1:-1;var e=this.options,b=this.cssPosition=="absolute"&&!(this.scrollParent[0]!=document&&a.ui.contains(this.scrollParent[0],this.offsetParent[0]))?this.offsetParent:this.scrollParent,g=(/(html|body)/i).test(b[0].tagName);return{top:(h.top+this.offset.relative.top*c+this.offset.parent.top*c-(a.browser.safari&&this.cssPosition=="fixed"?0:(this.cssPosition=="fixed"?-this.scrollParent.scrollTop():(g?0:b.scrollTop()))*c)),left:(h.left+this.offset.relative.left*c+this.offset.parent.left*c-(a.browser.safari&&this.cssPosition=="fixed"?0:(this.cssPosition=="fixed"?-this.scrollParent.scrollLeft():g?0:b.scrollLeft())*c))}},_generatePosition:function(e){var h=this.options,b=this.cssPosition=="absolute"&&!(this.scrollParent[0]!=document&&a.ui.contains(this.scrollParent[0],this.offsetParent[0]))?this.offsetParent:this.scrollParent,i=(/(html|body)/i).test(b[0].tagName);if(this.cssPosition=="relative"&&!(this.scrollParent[0]!=document&&this.scrollParent[0]!=this.offsetParent[0])){this.offset.relative=this._getRelativeOffset()}var d=e.pageX;var c=e.pageY;if(this.originalPosition){if(this.containment){if(e.pageX-this.offset.click.left<this.containment[0]){d=this.containment[0]+this.offset.click.left}if(e.pageY-this.offset.click.top<this.containment[1]){c=this.containment[1]+this.offset.click.top}if(e.pageX-this.offset.click.left>this.containment[2]){d=this.containment[2]+this.offset.click.left}if(e.pageY-this.offset.click.top>this.containment[3]){c=this.containment[3]+this.offset.click.top}}if(h.grid){var g=this.originalPageY+Math.round((c-this.originalPageY)/h.grid[1])*h.grid[1];c=this.containment?(!(g-this.offset.click.top<this.containment[1]||g-this.offset.click.top>this.containment[3])?g:(!(g-this.offset.click.top<this.containment[1])?g-h.grid[1]:g+h.grid[1])):g;var f=this.originalPageX+Math.round((d-this.originalPageX)/h.grid[0])*h.grid[0];d=this.containment?(!(f-this.offset.click.left<this.containment[0]||f-this.offset.click.left>this.containment[2])?f:(!(f-this.offset.click.left<this.containment[0])?f-h.grid[0]:f+h.grid[0])):f}}return{top:(c-this.offset.click.top-this.offset.relative.top-this.offset.parent.top+(a.browser.safari&&this.cssPosition=="fixed"?0:(this.cssPosition=="fixed"?-this.scrollParent.scrollTop():(i?0:b.scrollTop())))),left:(d-this.offset.click.left-this.offset.relative.left-this.offset.parent.left+(a.browser.safari&&this.cssPosition=="fixed"?0:(this.cssPosition=="fixed"?-this.scrollParent.scrollLeft():i?0:b.scrollLeft())))}},_clear:function(){this.helper.removeClass("ui-draggable-dragging");if(this.helper[0]!=this.element[0]&&!this.cancelHelperRemoval){this.helper.remove()}this.helper=null;this.cancelHelperRemoval=false},_trigger:function(b,c,d){d=d||this._uiHash();a.ui.plugin.call(this,b,[c,d]);if(b=="drag"){this.positionAbs=this._convertPositionTo("absolute")}return a.widget.prototype._trigger.call(this,b,c,d)},plugins:{},_uiHash:function(b){return{helper:this.helper,position:this.position,absolutePosition:this.positionAbs,offset:this.positionAbs}}}));a.extend(a.ui.draggable,{version:"1.7.3",eventPrefix:"drag",defaults:{addClasses:true,appendTo:"parent",axis:false,cancel:":input,option",connectToSortable:false,containment:false,cursor:"auto",cursorAt:false,delay:0,distance:1,grid:false,handle:false,helper:"original",iframeFix:false,opacity:false,refreshPositions:false,revert:false,revertDuration:500,scope:"default",scroll:true,scrollSensitivity:20,scrollSpeed:20,snap:false,snapMode:"both",snapTolerance:20,stack:false,zIndex:false}});a.ui.plugin.add("draggable","connectToSortable",{start:function(c,e){var d=a(this).data("draggable"),f=d.options,b=a.extend({},e,{item:d.element});d.sortables=[];a(f.connectToSortable).each(function(){var g=a.data(this,"sortable");if(g&&!g.options.disabled){d.sortables.push({instance:g,shouldRevert:g.options.revert});g._refreshItems();g._trigger("activate",c,b)}})},stop:function(c,e){var d=a(this).data("draggable"),b=a.extend({},e,{item:d.element});a.each(d.sortables,function(){if(this.instance.isOver){this.instance.isOver=0;d.cancelHelperRemoval=true;this.instance.cancelHelperRemoval=false;if(this.shouldRevert){this.instance.options.revert=true}this.instance._mouseStop(c);this.instance.options.helper=this.instance.options._helper;if(d.options.helper=="original"){this.instance.currentItem.css({top:"auto",left:"auto"})}}else{this.instance.cancelHelperRemoval=false;this.instance._trigger("deactivate",c,b)}})},drag:function(c,f){var e=a(this).data("draggable"),b=this;var d=function(i){var n=this.offset.click.top,m=this.offset.click.left;var g=this.positionAbs.top,k=this.positionAbs.left;var j=i.height,l=i.width;var p=i.top,h=i.left;return a.ui.isOver(g+n,k+m,p,h,j,l)};a.each(e.sortables,function(g){this.instance.positionAbs=e.positionAbs;this.instance.helperProportions=e.helperProportions;this.instance.offset.click=e.offset.click;if(this.instance._intersectsWith(this.instance.containerCache)){if(!this.instance.isOver){this.instance.isOver=1;this.instance.currentItem=a(b).clone().appendTo(this.instance.element).data("sortable-item",true);this.instance.options._helper=this.instance.options.helper;this.instance.options.helper=function(){return f.helper[0]};c.target=this.instance.currentItem[0];this.instance._mouseCapture(c,true);this.instance._mouseStart(c,true,true);this.instance.offset.click.top=e.offset.click.top;this.instance.offset.click.left=e.offset.click.left;this.instance.offset.parent.left-=e.offset.parent.left-this.instance.offset.parent.left;this.instance.offset.parent.top-=e.offset.parent.top-this.instance.offset.parent.top;e._trigger("toSortable",c);e.dropped=this.instance.element;e.currentItem=e.element;this.instance.fromOutside=e}if(this.instance.currentItem){this.instance._mouseDrag(c)}}else{if(this.instance.isOver){this.instance.isOver=0;this.instance.cancelHelperRemoval=true;this.instance.options.revert=false;this.instance._trigger("out",c,this.instance._uiHash(this.instance));this.instance._mouseStop(c,true);this.instance.options.helper=this.instance.options._helper;this.instance.currentItem.remove();if(this.instance.placeholder){this.instance.placeholder.remove()}e._trigger("fromSortable",c);e.dropped=false}}})}});a.ui.plugin.add("draggable","cursor",{start:function(c,d){var b=a("body"),e=a(this).data("draggable").options;if(b.css("cursor")){e._cursor=b.css("cursor")}b.css("cursor",e.cursor)},stop:function(b,c){var d=a(this).data("draggable").options;if(d._cursor){a("body").css("cursor",d._cursor)}}});a.ui.plugin.add("draggable","iframeFix",{start:function(b,c){var d=a(this).data("draggable").options;a(d.iframeFix===true?"iframe":d.iframeFix).each(function(){a('<div class="ui-draggable-iframeFix" style="background: #fff;"></div>').css({width:this.offsetWidth+"px",height:this.offsetHeight+"px",position:"absolute",opacity:"0.001",zIndex:1000}).css(a(this).offset()).appendTo("body")})},stop:function(b,c){a("div.ui-draggable-iframeFix").each(function(){this.parentNode.removeChild(this)})}});a.ui.plugin.add("draggable","opacity",{start:function(c,d){var b=a(d.helper),e=a(this).data("draggable").options;if(b.css("opacity")){e._opacity=b.css("opacity")}b.css("opacity",e.opacity)},stop:function(b,c){var d=a(this).data("draggable").options;if(d._opacity){a(c.helper).css("opacity",d._opacity)}}});a.ui.plugin.add("draggable","scroll",{start:function(c,d){var b=a(this).data("draggable");if(b.scrollParent[0]!=document&&b.scrollParent[0].tagName!="HTML"){b.overflowOffset=b.scrollParent.offset()}},drag:function(d,e){var c=a(this).data("draggable"),f=c.options,b=false;if(c.scrollParent[0]!=document&&c.scrollParent[0].tagName!="HTML"){if(!f.axis||f.axis!="x"){if((c.overflowOffset.top+c.scrollParent[0].offsetHeight)-d.pageY<f.scrollSensitivity){c.scrollParent[0].scrollTop=b=c.scrollParent[0].scrollTop+f.scrollSpeed}else{if(d.pageY-c.overflowOffset.top<f.scrollSensitivity){c.scrollParent[0].scrollTop=b=c.scrollParent[0].scrollTop-f.scrollSpeed}}}if(!f.axis||f.axis!="y"){if((c.overflowOffset.left+c.scrollParent[0].offsetWidth)-d.pageX<f.scrollSensitivity){c.scrollParent[0].scrollLeft=b=c.scrollParent[0].scrollLeft+f.scrollSpeed}else{if(d.pageX-c.overflowOffset.left<f.scrollSensitivity){c.scrollParent[0].scrollLeft=b=c.scrollParent[0].scrollLeft-f.scrollSpeed}}}}else{if(!f.axis||f.axis!="x"){if(d.pageY-a(document).scrollTop()<f.scrollSensitivity){b=a(document).scrollTop(a(document).scrollTop()-f.scrollSpeed)}else{if(a(window).height()-(d.pageY-a(document).scrollTop())<f.scrollSensitivity){b=a(document).scrollTop(a(document).scrollTop()+f.scrollSpeed)}}}if(!f.axis||f.axis!="y"){if(d.pageX-a(document).scrollLeft()<f.scrollSensitivity){b=a(document).scrollLeft(a(document).scrollLeft()-f.scrollSpeed)}else{if(a(window).width()-(d.pageX-a(document).scrollLeft())<f.scrollSensitivity){b=a(document).scrollLeft(a(document).scrollLeft()+f.scrollSpeed)}}}}if(b!==false&&a.ui.ddmanager&&!f.dropBehaviour){a.ui.ddmanager.prepareOffsets(c,d)}}});a.ui.plugin.add("draggable","snap",{start:function(c,d){var b=a(this).data("draggable"),e=b.options;b.snapElements=[];a(e.snap.constructor!=String?(e.snap.items||":data(draggable)"):e.snap).each(function(){var g=a(this);var f=g.offset();if(this!=b.element[0]){b.snapElements.push({item:this,width:g.outerWidth(),height:g.outerHeight(),top:f.top,left:f.left})}})},drag:function(u,p){var g=a(this).data("draggable"),q=g.options;var y=q.snapTolerance;var x=p.offset.left,w=x+g.helperProportions.width,f=p.offset.top,e=f+g.helperProportions.height;for(var v=g.snapElements.length-1;v>=0;v--){var s=g.snapElements[v].left,n=s+g.snapElements[v].width,m=g.snapElements[v].top,A=m+g.snapElements[v].height;if(!((s-y<x&&x<n+y&&m-y<f&&f<A+y)||(s-y<x&&x<n+y&&m-y<e&&e<A+y)||(s-y<w&&w<n+y&&m-y<f&&f<A+y)||(s-y<w&&w<n+y&&m-y<e&&e<A+y))){if(g.snapElements[v].snapping){(g.options.snap.release&&g.options.snap.release.call(g.element,u,a.extend(g._uiHash(),{snapItem:g.snapElements[v].item})))}g.snapElements[v].snapping=false;continue}if(q.snapMode!="inner"){var c=Math.abs(m-e)<=y;var z=Math.abs(A-f)<=y;var j=Math.abs(s-w)<=y;var k=Math.abs(n-x)<=y;if(c){p.position.top=g._convertPositionTo("relative",{top:m-g.helperProportions.height,left:0}).top-g.margins.top}if(z){p.position.top=g._convertPositionTo("relative",{top:A,left:0}).top-g.margins.top}if(j){p.position.left=g._convertPositionTo("relative",{top:0,left:s-g.helperProportions.width}).left-g.margins.left}if(k){p.position.left=g._convertPositionTo("relative",{top:0,left:n}).left-g.margins.left}}var h=(c||z||j||k);if(q.snapMode!="outer"){var c=Math.abs(m-f)<=y;var z=Math.abs(A-e)<=y;var j=Math.abs(s-x)<=y;var k=Math.abs(n-w)<=y;if(c){p.position.top=g._convertPositionTo("relative",{top:m,left:0}).top-g.margins.top}if(z){p.position.top=g._convertPositionTo("relative",{top:A-g.helperProportions.height,left:0}).top-g.margins.top}if(j){p.position.left=g._convertPositionTo("relative",{top:0,left:s}).left-g.margins.left}if(k){p.position.left=g._convertPositionTo("relative",{top:0,left:n-g.helperProportions.width}).left-g.margins.left}}if(!g.snapElements[v].snapping&&(c||z||j||k||h)){(g.options.snap.snap&&g.options.snap.snap.call(g.element,u,a.extend(g._uiHash(),{snapItem:g.snapElements[v].item})))}g.snapElements[v].snapping=(c||z||j||k||h)}}});a.ui.plugin.add("draggable","stack",{start:function(b,c){var e=a(this).data("draggable").options;var d=a.makeArray(a(e.stack.group)).sort(function(g,f){return(parseInt(a(g).css("zIndex"),10)||e.stack.min)-(parseInt(a(f).css("zIndex"),10)||e.stack.min)});a(d).each(function(f){this.style.zIndex=e.stack.min+f});this[0].style.zIndex=e.stack.min+d.length}});a.ui.plugin.add("draggable","zIndex",{start:function(c,d){var b=a(d.helper),e=a(this).data("draggable").options;if(b.css("zIndex")){e._zIndex=b.css("zIndex")}b.css("zIndex",e.zIndex)},stop:function(b,c){var d=a(this).data("draggable").options;if(d._zIndex){a(c.helper).css("zIndex",d._zIndex)}}})})(this.jQuery);;               
   
      
      /*
       * jQuery UI Effects 1.7.3
       *
       * Copyright (c) 2009 AUTHORS.txt (http://jqueryui.com/about)
       * Dual licensed under the MIT (MIT-LICENSE.txt)
       * and GPL (GPL-LICENSE.txt) licenses.
       *
       * http://docs.jquery.com/UI/Effects/
       */
      /*
      this.jQuery.effects||(function(d){d.effects={version:"1.7.3",save:function(g,h){for(var f=0;f<h.length;f++){if(h[f]!==null){g.data("ec.storage."+h[f],g[0].style[h[f]])}}},restore:function(g,h){for(var f=0;f<h.length;f++){if(h[f]!==null){g.css(h[f],g.data("ec.storage."+h[f]))}}},setMode:function(f,g){if(g=="toggle"){g=f.is(":hidden")?"show":"hide"}return g},getBaseline:function(g,h){var i,f;switch(g[0]){case"top":i=0;break;case"middle":i=0.5;break;case"bottom":i=1;break;default:i=g[0]/h.height}switch(g[1]){case"left":f=0;break;case"center":f=0.5;break;case"right":f=1;break;default:f=g[1]/h.width}return{x:f,y:i}},createWrapper:function(f){if(f.parent().is(".ui-effects-wrapper")){return f.parent()}var g={width:f.outerWidth(true),height:f.outerHeight(true),"float":f.css("float")};f.wrap('<div class="ui-effects-wrapper" style="font-size:100%;background:transparent;border:none;margin:0;padding:0"></div>');var j=f.parent();if(f.css("position")=="static"){j.css({position:"relative"});f.css({position:"relative"})}else{var i=f.css("top");if(isNaN(parseInt(i,10))){i="auto"}var h=f.css("left");if(isNaN(parseInt(h,10))){h="auto"}j.css({position:f.css("position"),top:i,left:h,zIndex:f.css("z-index")}).show();f.css({position:"relative",top:0,left:0})}j.css(g);return j},removeWrapper:function(f){if(f.parent().is(".ui-effects-wrapper")){return f.parent().replaceWith(f)}return f},setTransition:function(g,i,f,h){h=h||{};d.each(i,function(k,j){unit=g.cssUnit(j);if(unit[0]>0){h[j]=unit[0]*f+unit[1]}});return h},animateClass:function(h,i,k,j){var f=(typeof k=="function"?k:(j?j:null));var g=(typeof k=="string"?k:null);return this.each(function(){var q={};var o=d(this);var p=o.attr("style")||"";if(typeof p=="object"){p=p.cssText}if(h.toggle){o.hasClass(h.toggle)?h.remove=h.toggle:h.add=h.toggle}var l=d.extend({},(document.defaultView?document.defaultView.getComputedStyle(this,null):this.currentStyle));if(h.add){o.addClass(h.add)}if(h.remove){o.removeClass(h.remove)}var m=d.extend({},(document.defaultView?document.defaultView.getComputedStyle(this,null):this.currentStyle));if(h.add){o.removeClass(h.add)}if(h.remove){o.addClass(h.remove)}for(var r in m){if(typeof m[r]!="function"&&m[r]&&r.indexOf("Moz")==-1&&r.indexOf("length")==-1&&m[r]!=l[r]&&(r.match(/color/i)||(!r.match(/color/i)&&!isNaN(parseInt(m[r],10))))&&(l.position!="static"||(l.position=="static"&&!r.match(/left|top|bottom|right/)))){q[r]=m[r]}}o.animate(q,i,g,function(){if(typeof d(this).attr("style")=="object"){d(this).attr("style")["cssText"]="";d(this).attr("style")["cssText"]=p}else{d(this).attr("style",p)}if(h.add){d(this).addClass(h.add)}if(h.remove){d(this).removeClass(h.remove)}if(f){f.apply(this,arguments)}})})}};function c(g,f){var i=g[1]&&g[1].constructor==Object?g[1]:{};if(f){i.mode=f}var h=g[1]&&g[1].constructor!=Object?g[1]:(i.duration?i.duration:g[2]);h=d.fx.off?0:typeof h==="number"?h:d.fx.speeds[h]||d.fx.speeds._default;var j=i.callback||(d.isFunction(g[1])&&g[1])||(d.isFunction(g[2])&&g[2])||(d.isFunction(g[3])&&g[3]);return[g[0],i,h,j]}d.fn.extend({_show:d.fn.show,_hide:d.fn.hide,__toggle:d.fn.toggle,_addClass:d.fn.addClass,_removeClass:d.fn.removeClass,_toggleClass:d.fn.toggleClass,effect:function(g,f,h,i){return d.effects[g]?d.effects[g].call(this,{method:g,options:f||{},duration:h,callback:i}):null},show:function(){if(!arguments[0]||(arguments[0].constructor==Number||(/(slow|normal|fast)/).test(arguments[0]))){return this._show.apply(this,arguments)}else{return this.effect.apply(this,c(arguments,"show"))}},hide:function(){if(!arguments[0]||(arguments[0].constructor==Number||(/(slow|normal|fast)/).test(arguments[0]))){return this._hide.apply(this,arguments)}else{return this.effect.apply(this,c(arguments,"hide"))}},toggle:function(){if(!arguments[0]||(arguments[0].constructor==Number||(/(slow|normal|fast)/).test(arguments[0]))||(d.isFunction(arguments[0])||typeof arguments[0]=="boolean")){return this.__toggle.apply(this,arguments)}else{return this.effect.apply(this,c(arguments,"toggle"))}},addClass:function(g,f,i,h){return f?d.effects.animateClass.apply(this,[{add:g},f,i,h]):this._addClass(g)},removeClass:function(g,f,i,h){return f?d.effects.animateClass.apply(this,[{remove:g},f,i,h]):this._removeClass(g)},toggleClass:function(g,f,i,h){return((typeof f!=="boolean")&&f)?d.effects.animateClass.apply(this,[{toggle:g},f,i,h]):this._toggleClass(g,f)},morph:function(f,h,g,j,i){return d.effects.animateClass.apply(this,[{add:h,remove:f},g,j,i])},switchClass:function(){return this.morph.apply(this,arguments)},cssUnit:function(f){var g=this.css(f),h=[];d.each(["em","px","%","pt"],function(j,k){if(g.indexOf(k)>0){h=[parseFloat(g),k]}});return h}});d.each(["backgroundColor","borderBottomColor","borderLeftColor","borderRightColor","borderTopColor","color","outlineColor"],function(g,f){d.fx.step[f]=function(h){if(h.state==0){h.start=e(h.elem,f);h.end=b(h.end)}h.elem.style[f]="rgb("+[Math.max(Math.min(parseInt((h.pos*(h.end[0]-h.start[0]))+h.start[0],10),255),0),Math.max(Math.min(parseInt((h.pos*(h.end[1]-h.start[1]))+h.start[1],10),255),0),Math.max(Math.min(parseInt((h.pos*(h.end[2]-h.start[2]))+h.start[2],10),255),0)].join(",")+")"}});function b(g){var f;if(g&&g.constructor==Array&&g.length==3){return g}if(f=/rgb\(\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*\)/.exec(g)){return[parseInt(f[1],10),parseInt(f[2],10),parseInt(f[3],10)]}if(f=/rgb\(\s*([0-9]+(?:\.[0-9]+)?)\%\s*,\s*([0-9]+(?:\.[0-9]+)?)\%\s*,\s*([0-9]+(?:\.[0-9]+)?)\%\s*\)/.exec(g)){return[parseFloat(f[1])*2.55,parseFloat(f[2])*2.55,parseFloat(f[3])*2.55]}if(f=/#([a-fA-F0-9]{2})([a-fA-F0-9]{2})([a-fA-F0-9]{2})/.exec(g)){return[parseInt(f[1],16),parseInt(f[2],16),parseInt(f[3],16)]}if(f=/#([a-fA-F0-9])([a-fA-F0-9])([a-fA-F0-9])/.exec(g)){return[parseInt(f[1]+f[1],16),parseInt(f[2]+f[2],16),parseInt(f[3]+f[3],16)]}if(f=/rgba\(0, 0, 0, 0\)/.exec(g)){return a.transparent}return a[d.trim(g).toLowerCase()]}function e(h,f){var g;do{g=d.curCSS(h,f);if(g!=""&&g!="transparent"||d.nodeName(h,"body")){break}f="backgroundColor"}while(h=h.parentNode);return b(g)}var a={aqua:[0,255,255],azure:[240,255,255],beige:[245,245,220],black:[0,0,0],blue:[0,0,255],brown:[165,42,42],cyan:[0,255,255],darkblue:[0,0,139],darkcyan:[0,139,139],darkgrey:[169,169,169],darkgreen:[0,100,0],darkkhaki:[189,183,107],darkmagenta:[139,0,139],darkolivegreen:[85,107,47],darkorange:[255,140,0],darkorchid:[153,50,204],darkred:[139,0,0],darksalmon:[233,150,122],darkviolet:[148,0,211],fuchsia:[255,0,255],gold:[255,215,0],green:[0,128,0],indigo:[75,0,130],khaki:[240,230,140],lightblue:[173,216,230],lightcyan:[224,255,255],lightgreen:[144,238,144],lightgrey:[211,211,211],lightpink:[255,182,193],lightyellow:[255,255,224],lime:[0,255,0],magenta:[255,0,255],maroon:[128,0,0],navy:[0,0,128],olive:[128,128,0],orange:[255,165,0],pink:[255,192,203],purple:[128,0,128],violet:[128,0,128],red:[255,0,0],silver:[192,192,192],white:[255,255,255],yellow:[255,255,0],transparent:[255,255,255]};d.easing.jswing=d.easing.swing;d.extend(d.easing,{def:"easeOutQuad",swing:function(g,h,f,j,i){return d.easing[d.easing.def](g,h,f,j,i)},easeInQuad:function(g,h,f,j,i){return j*(h/=i)*h+f},easeOutQuad:function(g,h,f,j,i){return -j*(h/=i)*(h-2)+f},easeInOutQuad:function(g,h,f,j,i){if((h/=i/2)<1){return j/2*h*h+f}return -j/2*((--h)*(h-2)-1)+f},easeInCubic:function(g,h,f,j,i){return j*(h/=i)*h*h+f},easeOutCubic:function(g,h,f,j,i){return j*((h=h/i-1)*h*h+1)+f},easeInOutCubic:function(g,h,f,j,i){if((h/=i/2)<1){return j/2*h*h*h+f}return j/2*((h-=2)*h*h+2)+f},easeInQuart:function(g,h,f,j,i){return j*(h/=i)*h*h*h+f},easeOutQuart:function(g,h,f,j,i){return -j*((h=h/i-1)*h*h*h-1)+f},easeInOutQuart:function(g,h,f,j,i){if((h/=i/2)<1){return j/2*h*h*h*h+f}return -j/2*((h-=2)*h*h*h-2)+f},easeInQuint:function(g,h,f,j,i){return j*(h/=i)*h*h*h*h+f},easeOutQuint:function(g,h,f,j,i){return j*((h=h/i-1)*h*h*h*h+1)+f},easeInOutQuint:function(g,h,f,j,i){if((h/=i/2)<1){return j/2*h*h*h*h*h+f}return j/2*((h-=2)*h*h*h*h+2)+f},easeInSine:function(g,h,f,j,i){return -j*Math.cos(h/i*(Math.PI/2))+j+f},easeOutSine:function(g,h,f,j,i){return j*Math.sin(h/i*(Math.PI/2))+f},easeInOutSine:function(g,h,f,j,i){return -j/2*(Math.cos(Math.PI*h/i)-1)+f},easeInExpo:function(g,h,f,j,i){return(h==0)?f:j*Math.pow(2,10*(h/i-1))+f},easeOutExpo:function(g,h,f,j,i){return(h==i)?f+j:j*(-Math.pow(2,-10*h/i)+1)+f},easeInOutExpo:function(g,h,f,j,i){if(h==0){return f}if(h==i){return f+j}if((h/=i/2)<1){return j/2*Math.pow(2,10*(h-1))+f}return j/2*(-Math.pow(2,-10*--h)+2)+f},easeInCirc:function(g,h,f,j,i){return -j*(Math.sqrt(1-(h/=i)*h)-1)+f},easeOutCirc:function(g,h,f,j,i){return j*Math.sqrt(1-(h=h/i-1)*h)+f},easeInOutCirc:function(g,h,f,j,i){if((h/=i/2)<1){return -j/2*(Math.sqrt(1-h*h)-1)+f}return j/2*(Math.sqrt(1-(h-=2)*h)+1)+f},easeInElastic:function(g,i,f,m,l){var j=1.70158;var k=0;var h=m;if(i==0){return f}if((i/=l)==1){return f+m}if(!k){k=l*0.3}if(h<Math.abs(m)){h=m;var j=k/4}else{var j=k/(2*Math.PI)*Math.asin(m/h)}return -(h*Math.pow(2,10*(i-=1))*Math.sin((i*l-j)*(2*Math.PI)/k))+f},easeOutElastic:function(g,i,f,m,l){var j=1.70158;var k=0;var h=m;if(i==0){return f}if((i/=l)==1){return f+m}if(!k){k=l*0.3}if(h<Math.abs(m)){h=m;var j=k/4}else{var j=k/(2*Math.PI)*Math.asin(m/h)}return h*Math.pow(2,-10*i)*Math.sin((i*l-j)*(2*Math.PI)/k)+m+f},easeInOutElastic:function(g,i,f,m,l){var j=1.70158;var k=0;var h=m;if(i==0){return f}if((i/=l/2)==2){return f+m}if(!k){k=l*(0.3*1.5)}if(h<Math.abs(m)){h=m;var j=k/4}else{var j=k/(2*Math.PI)*Math.asin(m/h)}if(i<1){return -0.5*(h*Math.pow(2,10*(i-=1))*Math.sin((i*l-j)*(2*Math.PI)/k))+f}return h*Math.pow(2,-10*(i-=1))*Math.sin((i*l-j)*(2*Math.PI)/k)*0.5+m+f},easeInBack:function(g,h,f,k,j,i){if(i==undefined){i=1.70158}return k*(h/=j)*h*((i+1)*h-i)+f},easeOutBack:function(g,h,f,k,j,i){if(i==undefined){i=1.70158}return k*((h=h/j-1)*h*((i+1)*h+i)+1)+f},easeInOutBack:function(g,h,f,k,j,i){if(i==undefined){i=1.70158}if((h/=j/2)<1){return k/2*(h*h*(((i*=(1.525))+1)*h-i))+f}return k/2*((h-=2)*h*(((i*=(1.525))+1)*h+i)+2)+f},easeInBounce:function(g,h,f,j,i){return j-d.easing.easeOutBounce(g,i-h,0,j,i)+f},easeOutBounce:function(g,h,f,j,i){if((h/=i)<(1/2.75)){return j*(7.5625*h*h)+f}else{if(h<(2/2.75)){return j*(7.5625*(h-=(1.5/2.75))*h+0.75)+f}else{if(h<(2.5/2.75)){return j*(7.5625*(h-=(2.25/2.75))*h+0.9375)+f}else{return j*(7.5625*(h-=(2.625/2.75))*h+0.984375)+f}}}},easeInOutBounce:function(g,h,f,j,i){if(h<i/2){return d.easing.easeInBounce(g,h*2,0,j,i)*0.5+f}return d.easing.easeOutBounce(g,h*2-i,0,j,i)*0.5+j*0.5+f}})})(this.jQuery);;
      */
      
      /*
       * jQuery UI Effects Scale 1.7.3
       *
       * Copyright (c) 2009 AUTHORS.txt (http://jqueryui.com/about)
       * Dual licensed under the MIT (MIT-LICENSE.txt)
       * and GPL (GPL-LICENSE.txt) licenses.
       *
       * http://docs.jquery.com/UI/Effects/Scale
       *
       * Depends:
       * effects.core.js
       */
      /*
      (function(a){a.effects.puff=function(b){return this.queue(function(){var f=a(this);var c=a.extend(true,{},b.options);var h=a.effects.setMode(f,b.options.mode||"hide");var g=parseInt(b.options.percent,10)||150;c.fade=true;var e={height:f.height(),width:f.width()};var d=g/100;f.from=(h=="hide")?e:{height:e.height*d,width:e.width*d};c.from=f.from;c.percent=(h=="hide")?g:100;c.mode=h;f.effect("scale",c,b.duration,b.callback);f.dequeue()})};a.effects.scale=function(b){return this.queue(function(){var g=a(this);var d=a.extend(true,{},b.options);var j=a.effects.setMode(g,b.options.mode||"effect");var h=parseInt(b.options.percent,10)||(parseInt(b.options.percent,10)==0?0:(j=="hide"?0:100));var i=b.options.direction||"both";var c=b.options.origin;if(j!="effect"){d.origin=c||["middle","center"];d.restore=true}var f={height:g.height(),width:g.width()};g.from=b.options.from||(j=="show"?{height:0,width:0}:f);var e={y:i!="horizontal"?(h/100):1,x:i!="vertical"?(h/100):1};g.to={height:f.height*e.y,width:f.width*e.x};if(b.options.fade){if(j=="show"){g.from.opacity=0;g.to.opacity=1}if(j=="hide"){g.from.opacity=1;g.to.opacity=0}}d.from=g.from;d.to=g.to;d.mode=j;g.effect("size",d,b.duration,b.callback);g.dequeue()})};a.effects.size=function(b){return this.queue(function(){var c=a(this),n=["position","top","left","width","height","overflow","opacity"];var m=["position","top","left","overflow","opacity"];var j=["width","height","overflow"];var p=["fontSize"];var k=["borderTopWidth","borderBottomWidth","paddingTop","paddingBottom"];var f=["borderLeftWidth","borderRightWidth","paddingLeft","paddingRight"];var g=a.effects.setMode(c,b.options.mode||"effect");var i=b.options.restore||false;var e=b.options.scale||"both";var o=b.options.origin;var d={height:c.height(),width:c.width()};c.from=b.options.from||d;c.to=b.options.to||d;if(o){var h=a.effects.getBaseline(o,d);c.from.top=(d.height-c.from.height)*h.y;c.from.left=(d.width-c.from.width)*h.x;c.to.top=(d.height-c.to.height)*h.y;c.to.left=(d.width-c.to.width)*h.x}var l={from:{y:c.from.height/d.height,x:c.from.width/d.width},to:{y:c.to.height/d.height,x:c.to.width/d.width}};if(e=="box"||e=="both"){if(l.from.y!=l.to.y){n=n.concat(k);c.from=a.effects.setTransition(c,k,l.from.y,c.from);c.to=a.effects.setTransition(c,k,l.to.y,c.to)}if(l.from.x!=l.to.x){n=n.concat(f);c.from=a.effects.setTransition(c,f,l.from.x,c.from);c.to=a.effects.setTransition(c,f,l.to.x,c.to)}}if(e=="content"||e=="both"){if(l.from.y!=l.to.y){n=n.concat(p);c.from=a.effects.setTransition(c,p,l.from.y,c.from);c.to=a.effects.setTransition(c,p,l.to.y,c.to)}}a.effects.save(c,i?n:m);c.show();a.effects.createWrapper(c);c.css("overflow","hidden").css(c.from);if(e=="content"||e=="both"){k=k.concat(["marginTop","marginBottom"]).concat(p);f=f.concat(["marginLeft","marginRight"]);j=n.concat(k).concat(f);c.find("*[width]").each(function(){child=a(this);if(i){a.effects.save(child,j)}var q={height:child.height(),width:child.width()};child.from={height:q.height*l.from.y,width:q.width*l.from.x};child.to={height:q.height*l.to.y,width:q.width*l.to.x};if(l.from.y!=l.to.y){child.from=a.effects.setTransition(child,k,l.from.y,child.from);child.to=a.effects.setTransition(child,k,l.to.y,child.to)}if(l.from.x!=l.to.x){child.from=a.effects.setTransition(child,f,l.from.x,child.from);child.to=a.effects.setTransition(child,f,l.to.x,child.to)}child.css(child.from);child.animate(child.to,b.duration,b.options.easing,function(){if(i){a.effects.restore(child,j)}})})}c.animate(c.to,{queue:false,duration:b.duration,easing:b.options.easing,complete:function(){if(g=="hide"){c.hide()}a.effects.restore(c,i?n:m);a.effects.removeWrapper(c);if(b.callback){b.callback.apply(this,arguments)}c.dequeue()}})})}})(this.jQuery);;
      */
   }
}

/**
 * Aliases for backward compatibility
 */
var ptInitPearl = PEARLTREES.embed.initPearl;
var ptInitTree  = PEARLTREES.embed.initTree;

PEARLTREES.libs.init();
PEARLTREES.embed.init();
}
