2017-02-28 16:06:18 +01:00
/ * !
2019-04-28 20:15:55 +02:00
* Minimal Mistakes Jekyll Theme 4.16 . 1 by Michael Rose
2019-01-02 01:12:04 +01:00
* Copyright 2013 - 2019 Michael Rose - mademistakes . com | @ mmistakes
2017-02-28 16:06:18 +01:00
* Licensed under MIT
* /
2019-04-28 20:15:55 +02:00
! function ( e , t ) { "use strict" ; "object" == typeof module && "object" == typeof module . exports ? module . exports = e . document ? t ( e , ! 0 ) : function ( e ) { if ( ! e . document ) throw new Error ( "jQuery requires a window with a document" ) ; return t ( e ) } : t ( e ) } ( "undefined" != typeof window ? window : this , function ( e , t ) { "use strict" ; function n ( e , t , n ) { var r , o , i = ( n = n || Z ) . createElement ( "script" ) ; if ( i . text = e , t ) for ( r in de ) ( o = t [ r ] || t . getAttribute && t . getAttribute ( r ) ) && i . setAttribute ( r , o ) ; n . head . appendChild ( i ) . parentNode . removeChild ( i ) } function r ( e ) { return null == e ? e + "" : "object" == typeof e || "function" == typeof e ? oe [ ie . call ( e ) ] || "object" : typeof e } function o ( e ) { var t = ! ! e && "length" in e && e . length , n = r ( e ) ; return ! ce ( e ) && ! fe ( e ) && ( "array" === n || 0 === t || "number" == typeof t && t > 0 && t - 1 in e ) } function i ( e , t ) { return e . nodeName && e . nodeName . toLowerCase ( ) === t . toLowerCase ( ) } function a ( e , t , n ) { return ce ( t ) ? he . grep ( e , function ( e , r ) { return ! ! t . call ( e , r , e ) !== n } ) : t . nodeType ? he . grep ( e , function ( e ) { return e === t !== n } ) : "string" != typeof t ? he . grep ( e , function ( e ) { return - 1 < re . call ( t , e ) !== n } ) : he . filter ( t , e , n ) } function s ( e , t ) { for ( ; ( e = e [ t ] ) && 1 !== e . nodeType ; ) ; return e } function u ( e ) { return e } function l ( e ) { throw e } function c ( e , t , n , r ) { var o ; try { e && ce ( o = e . promise ) ? o . call ( e ) . done ( t ) . fail ( n ) : e && ce ( o = e . then ) ? o . call ( e , t , n ) : t . apply ( void 0 , [ e ] . slice ( r ) ) } catch ( e ) { n . apply ( void 0 , [ e ] ) } } function f ( ) { Z . removeEventListener ( "DOMContentLoaded" , f ) , e . removeEventListener ( "load" , f ) , he . ready ( ) } function d ( e , t ) { return t . toUpperCase ( ) } function p ( e ) { return e . replace ( je , "ms-" ) . replace ( Ie , d ) } function h ( ) { this . expando = he . expando + h . uid ++ } function m ( e , t , n ) { var r , o ; if ( void 0 === n && 1 === e . nodeType ) if ( r = "data-" + t . replace ( Pe , "-$&" ) . toLowerCase ( ) , "string" == typeof ( n = e . getAttribute ( r ) ) ) { try { n = "true" === ( o = n ) || "false" !== o && ( "null" === o ? null : o === + o + "" ? + o : He . test ( o ) ? JSON . parse ( o ) : o ) } catch ( e ) { } Oe . set ( e , t , n ) } else n = void 0 ; return n } function g ( e , t , n , r ) { var o , i , a = 20 , s = r ? function ( ) { return r . cur ( ) } : function ( ) { return he . css ( e , t , "" ) } , u = s ( ) , l = n && n [ 3 ] || ( he . cssNumber [ t ] ? "" : "px" ) , c = e . nodeType && ( he . cssNumber [ t ] || "px" !== l && + u ) && Me . exec ( he . css ( e , t ) ) ; if ( c && c [ 3 ] !== l ) { for ( u /= 2 , l = l || c [ 3 ] , c = + u || 1 ; a -- ; ) he . style ( e , t , c + l ) , ( 1 - i ) * ( 1 - ( i = s ( ) / u || . 5 ) ) <= 0 && ( a = 0 ) , c /= i ; c *= 2 , he . style ( e , t , c + l ) , n = n || [ ] } return n && ( c = + c || + u || 0 , o = n [ 1 ] ? c + ( n [ 1 ] + 1 ) * n [ 2 ] : + n [ 2 ] , r && ( r . unit = l , r . start = c , r . end = o ) ) , o } function v ( e , t ) { for ( var n , r , o , i , a , s , u , l = [ ] , c = 0 , f = e . length ; f > c ; c ++ ) ( r = e [ c ] ) . style && ( n = r . style . display , t ? ( "none" === n && ( l [ c ] = De . get ( r , "display" ) || null , l [ c ] || ( r . style . display = "" ) ) , "" === r . style . display && Fe ( r ) && ( l [ c ] = ( u = a = i = void 0 , a = ( o = r ) . ownerDocument , s = o . nodeName , ( u = We [ s ] ) || ( i = a . body . appendChild ( a . createElement ( s ) ) , u = he . css ( i , "display" ) , i . parentNode . removeChild ( i ) , "none" === u && ( u = "block" ) , We [ s ] = u ) ) ) ) : "none" !== n && ( l [ c ] = "none" , De . set ( r , "display" , n ) ) ) ; for ( c = 0 ; f > c ; c ++ ) null != l [ c ] && ( e [ c ] . style . display = l [ c ] ) ; return e } function y ( e , t ) { var n ; return n = "undefined" != typeof e . getElementsByTagName ? e . getElementsByTagName ( t || "*" ) : "undefined" != typeof e . querySelectorAll ? e . querySelectorAll ( t || "*" ) : [ ] , void 0 === t || t && i ( e , t ) ? he . merge ( [ e ] , n ) : n } function b ( e , t ) { for ( var n = 0 , r = e . length ; r > n ; n ++ ) De . set ( e [ n ] , "globalEval" , ! t || De . get ( t [ n ] , "globalEval" ) ) } function x ( e , t , n , o , i ) { for ( var a , s , u , l , c , f , d = t . createDocumentFragment ( ) , p = [ ] , h = 0 , m = e . length ; m > h ; h ++ ) if ( ( a = e [ h ] ) || 0 === a ) if ( "object" === r ( a ) ) he . merge ( p , a . nodeType ? [ a ] : a ) ; else if ( Ke . test ( a ) ) { for ( s = s || d . appendChild ( t . createElement ( "div" ) ) , u = ( Xe . exec ( a ) || [ "" , "" ] ) [ 1 ] . toLowerCase ( ) , l = Ye [ u ] || Ye . _default , s . innerHTML = l [ 1 ] + he . htmlPrefilter ( a ) + l [ 2 ] , f = l [ 0 ] ; f -- ; ) s = s . lastChild ; he . merge ( p , s . childNodes ) , ( s = d . firstChild ) . textContent = "" } else p . push ( t . createTextNode ( a ) ) ; for ( d . textContent = "" , h = 0 ; a = p [ h ++ ] ; ) if ( o && - 1 < he . inArray ( a , o ) ) i && i . push ( a ) ; else if ( c = Re ( a ) , s = y ( d . appendChild ( a ) , "script" ) , c && b ( s ) , n ) for ( f = 0 ; a = s [ f ++ ] ; ) Qe . test ( a . type || "" ) && n . push ( a ) ; return d } function w ( ) { return ! 0 } function C ( ) { return ! 1 } function T ( e , t ) { return e === function ( ) { try { return Z . activeElement } catch ( e ) { } } ( ) == ( "focus" === t ) } function E ( e , t , n , r , o , i ) { var a , s ; if ( "object" == typeof t ) { for ( s in "string" != typeof n && ( r = r || n , n = void 0 ) , t ) E ( e , s , n , r , t [ s ] , i ) ; return e } if ( null == r && null == o ? ( o = n , r = n = void 0 ) : null == o && ( "string" == typeof n ? ( o = r , r = void 0 ) : ( o = r , r = n , n = void 0 ) ) , ! 1 === o
} return l && ( R = x , A = y ) , m } , s ? r ( l ) : l ) ) ) . selector = e } return d } , k = t . select = function ( e , t , n , r ) { var o , i , a , s , u , l = "function" == typeof e && e , c = ! r && E ( e = l . selector || e ) ; if ( n = n || [ ] , 1 === c . length ) { if ( 2 < ( i = c [ 0 ] = c [ 0 ] . slice ( 0 ) ) . length && "ID" === ( a = i [ 0 ] ) . type && 9 === t . nodeType && O && w . relative [ i [ 1 ] . type ] ) { if ( ! ( t = ( w . find . ID ( a . matches [ 0 ] . replace ( be , xe ) , t ) || [ ] ) [ 0 ] ) ) return n ; l && ( t = t . parentNode ) , e = e . slice ( i . shift ( ) . value . length ) } for ( o = de . needsContext . test ( e ) ? 0 : i . length ; o -- && ( a = i [ o ] , ! w . relative [ s = a . type ] ) ; ) if ( ( u = w . find [ s ] ) && ( r = u ( a . matches [ 0 ] . replace ( be , xe ) , ye . test ( i [ 0 ] . type ) && f ( t . parentNode ) || t ) ) ) { if ( i . splice ( o , 1 ) , ! ( e = r . length && p ( i ) ) ) return K . apply ( n , r ) , n ; break } } return ( l || S ( e , c ) ) ( r , t , ! O , n , ! t || ye . test ( e ) && f ( t . parentNode ) || t ) , n } , x . sortStable = _ . split ( "" ) . sort ( X ) . join ( "" ) === _ , x . detectDuplicates = ! ! j , I ( ) , x . sortDetached = o ( function ( e ) { return 1 & e . compareDocumentPosition ( L . createElement ( "fieldset" ) ) } ) , o ( function ( e ) { return e . innerHTML = "<a href='#'></a>" , "#" === e . firstChild . getAttribute ( "href" ) } ) || i ( "type|href|height|width" , function ( e , t , n ) { return n ? void 0 : e . getAttribute ( t , "type" === t . toLowerCase ( ) ? 1 : 2 ) } ) , x . attributes && o ( function ( e ) { return e . innerHTML = "<input/>" , e . firstChild . setAttribute ( "value" , "" ) , "" === e . firstChild . getAttribute ( "value" ) } ) || i ( "value" , function ( e , t , n ) { return n || "input" !== e . nodeName . toLowerCase ( ) ? void 0 : e . defaultValue } ) , o ( function ( e ) { return null == e . getAttribute ( "disabled" ) } ) || i ( ee , function ( e , t , n ) { var r ; return n ? void 0 : ! 0 === e [ t ] ? t . toLowerCase ( ) : ( r = e . getAttributeNode ( t ) ) && r . specified ? r . value : null } ) , t } ( e ) ; he . find = ge , he . expr = ge . selectors , he . expr [ ":" ] = he . expr . pseudos , he . uniqueSort = he . unique = ge . uniqueSort , he . text = ge . getText , he . isXMLDoc = ge . isXML , he . contains = ge . contains , he . escapeSelector = ge . escape ; var ve = function ( e , t , n ) { for ( var r = [ ] , o = void 0 !== n ; ( e = e [ t ] ) && 9 !== e . nodeType ; ) if ( 1 === e . nodeType ) { if ( o && he ( e ) . is ( n ) ) break ; r . push ( e ) } return r } , ye = function ( e , t ) { for ( var n = [ ] ; e ; e = e . nextSibling ) 1 === e . nodeType && e !== t && n . push ( e ) ; return n } , be = he . expr . match . needsContext , xe = /^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i ; he . filter = function ( e , t , n ) { var r = t [ 0 ] ; return n && ( e = ":not(" + e + ")" ) , 1 === t . length && 1 === r . nodeType ? he . find . matchesSelector ( r , e ) ? [ r ] : [ ] : he . find . matches ( e , he . grep ( t , function ( e ) { return 1 === e . nodeType } ) ) } , he . fn . extend ( { find : function ( e ) { var t , n , r = this . length , o = this ; if ( "string" != typeof e ) return this . pushStack ( he ( e ) . filter ( function ( ) { for ( t = 0 ; r > t ; t ++ ) if ( he . contains ( o [ t ] , this ) ) return ! 0 } ) ) ; for ( n = this . pushStack ( [ ] ) , t = 0 ; r > t ; t ++ ) he . find ( e , o [ t ] , n ) ; return r > 1 ? he . uniqueSort ( n ) : n } , filter : function ( e ) { return this . pushStack ( a ( this , e || [ ] , ! 1 ) ) } , not : function ( e ) { return this . pushStack ( a ( this , e || [ ] , ! 0 ) ) } , is : function ( e ) { return ! ! a ( this , "string" == typeof e && be . test ( e ) ? he ( e ) : e || [ ] , ! 1 ) . length } } ) ; var we , Ce = /^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/ ; ( he . fn . init = function ( e , t , n ) { var r , o ; if ( ! e ) return this ; if ( n = n || we , "string" == typeof e ) { if ( ! ( r = "<" === e [ 0 ] && ">" === e [ e . length - 1 ] && 3 <= e . length ? [ null , e , null ] : Ce . exec ( e ) ) || ! r [ 1 ] && t ) return ! t || t . jquery ? ( t || n ) . find ( e ) : this . constructor ( t ) . find ( e ) ; if ( r [ 1 ] ) { if ( t = t instanceof he ? t [ 0 ] : t , he . merge ( this , he . parseHTML ( r [ 1 ] , t && t . nodeType ? t . ownerDocument || t : Z , ! 0 ) ) , xe . test ( r [ 1 ] ) && he . isPlainObject ( t ) ) for ( r in t ) ce ( this [ r ] ) ? this [ r ] ( t [ r ] ) : this . attr ( r , t [ r ] ) ; return this } return ( o = Z . getElementById ( r [ 2 ] ) ) && ( this [ 0 ] = o , this . length = 1 ) , this } return e . nodeType ? ( this [ 0 ] = e , this . length = 1 , this ) : ce ( e ) ? void 0 !== n . ready ? n . ready ( e ) : e ( he ) : he . makeArray ( e , this ) } ) . prototype = he . fn , we = he ( Z ) ; var Te = /^(?:parents|prev(?:Until|All))/ , Ee = { children : ! 0 , contents : ! 0 , next : ! 0 , prev : ! 0 } ; he . fn . extend ( { has : function ( e ) { var t = he ( e , this ) , n = t . length ; return this . filter ( function ( ) { for ( var e = 0 ; n > e ; e ++ ) if ( he . contains ( this , t [ e ] ) ) return ! 0 } ) } , closest : function ( e , t ) { var n , r = 0 , o = this . length , i = [ ] , a = "string" != typeof e && he ( e ) ; if ( ! be . test ( e ) ) for ( ; o > r ; r ++ ) for ( n = this [ r ] ; n && n !== t ; n = n . parentNode ) if ( n . nodeType < 11 && ( a ? - 1 < a . index ( n ) : 1 === n . nodeType && he . find . matchesSelector ( n , e ) ) ) { i . push ( n ) ; break } return this . pushStack ( 1 < i . length ? he . uniqueSort ( i ) : i ) } , index : function ( e ) { return e ? "string" == typeof e ? re . call ( he ( e ) , this [ 0 ] ) : re . call ( this , e . jquery ? e [ 0 ] : e ) : this [ 0 ] && this [ 0 ] . parentNode ? this . first ( ) . prevAll ( ) . length : - 1 } , add : function ( e , t ) { return this . pu
for ( o = i . length ; o -- ; ) i [ o ] . elem !== this || null != e && i [ o ] . queue !== e || ( i [ o ] . anim . stop ( n ) , t = ! 1 , i . splice ( o , 1 ) ) ; ! t && n || he . dequeue ( this , e ) } ) } , finish : function ( e ) { return ! 1 !== e && ( e = e || "fx" ) , this . each ( function ( ) { var t , n = De . get ( this ) , r = n [ e + "queue" ] , o = n [ e + "queueHooks" ] , i = he . timers , a = r ? r . length : 0 ; for ( n . finish = ! 0 , he . queue ( this , e , [ ] ) , o && o . stop && o . stop . call ( this , ! 0 ) , t = i . length ; t -- ; ) i [ t ] . elem === this && i [ t ] . queue === e && ( i [ t ] . anim . stop ( ! 0 ) , i . splice ( t , 1 ) ) ; for ( t = 0 ; a > t ; t ++ ) r [ t ] && r [ t ] . finish && r [ t ] . finish . call ( this ) ; delete n . finish } ) } } ) , he . each ( [ "toggle" , "show" , "hide" ] , function ( e , t ) { var n = he . fn [ t ] ; he . fn [ t ] = function ( e , r , o ) { return null == e || "boolean" == typeof e ? n . apply ( this , arguments ) : this . animate ( $ ( t , ! 0 ) , e , r , o ) } } ) , he . each ( { slideDown : $ ( "show" ) , slideUp : $ ( "hide" ) , slideToggle : $ ( "toggle" ) , fadeIn : { opacity : "show" } , fadeOut : { opacity : "hide" } , fadeToggle : { opacity : "toggle" } } , function ( e , t ) { he . fn [ e ] = function ( e , n , r ) { return this . animate ( t , e , n , r ) } } ) , he . timers = [ ] , he . fx . tick = function ( ) { var e , t = 0 , n = he . timers ; for ( mt = Date . now ( ) ; t < n . length ; t ++ ) ( e = n [ t ] ) ( ) || n [ t ] !== e || n . splice ( t -- , 1 ) ; n . length || he . fx . stop ( ) , mt = void 0 } , he . fx . timer = function ( e ) { he . timers . push ( e ) , he . fx . start ( ) } , he . fx . interval = 13 , he . fx . start = function ( ) { gt || ( gt = ! 0 , B ( ) ) } , he . fx . stop = function ( ) { gt = null } , he . fx . speeds = { slow : 600 , fast : 200 , _default : 400 } , he . fn . delay = function ( t , n ) { return t = he . fx && he . fx . speeds [ t ] || t , n = n || "fx" , this . queue ( n , function ( n , r ) { var o = e . setTimeout ( n , t ) ; r . stop = function ( ) { e . clearTimeout ( o ) } } ) } , vt = Z . createElement ( "input" ) , yt = Z . createElement ( "select" ) . appendChild ( Z . createElement ( "option" ) ) , vt . type = "checkbox" , le . checkOn = "" !== vt . value , le . optSelected = yt . selected , ( vt = Z . createElement ( "input" ) ) . value = "t" , vt . type = "radio" , le . radioValue = "t" === vt . value ; var wt , Ct = he . expr . attrHandle ; he . fn . extend ( { attr : function ( e , t ) { return Ne ( this , he . attr , e , t , 1 < arguments . length ) } , removeAttr : function ( e ) { return this . each ( function ( ) { he . removeAttr ( this , e ) } ) } } ) , he . extend ( { attr : function ( e , t , n ) { var r , o , i = e . nodeType ; return 3 !== i && 8 !== i && 2 !== i ? "undefined" == typeof e . getAttribute ? he . prop ( e , t , n ) : ( 1 === i && he . isXMLDoc ( e ) || ( o = he . attrHooks [ t . toLowerCase ( ) ] || ( he . expr . match . bool . test ( t ) ? wt : void 0 ) ) , void 0 !== n ? null === n ? void he . removeAttr ( e , t ) : o && "set" in o && void 0 !== ( r = o . set ( e , n , t ) ) ? r : ( e . setAttribute ( t , n + "" ) , n ) : o && "get" in o && null !== ( r = o . get ( e , t ) ) ? r : null == ( r = he . find . attr ( e , t ) ) ? void 0 : r ) : void 0 } , attrHooks : { type : { set : function ( e , t ) { if ( ! le . radioValue && "radio" === t && i ( e , "input" ) ) { var n = e . value ; return e . setAttribute ( "type" , t ) , n && ( e . value = n ) , t } } } } , removeAttr : function ( e , t ) { var n , r = 0 , o = t && t . match ( Se ) ; if ( o && 1 === e . nodeType ) for ( ; n = o [ r ++ ] ; ) e . removeAttribute ( n ) } } ) , wt = { set : function ( e , t , n ) { return ! 1 === t ? he . removeAttr ( e , n ) : e . setAttribute ( n , n ) , n } } , he . each ( he . expr . match . bool . source . match ( /\w+/g ) , function ( e , t ) { var n = Ct [ t ] || he . find . attr ; Ct [ t ] = function ( e , t , r ) { var o , i , a = t . toLowerCase ( ) ; return r || ( i = Ct [ a ] , Ct [ a ] = o , o = null != n ( e , t , r ) ? a : null , Ct [ a ] = i ) , o } } ) ; var Tt = /^(?:input|select|textarea|button)$/i , Et = /^(?:a|area)$/i ; he . fn . extend ( { prop : function ( e , t ) { return Ne ( this , he . prop , e , t , 1 < arguments . length ) } , removeProp : function ( e ) { return this . each ( function ( ) { delete this [ he . propFix [ e ] || e ] } ) } } ) , he . extend ( { prop : function ( e , t , n ) { var r , o , i = e . nodeType ; return 3 !== i && 8 !== i && 2 !== i ? ( 1 === i && he . isXMLDoc ( e ) || ( t = he . propFix [ t ] || t , o = he . propHooks [ t ] ) , void 0 !== n ? o && "set" in o && void 0 !== ( r = o . set ( e , n , t ) ) ? r : e [ t ] = n : o && "get" in o && null !== ( r = o . get ( e , t ) ) ? r : e [ t ] ) : void 0 } , propHooks : { tabIndex : { get : function ( e ) { var t = he . find . attr ( e , "tabindex" ) ; return t ? parseInt ( t , 10 ) : Tt . test ( e . nodeName ) || Et . test ( e . nodeName ) && e . href ? 0 : - 1 } } } , propFix : { "for" : "htmlFor" , "class" : "className" } } ) , le . optSelected || ( he . propHooks . selected = { get : function ( e ) { var t = e . parentNode ; return t && t . parentNode && t . parentNode . selectedIndex , null } , set : function ( e ) { var t = e . parentNode ; t && ( t . selectedIndex , t . parentNode && t . parentNode . selectedIndex ) } } ) , he . each ( [ "tabIndex" , "readOnly" , "maxLength" , "cellSpacing" , "cellPadding" , "rowSpan" , "colSpan" , "useMap" , "frameBorder" , "contentEditable" ] , function ( ) { he . propFix [ this . toLowerCase ( ) ] = this } ) , he . fn . extend ( { addClass : function ( e ) { var t , n , r , o , i , a , s , u = 0 ; if ( ce ( e ) ) return this . each ( function ( t ) { he ( this ) . addClass ( e . call ( this , t , U ( this ) ) ) } ) ; if ( ( t = X ( e ) ) . length ) for (
t . wrap . css ( "height" , r ) , t . wH = r } else t . wH = e || w . height ( ) ; t . fixedContentPos || t . wrap . css ( "height" , t . wH ) , E ( "Resize" ) } , updateItemHTML : function ( ) { var n = t . items [ t . index ] ; t . contentContainer . detach ( ) , t . content && t . content . detach ( ) , n . parsed || ( n = t . parseEl ( t . index ) ) ; var r = n . type ; if ( E ( "BeforeChange" , [ t . currItem ? t . currItem . type : "" , r ] ) , t . currItem = n , ! t . currTemplate [ r ] ) { var i = t . st [ r ] ? t . st [ r ] . markup : ! 1 ; E ( "FirstMarkupParse" , i ) , i ? t . currTemplate [ r ] = e ( i ) : t . currTemplate [ r ] = ! 0 } o && o !== n . type && t . container . removeClass ( "mfp-" + o + "-holder" ) ; var a = t [ "get" + r . charAt ( 0 ) . toUpperCase ( ) + r . slice ( 1 ) ] ( n , t . currTemplate [ r ] ) ; t . appendContent ( a , r ) , n . preloaded = ! 0 , E ( p , n ) , o = n . type , t . container . prepend ( t . contentContainer ) , E ( "AfterChange" ) } , appendContent : function ( e , n ) { t . content = e , e ? t . st . showCloseBtn && t . st . closeBtnInside && t . currTemplate [ n ] === ! 0 ? t . content . find ( ".mfp-close" ) . length || t . content . append ( S ( ) ) : t . content = e : t . content = "" , E ( c ) , t . container . addClass ( "mfp-" + n + "-holder" ) , t . contentContainer . append ( t . content ) } , parseEl : function ( n ) { var r , o = t . items [ n ] ; if ( o . tagName ? o = { el : e ( o ) } : ( r = o . type , o = { data : o , src : o . src } ) , o . el ) { for ( var i = t . types , a = 0 ; a < i . length ; a ++ ) if ( o . el . hasClass ( "mfp-" + i [ a ] ) ) { r = i [ a ] ; break } o . src = o . el . attr ( "data-mfp-src" ) , o . src || ( o . src = o . el . attr ( "href" ) ) } return o . type = r || t . st . type || "inline" , o . index = n , o . parsed = ! 0 , t . items [ n ] = o , E ( "ElementParse" , o ) , t . items [ n ] } , addGroup : function ( e , n ) { var r = function ( r ) { r . mfpEl = this , t . _openClick ( r , e , n ) } ; n || ( n = { } ) ; var o = "click.magnificPopup" ; n . mainEl = e , n . items ? ( n . isObj = ! 0 , e . off ( o ) . on ( o , r ) ) : ( n . isObj = ! 1 , n . delegate ? e . off ( o ) . on ( o , n . delegate , r ) : ( n . items = e , e . off ( o ) . on ( o , r ) ) ) } , _openClick : function ( n , r , o ) { var i = void 0 !== o . midClick ? o . midClick : e . magnificPopup . defaults . midClick ; if ( i || ! ( 2 === n . which || n . ctrlKey || n . metaKey || n . altKey || n . shiftKey ) ) { var a = void 0 !== o . disableOn ? o . disableOn : e . magnificPopup . defaults . disableOn ; if ( a ) if ( e . isFunction ( a ) ) { if ( ! a . call ( t ) ) return ! 0 } else if ( w . width ( ) < a ) return ! 0 ; n . type && ( n . preventDefault ( ) , t . isOpen && n . stopPropagation ( ) ) , o . el = e ( n . mfpEl ) , o . delegate && ( o . items = r . find ( o . delegate ) ) , t . open ( o ) } } , updateStatus : function ( e , r ) { if ( t . preloader ) { n !== e && t . container . removeClass ( "mfp-s-" + n ) , r || "loading" !== e || ( r = t . st . tLoading ) ; var o = { status : e , text : r } ; E ( "UpdateStatus" , o ) , e = o . status , r = o . text , t . preloader . html ( r ) , t . preloader . find ( "a" ) . on ( "click" , function ( e ) { e . stopImmediatePropagation ( ) } ) , t . container . addClass ( "mfp-s-" + e ) , n = e } } , _checkIfClose : function ( n ) { if ( ! e ( n ) . hasClass ( y ) ) { var r = t . st . closeOnContentClick , o = t . st . closeOnBgClick ; if ( r && o ) return ! 0 ; if ( ! t . content || e ( n ) . hasClass ( "mfp-close" ) || t . preloader && n === t . preloader [ 0 ] ) return ! 0 ; if ( n === t . content [ 0 ] || e . contains ( t . content [ 0 ] , n ) ) { if ( r ) return ! 0 } else if ( o && e . contains ( document , n ) ) return ! 0 ; return ! 1 } } , _addClassToMFP : function ( e ) { t . bgOverlay . addClass ( e ) , t . wrap . addClass ( e ) } , _removeClassFromMFP : function ( e ) { this . bgOverlay . removeClass ( e ) , t . wrap . removeClass ( e ) } , _hasScrollBar : function ( e ) { return ( t . isIE7 ? r . height ( ) : document . body . scrollHeight ) > ( e || w . height ( ) ) } , _setFocus : function ( ) { ( t . st . focus ? t . content . find ( t . st . focus ) . eq ( 0 ) : t . wrap ) . focus ( ) } , _onFocusIn : function ( n ) { return n . target === t . wrap [ 0 ] || e . contains ( t . wrap [ 0 ] , n . target ) ? void 0 : ( t . _setFocus ( ) , ! 1 ) } , _parseMarkup : function ( t , n , r ) { var o ; r . data && ( n = e . extend ( r . data , n ) ) , E ( f , [ t , n , r ] ) , e . each ( n , function ( n , r ) { if ( void 0 === r || r === ! 1 ) return ! 0 ; if ( o = n . split ( "_" ) , o . length > 1 ) { var i = t . find ( m + "-" + o [ 0 ] ) ; if ( i . length > 0 ) { var a = o [ 1 ] ; "replaceWith" === a ? i [ 0 ] !== r [ 0 ] && i . replaceWith ( r ) : "img" === a ? i . is ( "img" ) ? i . attr ( "src" , r ) : i . replaceWith ( e ( "<img>" ) . attr ( "src" , r ) . attr ( "class" , i . attr ( "class" ) ) ) : i . attr ( o [ 1 ] , r ) } } else t . find ( m + "-" + n ) . html ( r ) } ) } , _getScrollbarSize : function ( ) { if ( void 0 === t . scrollbarSize ) { var e = document . createElement ( "div" ) ; e . style . cssText = "width: 99px; height: 99px; overflow: scroll; position: absolute; top: -9999px;" , document . body . appendChild ( e ) , t . scrollbarSize = e . offsetWidth - e . clientWidth , document . body . removeChild ( e ) } return t . scrollbarSize } } , e . magnificPopup = { instance : null , proto : b . prototype , modules : [ ] , open : function ( t , n ) { return k ( ) , t = t ? e . extend ( ! 0 , { } , t ) : { } , t . isObj = ! 0 , t . index = n || 0 , this . instance . open ( t ) } , close : function ( ) { return e . magnificPopup . instance && e . magnificPopup . instance . close ( ) } , registerModule : fun