diff --git a/404.html b/404.html index 4db1fb4..f159ee5 100644 --- a/404.html +++ b/404.html @@ -1 +1 @@ -
\ No newline at end of file +
\ No newline at end of file diff --git a/404/index.html b/404/index.html index 5674192..90f1e2c 100644 --- a/404/index.html +++ b/404/index.html @@ -1 +1 @@ -
\ No newline at end of file +
\ No newline at end of file diff --git a/7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30-a2b573f288bb94ad12ca.js b/7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30-a2b573f288bb94ad12ca.js deleted file mode 100644 index 8b5ae44..0000000 --- a/7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30-a2b573f288bb94ad12ca.js +++ /dev/null @@ -1,3 +0,0 @@ -/*! For license information please see 7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30-a2b573f288bb94ad12ca.js.LICENSE.txt */ -(self.webpackChunk_adamgraham_portfolio=self.webpackChunk_adamgraham_portfolio||[]).push([[771],{3892:function(e,t,n){"use strict";n.d(t,{Ex:function(){return Oe},$n:function(){return Se},e2:function(){return _e},QN:function(){return Ie},In:function(){return se},i_:function(){return Ye},N_:function(){return re},jq:function(){return pe},vb:function(){return $e},b6:function(){return ge},Vz:function(){return Ke},Ub:function(){return ye},ln:function(){return we},DP:function(){return Ee}});var r=n(5556),a=n.n(r),i=n(6540),o=n(6942),s=n.n(o),l=(n(8848),n(5624),n(5651),n(1113),n(5723),n(4312),n(961)),c=n(7427);function u(e,t){void 0===t&&(t={});var n=function(e){if(e&&"j"===e[0]&&":"===e[1])return e.substr(2);return e}(e);if(function(e,t){return void 0===t&&(t=!e||"{"!==e[0]&&"["!==e[0]&&'"'!==e[0]),!t}(n,t.doNotParse))try{return JSON.parse(n)}catch(r){}return e}var d=function(){return d=Object.assign||function(e){for(var t,n=1,r=arguments.length;n=0&&this.changeListeners.splice(t,1)},e}(),p=i.createContext(new m);p.Provider,p.Consumer;var h=n(312),f=n.n(h);function g(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function v(e){for(var t=1;te.length)&&(t=e.length);for(var n=0,r=new Array(t);n1&&void 0!==arguments[1]?arguments[1]:null;if(!e)return"";var n=e;return t&&Object.keys(t).forEach((function(e){n=n.replace(e,t[e])})),n}function A(){return void 0!==n.g.window?n.g.window.innerWidth:0}function P(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:n.g.window.self;return e===n.g.window.top||function(){try{return n.g.window.location.hostname!==n.g.window.parent.location.hostname}catch(e){return!0}}()?e:P(e.parent)}var M=300,F=27,L=37,j=39,z=function(e){!function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function");e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,writable:!0,configurable:!0}}),t&&k(e,t)}(s,e);var t,r,a,o=C(s);function s(e){var t;return function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,s),(t=o.call(this,e)).state={isClosing:!e.animationDisabled,shouldAnimate:!1,zoomLevel:0,offsetX:0,offsetY:0,loadErrorStatus:{}},t.outerEl=i.createRef(),t.zoomInBtn=i.createRef(),t.zoomOutBtn=i.createRef(),t.caption=i.createRef(),t.closeIfClickInner=t.closeIfClickInner.bind(x(t)),t.handleImageDoubleClick=t.handleImageDoubleClick.bind(x(t)),t.handleImageMouseWheel=t.handleImageMouseWheel.bind(x(t)),t.handleKeyInput=t.handleKeyInput.bind(x(t)),t.handleMouseUp=t.handleMouseUp.bind(x(t)),t.handleMouseDown=t.handleMouseDown.bind(x(t)),t.handleMouseMove=t.handleMouseMove.bind(x(t)),t.handleOuterMousewheel=t.handleOuterMousewheel.bind(x(t)),t.handleTouchStart=t.handleTouchStart.bind(x(t)),t.handleTouchMove=t.handleTouchMove.bind(x(t)),t.handleTouchEnd=t.handleTouchEnd.bind(x(t)),t.handlePointerEvent=t.handlePointerEvent.bind(x(t)),t.handleCaptionMousewheel=t.handleCaptionMousewheel.bind(x(t)),t.handleWindowResize=t.handleWindowResize.bind(x(t)),t.handleZoomInButtonClick=t.handleZoomInButtonClick.bind(x(t)),t.handleZoomOutButtonClick=t.handleZoomOutButtonClick.bind(x(t)),t.requestClose=t.requestClose.bind(x(t)),t.requestMoveNext=t.requestMoveNext.bind(x(t)),t.requestMovePrev=t.requestMovePrev.bind(x(t)),t.timeouts=[],t.currentAction=0,t.eventsSource=0,t.pointerList=[],t.preventInnerClose=!1,t.preventInnerCloseTimeout=null,t.keyPressed=!1,t.imageCache={},t.lastKeyDownTime=0,t.resizeTimeout=null,t.wheelActionTimeout=null,t.resetScrollTimeout=null,t.scrollX=0,t.scrollY=0,t.moveStartX=0,t.moveStartY=0,t.moveStartOffsetX=0,t.moveStartOffsetY=0,t.swipeStartX=0,t.swipeStartY=0,t.swipeEndX=0,t.swipeEndY=0,t.pinchTouchList=null,t.pinchDistance=0,t.keyCounter=0,t.moveRequested=!1,t}return t=s,r=[{key:"componentDidMount",value:function(){var e=this;this.props.animationDisabled||this.setState({isClosing:!1}),this.windowContext=P(),this.listeners={resize:this.handleWindowResize,mouseup:this.handleMouseUp,touchend:this.handleTouchEnd,touchcancel:this.handleTouchEnd,pointerdown:this.handlePointerEvent,pointermove:this.handlePointerEvent,pointerup:this.handlePointerEvent,pointercancel:this.handlePointerEvent},Object.keys(this.listeners).forEach((function(t){e.windowContext.addEventListener(t,e.listeners[t])})),this.loadAllImages()}},{key:"shouldComponentUpdate",value:function(e){var t=this;return this.getSrcTypes().forEach((function(n){t.props[n.name]!==e[n.name]&&(t.moveRequested=!1)})),!this.moveRequested}},{key:"componentDidUpdate",value:function(e){var t=this,n=!1,r={},a={};this.getSrcTypes().forEach((function(i){e[i.name]!==t.props[i.name]&&(n=!0,r[e[i.name]]=!0,a[t.props[i.name]]=!0)})),(n||this.moveRequested)&&(Object.keys(r).forEach((function(e){!(e in a)&&e in t.imageCache&&(t.imageCache[e].loaded=!1)})),this.moveRequested=!1,this.loadAllImages(this.props))}},{key:"componentWillUnmount",value:function(){var e=this;this.didUnmount=!0,Object.keys(this.listeners).forEach((function(t){e.windowContext.removeEventListener(t,e.listeners[t])})),this.timeouts.forEach((function(e){return clearTimeout(e)}))}},{key:"setTimeout",value:function(e){function t(t,n){return e.apply(this,arguments)}return t.toString=function(){return e.toString()},t}((function(e,t){var n=this,r=setTimeout((function(){n.timeouts=n.timeouts.filter((function(e){return e!==r})),e()}),t);return this.timeouts.push(r),r}))},{key:"setPreventInnerClose",value:function(){var e=this;this.preventInnerCloseTimeout&&this.clearTimeout(this.preventInnerCloseTimeout),this.preventInnerClose=!0,this.preventInnerCloseTimeout=this.setTimeout((function(){e.preventInnerClose=!1,e.preventInnerCloseTimeout=null}),100)}},{key:"getBestImageForType",value:function(e){var t=this.props[e],n={};if(this.isImageLoaded(t))n=this.getFitSizes(this.imageCache[t].width,this.imageCache[t].height);else{if(!this.isImageLoaded(this.props["".concat(e,"Thumbnail")]))return null;t=this.props["".concat(e,"Thumbnail")],n=this.getFitSizes(this.imageCache[t].width,this.imageCache[t].height,!0)}return{src:t,height:this.imageCache[t].height,width:this.imageCache[t].width,targetHeight:n.height,targetWidth:n.width}}},{key:"getFitSizes",value:function(e,t,n){var r=this.getLightboxRect(),a=r.height-2*this.props.imagePadding,i=r.width-2*this.props.imagePadding;return n||(a=Math.min(a,t),i=Math.min(i,e)),i/a>e/t?{width:e*a/t,height:a}:{width:i,height:t*i/e}}},{key:"getMaxOffsets",value:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.state.zoomLevel,t=this.getBestImageForType("mainSrc");if(null===t)return{maxX:0,minX:0,maxY:0,minY:0};var n=this.getLightboxRect(),r=this.getZoomMultiplier(e),a=0,i=0;return{maxX:a=r*t.width-n.width<0?(n.width-r*t.width)/2:(r*t.width-n.width)/2,maxY:i=r*t.height-n.height<0?(n.height-r*t.height)/2:(r*t.height-n.height)/2,minX:-1*a,minY:-1*i}}},{key:"getSrcTypes",value:function(){return[{name:"mainSrc",keyEnding:"i".concat(this.keyCounter)},{name:"mainSrcThumbnail",keyEnding:"t".concat(this.keyCounter)},{name:"nextSrc",keyEnding:"i".concat(this.keyCounter+1)},{name:"nextSrcThumbnail",keyEnding:"t".concat(this.keyCounter+1)},{name:"prevSrc",keyEnding:"i".concat(this.keyCounter-1)},{name:"prevSrcThumbnail",keyEnding:"t".concat(this.keyCounter-1)}]}},{key:"getZoomMultiplier",value:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.state.zoomLevel;return Math.pow(1.007,e)}},{key:"getLightboxRect",value:function(){return this.outerEl.current?this.outerEl.current.getBoundingClientRect():{width:A(),height:void 0!==n.g.window?n.g.window.innerHeight:0,top:0,right:0,bottom:0,left:0}}},{key:"clearTimeout",value:function(e){function t(t){return e.apply(this,arguments)}return t.toString=function(){return e.toString()},t}((function(e){this.timeouts=this.timeouts.filter((function(t){return t!==e})),clearTimeout(e)}))},{key:"changeZoom",value:function(e,t,n){if(this.props.enableZoom){var r=Math.max(0,Math.min(M,e));if(r!==this.state.zoomLevel)if(0!==r){var a=this.getBestImageForType("mainSrc");if(null!==a){var i=this.getZoomMultiplier(),o=this.getZoomMultiplier(r),s=this.getLightboxRect(),l=void 0!==t?t-s.left:s.width/2,c=void 0!==n?n-s.top:s.height/2,u=(s.width-a.width*i)/2,d=(s.height-a.height*i)/2,m=l-(l-(u-this.state.offsetX))/i*o,p=c-(c-(d-this.state.offsetY))/i*o,h=(s.width-a.width*o)/2-m,f=(s.height-a.height*o)/2-p;if(3!==this.currentAction){var g=this.getMaxOffsets();this.state.zoomLevel>r&&(h=Math.max(g.minX,Math.min(g.maxX,h)),f=Math.max(g.minY,Math.min(g.maxY,f)))}this.setState({zoomLevel:r,offsetX:h,offsetY:f})}}else this.setState({zoomLevel:r,offsetX:0,offsetY:0})}}},{key:"closeIfClickInner",value:function(e){!this.preventInnerClose&&e.target.className.search(/\bril-inner\b/)>-1&&this.requestClose(e)}},{key:"handleKeyInput",value:function(e){if(e.stopPropagation(),!this.isAnimating())if("keyup"!==e.type){var t=e.which||e.keyCode,n=new Date;if(!(n.getTime()-this.lastKeyDownTime=200||e.deltaX>=100?(this.requestMoveNext(e),n=500,this.scrollX=0):(this.scrollX<=-200||e.deltaX<=-100)&&(this.requestMovePrev(e),n=500,this.scrollX=0)),0!==n&&(this.wheelActionTimeout=this.setTimeout((function(){t.wheelActionTimeout=null}),n)))}},{key:"handleImageMouseWheel",value:function(e){if(Math.abs(e.deltaY)>=Math.abs(e.deltaX)){if(e.stopPropagation(),Math.abs(e.deltaY)<1)return;this.scrollX=0,this.scrollY+=e.deltaY,this.changeZoom(this.state.zoomLevel-e.deltaY,e.clientX,e.clientY)}}},{key:"handleImageDoubleClick",value:function(e){this.state.zoomLevel>0?this.changeZoom(0,e.clientX,e.clientY):this.changeZoom(this.state.zoomLevel+100,e.clientX,e.clientY)}},{key:"shouldHandleEvent",value:function(e){if(this.eventsSource===e)return!0;if(0===this.eventsSource)return this.eventsSource=e,!0;switch(e){case 1:default:return!1;case 2:return this.eventsSource=2,this.filterPointersBySource(),!0;case 3:return 1===this.eventsSource&&(this.eventsSource=3,this.filterPointersBySource(),!0)}}},{key:"addPointer",value:function(e){this.pointerList.push(e)}},{key:"removePointer",value:function(e){this.pointerList=this.pointerList.filter((function(t){return t.id!==e.id}))}},{key:"filterPointersBySource",value:function(){var e=this;this.pointerList=this.pointerList.filter((function(t){return t.source===e.eventsSource}))}},{key:"handleMouseDown",value:function(e){this.shouldHandleEvent(1)&&s.isTargetMatchImage(e.target)&&(this.addPointer(s.parseMouseEvent(e)),this.multiPointerStart(e))}},{key:"handleMouseMove",value:function(e){this.shouldHandleEvent(1)&&this.multiPointerMove(e,[s.parseMouseEvent(e)])}},{key:"handleMouseUp",value:function(e){this.shouldHandleEvent(1)&&(this.removePointer(s.parseMouseEvent(e)),this.multiPointerEnd(e))}},{key:"handlePointerEvent",value:function(e){if(this.shouldHandleEvent(3))switch(e.type){case"pointerdown":s.isTargetMatchImage(e.target)&&(this.addPointer(s.parsePointerEvent(e)),this.multiPointerStart(e));break;case"pointermove":this.multiPointerMove(e,[s.parsePointerEvent(e)]);break;case"pointerup":case"pointercancel":this.removePointer(s.parsePointerEvent(e)),this.multiPointerEnd(e)}}},{key:"handleTouchStart",value:function(e){var t=this;this.shouldHandleEvent(2)&&s.isTargetMatchImage(e.target)&&([].forEach.call(e.changedTouches,(function(e){return t.addPointer(s.parseTouchPointer(e))})),this.multiPointerStart(e))}},{key:"handleTouchMove",value:function(e){this.shouldHandleEvent(2)&&this.multiPointerMove(e,[].map.call(e.changedTouches,(function(e){return s.parseTouchPointer(e)})))}},{key:"handleTouchEnd",value:function(e){var t=this;this.shouldHandleEvent(2)&&([].map.call(e.changedTouches,(function(e){return t.removePointer(s.parseTouchPointer(e))})),this.multiPointerEnd(e))}},{key:"decideMoveOrSwipe",value:function(e){this.state.zoomLevel<=0?this.handleSwipeStart(e):this.handleMoveStart(e)}},{key:"multiPointerStart",value:function(e){switch(this.handleEnd(null),this.pointerList.length){case 1:e.preventDefault(),this.decideMoveOrSwipe(this.pointerList[0]);break;case 2:e.preventDefault(),this.handlePinchStart(this.pointerList)}}},{key:"multiPointerMove",value:function(e,t){switch(this.currentAction){case 1:e.preventDefault(),this.handleMove(t[0]);break;case 2:e.preventDefault(),this.handleSwipe(t[0]);break;case 3:e.preventDefault(),this.handlePinch(t)}}},{key:"multiPointerEnd",value:function(e){switch(0!==this.currentAction&&(this.setPreventInnerClose(),this.handleEnd(e)),this.pointerList.length){case 0:this.eventsSource=0;break;case 1:e.preventDefault(),this.decideMoveOrSwipe(this.pointerList[0]);break;case 2:e.preventDefault(),this.handlePinchStart(this.pointerList)}}},{key:"handleEnd",value:function(e){switch(this.currentAction){case 1:this.handleMoveEnd(e);break;case 2:this.handleSwipeEnd(e);break;case 3:this.handlePinchEnd(e)}}},{key:"handleMoveStart",value:function(e){var t=e.x,n=e.y;this.props.enableZoom&&(this.currentAction=1,this.moveStartX=t,this.moveStartY=n,this.moveStartOffsetX=this.state.offsetX,this.moveStartOffsetY=this.state.offsetY)}},{key:"handleMove",value:function(e){var t=e.x,n=e.y,r=this.moveStartX-t+this.moveStartOffsetX,a=this.moveStartY-n+this.moveStartOffsetY;this.state.offsetX===r&&this.state.offsetY===a||this.setState({offsetX:r,offsetY:a})}},{key:"handleMoveEnd",value:function(){var e=this;this.currentAction=0,this.moveStartX=0,this.moveStartY=0,this.moveStartOffsetX=0,this.moveStartOffsetY=0;var t=this.getMaxOffsets(),n=Math.max(t.minX,Math.min(t.maxX,this.state.offsetX)),r=Math.max(t.minY,Math.min(t.maxY,this.state.offsetY));n===this.state.offsetX&&r===this.state.offsetY||(this.setState({offsetX:n,offsetY:r,shouldAnimate:!0}),this.setTimeout((function(){e.setState({shouldAnimate:!1})}),this.props.animationDuration))}},{key:"handleSwipeStart",value:function(e){var t=e.x,n=e.y;this.currentAction=2,this.swipeStartX=t,this.swipeStartY=n,this.swipeEndX=t,this.swipeEndY=n}},{key:"handleSwipe",value:function(e){var t=e.x,n=e.y;this.swipeEndX=t,this.swipeEndY=n}},{key:"handleSwipeEnd",value:function(e){var t=this.swipeEndX-this.swipeStartX,n=Math.abs(t),r=Math.abs(this.swipeEndY-this.swipeStartY);if(this.currentAction=0,this.swipeStartX=0,this.swipeStartY=0,this.swipeEndX=0,this.swipeEndY=0,!(!e||this.isAnimating()||n<1.5*r)){if(n<200&&n0&&this.props.prevSrc?(e.preventDefault(),this.requestMovePrev()):t<0&&this.props.nextSrc&&(e.preventDefault(),this.requestMoveNext())}}},{key:"calculatePinchDistance",value:function(){var e=O(arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.pinchTouchList,2),t=e[0],n=e[1];return Math.sqrt(Math.pow(t.x-n.x,2)+Math.pow(t.y-n.y,2))}},{key:"calculatePinchCenter",value:function(){var e=O(arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.pinchTouchList,2),t=e[0],n=e[1];return{x:t.x-(t.x-n.x)/2,y:t.y-(t.y-n.y)/2}}},{key:"handlePinchStart",value:function(e){this.props.enableZoom&&(this.currentAction=3,this.pinchTouchList=e.map((function(e){return{id:e.id,x:e.x,y:e.y}})),this.pinchDistance=this.calculatePinchDistance())}},{key:"handlePinch",value:function(e){this.pinchTouchList=this.pinchTouchList.map((function(t){for(var n=0;n0&&t+a>=r||e.deltaY<0&&a<=0)&&e.preventDefault()}}},{key:"isAnimating",value:function(){return this.state.shouldAnimate||this.state.isClosing}},{key:"isImageLoaded",value:function(e){return e&&e in this.imageCache&&this.imageCache[e].loaded}},{key:"loadImage",value:function(e,t,r){var a=this;if(this.isImageLoaded(t))this.setTimeout((function(){r()}),1);else{var i=new n.g.Image;this.props.imageCrossOrigin&&(i.crossOrigin=this.props.imageCrossOrigin),i.onerror=function(n){a.props.onImageLoadError(t,e,n),a.setState((function(t){return{loadErrorStatus:v(v({},t.loadErrorStatus),{},b({},e,!0))}})),r(n)},i.onload=function(){a.props.onImageLoad(t,e,i),a.imageCache[t]={loaded:!0,width:i.width,height:i.height},r()},i.src=t}}},{key:"loadAllImages",value:function(){var e=this,t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.props;this.getSrcTypes().forEach((function(n){var r=n.name;t[r]&&e.state.loadErrorStatus[r]&&e.setState((function(e){return{loadErrorStatus:v(v({},e.loadErrorStatus),{},b({},r,!1))}})),t[r]&&!e.isImageLoaded(t[r])&&e.loadImage(r,t[r],function(t,n){return function(r){r||e.props[t]!==n||e.didUnmount||e.forceUpdate()}}(r,t[r]))}))}},{key:"requestClose",value:function(e){var t=this,n=function(){return t.props.onCloseRequest(e)};this.props.animationDisabled||"keydown"===e.type&&!this.props.animationOnKeyInput?n():(this.setState({isClosing:!0}),this.setTimeout(n,this.props.animationDuration))}},{key:"requestMove",value:function(e,t){var n=this,r={zoomLevel:0,offsetX:0,offsetY:0};this.props.animationDisabled||this.keyPressed&&!this.props.animationOnKeyInput||(r.shouldAnimate=!0,this.setTimeout((function(){return n.setState({shouldAnimate:!1})}),this.props.animationDuration)),this.keyPressed=!1,this.moveRequested=!0,"prev"===e?(this.keyCounter-=1,this.setState(r),this.props.onMovePrevRequest(t)):(this.keyCounter+=1,this.setState(r),this.props.onMoveNextRequest(t))}},{key:"requestMoveNext",value:function(e){this.requestMove("next",e)}},{key:"requestMovePrev",value:function(e){this.requestMove("prev",e)}},{key:"render",value:function(){var e=this,t=this.props,r=t.animationDisabled,a=t.animationDuration,o=t.clickOutsideToClose,l=t.discourageDownloads,c=t.enableZoom,u=t.imageTitle,d=t.nextSrc,m=t.prevSrc,p=t.toolbarButtons,h=t.reactModalStyle,g=t.onAfterOpen,y=t.imageCrossOrigin,b=t.reactModalProps,E=t.loader,k=this.state,x=k.zoomLevel,C=k.offsetX,O=k.offsetY,S=k.isClosing,_=k.loadErrorStatus,A=this.getLightboxRect(),P={};!r&&this.isAnimating()&&(P=v(v({},P),{},{transition:"transform ".concat(a,"ms")}));var F={};this.getSrcTypes().forEach((function(e){var t=e.name,n=e.keyEnding;F[t]=n}));var L=[],j=function(t,n,r){if(e.props[t]){var a,o=e.getBestImageForType(t),c=v(v({},P),s.getTransform(v(v({},r),o)));if(x>0&&(c.cursor="move"),null===o&&(a=_,Object.keys(a).some((function(e){return a[e]}))))L.push(i.createElement("div",{className:"".concat(n," ril__image ril-errored"),style:c,key:e.props[t]+F[t]},i.createElement("div",{className:"ril__errorContainer"},e.props.imageLoadErrorMessage)));else if(null!==o){var d=o.src;l?(c.backgroundImage="url('".concat(d,"')"),L.push(i.createElement("div",{className:"".concat(n," ril__image ril__imageDiscourager"),onDoubleClick:e.handleImageDoubleClick,onWheel:e.handleImageMouseWheel,style:c,key:d+F[t]},i.createElement("div",{className:"ril-download-blocker ril__downloadBlocker"})))):L.push(i.createElement("img",w({},y?{crossOrigin:y}:{},{className:"".concat(n," ril__image"),onDoubleClick:e.handleImageDoubleClick,onWheel:e.handleImageMouseWheel,onDragStart:function(e){return e.preventDefault()},style:c,src:d,key:d+F[t],alt:"string"==typeof u?u:N("Image"),draggable:!1})))}else{var m=void 0!==E?E:i.createElement("div",{className:"ril-loading-circle ril__loadingCircle ril__loadingContainer__icon"},T(new Array(12)).map((function(e,t){return i.createElement("div",{key:t,className:"ril-loading-circle-point ril__loadingCirclePoint"})})));L.push(i.createElement("div",{className:"".concat(n," ril__image ril-not-loaded"),style:c,key:e.props[t]+F[t]},i.createElement("div",{className:"ril__loadingContainer"},m)))}}},z=this.getZoomMultiplier();j("nextSrc","ril-image-next ril__imageNext",{x:A.width}),j("mainSrc","ril-image-current",{x:-1*C,y:-1*O,zoom:z}),j("prevSrc","ril-image-prev ril__imagePrev",{x:-1*A.width});var I={overlay:v({zIndex:1e3,backgroundColor:"transparent"},h.overlay),content:v({backgroundColor:"transparent",overflow:"hidden",border:"none",borderRadius:0,padding:0,top:0,left:0,right:0,bottom:0},h.content)};return i.createElement(f(),w({isOpen:!0,onRequestClose:o?this.requestClose:void 0,onAfterOpen:function(){e.outerEl.current&&e.outerEl.current.focus(),g()},style:I,contentLabel:N("Lightbox"),appElement:void 0!==n.g.window?n.g.window.document.body:void 0},b),i.createElement("div",{className:"ril-outer ril__outer ril__outerAnimating ".concat(this.props.wrapperClassName," ").concat(S?"ril-closing ril__outerClosing":""),style:{transition:"opacity ".concat(a,"ms"),animationDuration:"".concat(a,"ms"),animationDirection:S?"normal":"reverse"},ref:this.outerEl,onWheel:this.handleOuterMousewheel,onMouseMove:this.handleMouseMove,onMouseDown:this.handleMouseDown,onTouchStart:this.handleTouchStart,onTouchMove:this.handleTouchMove,tabIndex:"-1",onKeyDown:this.handleKeyInput,onKeyUp:this.handleKeyInput},i.createElement("div",{className:"ril-inner ril__inner",onClick:o?this.closeIfClickInner:void 0},L),m&&i.createElement("button",{type:"button",className:"ril-prev-button ril__navButtons ril__navButtonPrev",key:"prev","aria-label":this.props.prevLabel,title:this.props.prevLabel,onClick:this.isAnimating()?void 0:this.requestMovePrev}),d&&i.createElement("button",{type:"button",className:"ril-next-button ril__navButtons ril__navButtonNext",key:"next","aria-label":this.props.nextLabel,title:this.props.nextLabel,onClick:this.isAnimating()?void 0:this.requestMoveNext}),i.createElement("div",{className:"ril-toolbar ril__toolbar"},i.createElement("ul",{className:"ril-toolbar-left ril__toolbarSide ril__toolbarLeftSide"},i.createElement("li",{className:"ril-toolbar__item ril__toolbarItem"},i.createElement("span",{className:"ril-toolbar__item__child ril__toolbarItemChild"},u))),i.createElement("ul",{className:"ril-toolbar-right ril__toolbarSide ril__toolbarRightSide"},p&&p.map((function(e,t){return i.createElement("li",{key:"button_".concat(t+1),className:"ril-toolbar__item ril__toolbarItem"},e)})),c&&i.createElement("li",{className:"ril-toolbar__item ril__toolbarItem"},i.createElement("button",{type:"button",key:"zoom-in","aria-label":this.props.zoomInLabel,title:this.props.zoomInLabel,className:["ril-zoom-in","ril__toolbarItemChild","ril__builtinButton","ril__zoomInButton"].concat(T(x===M?["ril__builtinButtonDisabled"]:[])).join(" "),ref:this.zoomInBtn,disabled:this.isAnimating()||x===M,onClick:this.isAnimating()||x===M?void 0:this.handleZoomInButtonClick})),c&&i.createElement("li",{className:"ril-toolbar__item ril__toolbarItem"},i.createElement("button",{type:"button",key:"zoom-out","aria-label":this.props.zoomOutLabel,title:this.props.zoomOutLabel,className:["ril-zoom-out","ril__toolbarItemChild","ril__builtinButton","ril__zoomOutButton"].concat(T(0===x?["ril__builtinButtonDisabled"]:[])).join(" "),ref:this.zoomOutBtn,disabled:this.isAnimating()||0===x,onClick:this.isAnimating()||0===x?void 0:this.handleZoomOutButtonClick})),i.createElement("li",{className:"ril-toolbar__item ril__toolbarItem"},i.createElement("button",{type:"button",key:"close","aria-label":this.props.closeLabel,title:this.props.closeLabel,className:"ril-close ril-toolbar__item__child ril__toolbarItemChild ril__builtinButton ril__closeButton",onClick:this.isAnimating()?void 0:this.requestClose})))),this.props.imageCaption&&i.createElement("div",{onWheel:this.handleCaptionMousewheel,onMouseDown:function(e){return e.stopPropagation()},className:"ril-caption ril__caption",ref:this.caption},i.createElement("div",{className:"ril-caption-content ril__captionContent"},this.props.imageCaption))))}}],a=[{key:"isTargetMatchImage",value:function(e){return e&&/ril-image-current/.test(e.className)}},{key:"parseMouseEvent",value:function(e){return{id:"mouse",source:1,x:parseInt(e.clientX,10),y:parseInt(e.clientY,10)}}},{key:"parseTouchPointer",value:function(e){return{id:e.identifier,source:2,x:parseInt(e.clientX,10),y:parseInt(e.clientY,10)}}},{key:"parsePointerEvent",value:function(e){return{id:e.pointerId,source:3,x:parseInt(e.clientX,10),y:parseInt(e.clientY,10)}}},{key:"getTransform",value:function(e){var t=e.x,n=void 0===t?0:t,r=e.y,a=void 0===r?0:r,i=e.zoom,o=void 0===i?1:i,s=e.width,l=e.targetWidth,c=n,u=A();s>u&&(c+=(u-s)/2);var d=o*(l/s);return{transform:"translate3d(".concat(c,"px,").concat(a,"px,0) scale3d(").concat(d,",").concat(d,",1)")}}}],r&&y(t.prototype,r),a&&y(t,a),s}(i.Component);z.propTypes={mainSrc:a().string.isRequired,prevSrc:a().string,nextSrc:a().string,mainSrcThumbnail:a().string,prevSrcThumbnail:a().string,nextSrcThumbnail:a().string,onCloseRequest:a().func.isRequired,onMovePrevRequest:a().func,onMoveNextRequest:a().func,onImageLoadError:a().func,onImageLoad:a().func,onAfterOpen:a().func,discourageDownloads:a().bool,animationDisabled:a().bool,animationOnKeyInput:a().bool,animationDuration:a().number,keyRepeatLimit:a().number,keyRepeatKeyupBonus:a().number,imageTitle:a().node,imageCaption:a().node,imageCrossOrigin:a().string,reactModalStyle:a().shape({}),imagePadding:a().number,wrapperClassName:a().string,toolbarButtons:a().arrayOf(a().node),clickOutsideToClose:a().bool,enableZoom:a().bool,reactModalProps:a().shape({}),nextLabel:a().string,prevLabel:a().string,zoomInLabel:a().string,zoomOutLabel:a().string,closeLabel:a().string,imageLoadErrorMessage:a().node,loader:a().node},z.defaultProps={imageTitle:null,imageCaption:null,toolbarButtons:null,reactModalProps:{},animationDisabled:!1,animationDuration:300,animationOnKeyInput:!1,clickOutsideToClose:!0,closeLabel:"Close lightbox",discourageDownloads:!1,enableZoom:!0,imagePadding:10,imageCrossOrigin:null,keyRepeatKeyupBonus:40,keyRepeatLimit:180,mainSrcThumbnail:null,nextLabel:"Next image",nextSrc:null,nextSrcThumbnail:null,onAfterOpen:function(){},onImageLoadError:function(){},onImageLoad:function(){},onMoveNextRequest:function(){},onMovePrevRequest:function(){},prevLabel:"Previous image",prevSrc:null,prevSrcThumbnail:null,reactModalStyle:{},wrapperClassName:"",zoomInLabel:"Zoom in",zoomOutLabel:"Zoom out",imageLoadErrorMessage:"This image failed to load",loader:void 0};var I=z,R=i.createElement("svg",{focusable:"false",role:"img",viewBox:"0 0 24 24",width:"24px",height:"24px",xmlns:"http://www.w3.org/2000/svg"},i.createElement("title",null,"Discord"),i.createElement("path",{d:"M20.222 0c1.406 0 2.54 1.137 2.607 2.475V24l-2.677-2.273-1.47-1.338-1.604-1.398.67 2.205H3.71c-1.402 0-2.54-1.065-2.54-2.476V2.48C1.17 1.142 2.31.003 3.715.003h16.5L20.222 0zm-6.118 5.683h-.03l-.202.2c2.073.6 3.076 1.537 3.076 1.537-1.336-.668-2.54-1.002-3.744-1.137-.87-.135-1.74-.064-2.475 0h-.2c-.47 0-1.47.2-2.81.735-.467.203-.735.336-.735.336s1.002-1.002 3.21-1.537l-.135-.135s-1.672-.064-3.477 1.27c0 0-1.805 3.144-1.805 7.02 0 0 1 1.74 3.743 1.806 0 0 .4-.533.805-1.002-1.54-.468-2.14-1.404-2.14-1.404s.134.066.335.2h.06c.03 0 .044.015.06.03v.006c.016.016.03.03.06.03.33.136.66.27.93.4.466.202 1.065.403 1.8.536.93.135 1.996.2 3.21 0 .6-.135 1.2-.267 1.8-.535.39-.2.87-.4 1.397-.737 0 0-.6.936-2.205 1.404.33.466.795 1 .795 1 2.744-.06 3.81-1.8 3.87-1.726 0-3.87-1.815-7.02-1.815-7.02-1.635-1.214-3.165-1.26-3.435-1.26l.056-.02zm.168 4.413c.703 0 1.27.6 1.27 1.335 0 .74-.57 1.34-1.27 1.34-.7 0-1.27-.6-1.27-1.334.002-.74.573-1.338 1.27-1.338zm-4.543 0c.7 0 1.266.6 1.266 1.335 0 .74-.57 1.34-1.27 1.34-.7 0-1.27-.6-1.27-1.334 0-.74.57-1.338 1.27-1.338z"})),D=i.createElement("svg",{focusable:"false",role:"img",viewBox:"0 0 184 184",width:"24px",height:"24px",xmlns:"http://www.w3.org/2000/svg"},i.createElement("title",null,"Email"),i.createElement("path",{d:"M160.746,24.61H23.254C10.432,24.61,0,35.042,0,47.864v88.271c0,12.822,10.432,23.254,23.254,23.254h137.492c12.822,0,23.254-10.432,23.254-23.254V47.864C184,35.042,173.568,24.61,160.746,24.61z M157.113,39.61L92,89.909L26.887,39.61H157.113z M160.746,144.39H23.254c-4.551,0-8.254-3.703-8.254-8.254V49.382l72.415,55.94c1.35,1.043,2.968,1.564,4.585,1.564s3.235-0.521,4.585-1.564L169,49.382v86.753C169,140.687,165.297,144.39,160.746,144.39z"})),$=i.createElement("svg",{focusable:"false",role:"img",viewBox:"0 0 24 24",width:"24px",height:"24px",xmlns:"http://www.w3.org/2000/svg"},i.createElement("title",null,"Facebook"),i.createElement("path",{d:"M23.9981 11.9991C23.9981 5.37216 18.626 0 11.9991 0C5.37216 0 0 5.37216 0 11.9991C0 17.9882 4.38789 22.9522 10.1242 23.8524V15.4676H7.07758V11.9991H10.1242V9.35553C10.1242 6.34826 11.9156 4.68714 14.6564 4.68714C15.9692 4.68714 17.3424 4.92149 17.3424 4.92149V7.87439H15.8294C14.3388 7.87439 13.8739 8.79933 13.8739 9.74824V11.9991H17.2018L16.6698 15.4676H13.8739V23.8524C19.6103 22.9522 23.9981 17.9882 23.9981 11.9991Z"})),B=i.createElement("svg",{focusable:"false",role:"img",viewBox:"0 0 24 24",width:"24px",height:"24px",xmlns:"http://www.w3.org/2000/svg"},i.createElement("title",null,"GitHub"),i.createElement("path",{d:"M12 .297c-6.63 0-12 5.373-12 12 0 5.303 3.438 9.8 8.205 11.385.6.113.82-.258.82-.577 0-.285-.01-1.04-.015-2.04-3.338.724-4.042-1.61-4.042-1.61C4.422 18.07 3.633 17.7 3.633 17.7c-1.087-.744.084-.729.084-.729 1.205.084 1.838 1.236 1.838 1.236 1.07 1.835 2.809 1.305 3.495.998.108-.776.417-1.305.76-1.605-2.665-.3-5.466-1.332-5.466-5.93 0-1.31.465-2.38 1.235-3.22-.135-.303-.54-1.523.105-3.176 0 0 1.005-.322 3.3 1.23.96-.267 1.98-.399 3-.405 1.02.006 2.04.138 3 .405 2.28-1.552 3.285-1.23 3.285-1.23.645 1.653.24 2.873.12 3.176.765.84 1.23 1.91 1.23 3.22 0 4.61-2.805 5.625-5.475 5.92.42.36.81 1.096.81 2.22 0 1.606-.015 2.896-.015 3.286 0 .315.21.69.825.57C20.565 22.092 24 17.592 24 12.297c0-6.627-5.373-12-12-12"})),q=i.createElement("svg",{focusable:"false",role:"img",viewBox:"0 0 24 24",width:"24px",height:"24px",xmlns:"http://www.w3.org/2000/svg"},i.createElement("title",null,"Instagram"),i.createElement("path",{d:"M12 0C8.74 0 8.333.015 7.053.072 5.775.132 4.905.333 4.14.63c-.789.306-1.459.717-2.126 1.384S.935 3.35.63 4.14C.333 4.905.131 5.775.072 7.053.012 8.333 0 8.74 0 12s.015 3.667.072 4.947c.06 1.277.261 2.148.558 2.913.306.788.717 1.459 1.384 2.126.667.666 1.336 1.079 2.126 1.384.766.296 1.636.499 2.913.558C8.333 23.988 8.74 24 12 24s3.667-.015 4.947-.072c1.277-.06 2.148-.262 2.913-.558.788-.306 1.459-.718 2.126-1.384.666-.667 1.079-1.335 1.384-2.126.296-.765.499-1.636.558-2.913.06-1.28.072-1.687.072-4.947s-.015-3.667-.072-4.947c-.06-1.277-.262-2.149-.558-2.913-.306-.789-.718-1.459-1.384-2.126C21.319 1.347 20.651.935 19.86.63c-.765-.297-1.636-.499-2.913-.558C15.667.012 15.26 0 12 0zm0 2.16c3.203 0 3.585.016 4.85.071 1.17.055 1.805.249 2.227.415.562.217.96.477 1.382.896.419.42.679.819.896 1.381.164.422.36 1.057.413 2.227.057 1.266.07 1.646.07 4.85s-.015 3.585-.074 4.85c-.061 1.17-.256 1.805-.421 2.227-.224.562-.479.96-.899 1.382-.419.419-.824.679-1.38.896-.42.164-1.065.36-2.235.413-1.274.057-1.649.07-4.859.07-3.211 0-3.586-.015-4.859-.074-1.171-.061-1.816-.256-2.236-.421-.569-.224-.96-.479-1.379-.899-.421-.419-.69-.824-.9-1.38-.165-.42-.359-1.065-.42-2.235-.045-1.26-.061-1.649-.061-4.844 0-3.196.016-3.586.061-4.861.061-1.17.255-1.814.42-2.234.21-.57.479-.96.9-1.381.419-.419.81-.689 1.379-.898.42-.166 1.051-.361 2.221-.421 1.275-.045 1.65-.06 4.859-.06l.045.03zm0 3.678c-3.405 0-6.162 2.76-6.162 6.162 0 3.405 2.76 6.162 6.162 6.162 3.405 0 6.162-2.76 6.162-6.162 0-3.405-2.76-6.162-6.162-6.162zM12 16c-2.21 0-4-1.79-4-4s1.79-4 4-4 4 1.79 4 4-1.79 4-4 4zm7.846-10.405c0 .795-.646 1.44-1.44 1.44-.795 0-1.44-.646-1.44-1.44 0-.794.646-1.439 1.44-1.439.793-.001 1.44.645 1.44 1.439z"})),H=i.createElement("svg",{focusable:"false",role:"img",viewBox:"0 0 24 24",width:"24px",height:"24px",xmlns:"http://www.w3.org/2000/svg"},i.createElement("title",null,"LinkedIn"),i.createElement("path",{d:"M20.447 20.452h-3.554v-5.569c0-1.328-.027-3.037-1.852-3.037-1.853 0-2.136 1.445-2.136 2.939v5.667H9.351V9h3.414v1.561h.046c.477-.9 1.637-1.85 3.37-1.85 3.601 0 4.267 2.37 4.267 5.455v6.286zM5.337 7.433c-1.144 0-2.063-.926-2.063-2.065 0-1.138.92-2.063 2.063-2.063 1.14 0 2.064.925 2.064 2.063 0 1.139-.925 2.065-2.064 2.065zm1.782 13.019H3.555V9h3.564v11.452zM22.225 0H1.771C.792 0 0 .774 0 1.729v20.542C0 23.227.792 24 1.771 24h20.451C23.2 24 24 23.227 24 22.271V1.729C24 .774 23.2 0 22.222 0h.003z"})),Y=i.createElement("svg",{focusable:"false",role:"img",viewBox:"0 0 24 24",width:"24px",height:"24px",xmlns:"http://www.w3.org/2000/svg"},i.createElement("title",null,"Patreon"),i.createElement("path",{d:"M0 .48v23.04h4.22V.48zm15.385 0c-4.764 0-8.641 3.88-8.641 8.65 0 4.755 3.877 8.623 8.641 8.623 4.75 0 8.615-3.868 8.615-8.623C24 4.36 20.136.48 15.385.48z"})),U=i.createElement("svg",{focusable:"false",viewBox:"0 0 25.576 30.177",width:"25.576px",height:"30.177px",xmlns:"http://www.w3.org/2000/svg"},i.createElement("path",{d:"M7.266 29.154l.523-3.322-1.165-.027H1.061L4.927 1.292a.316.316 0 01.314-.268h9.38c3.114 0 5.263.648 6.385 1.927.526.6.861 1.227 1.023 1.917.17.724.173 1.589.007 2.644l-.012.077v.676l.526.298a3.69 3.69 0 011.065.812c.45.513.741 1.165.864 1.938.127.795.085 1.741-.123 2.812-.24 1.232-.628 2.305-1.152 3.183a6.547 6.547 0 01-1.825 2c-.696.494-1.523.869-2.458 1.109-.906.236-1.939.355-3.072.355h-.73c-.522 0-1.029.188-1.427.525a2.21 2.21 0 00-.744 1.328l-.055.299-.924 5.855-.042.215c-.011.068-.03.102-.058.125a.155.155 0 01-.096.035H7.266z",fill:"#253b80"}),i.createElement("path",{d:"M23.048 7.667c-.028.179-.06.362-.096.55-1.237 6.351-5.469 8.545-10.874 8.545H9.326c-.661 0-1.218.48-1.321 1.132L6.596 26.83l-.399 2.533a.704.704 0 00.695.814h4.881c.578 0 1.069-.42 1.16-.99l.048-.248.919-5.832.059-.32c.09-.572.582-.992 1.16-.992h.73c4.729 0 8.431-1.92 9.513-7.476.452-2.321.218-4.259-.978-5.622a4.667 4.667 0 00-1.336-1.03z",fill:"#179bd7"}),i.createElement("path",{d:"M21.754 7.151a9.757 9.757 0 00-1.203-.267 15.284 15.284 0 00-2.426-.177h-7.352a1.172 1.172 0 00-1.159.992L8.05 17.605l-.045.289a1.336 1.336 0 011.321-1.132h2.752c5.405 0 9.637-2.195 10.874-8.545.037-.188.068-.371.096-.55a6.594 6.594 0 00-1.017-.429 9.045 9.045 0 00-.277-.087z",fill:"#222d65"}),i.createElement("path",{d:"M9.614 7.699a1.169 1.169 0 011.159-.991h7.352c.871 0 1.684.057 2.426.177a9.757 9.757 0 011.481.353c.365.121.704.264 1.017.429.368-2.347-.003-3.945-1.272-5.392C20.378.682 17.853 0 14.622 0h-9.38c-.66 0-1.223.48-1.325 1.133L.01 25.898a.806.806 0 00.795.932h5.791l1.454-9.225 1.564-9.906z",fill:"#253b80"})),X=i.createElement("svg",{focusable:"false",role:"img",style:{transform:"translateY(1px)"},viewBox:"0 0 24 24",width:"24px",height:"24px",xmlns:"http://www.w3.org/2000/svg"},i.createElement("title",null,"Twitch"),i.createElement("path",{d:"M11.571 4.714h1.715v5.143H11.57zm4.715 0H18v5.143h-1.714zM6 0L1.714 4.286v15.428h5.143V24l4.286-4.286h3.428L22.286 12V0zm14.571 11.143l-3.428 3.428h-3.429l-3 3v-3H6.857V1.714h13.714Z"})),Z=i.createElement("svg",{focusable:"false",role:"img",style:{transform:"scale(1.1)"},viewBox:"0 0 24 24",width:"24px",height:"24px",xmlns:"http://www.w3.org/2000/svg"},i.createElement("title",null,"Twitter"),i.createElement("path",{d:"M23.954 4.569c-.885.389-1.83.654-2.825.775 1.014-.611 1.794-1.574 2.163-2.723-.951.555-2.005.959-3.127 1.184-.896-.959-2.173-1.559-3.591-1.559-2.717 0-4.92 2.203-4.92 4.917 0 .39.045.765.127 1.124C7.691 8.094 4.066 6.13 1.64 3.161c-.427.722-.666 1.561-.666 2.475 0 1.71.87 3.213 2.188 4.096-.807-.026-1.566-.248-2.228-.616v.061c0 2.385 1.693 4.374 3.946 4.827-.413.111-.849.171-1.296.171-.314 0-.615-.03-.916-.086.631 1.953 2.445 3.377 4.604 3.417-1.68 1.319-3.809 2.105-6.102 2.105-.39 0-.779-.023-1.17-.067 2.189 1.394 4.768 2.209 7.557 2.209 9.054 0 13.999-7.496 13.999-13.986 0-.209 0-.42-.015-.63.961-.689 1.8-1.56 2.46-2.548l-.047-.02z"})),W=i.createElement("svg",{focusable:"false",role:"img",viewBox:"0 0 24 24",width:"24px",height:"24px",xmlns:"http://www.w3.org/2000/svg"},i.createElement("title",null,"Unity"),i.createElement("path",{d:"M24 9.533L21.374 0 11.57 2.555l-1.45 2.49-2.945-.022L0 12l7.176 6.978 2.943-.023 1.454 2.49 9.8 2.554L24 14.47 22.508 12 24 9.533zM10.356 5.445l7.499-1.874-4.304 7.251H4.94l5.416-5.377zm0 13.11L4.94 13.18h8.61l4.305 7.251-7.5-1.874zm9.598.696l-4.307-7.25 4.307-7.253L22.033 12l-2.08 7.25z"})),V=i.createElement("svg",{focusable:"false",role:"img",style:{transform:"scale(1.125)"},viewBox:"0 0 24 24",width:"24px",height:"24px",xmlns:"http://www.w3.org/2000/svg"},i.createElement("title",null,"YouTube"),i.createElement("path",{d:"M23.495 6.205a3.007 3.007 0 0 0-2.088-2.088c-1.87-.501-9.396-.501-9.396-.501s-7.507-.01-9.396.501A3.007 3.007 0 0 0 .527 6.205a31.247 31.247 0 0 0-.522 5.805 31.247 31.247 0 0 0 .522 5.783 3.007 3.007 0 0 0 2.088 2.088c1.868.502 9.396.502 9.396.502s7.506 0 9.396-.502a3.007 3.007 0 0 0 2.088-2.088 31.247 31.247 0 0 0 .5-5.783 31.247 31.247 0 0 0-.5-5.805zM9.609 15.601V8.408l6.264 3.602z"})),K={discord:R,email:D,facebook:$,github:B,instagram:q,linkedIn:H,patreon:Y,paypal:U,twitch:X,twitter:Z,unity:W,youtube:V},J=a().oneOfType([a().string,a().shape({key:a().string,name:a().string,color:a().string,url:a().string,icon:a().element})]),G={discord:{key:"discord",name:"Discord",color:"#7289da",url:"https://discord.gg/DdYyWVb",icon:R},email:{key:"email",name:"Email",url:"mailto:support@zigurous.com",icon:D},facebook:{key:"facebook",name:"Facebook",color:"#1877f2",url:"https://facebook.com/zigurous",icon:$},github:{key:"github",name:"GitHub",url:"https://github.com/zigurous",icon:B},instagram:{key:"instagram",name:"Instagram",color:"#e4405f",url:"https://instagram.com/zigurous",icon:q},patreon:{key:"patreon",name:"Patreon",color:"#ff424d",url:"https://patreon.com/zigurous",icon:Y},paypal:{key:"paypal",name:"PayPal",color:"#00457c",url:"https://paypal.com/donate?hosted_button_id=BGS8Y9U798JS8",icon:U},twitch:{key:"twitch",name:"Twitch",color:"#9146ff",url:"https://twitch.tv/zigurous",icon:X},twitter:{key:"twitter",name:"Twitter",color:"#1da1f2",url:"https://twitter.com/zigurous",icon:Z},unity:{key:"unity",name:"Unity",url:"https://assetstore.unity.com/publishers/51884",icon:W},youtube:{key:"youtube",name:"YouTube",color:"#ff0000",url:"https://youtube.com/c/zigurous?sub_confirmation=1",icon:V}},Q={wordmark:i.createElement("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 596 192"},i.createElement("path",{d:"M528.71,98.72a18.85,18.85,0,0,0-7.36-5.56,92.48,92.48,0,0,0-10.88-3.52A43,43,0,0,1,501.91,87a4.28,4.28,0,0,1-2.76-4,4.21,4.21,0,0,1,1.72-3.52,8.33,8.33,0,0,1,5-1.28A9.36,9.36,0,0,1,511.91,80a7.68,7.68,0,0,1,2.76,5.16h17c-.64-6.4-3.12-11.56-7.48-15.4S513.91,64,506.39,64a31,31,0,0,0-13.2,2.56,19.26,19.26,0,0,0-8.4,7A17.5,17.5,0,0,0,482,83.28q0,6.36,3.12,10.08a18.58,18.58,0,0,0,7.4,5.48,79.1,79.1,0,0,0,10.8,3.28A55.41,55.41,0,0,1,512,105a4.27,4.27,0,0,1,2.68,4,4.37,4.37,0,0,1-1.88,3.64,9,9,0,0,1-5.32,1.4,9.94,9.94,0,0,1-6.36-2,7.23,7.23,0,0,1-2.92-5.2H480a20.18,20.18,0,0,0,4,10.84,23.8,23.8,0,0,0,9.68,7.64,33.14,33.14,0,0,0,14,2.8,32.3,32.3,0,0,0,12.88-2.44A19.55,19.55,0,0,0,529,118.8a16.93,16.93,0,0,0,3-9.76C531.91,104.72,530.83,101.28,528.71,98.72Z"}),i.createElement("polygon",{points:"64 40.01 64 58.01 101.8 58.01 97.6 64.01 65.4 110.01 64 112.01 64 128.01 77.6 128.01 128 128.01 128 110.01 90.2 110.01 122.4 64.01 126.6 58.01 128 56.01 128 40.01 114.4 40.01 64 40.01"}),i.createElement("path",{d:"M368,64a32,32,0,1,0,32,32.16v-.24A32,32,0,0,0,368,64Zm0,48a16,16,0,1,1,16-16A16,16,0,0,1,368,112Z"}),i.createElement("path",{d:"M312,71.23V64H292v36.24a12,12,0,0,1-24,0V64H248v38a26,26,0,0,0,20,25.28,24.65,24.65,0,0,0,6,.72,25.92,25.92,0,0,0,18-7.24V128h20V96a16,16,0,0,1,16-16h4V64.07c-.68,0-1.32-.08-2-.08A25.92,25.92,0,0,0,312,71.23Z"}),i.createElement("path",{d:"M452,83.23v17a12,12,0,0,1-24,0V64H408v38a26,26,0,0,0,20,25.28,24.65,24.65,0,0,0,6,.72,25.92,25.92,0,0,0,18-7.24V128h20V64H452Z"}),i.createElement("path",{d:"M216,69.76A25.37,25.37,0,0,0,200,64c-15.48,0-28,14.32-28,32a35.72,35.72,0,0,0,3.4,15.32,30.58,30.58,0,0,0,10.4,12.24,24.93,24.93,0,0,0,28.4,0,18.85,18.85,0,0,0,1.8-1.32V130c0,7.72-7.16,14-16,14a17,17,0,0,1-10.4-3.4l-8.92,12.72a37.37,37.37,0,0,0,35.32,4c11.8-4.64,20-15.12,20-27.28V64H216ZM204,112a15.93,15.93,0,0,1-14.72-9.8A15.22,15.22,0,0,1,188,96a16,16,0,1,1,30.08,7.6,17.11,17.11,0,0,1-2.08,3A15.93,15.93,0,0,1,204,112Z"}),i.createElement("rect",{x:"140.01",y:"64.01",width:"20",height:"64"}),i.createElement("path",{d:"M150,36a11,11,0,0,0-10,6.16,9.83,9.83,0,0,0,0,8.64,11.16,11.16,0,0,0,20,0,9.83,9.83,0,0,0,0-8.64A11,11,0,0,0,150,36Z"})),lettermark:i.createElement("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 512 512"},i.createElement("polygon",{points:"382.81 331.67 382.81 384.03 311.24 384.03 347.9 331.67 382.81 331.67"}),i.createElement("polygon",{points:"380.48 128.03 237.93 331.67 312.99 331.67 276.33 384.03 129.13 384.03 271.68 180.39 308.33 128.03 380.48 128.03"}),i.createElement("polygon",{points:"272.26 128.03 235.6 180.39 150.08 180.39 150.08 128.03 272.26 128.03"})),logomark:i.createElement("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 512 512"},i.createElement("polygon",{points:"368.46 177.61 256 112.68 143.54 177.61 256 242.54 368.46 177.61"}),i.createElement("polygon",{points:"128 334.39 240.46 399.32 240.46 269.46 128 204.53 128 334.39"}),i.createElement("polygon",{points:"384 204.53 271.54 269.46 271.54 399.32 384 334.39 384 204.53"}))};function ee(){return(ee=Object.assign?Object.assign.bind():function(e){for(var t=1;t=0||(a[n]=e[n]);return a}var ne=["activeClassName","children","className","ElementType","external","href","path","rel","target","to","underlined","unstyled"];function re(e){var t=e.activeClassName,n=e.children,r=e.className,a=e.ElementType,o=void 0===a?"a":a,l=e.external,c=void 0!==l&&l,u=e.href,d=e.path,m=e.rel,p=e.target,h=e.to,f=e.underlined,g=void 0!==f&&f,v=e.unstyled,y=void 0!==v&&v,b=te(e,ne);return i.createElement(o,ee({},b,"a"===o?{href:u||d||h,rel:m||(c?"noopener noreferrer":void 0),target:p||(c?"_blank":void 0)}:{to:h||d||u,href:u||d||h,activeClassName:t},{className:s()({link:!y},{"link--underlined":g&&!y},r)}),n)}function ae(e,t){return e?i.createElement("img",{alt:"Logo",src:e}):Q[t]}function ie(e){var t=e.fill,n=e.image,r=e.onClick,a=e.size,o=e.style,l=e.variant,c=void 0===l?"wordmark":l;return i.createElement("div",{className:s()("logo",c,void 0===a?"medium":a,e.className),style:ee({},o,{fill:t})},r?i.createElement("button",{"aria-label":"Logo",onClick:function(e){e.target.blur(),r()}},ae(n,c)):ae(n,c))}re.propTypes={activeClassName:a().string,children:a().node,className:a().string,ElementType:a().elementType,external:a().bool,href:a().string,path:a().string,rel:a().string,target:a().string,to:a().string,underlined:a().bool,unstyled:a().bool},ie.size=Object.freeze({xs:"xs",extraSmall:"extraSmall",sm:"sm",small:"small",md:"md",medium:"medium",lg:"lg",large:"large",xl:"xl",extraLarge:"extraLarge"}),ie.variant=Object.freeze({wordmark:"wordmark",lettermark:"lettermark",logomark:"logomark"}),ie.propTypes={className:a().string,fill:a().string,image:a().string,onClick:a().func,size:a().oneOf(Object.values(ie.size)),style:a().object,variant:a().oneOf(Object.values(ie.variant))},a().bool,a().string,a().node,a().bool,a().elementType,a().arrayOf(a().shape(re.propTypes)),a().func,a().func,a().bool,a().string,a().bool;var oe=["ariaHidden","children","className","inactive","material","name","size","theme"];function se(e){var t,n,r=e.ariaHidden,a=void 0===r||r,o=e.children,l=e.className,c=e.inactive,u=e.material,d=void 0===u||u,m=e.name,p=e.size,h=void 0===p?"medium":p,f=e.theme,g=te(e,oe);return i.createElement("i",ee({"aria-hidden":a,className:s()("icon",(t={},t["icon--"+h]=h,t),(n={},n["icon--"+f]=f,n),{"icon--active":!c},{"icon--inactive":c},{"icon--material":d},l)},g),m||o)}function le(e,t,n){e.addEventListener?e.addEventListener(t,n):e.attachEvent&&e.attachEvent("on"+t,n)}function ce(e,t,n){e.removeEventListener?e.removeEventListener(t,n):e.detachEvent&&e.detachEvent("on"+t,n)}function ue(e){return void 0===e&&(e=function(){}),function(t){if(!t.defaultPrevented){var n=!1;"Enter"===t.key&&(n=!0,e(t)),n&&t.preventDefault()}}}function de(e,t){return!!t&&("/"===e?e===t.pathname:t.pathname.includes(e))}function me(e,t){return Object.keys(e).reduce((function(n,r){return Array.isArray(t)?t.includes(r)||(n[r]=e[r]):r!==t&&(n[r]=e[r]),n}),{})}function pe(e){var t=e.hidden,n=e.LinkElementType,r=void 0===n?"a":n,a=e.links,o=void 0===a?[]:a,l=e.location,c=void 0===l?"undefined"!=typeof window&&window.location:l,u=e.onLinkClick;return i.createElement("nav",{className:s()("navbar",{"display-none":void 0!==t&&t},e.className)},i.createElement("ul",null,o.map((function(e){var t=e.to||e.path||e.href,n=de(t,c);return i.createElement("li",{key:t},i.createElement(re,ee({},me(e,["leftIcon","rightIcon"]),{activeClassName:"","aria-current":n?"page":"false","aria-label":e.name,className:s()({active:n}),ElementType:e.ElementType||r,onClick:function(){u&&u(e)},unstyled:!0}),e.leftIcon&&i.createElement(se,{className:"margin-right-md",name:e.leftIcon,size:"small"}),e.name,e.rightIcon&&i.createElement(se,{className:"margin-left-md",name:e.rightIcon,size:"small"})))}))))}function he(e){var t=e.children,n=e.rootElement,r=void 0===n?"#root":n,a=(0,i.useState)(null),o=a[0],s=a[1];return(0,i.useEffect)((function(){s("undefined"!=typeof document?document.querySelector(r):null)}),[r]),o?(0,l.createPortal)(t,o):null}se.size=Object.freeze({inherit:"inherit",sm:"sm",small:"small",md:"md",medium:"medium",lg:"lg",large:"large",xl:"xl",extraLarge:"extraLarge"}),se.theme=Object.freeze({light:"light",dark:"dark"}),se.propTypes={ariaHidden:a().bool,children:a().node,className:a().string,inactive:a().bool,material:a().bool,name:a().string,size:a().oneOf(Object.keys(se.size)),theme:a().oneOf(Object.values(se.theme))},pe.propTypes={className:a().string,hidden:a().bool,LinkElementType:a().elementType,links:a().arrayOf(a().shape(re.propTypes)),location:a().object,onLinkClick:a().func},he.propTypes={children:a().node.isRequired,rootElement:a().string};var fe=["altText","backgroundColor","className","ElementType","foregroundColor","icon","iconName","innerPadding","rounded","size"];function ge(e){var t=e.backgroundColor,n=e.className,r=e.ElementType,a=void 0===r?"i":r,o=e.foregroundColor,l=e.icon,c=e.iconName,u=e.innerPadding,d=void 0===u?8:u,m=e.rounded,p=void 0!==m&&m,h=e.size,f=void 0===h?24:h,g=te(e,fe);return i.createElement(a,ee({},g,{className:s()("icon","social-icon",{"social-icon--rounded":p},c,n),style:{backgroundColor:t,fill:o,width:f,height:f,padding:d}}),l||K[c])}function ve(e){var t=e.backgroundColor,n=e.foregroundColor,r=e.hidden,a=e.iconInnerPadding,o=void 0===a?16:a,l=e.iconSize,c=void 0===l?32:l,u=e.iconSpacing,d=e.links,m=void 0===d?[]:d,p=e.onLinkClick,h=e.rounded,f=void 0!==h&&h,g=e.wrap,v=void 0!==g&&g;return i.createElement("div",{className:s()("social-nav-links",{"display-none":void 0!==r&&r},e.className)},i.createElement("ul",{className:s()("social-nav-links__list",{"flex-wrap":v})},m.map((function(e){var r="string"==typeof e?G[e]:e;return i.createElement("li",{className:"social-nav-links__item",key:r.key,style:{margin:u}},i.createElement(ge,{"aria-label":r.name,backgroundColor:t,ElementType:"a",foregroundColor:n||r.color,href:r.url,icon:r.icon,iconName:r.key,innerPadding:o,onClick:function(){p&&p(r)},rel:"noopener noreferrer",rounded:f,size:c,target:"_blank"}))}))))}function ye(e,t){var n="undefined"!=typeof window?window.matchMedia(e):null,r=(0,i.useState)(n),a=r[0],o=r[1],s=(0,i.useState)(Boolean(a&&a.matches)),l=s[0],c=s[1];return(0,i.useEffect)((function(){"undefined"!=typeof window&&o(window.matchMedia(e))}),[e]),(0,i.useEffect)((function(){var e,n=a;return n&&le(n,"change",e=function(){c(n.matches),t&&t(n.matches)}),function(){n&&e&&ce(n,"change",e)}}),[a,t]),l}ge.propTypes={altText:a().string,backgroundColor:a().string,className:a().string,ElementType:a().elementType,foregroundColor:a().string,icon:a().element,iconName:a().oneOf(Object.keys(K)),innerPadding:a().oneOfType([a().number,a().string]),rounded:a().bool,size:a().oneOfType([a().number,a().string])},ve.propTypes={backgroundColor:a().string,className:a().string,foregroundColor:a().string,hidden:a().bool,iconInnerPadding:a().oneOfType([a().number,a().string]),iconSize:a().oneOfType([a().number,a().string]),iconSpacing:a().oneOfType([a().number,a().string]),links:a().arrayOf(J),onLinkClick:a().func,rounded:a().bool,wrap:a().bool};function be(e){var t=(0,i.useState)(!0),n=t[0],r=t[1],a=function(){r(!1)};return(0,i.useEffect)((function(){var t=e.current;return t&&n&&(t.complete?a():le(t,"load",a)),function(){t&&ce(t,"load",a)}}),[e,n]),n}function we(e,t){void 0===e&&(e=!1),void 0===t&&(t=!0),(0,i.useEffect)((function(){if("undefined"!=typeof document)if(e){if(t){var n="undefined"!=typeof window&&"undefined"!=typeof document?(window.innerWidth||0)-(document.documentElement.clientWidth||0):0;n>0&&(document.body.style.paddingRight=n+"px")}document.body.classList.add("overflow-hidden")}else document.body.classList.remove("overflow-hidden"),t&&(document.body.style.paddingRight=null)}),[e,t])}(0,i.createContext)({theme:"dark",setTheme:function(){},toggleTheme:function(){}});function Ee(e){void 0===e&&(e="light");var t=function(e,t){var n=(0,i.useState)((function(){return function(e,t){if("undefined"==typeof window||!localStorage)return t;var n=localStorage.getItem(e);return n&&JSON.parse(n)||t}(e,t)})),r=n[0],a=n[1];return(0,i.useEffect)((function(){"undefined"!=typeof window&&localStorage&&localStorage.setItem(e,JSON.stringify(r))}),[e,r]),[r,a]}("theme",e),n=t[0],r=t[1],a=(0,i.useCallback)((function(){r("dark"===n?"light":"dark")}),[n,r]);return"undefined"!=typeof window&&document&&document.documentElement&&document.documentElement.style.setProperty("color-scheme",n),[n,r,a]}function ke(e){var t=e.animated,n=void 0!==t&&t,r=e.className,a=e.hideSocialLinks,o=void 0===a||a,l=e.LinkElementType,c=void 0===l?"a":l,u=e.links,d=void 0===u?[]:u,m=e.location,p=void 0===m?"undefined"!=typeof window&&window.location:m,h=e.onLinkClick,f=e.rootElement,g=e.socialLinks,v=void 0===g?[]:g,y=e.theme,b=(0,i.useState)(!1),w=b[0],E=b[1];return we(w,!0),(0,i.useEffect)((function(){E(!1)}),[p]),i.createElement(i.Fragment,null,i.createElement("button",{"aria-label":w?"Close":"Open",className:"navmenu__button",onClick:function(){return E(!w)},size:"small",style:{zIndex:w?1055:void 0}},i.createElement(se,{name:w?"close":"menu",material:!0})),w&&i.createElement(he,{rootElement:f},i.createElement("div",{className:s()("navmenu",{"navmenu--open":w,"navmenu--closed":!w},{"navmenu--animated":n},r),"data-theme":y},i.createElement("div",{className:"navmenu__overlay"}),i.createElement("div",{className:"navmenu__container container"},i.createElement("div",{className:"navmenu__wrapper"},i.createElement("ul",{className:"navmenu__list"},d.map((function(e){var t=e.to||e.path||e.href,n=de(t,p);return i.createElement("li",{className:"navmenu__item",key:t},i.createElement(re,ee({},me(e,["leftIcon","rightIcon"]),{activeClassName:"","aria-current":n?"page":"false","aria-label":e.name,className:s()({active:n}),ElementType:e.ElementType||c,onClick:function(){h&&h(e)},unstyled:!0}),e.name))}))),!o&&i.createElement(ve,{foregroundColor:"inherit",iconInnerPadding:10,iconSize:20,links:Object.values(v)}))))))}function xe(e,t){return void 0===e&&(e="en-us"),void 0===t&&(t=e),{ios:"https://linkmaker.itunes.apple.com/images/badges/"+e+"/badge_appstore-lrg.svg",android:"https://raw.github.com/yjb94/google-play-badge-svg/master/img/"+t+"_get.svg?sanitize=true"}}function Ce(e){var t=e.alt,n=void 0===t?"Download on the App Store":t,r=e.className,a=e.defaultLocale,o=void 0===a?"en-us":a,l=e.locale,c=void 0===l?"undefined"!=typeof navigator&&navigator.language||o:l,u=e.platform,d=e.width,m=void 0===d?200:d,p=e.height,h=void 0===p?m/3.375:p,f=e.target,g=void 0===f?"_blank":f,v=e.url,y=c=c.toLowerCase();-1===["zh-cn","zh-tw"].indexOf(c)&&(y=c.split(/[_-]/)[0]);var b=(0,i.useState)(xe(c,y)),w=b[0],E=b[1];return(0,i.useLayoutEffect)((function(){E(xe(c,y))}),[c,y]),i.createElement("a",{className:s()("app-store-badge",r),href:v,target:g,style:{width:m,height:h}},i.createElement("img",{alt:n||"",src:w[u],onError:function(){E(xe(o,y))}}))}function Oe(e){var t,n=e.children,r=e.className,a=e.pill,o=void 0!==a&&a,l=e.type,c=void 0===l?"solid":l;return i.createElement("div",{className:s()("badge",(t={},t["badge--"+c]=c,t),{"badge--pill":o},r)},n)}ke.propTypes={animated:a().bool,className:a().string,hideSocialLinks:a().bool,LinkElementType:a().elementType,links:a().arrayOf(a().shape(re.propTypes)),location:a().object,onLinkClick:a().func,rootElement:a().string,socialLinks:a().arrayOf(J),theme:a().string},a().bool,a().string,a().bool,a().bool,a().bool,a().bool,a().elementType,a().arrayOf(a().shape(re.propTypes)),a().object,a().oneOf(Object.values(ie.size)),a().oneOf(Object.values(ie.variant)),a().func,a().func,a().func,a().string,a().arrayOf(J),a().bool,a().string,a().bool,Ce.platform=Object.freeze({ios:"ios",android:"android"}),Ce.propTypes={alt:a().string,className:a().string,defaultLocale:a().string,locale:a().string,platform:a().oneOf(Object.values(Ce.platform)).isRequired,width:a().number,height:a().number,target:a().string,url:a().string.isRequired},a().string,a().oneOf(["left","right"]),a().elementType,a().arrayOf(a().shape(re.propTypes)),a().string,Oe.type=Object.freeze({solid:"solid",outline:"outline"}),Oe.propTypes={children:a().node,className:a().string,pill:a().bool,type:a().oneOf(Object.values(Oe.type))};var Te=["children","className","color","icon","iconElement","iconName","onClick","shape","size","style","styles"];function Se(e){var t,n,r,a,o=e.children,l=e.className,c=e.color,u=void 0===c?"default":c,d=e.icon,m=e.iconElement,p=e.iconName,h=e.onClick,f=e.shape,g=void 0===f?"rounded-corners":f,v=e.size,y=void 0===v?"small":v,b=e.style,w=void 0===b?"solid":b,E=e.styles,k=te(e,Te);return i.createElement("button",ee({className:s()("btn",(t={},t["btn--"+u]=u,t),(n={},n["btn--"+g]=g,n),(r={},r["btn--"+w]=w,r),(a={},a["btn--"+y]=y,a),{"btn--icon-only":"only"===d},l),onClick:h,style:E},k),"left"===d&&i.createElement("span",{"aria-hidden":!0,className:"icon-wrapper margin-right-md"},m||i.createElement(se,{name:p,size:"inherit"})),"only"===d?i.createElement("span",{"aria-hidden":!0,className:"icon-wrapper"},i.createElement(se,{name:p,size:"inherit"})):o,"right"===d&&i.createElement("span",{"aria-hidden":!0,className:"icon-wrapper margin-left-md"},m||i.createElement(se,{name:p,size:"inherit"})))}function _e(e){var t,n=e.children,r=e.className,a=e.layout,o=void 0===a?"horizontal":a,l=e.spacing,c=void 0===l||l;return i.createElement("div",{className:s()("btn-group",(t={},t["btn-group--"+o]=o,t),{"btn-group--spacing":c},r)},n)}Se.color=Object.freeze({default:"default",primary:"primary",secondary:"secondary",tertiary:"tertiary",success:"success",danger:"danger",warning:"warning",info:"info"}),Se.shape=Object.freeze({square:"square",roundedCorners:"rounded-corners",rounded:"rounded",circle:"circle"}),Se.size=Object.freeze({sm:"sm",small:"small",md:"md",medium:"medium",lg:"lg",large:"large"}),Se.style=Object.freeze({solid:"solid",outline:"outline",text:"text",none:"unstyled"}),Se.propTypes={children:a().node,className:a().string,color:a().oneOf(Object.values(Se.color)),icon:a().oneOf(["left","right","only"]),iconElement:a().element,iconName:a().string,onClick:a().func,shape:a().oneOf(Object.values(Se.shape)),size:a().oneOf(Object.values(Se.size)),style:a().oneOf(Object.values(Se.style)),styles:a().object},_e.layout=Object.freeze({horizontal:"horizontal",vertical:"vertical"}),_e.propTypes={children:a().node,className:a().string,layout:a().oneOf(Object.values(_e.layout)),spacing:a().bool};var Ne=["children","className","external","history","link","linkTarget","onClick"];function Ae(e){var t=e.children,n=e.className,r=e.external,a=e.history,o=e.link,l=e.linkTarget,c=void 0===l?"_blank":l,u=e.onClick,d=te(e,Ne);return i.createElement("div",ee({},d,{className:s()(n,"cursor-pointer"),onClick:function(e){a&&o&&!r?a.push(o):"undefined"!=typeof window&&o&&r&&window.open(o,c),u&&u(e)},onKeyDown:ue(u),role:"button",tabIndex:"0"}),t)}Ae.propTypes={children:a().node,className:a().string,external:a().bool,history:a().shape({push:a().func.isRequired}),link:a().string,linkTarget:a().string,onClick:a().func},a().node,a().string.isRequired;a().oneOfType([a().bool,a().number,a().string,a().shape({offset:a().oneOfType([a().number,a().string]),order:a().oneOfType([a().number,a().string]),size:a().oneOfType([a().number,a().string])})]);a().node,a().string,a().oneOf(["sm","md","lg","none"]);var Pe=i.forwardRef((function(e,t){var n=e.onSubmit,r=void 0===n?function(){}:n;return i.createElement("form",{className:s()("contact-form",e.className),onSubmit:r,ref:t},i.createElement("input",{"aria-label":"Name",id:"contactName",name:"name",placeholder:"Name",required:!0,type:"text"}),i.createElement("input",{"aria-label":"Email",id:"contactEmail",name:"email",placeholder:"Email",required:!0,type:"email"}),i.createElement("textarea",{"aria-label":"Message",id:"contactMessage",name:"message",placeholder:"Message",required:!0}),i.createElement("input",{"aria-label":"Send",id:"contactSubmit",type:"submit",value:"Send"}))}));function Me(e){var t=e.loading,n=e.size;return i.createElement("div",{"aria-hidden":!0,className:s()("loading-spinner",{loading:void 0===t||t},void 0===n?"medium":n,e.className)},i.createElement("div",{className:"loading-spinner__animation"},i.createElement("div",null),i.createElement("div",null),i.createElement("div",null),i.createElement("div",null)))}Pe.displayName="ContactForm",Pe.propTypes={className:a().string,onSubmit:a().func},a().node,a().string,a().oneOfType([a().bool,a().oneOf(["sm","md","lg","xl","fluid"])]),a().string,a().string,a().string,a().func,a().string,a().string,Me.size=Object.freeze({sm:"sm",small:"small",md:"md",medium:"medium",lg:"lg",large:"large"}),Me.propTypes={className:a().string,loading:a().bool,size:a().oneOf(Object.values(Me.size))};var Fe=Object.freeze({xs:{width:320,height:180},extraSmall:{width:320,height:180},sm:{width:480,height:270},small:{width:480,height:270},md:{width:640,height:360},medium:{width:640,height:360},lg:{width:960,height:540},large:{width:960,height:540},xl:{width:1280,height:720},extraLarge:{width:1280,height:720}});function Le(e){return null==e||"string"==typeof e&&(e.endsWith("%")||e.endsWith("px"))?e:e+"px"}function je(e){var t=e.allowFullScreen,n=void 0===t||t,r=e.className,a=e.frameBorder,o=void 0===a?"0":a,l=e.height,c=e.id,u=void 0===c?"video-player":c,d=e.scrolling,m=void 0===d?"no":d,p=e.size,h=e.src,f=e.title,g=void 0===f?"Video Player":f,v=e.width,y=(0,i.useRef)(),b=be(y),w="undefined"!=typeof navigator&&!navigator.onLine,E=v||p&&Fe[p].width,k=l||p&&Fe[p].height;return i.createElement("div",{className:s()("embedded-video",{loading:b},p,r),style:{width:Le(E),height:Le(k)}},i.createElement("div",{className:s()("embedded-video__wrapper","transition","fade-in",{visible:!b})},i.createElement("iframe",{allowFullScreen:n,frameBorder:o,height:k||"100%",id:u,ref:y,scrolling:m,src:h,title:g,width:E||"100%"})),b&&!w&&i.createElement(Me,null))}je.size=Fe,je.propTypes={allowFullScreen:a().bool,className:a().string,frameBorder:a().string,height:a().oneOfType([a().string,a().number]),id:a().string,scrolling:a().string,size:a().oneOf(Object.keys(je.size)),src:a().string.isRequired,title:a().string,width:a().oneOfType([a().string,a().number])};a().string.isRequired,a().string,a().string,a().bool,a().bool,a().string;var ze=["autoplay","captions","className","hideBranding","hideControls","hideInfo","hideRelated","id","muted","origin","secure","startTime","title","videoId"];function Ie(e){var t=e.autoplay,n=void 0!==t&&t,r=e.captions,a=void 0!==r&&r,o=e.className,l=e.hideBranding,c=void 0!==l&&l,u=e.hideControls,d=void 0!==u&&u,m=e.hideInfo,p=void 0!==m&&m,h=e.hideRelated,f=void 0===h||h,g=e.id,v=void 0===g?"youtube-player":g,y=e.muted,b=void 0!==y&&y,w=e.origin,E=e.secure,k=void 0===E||E,x=e.startTime,C=e.title,O=void 0===C?"YouTube":C,T=e.videoId,S=te(e,ze),_="enablejsapi=1";_+="&origin="+w,f&&(_+="&rel=0"),d&&(_+="&controls=0"),p&&(_+="&showinfo=0"),c&&(_+="&modestbranding=1"),a&&(_+="&cc_load_policy=1"),n&&(_+="&autoplay=1"),b&&(_+="&mute=1"),x&&(_+="&start="+x);var N=k?"https":"http";return i.createElement(je,ee({className:s()("youtube",o),id:v,src:N+"://www.youtube.com/embed/"+T+"?"+_,title:O},S))}Ie.propTypes={autoplay:a().bool,captions:a().bool,className:a().string,hideBranding:a().bool,hideControls:a().bool,hideInfo:a().bool,hideRelated:a().bool,id:a().string,muted:a().bool,origin:a().string.isRequired,secure:a().bool,startTime:a().oneOf([a().number,a().string]),title:a().string,videoId:a().string.isRequired};var Re=["className","disabled","icon","iconAlignment","onBlur","onChange","onFocus","placeholder","size","type","value"];function De(e){var t,n,r=e.className,a=e.disabled,o=e.icon,l=e.iconAlignment,c=void 0===l?"right":l,u=e.onBlur,d=void 0===u?function(){}:u,m=e.onChange,p=void 0===m?function(){}:m,h=e.onFocus,f=void 0===h?function(){}:h,g=e.placeholder,v=e.size,y=e.type,b=e.value,w=te(e,Re),E=(0,i.useState)(!1),k=E[0],x=E[1];return i.createElement("div",{className:s()("input-wrapper",(t={},t["input-wrapper--"+v]=v,t),(n={},n["input-wrapper--icon-"+c]=o&&c,n),{focus:k,disabled:a},r)},i.createElement("input",ee({className:"input-wrapper__input",disabled:a,onBlur:function(){x(!1),d()},onChange:p,onFocus:function(){x(!0),f()},placeholder:g,type:y,value:b},w)),o&&i.createElement(se,{className:"input-wrapper__icon",name:o,size:"md"}))}function $e(e){var t=e.alt,n=e.animated,r=void 0===n||n,a=e.className,o=e.height,l=e.imageClassName,c=e.ImageElementType,u=void 0===c?"img":c,d=e.imageProps,m=void 0===d?{}:d,p=e.onLoad,h=void 0===p?function(){}:p,f=e.placeholder,g=e.placeholderClassName,v=e.placeholderProps,y=void 0===v?{}:v,b=e.showLoadingSpinner,w=void 0!==b&&b,E=e.src,k=e.width,x=(0,i.useRef)(),C=function(e,t){void 0===t&&(t=function(){});var n=!be(e);return(0,i.useEffect)((function(){n&&t()}),[n,t]),n}(x,h);return i.createElement("picture",{className:s()("progressive-image",{"progressive-image--loaded":C},{"progressive-image--animated":r},{"progressive-image--no-placeholder":!f},a)},i.createElement(u,ee({},m,{alt:m.alt||t,className:s()("progressive-image__source","img-fluid",l,m.className),width:k||m.width,height:o||m.height,ref:x,src:E})),f&&i.createElement(u,ee({},y,{alt:y.alt||t,className:s()("progressive-image__placeholder","img-fluid",g,y.className),width:k||y.width||m.width,height:o||y.height||m.height,src:f})),w&&!C&&i.createElement(Me,null))}function Be(e){return"string"==typeof e?e:e.src}function qe(e){return e?e+"px":void 0}function He(e,t,n){return"repeat("+(e||"auto-fit")+", minmax("+(qe(t)||0)+", "+(qe(n)||"1fr")+"))"}function Ye(e){var t=e.animated,n=void 0!==t&&t,r=e.animation,a=void 0===r?"fade-in-up":r,o=e.className,l=e.columns,c=e.fullWidthFirstItem,u=void 0!==c&&c,d=e.images,m=void 0===d?[]:d,p=e.maxWidth,h=e.minWidth,f=(0,i.useState)(!1),g=f[0],v=f[1],y=(0,i.useState)(0),b=y[0],w=y[1];return i.createElement("div",{className:s()("image-gallery",o)},i.createElement("div",{className:"image-gallery__thumbnails",style:{gridTemplateColumns:He(l,h,p)}},m.map((function(e,t){var r,o="object"==typeof e,l=o?e.src:e,c=o&&e.id||l;return i.createElement("button",{"aria-label":"Image Thumbnail",className:s()("image-gallery__thumbnail",{"image-gallery__thumbnail--full-width":0===t&&u},(r={"animation-short":n},r["animation-delay-"+(t+1)]=n,r[a]=n,r),o&&e.className),key:c,onClick:function(){w(t),v(!0)}},i.createElement($e,{imageProps:o?me(e,"className"):{},src:l}))}))),g&&i.createElement(I,{enableZoom:!1,mainSrc:Be(m[b]),nextSrc:Be(m[(b+1)%m.length]),prevSrc:Be(m[(b+m.length-1)%m.length]),onCloseRequest:function(){v(!1)},onMovePrevRequest:function(){w((b+m.length-1)%m.length)},onMoveNextRequest:function(){w((b+1)%m.length)},wrapperClassName:"image-gallery__lightbox"}))}function Ue(e){var t,n=e.backgroundColor,r=e.children,a=e.className,o=e.size,l=void 0===o?"medium":o,c=e.style,u=e.theme,d=e.transparent,m=void 0!==d&&d;return i.createElement("div",{className:s()("page-banner",(t={},t["page-banner--"+l]=l,t),{"page-banner--transparent":m},a),"data-theme":u,style:ee({backgroundColor:n},c)},r)}De.size=Object.freeze({sm:"sm",small:"small",md:"md",medium:"medium",lg:"lg",large:"large"}),De.iconAlignment=Object.freeze({left:"left",right:"right"}),De.propTypes={className:a().string,disabled:a().bool,icon:a().string,iconAlignment:a().oneOf(Object.values(De.iconAlignment)),onBlur:a().func,onChange:a().func,onFocus:a().func,placeholder:a().string,size:a().oneOf(Object.values(De.size)),type:a().string,value:a().any},$e.propTypes={alt:a().string,animated:a().bool,className:a().string,height:a().oneOfType([a().string,a().number]),imageClassName:a().string,ImageElementType:a().elementType,imageProps:a().object,onLoad:a().func,placeholder:a().string,placeholderClassName:a().string,placeholderProps:a().object,showLoadingSpinner:a().bool,src:a().string,width:a().oneOfType([a().string,a().number])},Ye.propTypes={animated:a().bool,animation:a().string,className:a().string,columns:a().number,fullWidthFirstItem:a().bool,images:a().arrayOf(a().oneOfType([a().shape({alt:a().string,className:a().string,id:a().string,src:a().string.isRequired}),a().string])),maxWidth:a().number,minWidth:a().number},a().node,a().string,a().element,a().oneOf(["left","right"]),a().string,a().func,a().bool,a().string,a().string,a().string,Ue.size=Object.freeze({xs:"xs",extraSmall:"extraSmall",sm:"sm",small:"small",md:"md",medium:"medium",lg:"lg",large:"large",xl:"xl",extraLarge:"extraLarge"}),Ue.propTypes={backgroundColor:a().string,children:a().node,className:a().string,size:a().oneOf(Object.values(Ue.size)),style:a().object,theme:a().string,transparent:a().bool},a().string,a().number,a().func,a().number.isRequired,a().node,a().string,a().oneOf(["sm","md","lg","none"]);a().string,a().number,a().bool,a().func,a().func,a().string,a().bool,a().string,a().node,a().bool,a().object,a().string,a().string;var Xe=["children","className","link","LinkElementType","primaryColor","secondaryColor","size","url"];function Ze(e){var t=e.children,n=e.className,r=e.link,a=e.LinkElementType,o=e.primaryColor,l=e.secondaryColor,c=e.size,u=void 0===c?Se.size.medium:c,d=e.url,m=te(e,Xe),p="string"==typeof r?G[r]:r,h=o||p.color;return i.createElement(re,{ElementType:a,external:!0,to:d||p.url,unstyled:!0},i.createElement(Se,ee({className:s()("social-button",p.key,n),icon:"left",iconElement:p.icon&&i.createElement(ge,{"aria-hidden":!0,ElementType:"i",icon:p.icon,iconName:p.key,innerPadding:0,size:"100%"}),size:u,styles:{"--btn-color-primary":h,"--btn-color-secondary":l,"--btn-color-emphasis":h},tabIndex:-1},m),t||p.name))}function We(e){var t,n=e.alignItems,r=e.children,a=e.direction,o=void 0===a?"column":a,l=e.justifyContent,c=e.reversed,u=void 0!==c&&c,d=e.wrap;return i.createElement("div",{className:s()("display-flex",{"flex-row":"row"===o&&!u,"flex-row-reverse":"row"===o&&u,"flex-column":"column"===o&&!u,"flex-column-reverse":"column"===o&&u,"flex-wrap":void 0!==d&&d},(t={},t["justify-content-"+l]=l,t["align-items-"+n]=n,t))},r)}Ze.shape=Se.shape,Ze.size=Se.size,Ze.style=Se.style,Ze.propTypes={children:a().node,className:a().string,link:J.isRequired,LinkElementType:a().elementType,primaryColor:a().string,secondaryColor:a().string,size:a().oneOf(Object.values(Se.size)),url:a().string},We.direction=Object.freeze({row:"row",column:"column"}),We.alignItems=Object.freeze({start:"start",end:"end",center:"center",stretch:"stretch",baseline:"baseline"}),We.justifyContent=Object.freeze({start:"start",end:"end",center:"center",between:"between",around:"around",evenly:"evenly"}),We.propTypes={alignItems:a().oneOf(Object.values(We.alignItems)),children:a().node,direction:a().oneOf(Object.values(We.direction)),justifyContent:a().oneOf(Object.values(We.justifyContent)),reversed:a().bool,wrap:a().bool};a().oneOf(["inherit","transparent","black","white","foreground","foreground-muted","foreground-subtle","background","surface-0","surface-1","surface-2","surface-3","surface-4","surface-5","surface-6","surface-7","surface-8","surface-9","border","default","primary","secondary","tertiary","success","danger","warning","info"]),a().oneOf([1,2,3,4,5,6,"1","2","3","4","5","6"]),a().oneOf(["xxxl","xxl","xl","lg","md","sm","xs","xxs","xxxs"]),a().oneOf([100,200,300,400,500,600,700,800,900,"100","200","300","400","500","600","700","800","900"]),a().oneOf(["0","none","xs","sm","md","lg","xl","xxl","xxxl","2xl","2xxl","2xxxl","1em","2em","3em","4em","5em","6em","7em","8em"]);a().bool,a().node,a().string,a().bool,a().elementType;var Ve=["alt","animated","animation","children","className","ElementType","height","image","imageClassName","ImageElementType","imageProps","index","placeholder","placeholderClassName","placeholderProps","rounded","shadow","style","width"];function Ke(e){var t,n=e.alt,r=e.animated,a=void 0!==r&&r,o=e.animation,l=void 0===o?"fade-translate-in":o,c=e.children,u=e.className,d=e.ElementType,m=void 0===d?"a":d,p=e.height,h=e.image,f=e.imageClassName,g=e.ImageElementType,v=void 0===g?"img":g,y=e.imageProps,b=void 0===y?{}:y,w=e.index,E=e.placeholder,k=e.placeholderClassName,x=e.placeholderProps,C=void 0===x?{}:x,O=e.rounded,T=void 0===O||O,S=e.shadow,_=void 0===S||S,N=e.width,A=te(e,Ve),P=(0,i.useRef)(),M=(0,i.useState)(!1),F=M[0],L=M[1];return(0,i.useEffect)((function(){var e;return a&&F&&(e=setTimeout((function(){P&&P.current&&(P.current.style.animation=0)}),600)),function(){e&&clearTimeout(e)}}),[a,F,P]),i.createElement(m,ee({},A,{className:s()("thumbnail",(t={"animation-short":a&&F},t["animation-delay-"+(w+1)]=a&&F&&w>=0,t[l]=a&&F,t),{rounded:T,shadow:_},u),ref:P}),v&&i.createElement($e,{alt:n,height:p,imageClassName:f,ImageElementType:v,imageProps:b,onLoad:function(){return L(!0)},placeholder:E,placeholderClassName:k,placeholderProps:C,src:h,width:N}),c)}Ke.propTypes={alt:a().string,animated:a().bool,animation:a().string,children:a().node,className:a().string,ElementType:a().elementType,height:a().oneOfType([a().string,a().number]),image:a().string,imageClassName:a().string,ImageElementType:a().elementType,imageProps:a().object,index:a().number,placeholder:a().string,placeholderClassName:a().string,placeholderProps:a().object,rounded:a().bool,shadow:a().bool,style:a().object,width:a().oneOfType([a().string,a().number])},a().bool,a().node,a().string,a().bool,a().bool,a().bool,a().bool,a().bool,a().elementType},7427:function(e,t){"use strict";t.q=function(e,t){if("string"!=typeof e)throw new TypeError("argument str must be a string");for(var r={},a=t||{},o=e.split(";"),s=a.decode||n,l=0;l{let{link:t,external:n=!1}=e;return i.createElement("div",{className:"dock__item",id:t.name},i.createElement(r.N_,{ElementType:t.ElementType||(n?"a":a.Link),external:n,to:t.to||t.url,unstyled:!0},t.icon?i.createElement(r.In,{name:t.icon}):i.createElement(r.b6,{iconName:t.key,innerPadding:0,size:18})),i.createElement("div",{className:"dock__tooltip"},t.name))};var l=e=>{let{theme:t,toggleTheme:n,secondaryLinks:a}=e;return i.createElement("div",{className:"dock"},i.createElement("div",{className:"dock__container",id:"primary"},i.createElement("div",{className:"dock__section",id:"navigation"},o.R1.map((e=>i.createElement(s,{link:e,key:e.key})))),i.createElement("div",{className:"dock__section",id:"socials"},o.lj.map((e=>i.createElement(s,{link:e,key:e.key,external:!0})))),i.createElement("div",{className:"dock__section",id:"gallery"},i.createElement("div",{className:"dock__item",id:"Previous"},i.createElement("button",{onClick:()=>{if(!document)return;const e=new Event("previous_slide");document.dispatchEvent(e)}},i.createElement(r.In,{name:"chevron_left"})),i.createElement("div",{className:"dock__tooltip"},"Previous")),i.createElement("div",{className:"dock__item",id:"Next"},i.createElement("button",{onClick:()=>{if(!document)return;const e=new Event("next_slide");document.dispatchEvent(e)}},i.createElement(r.In,{name:"chevron_right"})),i.createElement("div",{className:"dock__tooltip"},"Next"))),i.createElement("div",{className:"dock__section",id:"theme"},i.createElement("div",{className:"dock__item",id:"Theme"},i.createElement("button",{onClick:n},i.createElement(r.In,{name:"dark"===t?"light_mode":"dark_mode"})),i.createElement("div",{className:"dock__tooltip"},"dark"===t?"Light Mode":"Dark Mode")))),a&&i.createElement("div",{className:"dock__container",id:"secondary"},a.map((e=>i.createElement(s,{link:e,key:e.key||e.name,external:!0})))))},c=n(6942),u=n.n(c),d=n(5556),m=n.n(d);var p=e=>{let{children:t,...n}=e;return i.createElement(r.$n,Object.assign({className:"shadow-button",size:r.$n.size.small,shape:r.$n.shape.rounded},n),t)};const h=m().shape({sharp:m().shape({original:m().shape({src:m().string.isRequired,width:m().number,height:m().number})})});m().shape({category:m().string.isRequired,date:m().string,description:m().string,description_short:m().string,id:m().string.isRequired,image:h.isRequired,imageAltText:m().string,imageBorder:m().string,title:m().string.isRequired});var f=e=>{let{className:t,slide:n}=e;const o="undefined"!=typeof navigator&&!navigator.onLine,s=`/${n.category}/${n.id}`;return i.createElement("div",{className:u()("slide",t)},i.createElement("div",{className:"slide__image-wrapper"},i.createElement(r.N_,{className:"display-inline-flex",ElementType:a.Link,to:s,unstyled:!0},i.createElement(r.vb,{alt:n.imageAltText||"",animated:!1,className:u()("slide__image",{[`slide__image--border-${n.imageBorder}`]:n.imageBorder}),width:n.image.sharp.original.width,height:n.image.sharp.original.height,src:n.image.sharp.original.src,showLoadingSpinner:!o}))),i.createElement("div",{className:"slide__text-wrapper"},i.createElement("div",{className:"slide__text-container"},i.createElement("p",{className:"eyebrow"},n.date),i.createElement("h1",{className:"title"},n.title),i.createElement("p",{className:"description opacity-90p"},n.description_short||n.description),i.createElement(r.N_,{ElementType:a.Link,to:s,style:{marginLeft:"-4px"},unstyled:!0},i.createElement(p,null,"More Details")))))};var g=e=>{let{category:t,location:n,slides:o=[]}=e;const s=(0,r.Ub)("(max-width: 1365px)"),l=new URLSearchParams(null==n?void 0:n.search),c=(l.has("index")?Number.parseInt(l.get("index"))||0:function(e){return e&&"undefined"!=typeof sessionStorage&&Number.parseInt(sessionStorage.getItem(`${e}-slide`))||0}(t))%o.length,d=c>=0&&c{e>=o.length&&(e=0),e<0&&(e=o.length-1),function(e,t){e&&"undefined"!=typeof sessionStorage&&sessionStorage.setItem(`${e}-slide`,t)}(t,e),(0,a.navigate)(`/${t}?index=${e}`,{replace:!0})}),[t,o,c]);return(0,i.useEffect)((()=>{if(!document)return;const e=()=>m(c-1),t=()=>m(c+1);return document.addEventListener("previous_slide",e),document.addEventListener("next_slide",t),()=>{document.removeEventListener("previous_slide",e),document.removeEventListener("next_slide",t)}}),[c]),i.createElement("div",{className:u()("gallery",{"gallery--vertical":s}),id:t},i.createElement("button",{"aria-label":"Previous Slide",className:"gallery__button previous",onClick:()=>m(c-1)},i.createElement("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",width:"48px",height:"48px"},i.createElement("path",{d:"M14.71 6.71c-.39-.39-1.02-.39-1.41 0L8.71 11.3c-.39.39-.39 1.02 0 1.41l4.59 4.59c.39.39 1.02.39 1.41 0 .39-.39.39-1.02 0-1.41L10.83 12l3.88-3.88c.39-.39.38-1.03 0-1.41z"}))),i.createElement("div",{className:"gallery__slides"},d&&i.createElement(f,{slide:d})),i.createElement("button",{"aria-label":"Next Slide",className:"gallery__button next",onClick:()=>m(c+1)},i.createElement("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",width:"48px",height:"48px"},i.createElement("path",{d:"M9.29 6.71c-.39.39-.39 1.02 0 1.41L13.17 12l-3.88 3.88c-.39.39-.39 1.02 0 1.41.39.39 1.02.39 1.41 0l4.59-4.59c.39-.39.39-1.02 0-1.41L10.7 6.7c-.38-.38-1.02-.38-1.41.01z"}))))};var v=e=>{let{rounded:t=!1,size:n=48}=e;return i.createElement("div",{className:u()("ag-logo",{"ag-logo--rounded":t}),style:{width:`${n}px`,height:`${n}px`,minWidth:`${n}px`,minHeight:`${n}px`}},i.createElement(r.N_,{ElementType:a.Link,to:"/",unstyled:!0},i.createElement("div",{className:"ag-logo__background"}),i.createElement("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 512 512"},i.createElement("polygon",{points:"345.17 257.56 233.75 257.56 212.47 294.58 324.06 294.58 382.6 396.41 425 396.41 345.17 257.56"}),i.createElement("polygon",{points:"168.69 322.35 254.36 173.36 286.8 229.79 329.2 229.79 254.36 99.59 105 359.38 333.5 359.38 312.21 322.35 168.69 322.35"}))))};var y=e=>{let{open:t,onRequestClose:n=()=>{}}=e;return(0,r.ln)(t,!0),i.createElement("div",{className:u()("menu-gallery",{open:t,closed:!t})},i.createElement("div",{"aria-hidden":!t,className:"menu-gallery__container container-fluid"},i.createElement("ul",{className:"menu-gallery__list"},t&&i.createElement(a.StaticQuery,{query:"3141325806",render:e=>o.Jm.map((o=>{const s=e[o.key]||{nodes:[]};return i.createElement("li",{className:"menu-gallery__section",key:o.to},i.createElement(r.N_,{activeClassName:"","aria-disabled":!t,"aria-label":o.name,disabled:!t,ElementType:o.ElementType||a.Link,external:o.external,onClick:n,tabIndex:t?0:-1,to:o.to,unstyled:!0},i.createElement("span",null,o.name),i.createElement(r.$n,{className:"margin-top-md margin-left-lg active",icon:"only",iconName:"east",style:r.$n.style.text})),i.createElement("div",{className:"menu-gallery__grid"},s.nodes.map(((e,o)=>i.createElement(r.Vz,{alt:e.imageAltText||"",animated:!1,"aria-disabled":!t,"aria-label":e.title,className:"menu-gallery__thumbnail",disabled:!t,ElementType:a.Link,height:e.image.sharp.original.height,image:e.image.sharp.original.src,imageClassName:"img-fluid",index:o,key:e.id,onClick:n,shadow:!1,to:`/${e.category}/?index=${o}`,width:e.image.sharp.original.width})))))}))}))))};const b=e=>{let{location:t,pageTitle:n}=e;const{0:s,1:l}=(0,i.useState)(!1);return i.createElement(i.Fragment,null,i.createElement("header",{className:"header"},i.createElement("div",{className:"header__container container-fluid"},i.createElement(v,{size:44}),i.createElement(r.jq,{links:o.Jm,LinkElementType:a.Link,location:t}),n&&i.createElement(r.$n,{className:"header__title-button",onClick:()=>{const e=o.Jm.find((e=>e.name===n));e?(0,a.navigate)(e.to):l(!0)},style:r.$n.style.none},n),i.createElement("button",{"aria-label":s?"Close Gallery Menu":"Open Gallery Menu",className:"header__menu-button",onClick:()=>l(!s)},s?i.createElement("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",width:"36px",height:"36px"},i.createElement("path",{d:"M3 18h13v-2H3v2zm0-5h10v-2H3v2zm0-7v2h13V6H3zm18 9.59L17.42 12 21 8.41 19.59 7l-5 5 5 5L21 15.59z"})):i.createElement("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",width:"36px",height:"36px"},i.createElement("path",{d:"M3 18h18v-2H3v2zm0-5h18v-2H3v2zm0-7v2h18V6H3z"}))))),i.createElement(y,{open:s,onRequestClose:()=>l(!1)}))};b.propType={location:m().object,pageTitle:m().string};var w,E,k,x,C=b,O=n(2098),T=n.n(O),S=n(115),_=n.n(S),N=n(8828),A=n.n(N),P="bodyAttributes",M="htmlAttributes",F="titleAttributes",L={BASE:"base",BODY:"body",HEAD:"head",HTML:"html",LINK:"link",META:"meta",NOSCRIPT:"noscript",SCRIPT:"script",STYLE:"style",TITLE:"title"},j=(Object.keys(L).map((function(e){return L[e]})),"charset"),z="cssText",I="href",R="http-equiv",D="innerHTML",$="itemprop",B="name",q="property",H="rel",Y="src",U="target",X={accesskey:"accessKey",charset:"charSet",class:"className",contenteditable:"contentEditable",contextmenu:"contextMenu","http-equiv":"httpEquiv",itemprop:"itemProp",tabindex:"tabIndex"},Z="defaultTitle",W="defer",V="encodeSpecialCharacters",K="onChangeClientState",J="titleTemplate",G=Object.keys(X).reduce((function(e,t){return e[X[t]]=t,e}),{}),Q=[L.NOSCRIPT,L.SCRIPT,L.STYLE],ee="data-react-helmet",te="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},ne=function(){function e(e,t){for(var n=0;n=0||Object.prototype.hasOwnProperty.call(e,r)&&(n[r]=e[r]);return n},ie=function(e){return!1===(!(arguments.length>1&&void 0!==arguments[1])||arguments[1])?String(e):String(e).replace(/&/g,"&").replace(//g,">").replace(/"/g,""").replace(/'/g,"'")},oe=function(e){var t=de(e,L.TITLE),n=de(e,J);if(n&&t)return n.replace(/%s/g,(function(){return Array.isArray(t)?t.join(""):t}));var r=de(e,Z);return t||r||void 0},se=function(e){return de(e,K)||function(){}},le=function(e,t){return t.filter((function(t){return void 0!==t[e]})).map((function(t){return t[e]})).reduce((function(e,t){return re({},e,t)}),{})},ce=function(e,t){return t.filter((function(e){return void 0!==e[L.BASE]})).map((function(e){return e[L.BASE]})).reverse().reduce((function(t,n){if(!t.length)for(var r=Object.keys(n),a=0;a=0;n--){var r=e[n];if(r.hasOwnProperty(t))return r[t]}return null},me=(w=Date.now(),function(e){var t=Date.now();t-w>16?(w=t,e(t)):setTimeout((function(){me(e)}),0)}),pe=function(e){return clearTimeout(e)},he="undefined"!=typeof window?window.requestAnimationFrame&&window.requestAnimationFrame.bind(window)||window.webkitRequestAnimationFrame||window.mozRequestAnimationFrame||me:n.g.requestAnimationFrame||me,fe="undefined"!=typeof window?window.cancelAnimationFrame||window.webkitCancelAnimationFrame||window.mozCancelAnimationFrame||pe:n.g.cancelAnimationFrame||pe,ge=function(e){return console&&"function"==typeof console.warn&&console.warn(e)},ve=null,ye=function(e,t){var n=e.baseTag,r=e.bodyAttributes,a=e.htmlAttributes,i=e.linkTags,o=e.metaTags,s=e.noscriptTags,l=e.onChangeClientState,c=e.scriptTags,u=e.styleTags,d=e.title,m=e.titleAttributes;Ee(L.BODY,r),Ee(L.HTML,a),we(d,m);var p={baseTag:ke(L.BASE,n),linkTags:ke(L.LINK,i),metaTags:ke(L.META,o),noscriptTags:ke(L.NOSCRIPT,s),scriptTags:ke(L.SCRIPT,c),styleTags:ke(L.STYLE,u)},h={},f={};Object.keys(p).forEach((function(e){var t=p[e],n=t.newTags,r=t.oldTags;n.length&&(h[e]=n),r.length&&(f[e]=p[e].oldTags)})),t&&t(),l(e,h,f)},be=function(e){return Array.isArray(e)?e.join(""):e},we=function(e,t){void 0!==e&&document.title!==e&&(document.title=be(e)),Ee(L.TITLE,t)},Ee=function(e,t){var n=document.getElementsByTagName(e)[0];if(n){for(var r=n.getAttribute(ee),a=r?r.split(","):[],i=[].concat(a),o=Object.keys(t),s=0;s=0;d--)n.removeAttribute(i[d]);a.length===i.length?n.removeAttribute(ee):n.getAttribute(ee)!==o.join(",")&&n.setAttribute(ee,o.join(","))}},ke=function(e,t){var n=document.head||document.querySelector(L.HEAD),r=n.querySelectorAll(e+"["+ee+"]"),a=Array.prototype.slice.call(r),i=[],o=void 0;return t&&t.length&&t.forEach((function(t){var n=document.createElement(e);for(var r in t)if(t.hasOwnProperty(r))if(r===D)n.innerHTML=t.innerHTML;else if(r===z)n.styleSheet?n.styleSheet.cssText=t.cssText:n.appendChild(document.createTextNode(t.cssText));else{var s=void 0===t[r]?"":t[r];n.setAttribute(r,s)}n.setAttribute(ee,"true"),a.some((function(e,t){return o=t,n.isEqualNode(e)}))?a.splice(o,1):i.push(n)})),a.forEach((function(e){return e.parentNode.removeChild(e)})),i.forEach((function(e){return n.appendChild(e)})),{oldTags:a,newTags:i}},xe=function(e){return Object.keys(e).reduce((function(t,n){var r=void 0!==e[n]?n+'="'+e[n]+'"':""+n;return t?t+" "+r:r}),"")},Ce=function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return Object.keys(e).reduce((function(t,n){return t[X[n]||n]=e[n],t}),t)},Oe=function(e,t,n){switch(e){case L.TITLE:return{toComponent:function(){return e=t.title,n=t.titleAttributes,(r={key:e})[ee]=!0,a=Ce(n,r),[i.createElement(L.TITLE,a,e)];var e,n,r,a},toString:function(){return function(e,t,n,r){var a=xe(n),i=be(t);return a?"<"+e+" "+ee+'="true" '+a+">"+ie(i,r)+"":"<"+e+" "+ee+'="true">'+ie(i,r)+""}(e,t.title,t.titleAttributes,n)}};case P:case M:return{toComponent:function(){return Ce(t)},toString:function(){return xe(t)}};default:return{toComponent:function(){return function(e,t){return t.map((function(t,n){var r,a=((r={key:n})[ee]=!0,r);return Object.keys(t).forEach((function(e){var n=X[e]||e;if(n===D||n===z){var r=t.innerHTML||t.cssText;a.dangerouslySetInnerHTML={__html:r}}else a[n]=t[e]})),i.createElement(e,a)}))}(e,t)},toString:function(){return function(e,t,n){return t.reduce((function(t,r){var a=Object.keys(r).filter((function(e){return!(e===D||e===z)})).reduce((function(e,t){var a=void 0===r[t]?t:t+'="'+ie(r[t],n)+'"';return e?e+" "+a:a}),""),i=r.innerHTML||r.cssText||"",o=-1===Q.indexOf(e);return t+"<"+e+" "+ee+'="true" '+a+(o?"/>":">"+i+"")}),"")}(e,t,n)}}}},Te=function(e){var t=e.baseTag,n=e.bodyAttributes,r=e.encode,a=e.htmlAttributes,i=e.linkTags,o=e.metaTags,s=e.noscriptTags,l=e.scriptTags,c=e.styleTags,u=e.title,d=void 0===u?"":u,m=e.titleAttributes;return{base:Oe(L.BASE,t,r),bodyAttributes:Oe(P,n,r),htmlAttributes:Oe(M,a,r),link:Oe(L.LINK,i,r),meta:Oe(L.META,o,r),noscript:Oe(L.NOSCRIPT,s,r),script:Oe(L.SCRIPT,l,r),style:Oe(L.STYLE,c,r),title:Oe(L.TITLE,{title:d,titleAttributes:m},r)}},Se=T()((function(e){return{baseTag:ce([I,U],e),bodyAttributes:le(P,e),defer:de(e,W),encode:de(e,V),htmlAttributes:le(M,e),linkTags:ue(L.LINK,[H,I],e),metaTags:ue(L.META,[B,j,R,q,$],e),noscriptTags:ue(L.NOSCRIPT,[D],e),onChangeClientState:se(e),scriptTags:ue(L.SCRIPT,[Y,D],e),styleTags:ue(L.STYLE,[z],e),title:oe(e),titleAttributes:le(F,e)}}),(function(e){ve&&fe(ve),e.defer?ve=he((function(){ye(e,(function(){ve=null}))})):(ye(e),ve=null)}),Te)((function(){return null})),_e=(E=Se,x=k=function(e){function t(){return function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,t),function(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}(this,e.apply(this,arguments))}return function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}(t,e),t.prototype.shouldComponentUpdate=function(e){return!_()(this.props,e)},t.prototype.mapNestedChildrenToProps=function(e,t){if(!t)return null;switch(e.type){case L.SCRIPT:case L.NOSCRIPT:return{innerHTML:t};case L.STYLE:return{cssText:t}}throw new Error("<"+e.type+" /> elements are self-closing and can not contain children. Refer to our API for more information.")},t.prototype.flattenArrayTypeChildren=function(e){var t,n=e.child,r=e.arrayTypeChildren,a=e.newChildProps,i=e.nestedChildren;return re({},r,((t={})[n.type]=[].concat(r[n.type]||[],[re({},a,this.mapNestedChildrenToProps(n,i))]),t))},t.prototype.mapObjectTypeChildren=function(e){var t,n,r=e.child,a=e.newProps,i=e.newChildProps,o=e.nestedChildren;switch(r.type){case L.TITLE:return re({},a,((t={})[r.type]=o,t.titleAttributes=re({},i),t));case L.BODY:return re({},a,{bodyAttributes:re({},i)});case L.HTML:return re({},a,{htmlAttributes:re({},i)})}return re({},a,((n={})[r.type]=re({},i),n))},t.prototype.mapArrayTypeChildrenToProps=function(e,t){var n=re({},t);return Object.keys(e).forEach((function(t){var r;n=re({},n,((r={})[t]=e[t],r))})),n},t.prototype.warnOnInvalidChildren=function(e,t){return!0},t.prototype.mapChildrenToProps=function(e,t){var n=this,r={};return i.Children.forEach(e,(function(e){if(e&&e.props){var a=e.props,i=a.children,o=function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return Object.keys(e).reduce((function(t,n){return t[G[n]||n]=e[n],t}),t)}(ae(a,["children"]));switch(n.warnOnInvalidChildren(e,i),e.type){case L.LINK:case L.META:case L.NOSCRIPT:case L.SCRIPT:case L.STYLE:r=n.flattenArrayTypeChildren({child:e,arrayTypeChildren:r,newChildProps:o,nestedChildren:i});break;default:t=n.mapObjectTypeChildren({child:e,newProps:t,newChildProps:o,nestedChildren:i})}}})),t=this.mapArrayTypeChildrenToProps(r,t)},t.prototype.render=function(){var e=this.props,t=e.children,n=ae(e,["children"]),r=re({},n);return t&&(r=this.mapChildrenToProps(t,r)),i.createElement(E,r)},ne(t,null,[{key:"canUseDOM",set:function(e){E.canUseDOM=e}}]),t}(i.Component),k.propTypes={base:m().object,bodyAttributes:m().object,children:m().oneOfType([m().arrayOf(m().node),m().node]),defaultTitle:m().string,defer:m().bool,encodeSpecialCharacters:m().bool,htmlAttributes:m().object,link:m().arrayOf(m().object),meta:m().arrayOf(m().object),noscript:m().arrayOf(m().object),onChangeClientState:m().func,script:m().arrayOf(m().object),style:m().arrayOf(m().object),title:m().string,titleAttributes:m().object,titleTemplate:m().string},k.defaultProps={defer:!0,encodeSpecialCharacters:!0},k.peek=E.peek,k.rewind=function(){var e=E.rewind();return e||(e=Te({baseTag:[],bodyAttributes:{},encodeSpecialCharacters:!0,htmlAttributes:{},linkTags:[],metaTags:[],noscriptTags:[],scriptTags:[],styleTags:[],title:"",titleAttributes:{}})),e},x);_e.renderStatic=_e.rewind;var Ne=e=>{const t=(0,a.useStaticQuery)("1995548873"),{metadata:n}=t.site,r={...n,...e};return i.createElement(_e,null,i.createElement("title",null,r.title),i.createElement("meta",{name:"description",content:r.description}),r.image&&i.createElement("meta",{name:"image",content:r.image}),r.url&&i.createElement("meta",{property:"og:url",content:r.url}),i.createElement("meta",{property:"og:type",content:"website"}),i.createElement("meta",{property:"og:title",content:r.title}),i.createElement("meta",{property:"og:description",content:r.description}),r.image&&i.createElement("meta",{property:"og:image",content:r.image}),i.createElement("meta",{name:"twitter:card",content:"summary_large_image"}),i.createElement("meta",{name:"twitter:creator",content:"@zigurous"}),i.createElement("meta",{name:"twitter:title",content:r.title}),i.createElement("meta",{name:"twitter:description",content:r.description}),r.image&&i.createElement("meta",{name:"twitter:image",content:r.image}))};var Ae=e=>{let{children:t,className:n,dockLinks:a,hideDock:o=!1,hideHeader:s=!1,id:c,location:d,metadata:m,title:p}=e;const[h,f,g]=(0,r.DP)("light");return i.createElement("div",{className:"app","data-theme":h},i.createElement(Ne,m),!s&&i.createElement(C,{location:d,pageTitle:p}),i.createElement("main",{className:u()("page",n),id:c},t),!o&&i.createElement(l,{theme:h,toggleTheme:g,secondaryLinks:a}))};m().shape({buttons:m().arrayOf(m().shape({name:m().string.isRequired,url:m().string.isRequired,icon:m().string.isRequired})),category:m().string.isRequired,date:m().string,description:m().string,description_short:m().string,description_long:m().arrayOf(m().string),id:m().string.isRequired,image:h.isRequired,role:m().string,sections:m().arrayOf(m().shape({title:m().string,link:m().string,mainImage:h,mainImageLink:m().string,mainVideo:m().string,paragraphs:m().arrayOf(m().string),gallery:m().arrayOf(h),videos:m().arrayOf(m().string)})),tech:m().arrayOf(m().string),title:m().string.isRequired});var Pe=e=>{let{className:t,project:n}=e;return i.createElement("article",{className:u()("project","container-md",t)},i.createElement("section",null,i.createElement("h1",{className:"display-4 project__title"},n.title),i.createElement("div",{className:"project__subtitle"},n.date,i.createElement("span",{className:"separator"},"|"),n.role),n.tech&&i.createElement("div",{className:"project__badges"},n.tech.map((e=>i.createElement(r.Ex,{pill:!0,key:e},e)))),i.createElement("div",{className:"project__description"},n.description&&i.createElement("p",{className:"opacity-90p"},n.description),n.description_long&&n.description_long.map((e=>i.createElement("p",{className:"opacity-90p",key:e},e))))),n.sections&&n.sections.map(((e,t)=>i.createElement("section",{key:`section-${t}`},e.title&&i.createElement("h2",{className:"subtitle font-xl"},e.link?i.createElement(r.N_,{external:!0,href:e.link},i.createElement("b",null,e.title)):i.createElement("b",null,e.title)),e.mainImage&&(e.mainImageLink?i.createElement(r.N_,{external:!0,to:e.mainImageLink,unstyled:!0},i.createElement(r.vb,{alt:`${n.title} Screenshot`,width:e.mainImage.sharp.original.width,height:e.mainImage.sharp.original.height,src:e.mainImage.sharp.original.src})):i.createElement(r.vb,{alt:`${n.title} Screenshot`,width:e.mainImage.sharp.original.width,height:e.mainImage.sharp.original.height,src:e.mainImage.sharp.original.src})),e.mainVideo&&i.createElement(r.QN,{origin:"https://adamgraham.github.io",videoId:e.mainVideo}),e.paragraphs&&e.paragraphs.map(((e,n)=>i.createElement("p",{className:"font-sm",key:`section-${t}-paragraph-${n}`},e))),e.gallery&&i.createElement(r.i_,{images:e.gallery.map((e=>({width:e.sharp.original.width,height:e.sharp.original.height,src:e.sharp.original.src}))),minWidth:132}),e.videos&&e.videos.map((e=>i.createElement(r.QN,{className:"margin-bottom-lg",key:e,origin:"https://adamgraham.github.io",videoId:e})))))))}},1053:function(e,t,n){"use strict";n.d(t,{Jm:function(){return i},M:function(){return a},R1:function(){return o},lj:function(){return s},wW:function(){return r}});const r="https://adamgraham.github.io",a="https://github.com/adamgraham",i=[{key:"games",name:"Games",to:"/games"},{key:"websites",name:"Websites",to:"/websites"},{key:"art",name:"Interactive Art",to:"/art"},{key:"tech",name:"Tech Showcases",to:"/tech"},{key:"presentations",name:"Presentations",to:"/presentations"}],o=[{key:"home",name:"Home",icon:"home",to:"/"},{key:"gallery",name:"Gallery",icon:"collections",to:"/games"},{key:"projects",name:"Projects",icon:"menu",to:"/projects"}],s=[{key:"github",name:"GitHub",url:a},{key:"linkedIn",name:"LinkedIn",url:"https://www.linkedin.com/in/adamzigurous"},{key:"resume",name:"Resume",icon:"description",url:"https://docs.google.com/document/d/1qLHBV7Ry11O-pd0XC3HvALBIKJ8YDBmSafP0Z5c4dww/edit?usp=drive_link"},{key:"email",name:"Email",icon:"mail",url:"mailto:adam@zigurous.com"}]},5624:function(){Prism.languages.clike={comment:[{pattern:/(^|[^\\])\/\*[\s\S]*?(?:\*\/|$)/,lookbehind:!0,greedy:!0},{pattern:/(^|[^\\:])\/\/.*/,lookbehind:!0,greedy:!0}],string:{pattern:/(["'])(?:\\(?:\r\n|[\s\S])|(?!\1)[^\\\r\n])*\1/,greedy:!0},"class-name":{pattern:/(\b(?:class|extends|implements|instanceof|interface|new|trait)\s+|\bcatch\s+\()[\w.\\]+/i,lookbehind:!0,inside:{punctuation:/[.\\]/}},keyword:/\b(?:break|catch|continue|do|else|finally|for|function|if|in|instanceof|new|null|return|throw|try|while)\b/,boolean:/\b(?:false|true)\b/,function:/\b\w+(?=\()/,number:/\b0x[\da-f]+\b|(?:\b\d+(?:\.\d*)?|\B\.\d+)(?:e[+-]?\d+)?/i,operator:/[<>]=?|[!=]=?=?|--?|\+\+?|&&?|\|\|?|[?*/~^%]/,punctuation:/[{}[\];(),.:]/}},5651:function(){!function(e){function t(e,t){return e.replace(/<<(\d+)>>/g,(function(e,n){return"(?:"+t[+n]+")"}))}function n(e,n,r){return RegExp(t(e,n),r||"")}function r(e,t){for(var n=0;n>/g,(function(){return"(?:"+e+")"}));return e.replace(/<>/g,"[^\\s\\S]")}var a="bool byte char decimal double dynamic float int long object sbyte short string uint ulong ushort var void",i="class enum interface record struct",o="add alias and ascending async await by descending from(?=\\s*(?:\\w|$)) get global group into init(?=\\s*;) join let nameof not notnull on or orderby partial remove select set unmanaged value when where with(?=\\s*{)",s="abstract as base break case catch checked const continue default delegate do else event explicit extern finally fixed for foreach goto if implicit in internal is lock namespace new null operator out override params private protected public readonly ref return sealed sizeof stackalloc static switch this throw try typeof unchecked unsafe using virtual volatile while yield";function l(e){return"\\b(?:"+e.trim().replace(/ /g,"|")+")\\b"}var c=l(i),u=RegExp(l(a+" "+i+" "+o+" "+s)),d=l(i+" "+o+" "+s),m=l(a+" "+i+" "+s),p=r(/<(?:[^<>;=+\-*/%&|^]|<>)*>/.source,2),h=r(/\((?:[^()]|<>)*\)/.source,2),f=/@?\b[A-Za-z_]\w*\b/.source,g=t(/<<0>>(?:\s*<<1>>)?/.source,[f,p]),v=t(/(?!<<0>>)<<1>>(?:\s*\.\s*<<1>>)*/.source,[d,g]),y=/\[\s*(?:,\s*)*\]/.source,b=t(/<<0>>(?:\s*(?:\?\s*)?<<1>>)*(?:\s*\?)?/.source,[v,y]),w=t(/[^,()<>[\];=+\-*/%&|^]|<<0>>|<<1>>|<<2>>/.source,[p,h,y]),E=t(/\(<<0>>+(?:,<<0>>+)+\)/.source,[w]),k=t(/(?:<<0>>|<<1>>)(?:\s*(?:\?\s*)?<<2>>)*(?:\s*\?)?/.source,[E,v,y]),x={keyword:u,punctuation:/[<>()?,.:[\]]/},C=/'(?:[^\r\n'\\]|\\.|\\[Uux][\da-fA-F]{1,8})'/.source,O=/"(?:\\.|[^\\"\r\n])*"/.source,T=/@"(?:""|\\[\s\S]|[^\\"])*"(?!")/.source;e.languages.csharp=e.languages.extend("clike",{string:[{pattern:n(/(^|[^$\\])<<0>>/.source,[T]),lookbehind:!0,greedy:!0},{pattern:n(/(^|[^@$\\])<<0>>/.source,[O]),lookbehind:!0,greedy:!0}],"class-name":[{pattern:n(/(\busing\s+static\s+)<<0>>(?=\s*;)/.source,[v]),lookbehind:!0,inside:x},{pattern:n(/(\busing\s+<<0>>\s*=\s*)<<1>>(?=\s*;)/.source,[f,k]),lookbehind:!0,inside:x},{pattern:n(/(\busing\s+)<<0>>(?=\s*=)/.source,[f]),lookbehind:!0},{pattern:n(/(\b<<0>>\s+)<<1>>/.source,[c,g]),lookbehind:!0,inside:x},{pattern:n(/(\bcatch\s*\(\s*)<<0>>/.source,[v]),lookbehind:!0,inside:x},{pattern:n(/(\bwhere\s+)<<0>>/.source,[f]),lookbehind:!0},{pattern:n(/(\b(?:is(?:\s+not)?|as)\s+)<<0>>/.source,[b]),lookbehind:!0,inside:x},{pattern:n(/\b<<0>>(?=\s+(?!<<1>>|with\s*\{)<<2>>(?:\s*[=,;:{)\]]|\s+(?:in|when)\b))/.source,[k,m,f]),inside:x}],keyword:u,number:/(?:\b0(?:x[\da-f_]*[\da-f]|b[01_]*[01])|(?:\B\.\d+(?:_+\d+)*|\b\d+(?:_+\d+)*(?:\.\d+(?:_+\d+)*)?)(?:e[-+]?\d+(?:_+\d+)*)?)(?:[dflmu]|lu|ul)?\b/i,operator:/>>=?|<<=?|[-=]>|([-+&|])\1|~|\?\?=?|[-+*/%&|^!=<>]=?/,punctuation:/\?\.?|::|[{}[\];(),.:]/}),e.languages.insertBefore("csharp","number",{range:{pattern:/\.\./,alias:"operator"}}),e.languages.insertBefore("csharp","punctuation",{"named-parameter":{pattern:n(/([(,]\s*)<<0>>(?=\s*:)/.source,[f]),lookbehind:!0,alias:"punctuation"}}),e.languages.insertBefore("csharp","class-name",{namespace:{pattern:n(/(\b(?:namespace|using)\s+)<<0>>(?:\s*\.\s*<<0>>)*(?=\s*[;{])/.source,[f]),lookbehind:!0,inside:{punctuation:/\./}},"type-expression":{pattern:n(/(\b(?:default|sizeof|typeof)\s*\(\s*(?!\s))(?:[^()\s]|\s(?!\s)|<<0>>)*(?=\s*\))/.source,[h]),lookbehind:!0,alias:"class-name",inside:x},"return-type":{pattern:n(/<<0>>(?=\s+(?:<<1>>\s*(?:=>|[({]|\.\s*this\s*\[)|this\s*\[))/.source,[k,v]),inside:x,alias:"class-name"},"constructor-invocation":{pattern:n(/(\bnew\s+)<<0>>(?=\s*[[({])/.source,[k]),lookbehind:!0,inside:x,alias:"class-name"},"generic-method":{pattern:n(/<<0>>\s*<<1>>(?=\s*\()/.source,[f,p]),inside:{function:n(/^<<0>>/.source,[f]),generic:{pattern:RegExp(p),alias:"class-name",inside:x}}},"type-list":{pattern:n(/\b((?:<<0>>\s+<<1>>|record\s+<<1>>\s*<<5>>|where\s+<<2>>)\s*:\s*)(?:<<3>>|<<4>>|<<1>>\s*<<5>>|<<6>>)(?:\s*,\s*(?:<<3>>|<<4>>|<<6>>))*(?=\s*(?:where|[{;]|=>|$))/.source,[c,g,f,k,u.source,h,/\bnew\s*\(\s*\)/.source]),lookbehind:!0,inside:{"record-arguments":{pattern:n(/(^(?!new\s*\()<<0>>\s*)<<1>>/.source,[g,h]),lookbehind:!0,greedy:!0,inside:e.languages.csharp},keyword:u,"class-name":{pattern:RegExp(k),greedy:!0,inside:x},punctuation:/[,()]/}},preprocessor:{pattern:/(^[\t ]*)#.*/m,lookbehind:!0,alias:"property",inside:{directive:{pattern:/(#)\b(?:define|elif|else|endif|endregion|error|if|line|nullable|pragma|region|undef|warning)\b/,lookbehind:!0,alias:"keyword"}}}});var S=O+"|"+C,_=t(/\/(?![*/])|\/\/[^\r\n]*[\r\n]|\/\*(?:[^*]|\*(?!\/))*\*\/|<<0>>/.source,[S]),N=r(t(/[^"'/()]|<<0>>|\(<>*\)/.source,[_]),2),A=/\b(?:assembly|event|field|method|module|param|property|return|type)\b/.source,P=t(/<<0>>(?:\s*\(<<1>>*\))?/.source,[v,N]);e.languages.insertBefore("csharp","class-name",{attribute:{pattern:n(/((?:^|[^\s\w>)?])\s*\[\s*)(?:<<0>>\s*:\s*)?<<1>>(?:\s*,\s*<<1>>)*(?=\s*\])/.source,[A,P]),lookbehind:!0,greedy:!0,inside:{target:{pattern:n(/^<<0>>(?=\s*:)/.source,[A]),alias:"keyword"},"attribute-arguments":{pattern:n(/\(<<0>>*\)/.source,[N]),inside:e.languages.csharp},"class-name":{pattern:RegExp(v),inside:{punctuation:/\./}},punctuation:/[:,]/}}});var M=/:[^}\r\n]+/.source,F=r(t(/[^"'/()]|<<0>>|\(<>*\)/.source,[_]),2),L=t(/\{(?!\{)(?:(?![}:])<<0>>)*<<1>>?\}/.source,[F,M]),j=r(t(/[^"'/()]|\/(?!\*)|\/\*(?:[^*]|\*(?!\/))*\*\/|<<0>>|\(<>*\)/.source,[S]),2),z=t(/\{(?!\{)(?:(?![}:])<<0>>)*<<1>>?\}/.source,[j,M]);function I(t,r){return{interpolation:{pattern:n(/((?:^|[^{])(?:\{\{)*)<<0>>/.source,[t]),lookbehind:!0,inside:{"format-string":{pattern:n(/(^\{(?:(?![}:])<<0>>)*)<<1>>(?=\}$)/.source,[r,M]),lookbehind:!0,inside:{punctuation:/^:/}},punctuation:/^\{|\}$/,expression:{pattern:/[\s\S]+/,alias:"language-csharp",inside:e.languages.csharp}}},string:/[\s\S]+/}}e.languages.insertBefore("csharp","string",{"interpolation-string":[{pattern:n(/(^|[^\\])(?:\$@|@\$)"(?:""|\\[\s\S]|\{\{|<<0>>|[^\\{"])*"/.source,[L]),lookbehind:!0,greedy:!0,inside:I(L,F)},{pattern:n(/(^|[^@\\])\$"(?:\\.|\{\{|<<0>>|[^\\"{])*"/.source,[z]),lookbehind:!0,greedy:!0,inside:I(z,j)}],char:{pattern:RegExp(C),greedy:!0}}),e.languages.dotnet=e.languages.cs=e.languages.csharp}(Prism)},1113:function(){!function(e){var t=/(?:"(?:\\(?:\r\n|[\s\S])|[^"\\\r\n])*"|'(?:\\(?:\r\n|[\s\S])|[^'\\\r\n])*')/;e.languages.css={comment:/\/\*[\s\S]*?\*\//,atrule:{pattern:RegExp("@[\\w-](?:"+/[^;{\s"']|\s+(?!\s)/.source+"|"+t.source+")*?"+/(?:;|(?=\s*\{))/.source),inside:{rule:/^@[\w-]+/,"selector-function-argument":{pattern:/(\bselector\s*\(\s*(?![\s)]))(?:[^()\s]|\s+(?![\s)])|\((?:[^()]|\([^()]*\))*\))+(?=\s*\))/,lookbehind:!0,alias:"selector"},keyword:{pattern:/(^|[^\w-])(?:and|not|only|or)(?![\w-])/,lookbehind:!0}}},url:{pattern:RegExp("\\burl\\((?:"+t.source+"|"+/(?:[^\\\r\n()"']|\\[\s\S])*/.source+")\\)","i"),greedy:!0,inside:{function:/^url/i,punctuation:/^\(|\)$/,string:{pattern:RegExp("^"+t.source+"$"),alias:"url"}}},selector:{pattern:RegExp("(^|[{}\\s])[^{}\\s](?:[^{};\"'\\s]|\\s+(?![\\s{])|"+t.source+")*(?=\\s*\\{)"),lookbehind:!0},string:{pattern:t,greedy:!0},property:{pattern:/(^|[^-\w\xA0-\uFFFF])(?!\s)[-_a-z\xA0-\uFFFF](?:(?!\s)[-\w\xA0-\uFFFF])*(?=\s*:)/i,lookbehind:!0},important:/!important\b/i,function:{pattern:/(^|[^-a-z0-9])[-a-z0-9]+(?=\()/i,lookbehind:!0},punctuation:/[(){};:,]/},e.languages.css.atrule.inside.rest=e.languages.css;var n=e.languages.markup;n&&(n.tag.addInlined("style","css"),n.tag.addAttribute("style","css"))}(Prism)},5723:function(){Prism.languages.javascript=Prism.languages.extend("clike",{"class-name":[Prism.languages.clike["class-name"],{pattern:/(^|[^$\w\xA0-\uFFFF])(?!\s)[_$A-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\.(?:constructor|prototype))/,lookbehind:!0}],keyword:[{pattern:/((?:^|\})\s*)catch\b/,lookbehind:!0},{pattern:/(^|[^.]|\.\.\.\s*)\b(?:as|assert(?=\s*\{)|async(?=\s*(?:function\b|\(|[$\w\xA0-\uFFFF]|$))|await|break|case|class|const|continue|debugger|default|delete|do|else|enum|export|extends|finally(?=\s*(?:\{|$))|for|from(?=\s*(?:['"]|$))|function|(?:get|set)(?=\s*(?:[#\[$\w\xA0-\uFFFF]|$))|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|static|super|switch|this|throw|try|typeof|undefined|var|void|while|with|yield)\b/,lookbehind:!0}],function:/#?(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*(?:\.\s*(?:apply|bind|call)\s*)?\()/,number:{pattern:RegExp(/(^|[^\w$])/.source+"(?:"+/NaN|Infinity/.source+"|"+/0[bB][01]+(?:_[01]+)*n?/.source+"|"+/0[oO][0-7]+(?:_[0-7]+)*n?/.source+"|"+/0[xX][\dA-Fa-f]+(?:_[\dA-Fa-f]+)*n?/.source+"|"+/\d+(?:_\d+)*n/.source+"|"+/(?:\d+(?:_\d+)*(?:\.(?:\d+(?:_\d+)*)?)?|\.\d+(?:_\d+)*)(?:[Ee][+-]?\d+(?:_\d+)*)?/.source+")"+/(?![\w$])/.source),lookbehind:!0},operator:/--|\+\+|\*\*=?|=>|&&=?|\|\|=?|[!=]==|<<=?|>>>?=?|[-+*/%&|^!=<>]=?|\.{3}|\?\?=?|\?\.?|[~:]/}),Prism.languages.javascript["class-name"][0].pattern=/(\b(?:class|extends|implements|instanceof|interface|new)\s+)[\w.\\]+/,Prism.languages.insertBefore("javascript","keyword",{regex:{pattern:RegExp(/((?:^|[^$\w\xA0-\uFFFF."'\])\s]|\b(?:return|yield))\s*)/.source+/\//.source+"(?:"+/(?:\[(?:[^\]\\\r\n]|\\.)*\]|\\.|[^/\\\[\r\n])+\/[dgimyus]{0,7}/.source+"|"+/(?:\[(?:[^[\]\\\r\n]|\\.|\[(?:[^[\]\\\r\n]|\\.|\[(?:[^[\]\\\r\n]|\\.)*\])*\])*\]|\\.|[^/\\\[\r\n])+\/[dgimyus]{0,7}v[dgimyus]{0,7}/.source+")"+/(?=(?:\s|\/\*(?:[^*]|\*(?!\/))*\*\/)*(?:$|[\r\n,.;:})\]]|\/\/))/.source),lookbehind:!0,greedy:!0,inside:{"regex-source":{pattern:/^(\/)[\s\S]+(?=\/[a-z]*$)/,lookbehind:!0,alias:"language-regex",inside:Prism.languages.regex},"regex-delimiter":/^\/|\/$/,"regex-flags":/^[a-z]+$/}},"function-variable":{pattern:/#?(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*[=:]\s*(?:async\s*)?(?:\bfunction\b|(?:\((?:[^()]|\([^()]*\))*\)|(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*)\s*=>))/,alias:"function"},parameter:[{pattern:/(function(?:\s+(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*)?\s*\(\s*)(?!\s)(?:[^()\s]|\s+(?![\s)])|\([^()]*\))+(?=\s*\))/,lookbehind:!0,inside:Prism.languages.javascript},{pattern:/(^|[^$\w\xA0-\uFFFF])(?!\s)[_$a-z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*=>)/i,lookbehind:!0,inside:Prism.languages.javascript},{pattern:/(\(\s*)(?!\s)(?:[^()\s]|\s+(?![\s)])|\([^()]*\))+(?=\s*\)\s*=>)/,lookbehind:!0,inside:Prism.languages.javascript},{pattern:/((?:\b|\s|^)(?!(?:as|async|await|break|case|catch|class|const|continue|debugger|default|delete|do|else|enum|export|extends|finally|for|from|function|get|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|set|static|super|switch|this|throw|try|typeof|undefined|var|void|while|with|yield)(?![$\w\xA0-\uFFFF]))(?:(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*\s*)\(\s*|\]\s*\(\s*)(?!\s)(?:[^()\s]|\s+(?![\s)])|\([^()]*\))+(?=\s*\)\s*\{)/,lookbehind:!0,inside:Prism.languages.javascript}],constant:/\b[A-Z](?:[A-Z_]|\dx?)*\b/}),Prism.languages.insertBefore("javascript","string",{hashbang:{pattern:/^#!.*/,greedy:!0,alias:"comment"},"template-string":{pattern:/`(?:\\[\s\S]|\$\{(?:[^{}]|\{(?:[^{}]|\{[^}]*\})*\})+\}|(?!\$\{)[^\\`])*`/,greedy:!0,inside:{"template-punctuation":{pattern:/^`|`$/,alias:"string"},interpolation:{pattern:/((?:^|[^\\])(?:\\{2})*)\$\{(?:[^{}]|\{(?:[^{}]|\{[^}]*\})*\})+\}/,lookbehind:!0,inside:{"interpolation-punctuation":{pattern:/^\$\{|\}$/,alias:"punctuation"},rest:Prism.languages.javascript}},string:/[\s\S]+/}},"string-property":{pattern:/((?:^|[,{])[ \t]*)(["'])(?:\\(?:\r\n|[\s\S])|(?!\2)[^\\\r\n])*\2(?=\s*:)/m,lookbehind:!0,greedy:!0,alias:"property"}}),Prism.languages.insertBefore("javascript","operator",{"literal-property":{pattern:/((?:^|[,{])[ \t]*)(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*:)/m,lookbehind:!0,alias:"property"}}),Prism.languages.markup&&(Prism.languages.markup.tag.addInlined("script","javascript"),Prism.languages.markup.tag.addAttribute(/on(?:abort|blur|change|click|composition(?:end|start|update)|dblclick|error|focus(?:in|out)?|key(?:down|up)|load|mouse(?:down|enter|leave|move|out|over|up)|reset|resize|scroll|select|slotchange|submit|unload|wheel)/.source,"javascript")),Prism.languages.js=Prism.languages.javascript},4312:function(){Prism.languages.markup={comment:{pattern://,greedy:!0},prolog:{pattern:/<\?[\s\S]+?\?>/,greedy:!0},doctype:{pattern:/"'[\]]|"[^"]*"|'[^']*')+(?:\[(?:[^<"'\]]|"[^"]*"|'[^']*'|<(?!!--)|)*\]\s*)?>/i,greedy:!0,inside:{"internal-subset":{pattern:/(^[^\[]*\[)[\s\S]+(?=\]>$)/,lookbehind:!0,greedy:!0,inside:null},string:{pattern:/"[^"]*"|'[^']*'/,greedy:!0},punctuation:/^$|[[\]]/,"doctype-tag":/^DOCTYPE/i,name:/[^\s<>'"]+/}},cdata:{pattern://i,greedy:!0},tag:{pattern:/<\/?(?!\d)[^\s>\/=$<%]+(?:\s(?:\s*[^\s>\/=]+(?:\s*=\s*(?:"[^"]*"|'[^']*'|[^\s'">=]+(?=[\s>]))|(?=[\s/>])))+)?\s*\/?>/,greedy:!0,inside:{tag:{pattern:/^<\/?[^\s>\/]+/,inside:{punctuation:/^<\/?/,namespace:/^[^\s>\/:]+:/}},"special-attr":[],"attr-value":{pattern:/=\s*(?:"[^"]*"|'[^']*'|[^\s'">=]+)/,inside:{punctuation:[{pattern:/^=/,alias:"attr-equals"},{pattern:/^(\s*)["']|["']$/,lookbehind:!0}]}},punctuation:/\/?>/,"attr-name":{pattern:/[^\s>\/]+/,inside:{namespace:/^[^\s>\/:]+:/}}}},entity:[{pattern:/&[\da-z]{1,8};/i,alias:"named-entity"},/&#x?[\da-f]{1,8};/i]},Prism.languages.markup.tag.inside["attr-value"].inside.entity=Prism.languages.markup.entity,Prism.languages.markup.doctype.inside["internal-subset"].inside=Prism.languages.markup,Prism.hooks.add("wrap",(function(e){"entity"===e.type&&(e.attributes.title=e.content.replace(/&/,"&"))})),Object.defineProperty(Prism.languages.markup.tag,"addInlined",{value:function(e,t){var n={};n["language-"+t]={pattern:/(^$)/i,lookbehind:!0,inside:Prism.languages[t]},n.cdata=/^$/i;var r={"included-cdata":{pattern://i,inside:n}};r["language-"+t]={pattern:/[\s\S]+/,inside:Prism.languages[t]};var a={};a[e]={pattern:RegExp(/(<__[^>]*>)(?:))*\]\]>|(?!)/.source.replace(/__/g,(function(){return e})),"i"),lookbehind:!0,greedy:!0,inside:r},Prism.languages.insertBefore("markup","cdata",a)}}),Object.defineProperty(Prism.languages.markup.tag,"addAttribute",{value:function(e,t){Prism.languages.markup.tag.inside["special-attr"].push({pattern:RegExp(/(^|["'\s])/.source+"(?:"+e+")"+/\s*=\s*(?:"[^"]*"|'[^']*'|[^\s'">=]+(?=[\s>]))/.source,"i"),lookbehind:!0,inside:{"attr-name":/^[^\s=]+/,"attr-value":{pattern:/=[\s\S]+/,inside:{value:{pattern:/(^=\s*(["']|(?!["'])))\S[\s\S]*(?=\2$)/,lookbehind:!0,alias:[t,"language-"+t],inside:Prism.languages[t]},punctuation:[{pattern:/^=/,alias:"attr-equals"},/"|'/]}}}})}}),Prism.languages.html=Prism.languages.markup,Prism.languages.mathml=Prism.languages.markup,Prism.languages.svg=Prism.languages.markup,Prism.languages.xml=Prism.languages.extend("markup",{}),Prism.languages.ssml=Prism.languages.xml,Prism.languages.atom=Prism.languages.xml,Prism.languages.rss=Prism.languages.xml},8848:function(e,t,n){var r=function(e){var t=/(?:^|\s)lang(?:uage)?-([\w-]+)(?=\s|$)/i,n=0,r={},a={manual:e.Prism&&e.Prism.manual,disableWorkerMessageHandler:e.Prism&&e.Prism.disableWorkerMessageHandler,util:{encode:function e(t){return t instanceof i?new i(t.type,e(t.content),t.alias):Array.isArray(t)?t.map(e):t.replace(/&/g,"&").replace(/=d.reach);x+=k.value.length,k=k.next){var C=k.value;if(t.length>e.length)return;if(!(C instanceof i)){var O,T=1;if(y){if(!(O=o(E,x,e,v))||O.index>=e.length)break;var S=O.index,_=O.index+O[0].length,N=x;for(N+=k.value.length;S>=N;)N+=(k=k.next).value.length;if(x=N-=k.value.length,k.value instanceof i)continue;for(var A=k;A!==t.tail&&(N<_||"string"==typeof A.value);A=A.next)T++,N+=A.value.length;T--,C=e.slice(x,N),O.index-=x}else if(!(O=o(E,0,C,v)))continue;S=O.index;var P=O[0],M=C.slice(0,S),F=C.slice(S+P.length),L=x+C.length;d&&L>d.reach&&(d.reach=L);var j=k.prev;if(M&&(j=c(t,j,M),x+=M.length),u(t,j,T),k=c(t,j,new i(m,g?a.tokenize(P,g):P,b,P)),F&&c(t,k,F),T>1){var z={cause:m+","+h,reach:L};s(e,t,n,k.prev,x,z),d&&z.reach>d.reach&&(d.reach=z.reach)}}}}}}function l(){var e={value:null,prev:null,next:null},t={value:null,prev:e,next:null};e.next=t,this.head=e,this.tail=t,this.length=0}function c(e,t,n){var r=t.next,a={value:n,prev:t,next:r};return t.next=a,r.prev=a,e.length++,a}function u(e,t,n){for(var r=t.next,a=0;a"+i.content+""},!e.document)return e.addEventListener?(a.disableWorkerMessageHandler||e.addEventListener("message",(function(t){var n=JSON.parse(t.data),r=n.language,i=n.code,o=n.immediateClose;e.postMessage(a.highlight(i,a.languages[r],r)),o&&e.close()}),!1),a):a;var d=a.util.currentScript();function m(){a.manual||a.highlightAll()}if(d&&(a.filename=d.src,d.hasAttribute("data-manual")&&(a.manual=!0)),!a.manual){var p=document.readyState;"loading"===p||"interactive"===p&&d&&d.defer?document.addEventListener("DOMContentLoaded",m):window.requestAnimationFrame?window.requestAnimationFrame(m):window.setTimeout(m,16)}return a}("undefined"!=typeof window?window:"undefined"!=typeof WorkerGlobalScope&&self instanceof WorkerGlobalScope?self:{});e.exports&&(e.exports=r),void 0!==n.g&&(n.g.Prism=r),r.languages.markup={comment:{pattern://,greedy:!0},prolog:{pattern:/<\?[\s\S]+?\?>/,greedy:!0},doctype:{pattern:/"'[\]]|"[^"]*"|'[^']*')+(?:\[(?:[^<"'\]]|"[^"]*"|'[^']*'|<(?!!--)|)*\]\s*)?>/i,greedy:!0,inside:{"internal-subset":{pattern:/(^[^\[]*\[)[\s\S]+(?=\]>$)/,lookbehind:!0,greedy:!0,inside:null},string:{pattern:/"[^"]*"|'[^']*'/,greedy:!0},punctuation:/^$|[[\]]/,"doctype-tag":/^DOCTYPE/i,name:/[^\s<>'"]+/}},cdata:{pattern://i,greedy:!0},tag:{pattern:/<\/?(?!\d)[^\s>\/=$<%]+(?:\s(?:\s*[^\s>\/=]+(?:\s*=\s*(?:"[^"]*"|'[^']*'|[^\s'">=]+(?=[\s>]))|(?=[\s/>])))+)?\s*\/?>/,greedy:!0,inside:{tag:{pattern:/^<\/?[^\s>\/]+/,inside:{punctuation:/^<\/?/,namespace:/^[^\s>\/:]+:/}},"special-attr":[],"attr-value":{pattern:/=\s*(?:"[^"]*"|'[^']*'|[^\s'">=]+)/,inside:{punctuation:[{pattern:/^=/,alias:"attr-equals"},{pattern:/^(\s*)["']|["']$/,lookbehind:!0}]}},punctuation:/\/?>/,"attr-name":{pattern:/[^\s>\/]+/,inside:{namespace:/^[^\s>\/:]+:/}}}},entity:[{pattern:/&[\da-z]{1,8};/i,alias:"named-entity"},/&#x?[\da-f]{1,8};/i]},r.languages.markup.tag.inside["attr-value"].inside.entity=r.languages.markup.entity,r.languages.markup.doctype.inside["internal-subset"].inside=r.languages.markup,r.hooks.add("wrap",(function(e){"entity"===e.type&&(e.attributes.title=e.content.replace(/&/,"&"))})),Object.defineProperty(r.languages.markup.tag,"addInlined",{value:function(e,t){var n={};n["language-"+t]={pattern:/(^$)/i,lookbehind:!0,inside:r.languages[t]},n.cdata=/^$/i;var a={"included-cdata":{pattern://i,inside:n}};a["language-"+t]={pattern:/[\s\S]+/,inside:r.languages[t]};var i={};i[e]={pattern:RegExp(/(<__[^>]*>)(?:))*\]\]>|(?!)/.source.replace(/__/g,(function(){return e})),"i"),lookbehind:!0,greedy:!0,inside:a},r.languages.insertBefore("markup","cdata",i)}}),Object.defineProperty(r.languages.markup.tag,"addAttribute",{value:function(e,t){r.languages.markup.tag.inside["special-attr"].push({pattern:RegExp(/(^|["'\s])/.source+"(?:"+e+")"+/\s*=\s*(?:"[^"]*"|'[^']*'|[^\s'">=]+(?=[\s>]))/.source,"i"),lookbehind:!0,inside:{"attr-name":/^[^\s=]+/,"attr-value":{pattern:/=[\s\S]+/,inside:{value:{pattern:/(^=\s*(["']|(?!["'])))\S[\s\S]*(?=\2$)/,lookbehind:!0,alias:[t,"language-"+t],inside:r.languages[t]},punctuation:[{pattern:/^=/,alias:"attr-equals"},/"|'/]}}}})}}),r.languages.html=r.languages.markup,r.languages.mathml=r.languages.markup,r.languages.svg=r.languages.markup,r.languages.xml=r.languages.extend("markup",{}),r.languages.ssml=r.languages.xml,r.languages.atom=r.languages.xml,r.languages.rss=r.languages.xml,function(e){var t=/(?:"(?:\\(?:\r\n|[\s\S])|[^"\\\r\n])*"|'(?:\\(?:\r\n|[\s\S])|[^'\\\r\n])*')/;e.languages.css={comment:/\/\*[\s\S]*?\*\//,atrule:{pattern:RegExp("@[\\w-](?:"+/[^;{\s"']|\s+(?!\s)/.source+"|"+t.source+")*?"+/(?:;|(?=\s*\{))/.source),inside:{rule:/^@[\w-]+/,"selector-function-argument":{pattern:/(\bselector\s*\(\s*(?![\s)]))(?:[^()\s]|\s+(?![\s)])|\((?:[^()]|\([^()]*\))*\))+(?=\s*\))/,lookbehind:!0,alias:"selector"},keyword:{pattern:/(^|[^\w-])(?:and|not|only|or)(?![\w-])/,lookbehind:!0}}},url:{pattern:RegExp("\\burl\\((?:"+t.source+"|"+/(?:[^\\\r\n()"']|\\[\s\S])*/.source+")\\)","i"),greedy:!0,inside:{function:/^url/i,punctuation:/^\(|\)$/,string:{pattern:RegExp("^"+t.source+"$"),alias:"url"}}},selector:{pattern:RegExp("(^|[{}\\s])[^{}\\s](?:[^{};\"'\\s]|\\s+(?![\\s{])|"+t.source+")*(?=\\s*\\{)"),lookbehind:!0},string:{pattern:t,greedy:!0},property:{pattern:/(^|[^-\w\xA0-\uFFFF])(?!\s)[-_a-z\xA0-\uFFFF](?:(?!\s)[-\w\xA0-\uFFFF])*(?=\s*:)/i,lookbehind:!0},important:/!important\b/i,function:{pattern:/(^|[^-a-z0-9])[-a-z0-9]+(?=\()/i,lookbehind:!0},punctuation:/[(){};:,]/},e.languages.css.atrule.inside.rest=e.languages.css;var n=e.languages.markup;n&&(n.tag.addInlined("style","css"),n.tag.addAttribute("style","css"))}(r),r.languages.clike={comment:[{pattern:/(^|[^\\])\/\*[\s\S]*?(?:\*\/|$)/,lookbehind:!0,greedy:!0},{pattern:/(^|[^\\:])\/\/.*/,lookbehind:!0,greedy:!0}],string:{pattern:/(["'])(?:\\(?:\r\n|[\s\S])|(?!\1)[^\\\r\n])*\1/,greedy:!0},"class-name":{pattern:/(\b(?:class|extends|implements|instanceof|interface|new|trait)\s+|\bcatch\s+\()[\w.\\]+/i,lookbehind:!0,inside:{punctuation:/[.\\]/}},keyword:/\b(?:break|catch|continue|do|else|finally|for|function|if|in|instanceof|new|null|return|throw|try|while)\b/,boolean:/\b(?:false|true)\b/,function:/\b\w+(?=\()/,number:/\b0x[\da-f]+\b|(?:\b\d+(?:\.\d*)?|\B\.\d+)(?:e[+-]?\d+)?/i,operator:/[<>]=?|[!=]=?=?|--?|\+\+?|&&?|\|\|?|[?*/~^%]/,punctuation:/[{}[\];(),.:]/},r.languages.javascript=r.languages.extend("clike",{"class-name":[r.languages.clike["class-name"],{pattern:/(^|[^$\w\xA0-\uFFFF])(?!\s)[_$A-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\.(?:constructor|prototype))/,lookbehind:!0}],keyword:[{pattern:/((?:^|\})\s*)catch\b/,lookbehind:!0},{pattern:/(^|[^.]|\.\.\.\s*)\b(?:as|assert(?=\s*\{)|async(?=\s*(?:function\b|\(|[$\w\xA0-\uFFFF]|$))|await|break|case|class|const|continue|debugger|default|delete|do|else|enum|export|extends|finally(?=\s*(?:\{|$))|for|from(?=\s*(?:['"]|$))|function|(?:get|set)(?=\s*(?:[#\[$\w\xA0-\uFFFF]|$))|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|static|super|switch|this|throw|try|typeof|undefined|var|void|while|with|yield)\b/,lookbehind:!0}],function:/#?(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*(?:\.\s*(?:apply|bind|call)\s*)?\()/,number:{pattern:RegExp(/(^|[^\w$])/.source+"(?:"+/NaN|Infinity/.source+"|"+/0[bB][01]+(?:_[01]+)*n?/.source+"|"+/0[oO][0-7]+(?:_[0-7]+)*n?/.source+"|"+/0[xX][\dA-Fa-f]+(?:_[\dA-Fa-f]+)*n?/.source+"|"+/\d+(?:_\d+)*n/.source+"|"+/(?:\d+(?:_\d+)*(?:\.(?:\d+(?:_\d+)*)?)?|\.\d+(?:_\d+)*)(?:[Ee][+-]?\d+(?:_\d+)*)?/.source+")"+/(?![\w$])/.source),lookbehind:!0},operator:/--|\+\+|\*\*=?|=>|&&=?|\|\|=?|[!=]==|<<=?|>>>?=?|[-+*/%&|^!=<>]=?|\.{3}|\?\?=?|\?\.?|[~:]/}),r.languages.javascript["class-name"][0].pattern=/(\b(?:class|extends|implements|instanceof|interface|new)\s+)[\w.\\]+/,r.languages.insertBefore("javascript","keyword",{regex:{pattern:RegExp(/((?:^|[^$\w\xA0-\uFFFF."'\])\s]|\b(?:return|yield))\s*)/.source+/\//.source+"(?:"+/(?:\[(?:[^\]\\\r\n]|\\.)*\]|\\.|[^/\\\[\r\n])+\/[dgimyus]{0,7}/.source+"|"+/(?:\[(?:[^[\]\\\r\n]|\\.|\[(?:[^[\]\\\r\n]|\\.|\[(?:[^[\]\\\r\n]|\\.)*\])*\])*\]|\\.|[^/\\\[\r\n])+\/[dgimyus]{0,7}v[dgimyus]{0,7}/.source+")"+/(?=(?:\s|\/\*(?:[^*]|\*(?!\/))*\*\/)*(?:$|[\r\n,.;:})\]]|\/\/))/.source),lookbehind:!0,greedy:!0,inside:{"regex-source":{pattern:/^(\/)[\s\S]+(?=\/[a-z]*$)/,lookbehind:!0,alias:"language-regex",inside:r.languages.regex},"regex-delimiter":/^\/|\/$/,"regex-flags":/^[a-z]+$/}},"function-variable":{pattern:/#?(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*[=:]\s*(?:async\s*)?(?:\bfunction\b|(?:\((?:[^()]|\([^()]*\))*\)|(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*)\s*=>))/,alias:"function"},parameter:[{pattern:/(function(?:\s+(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*)?\s*\(\s*)(?!\s)(?:[^()\s]|\s+(?![\s)])|\([^()]*\))+(?=\s*\))/,lookbehind:!0,inside:r.languages.javascript},{pattern:/(^|[^$\w\xA0-\uFFFF])(?!\s)[_$a-z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*=>)/i,lookbehind:!0,inside:r.languages.javascript},{pattern:/(\(\s*)(?!\s)(?:[^()\s]|\s+(?![\s)])|\([^()]*\))+(?=\s*\)\s*=>)/,lookbehind:!0,inside:r.languages.javascript},{pattern:/((?:\b|\s|^)(?!(?:as|async|await|break|case|catch|class|const|continue|debugger|default|delete|do|else|enum|export|extends|finally|for|from|function|get|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|set|static|super|switch|this|throw|try|typeof|undefined|var|void|while|with|yield)(?![$\w\xA0-\uFFFF]))(?:(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*\s*)\(\s*|\]\s*\(\s*)(?!\s)(?:[^()\s]|\s+(?![\s)])|\([^()]*\))+(?=\s*\)\s*\{)/,lookbehind:!0,inside:r.languages.javascript}],constant:/\b[A-Z](?:[A-Z_]|\dx?)*\b/}),r.languages.insertBefore("javascript","string",{hashbang:{pattern:/^#!.*/,greedy:!0,alias:"comment"},"template-string":{pattern:/`(?:\\[\s\S]|\$\{(?:[^{}]|\{(?:[^{}]|\{[^}]*\})*\})+\}|(?!\$\{)[^\\`])*`/,greedy:!0,inside:{"template-punctuation":{pattern:/^`|`$/,alias:"string"},interpolation:{pattern:/((?:^|[^\\])(?:\\{2})*)\$\{(?:[^{}]|\{(?:[^{}]|\{[^}]*\})*\})+\}/,lookbehind:!0,inside:{"interpolation-punctuation":{pattern:/^\$\{|\}$/,alias:"punctuation"},rest:r.languages.javascript}},string:/[\s\S]+/}},"string-property":{pattern:/((?:^|[,{])[ \t]*)(["'])(?:\\(?:\r\n|[\s\S])|(?!\2)[^\\\r\n])*\2(?=\s*:)/m,lookbehind:!0,greedy:!0,alias:"property"}}),r.languages.insertBefore("javascript","operator",{"literal-property":{pattern:/((?:^|[,{])[ \t]*)(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*:)/m,lookbehind:!0,alias:"property"}}),r.languages.markup&&(r.languages.markup.tag.addInlined("script","javascript"),r.languages.markup.tag.addAttribute(/on(?:abort|blur|change|click|composition(?:end|start|update)|dblclick|error|focus(?:in|out)?|key(?:down|up)|load|mouse(?:down|enter|leave|move|out|over|up)|reset|resize|scroll|select|slotchange|submit|unload|wheel)/.source,"javascript")),r.languages.js=r.languages.javascript,function(){if(void 0!==r&&"undefined"!=typeof document){Element.prototype.matches||(Element.prototype.matches=Element.prototype.msMatchesSelector||Element.prototype.webkitMatchesSelector);var e={js:"javascript",py:"python",rb:"ruby",ps1:"powershell",psm1:"powershell",sh:"bash",bat:"batch",h:"c",tex:"latex"},t="data-src-status",n="loading",a="loaded",i="pre[data-src]:not(["+t+'="'+a+'"]):not(['+t+'="'+n+'"])';r.hooks.add("before-highlightall",(function(e){e.selector+=", "+i})),r.hooks.add("before-sanity-check",(function(o){var s=o.element;if(s.matches(i)){o.code="",s.setAttribute(t,n);var l=s.appendChild(document.createElement("CODE"));l.textContent="Loading…";var c=s.getAttribute("data-src"),u=o.language;if("none"===u){var d=(/\.(\w+)$/.exec(c)||[,"none"])[1];u=e[d]||d}r.util.setLanguage(l,u),r.util.setLanguage(s,u);var m=r.plugins.autoloader;m&&m.loadLanguages(u),function(e,t,n){var r=new XMLHttpRequest;r.open("GET",e,!0),r.onreadystatechange=function(){4==r.readyState&&(r.status<400&&r.responseText?t(r.responseText):r.status>=400?n("✖ Error "+r.status+" while fetching file: "+r.statusText):n("✖ Error: File does not exist or is empty"))},r.send(null)}(c,(function(e){s.setAttribute(t,a);var n=function(e){var t=/^\s*(\d+)\s*(?:(,)\s*(?:(\d+)\s*)?)?$/.exec(e||"");if(t){var n=Number(t[1]),r=t[2],a=t[3];return r?a?[n,Number(a)]:[n,void 0]:[n,n]}}(s.getAttribute("data-range"));if(n){var i=e.split(/\r\n?|\n/g),o=n[0],c=null==n[1]?i.length:n[1];o<0&&(o+=i.length),o=Math.max(0,Math.min(o-1,i.length)),c<0&&(c+=i.length),c=Math.max(0,Math.min(c,i.length)),e=i.slice(o,c).join("\n"),s.hasAttribute("data-start")||s.setAttribute("data-start",String(o+1))}l.textContent=e,r.highlightElement(l)}),(function(e){s.setAttribute(t,"failed"),l.textContent=e}))}})),r.plugins.fileHighlight={highlight:function(e){for(var t,n=(e||document).querySelectorAll(i),a=0;t=n[a++];)r.highlightElement(t)}};var o=!1;r.fileHighlight=function(){o||(console.warn("Prism.fileHighlight is deprecated. Use `Prism.plugins.fileHighlight.highlight` instead."),o=!0),r.plugins.fileHighlight.highlight.apply(this,arguments)}}}()},115:function(e){var t="undefined"!=typeof Element,n="function"==typeof Map,r="function"==typeof Set,a="function"==typeof ArrayBuffer&&!!ArrayBuffer.isView;function i(e,o){if(e===o)return!0;if(e&&o&&"object"==typeof e&&"object"==typeof o){if(e.constructor!==o.constructor)return!1;var s,l,c,u;if(Array.isArray(e)){if((s=e.length)!=o.length)return!1;for(l=s;0!=l--;)if(!i(e[l],o[l]))return!1;return!0}if(n&&e instanceof Map&&o instanceof Map){if(e.size!==o.size)return!1;for(u=e.entries();!(l=u.next()).done;)if(!o.has(l.value[0]))return!1;for(u=e.entries();!(l=u.next()).done;)if(!i(l.value[1],o.get(l.value[0])))return!1;return!0}if(r&&e instanceof Set&&o instanceof Set){if(e.size!==o.size)return!1;for(u=e.entries();!(l=u.next()).done;)if(!o.has(l.value[0]))return!1;return!0}if(a&&ArrayBuffer.isView(e)&&ArrayBuffer.isView(o)){if((s=e.length)!=o.length)return!1;for(l=s;0!=l--;)if(e[l]!==o[l])return!1;return!0}if(e.constructor===RegExp)return e.source===o.source&&e.flags===o.flags;if(e.valueOf!==Object.prototype.valueOf&&"function"==typeof e.valueOf&&"function"==typeof o.valueOf)return e.valueOf()===o.valueOf();if(e.toString!==Object.prototype.toString&&"function"==typeof e.toString&&"function"==typeof o.toString)return e.toString()===o.toString();if((s=(c=Object.keys(e)).length)!==Object.keys(o).length)return!1;for(l=s;0!=l--;)if(!Object.prototype.hasOwnProperty.call(o,c[l]))return!1;if(t&&e instanceof Element)return!1;for(l=s;0!=l--;)if(("_owner"!==c[l]&&"__v"!==c[l]&&"__o"!==c[l]||!e.$$typeof)&&!i(e[c[l]],o[c[l]]))return!1;return!0}return e!=e&&o!=o}e.exports=function(e,t){try{return i(e,t)}catch(n){if((n.message||"").match(/stack|recursion/i))return console.warn("react-fast-compare cannot handle circular refs"),!1;throw n}}},1720:function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.bodyOpenClassName=t.portalClassName=void 0;var r=Object.assign||function(e){for(var t=1;t0&&0===(y-=1)&&u.show(t),n.props.shouldFocusAfterRender&&(n.props.shouldReturnFocusAfterClose?(l.returnFocus(n.props.preventScroll),l.teardownScopedFocus()):l.popWithoutFocus()),n.props.onAfterClose&&n.props.onAfterClose(),h.default.deregister(n)},n.open=function(){n.beforeOpen(),n.state.afterOpen&&n.state.beforeClose?(clearTimeout(n.closeTimer),n.setState({beforeClose:!1})):(n.props.shouldFocusAfterRender&&(l.setupScopedFocus(n.node),l.markForFocusLater()),n.setState({isOpen:!0},(function(){n.openAnimationFrame=requestAnimationFrame((function(){n.setState({afterOpen:!0}),n.props.isOpen&&n.props.onAfterOpen&&n.props.onAfterOpen({overlayEl:n.overlay,contentEl:n.content})}))})))},n.close=function(){n.props.closeTimeoutMS>0?n.closeWithTimeout():n.closeWithoutTimeout()},n.focusContent=function(){return n.content&&!n.contentHasFocus()&&n.content.focus({preventScroll:!0})},n.closeWithTimeout=function(){var e=Date.now()+n.props.closeTimeoutMS;n.setState({beforeClose:!0,closesAt:e},(function(){n.closeTimer=setTimeout(n.closeWithoutTimeout,n.state.closesAt-Date.now())}))},n.closeWithoutTimeout=function(){n.setState({beforeClose:!1,isOpen:!1,afterOpen:!1,closesAt:null},n.afterClose)},n.handleKeyDown=function(e){(function(e){return"Tab"===e.code||9===e.keyCode})(e)&&(0,c.default)(n.content,e),n.props.shouldCloseOnEsc&&function(e){return"Escape"===e.code||27===e.keyCode}(e)&&(e.stopPropagation(),n.requestClose(e))},n.handleOverlayOnClick=function(e){null===n.shouldClose&&(n.shouldClose=!0),n.shouldClose&&n.props.shouldCloseOnOverlayClick&&(n.ownerHandlesClose()?n.requestClose(e):n.focusContent()),n.shouldClose=null},n.handleContentOnMouseUp=function(){n.shouldClose=!1},n.handleOverlayOnMouseDown=function(e){n.props.shouldCloseOnOverlayClick||e.target!=n.overlay||e.preventDefault()},n.handleContentOnClick=function(){n.shouldClose=!1},n.handleContentOnMouseDown=function(){n.shouldClose=!1},n.requestClose=function(e){return n.ownerHandlesClose()&&n.props.onRequestClose(e)},n.ownerHandlesClose=function(){return n.props.onRequestClose},n.shouldBeClosed=function(){return!n.state.isOpen&&!n.state.beforeClose},n.contentHasFocus=function(){return document.activeElement===n.content||n.content.contains(document.activeElement)},n.buildClassName=function(e,t){var r="object"===(void 0===t?"undefined":a(t))?t:{base:v[e],afterOpen:v[e]+"--after-open",beforeClose:v[e]+"--before-close"},i=r.base;return n.state.afterOpen&&(i=i+" "+r.afterOpen),n.state.beforeClose&&(i=i+" "+r.beforeClose),"string"==typeof t&&t?i+" "+t:i},n.attributesFromObject=function(e,t){return Object.keys(t).reduce((function(n,r){return n[e+"-"+r]=t[r],n}),{})},n.state={afterOpen:!1,beforeClose:!1},n.shouldClose=null,n.moveFromContentToOverlay=null,n}return function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}(t,e),i(t,[{key:"componentDidMount",value:function(){this.props.isOpen&&this.open()}},{key:"componentDidUpdate",value:function(e,t){this.props.isOpen&&!e.isOpen?this.open():!this.props.isOpen&&e.isOpen&&this.close(),this.props.shouldFocusAfterRender&&this.state.isOpen&&!t.isOpen&&this.focusContent()}},{key:"componentWillUnmount",value:function(){this.state.isOpen&&this.afterClose(),clearTimeout(this.closeTimer),cancelAnimationFrame(this.openAnimationFrame)}},{key:"beforeOpen",value:function(){var e=this.props,t=e.appElement,n=e.ariaHideApp,r=e.htmlOpenClassName,a=e.bodyOpenClassName,i=e.parentSelector,o=i&&i().ownerDocument||document;a&&d.add(o.body,a),r&&d.add(o.getElementsByTagName("html")[0],r),n&&(y+=1,u.hide(t)),h.default.register(this)}},{key:"render",value:function(){var e=this.props,t=e.id,n=e.className,a=e.overlayClassName,i=e.defaultStyles,o=e.children,s=n?{}:i.content,l=a?{}:i.overlay;if(this.shouldBeClosed())return null;var c={ref:this.setOverlayRef,className:this.buildClassName("overlay",a),style:r({},l,this.props.style.overlay),onClick:this.handleOverlayOnClick,onMouseDown:this.handleOverlayOnMouseDown},u=r({id:t,ref:this.setContentRef,style:r({},s,this.props.style.content),className:this.buildClassName("content",n),tabIndex:"-1",onKeyDown:this.handleKeyDown,onMouseDown:this.handleContentOnMouseDown,onMouseUp:this.handleContentOnMouseUp,onClick:this.handleContentOnClick,role:this.props.role,"aria-label":this.props.contentLabel},this.attributesFromObject("aria",r({modal:!0},this.props.aria)),this.attributesFromObject("data",this.props.data||{}),{"data-testid":this.props.testId}),d=this.props.contentElement(u,o);return this.props.overlayElement(c,d)}}]),t}(o.Component);b.defaultProps={style:{overlay:{},content:{}},defaultStyles:{}},b.propTypes={isOpen:s.default.bool.isRequired,defaultStyles:s.default.shape({content:s.default.object,overlay:s.default.object}),style:s.default.shape({content:s.default.object,overlay:s.default.object}),className:s.default.oneOfType([s.default.string,s.default.object]),overlayClassName:s.default.oneOfType([s.default.string,s.default.object]),parentSelector:s.default.func,bodyOpenClassName:s.default.string,htmlOpenClassName:s.default.string,ariaHideApp:s.default.bool,appElement:s.default.oneOfType([s.default.instanceOf(p.default),s.default.instanceOf(m.SafeHTMLCollection),s.default.instanceOf(m.SafeNodeList),s.default.arrayOf(s.default.instanceOf(p.default))]),onAfterOpen:s.default.func,onAfterClose:s.default.func,onRequestClose:s.default.func,closeTimeoutMS:s.default.number,shouldFocusAfterRender:s.default.bool,shouldCloseOnOverlayClick:s.default.bool,shouldReturnFocusAfterClose:s.default.bool,preventScroll:s.default.bool,role:s.default.string,contentLabel:s.default.string,aria:s.default.object,data:s.default.object,children:s.default.node,shouldCloseOnEsc:s.default.bool,overlayRef:s.default.func,contentRef:s.default.func,id:s.default.string,overlayElement:s.default.func,contentElement:s.default.func,testId:s.default.string},t.default=b,e.exports=t.default},6462:function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.resetState=function(){s&&(s.removeAttribute?s.removeAttribute("aria-hidden"):null!=s.length?s.forEach((function(e){return e.removeAttribute("aria-hidden")})):document.querySelectorAll(s).forEach((function(e){return e.removeAttribute("aria-hidden")})));s=null},t.log=function(){0},t.assertNodeList=l,t.setElement=function(e){var t=e;if("string"==typeof t&&o.canUseDOM){var n=document.querySelectorAll(t);l(n,t),t=n}return s=t||s},t.validateElement=c,t.hide=function(e){var t=!0,n=!1,r=void 0;try{for(var a,i=c(e)[Symbol.iterator]();!(t=(a=i.next()).done);t=!0){a.value.setAttribute("aria-hidden","true")}}catch(o){n=!0,r=o}finally{try{!t&&i.return&&i.return()}finally{if(n)throw r}}},t.show=function(e){var t=!0,n=!1,r=void 0;try{for(var a,i=c(e)[Symbol.iterator]();!(t=(a=i.next()).done);t=!0){a.value.removeAttribute("aria-hidden")}}catch(o){n=!0,r=o}finally{try{!t&&i.return&&i.return()}finally{if(n)throw r}}},t.documentNotReadyOrSSRTesting=function(){s=null};var r,a=n(9771),i=(r=a)&&r.__esModule?r:{default:r},o=n(834);var s=null;function l(e,t){if(!e||!e.length)throw new Error("react-modal: No elements were found for selector "+t+".")}function c(e){var t=e||s;return t?Array.isArray(t)||t instanceof HTMLCollection||t instanceof NodeList?t:[t]:((0,i.default)(!1,["react-modal: App element is not defined.","Please use `Modal.setAppElement(el)` or set `appElement={el}`.","This is needed so screen readers don't see main content","when modal is opened. It is not recommended, but you can opt-out","by setting `ariaHideApp={false}`."].join(" ")),[])}},7727:function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.resetState=function(){for(var e=[o,s],t=0;t0?(document.body.firstChild!==o&&document.body.insertBefore(o,document.body.firstChild),document.body.lastChild!==s&&document.body.appendChild(s)):(o.parentElement&&o.parentElement.removeChild(o),s.parentElement&&s.parentElement.removeChild(s))}))},4838:function(e,t){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.resetState=function(){var e=document.getElementsByTagName("html")[0];for(var t in n)a(e,n[t]);var i=document.body;for(var o in r)a(i,r[o]);n={},r={}},t.log=function(){0};var n={},r={};function a(e,t){e.classList.remove(t)}t.add=function(e,t){return a=e.classList,i="html"==e.nodeName.toLowerCase()?n:r,void t.split(" ").forEach((function(e){!function(e,t){e[t]||(e[t]=0),e[t]+=1}(i,e),a.add(e)}));var a,i},t.remove=function(e,t){return a=e.classList,i="html"==e.nodeName.toLowerCase()?n:r,void t.split(" ").forEach((function(e){!function(e,t){e[t]&&(e[t]-=1)}(i,e),0===i[e]&&a.remove(e)}));var a,i}},7791:function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.resetState=function(){o=[]},t.log=function(){0},t.handleBlur=c,t.handleFocus=u,t.markForFocusLater=function(){o.push(document.activeElement)},t.returnFocus=function(){var e=arguments.length>0&&void 0!==arguments[0]&&arguments[0],t=null;try{return void(0!==o.length&&(t=o.pop()).focus({preventScroll:e}))}catch(n){console.warn(["You tried to return focus to",t,"but it is not in the DOM anymore"].join(" "))}},t.popWithoutFocus=function(){o.length>0&&o.pop()},t.setupScopedFocus=function(e){s=e,window.addEventListener?(window.addEventListener("blur",c,!1),document.addEventListener("focus",u,!0)):(window.attachEvent("onBlur",c),document.attachEvent("onFocus",u))},t.teardownScopedFocus=function(){s=null,window.addEventListener?(window.removeEventListener("blur",c),document.removeEventListener("focus",u)):(window.detachEvent("onBlur",c),document.detachEvent("onFocus",u))};var r,a=n(2411),i=(r=a)&&r.__esModule?r:{default:r};var o=[],s=null,l=!1;function c(){l=!0}function u(){if(l){if(l=!1,!s)return;setTimeout((function(){s.contains(document.activeElement)||((0,i.default)(s)[0]||s).focus()}),0)}}},9628:function(e,t){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.log=function(){console.log("portalOpenInstances ----------"),console.log(r.openInstances.length),r.openInstances.forEach((function(e){return console.log(e)})),console.log("end portalOpenInstances ----------")},t.resetState=function(){r=new n};var n=function e(){var t=this;!function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,e),this.register=function(e){-1===t.openInstances.indexOf(e)&&(t.openInstances.push(e),t.emit("register"))},this.deregister=function(e){var n=t.openInstances.indexOf(e);-1!==n&&(t.openInstances.splice(n,1),t.emit("deregister"))},this.subscribe=function(e){t.subscribers.push(e)},this.emit=function(e){t.subscribers.forEach((function(n){return n(e,t.openInstances.slice())}))},this.openInstances=[],this.subscribers=[]},r=new n;t.default=r},834:function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.canUseDOM=t.SafeNodeList=t.SafeHTMLCollection=void 0;var r,a=n(411);var i=((r=a)&&r.__esModule?r:{default:r}).default,o=i.canUseDOM?window.HTMLElement:{};t.SafeHTMLCollection=i.canUseDOM?window.HTMLCollection:{},t.SafeNodeList=i.canUseDOM?window.NodeList:{},t.canUseDOM=i.canUseDOM;t.default=o},7067:function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default=function(e,t){var n=(0,i.default)(e);if(!n.length)return void t.preventDefault();var r=void 0,a=t.shiftKey,s=n[0],l=n[n.length-1],c=o();if(e===c){if(!a)return;r=l}l!==c||a||(r=s);s===c&&a&&(r=l);if(r)return t.preventDefault(),void r.focus();var u=/(\bChrome\b|\bSafari\b)\//.exec(navigator.userAgent);if(null==u||"Chrome"==u[1]||null!=/\biPod\b|\biPad\b/g.exec(navigator.userAgent))return;var d=n.indexOf(c);d>-1&&(d+=a?-1:1);if(void 0===(r=n[d]))return t.preventDefault(),void(r=a?l:s).focus();t.preventDefault(),r.focus()};var r,a=n(2411),i=(r=a)&&r.__esModule?r:{default:r};function o(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:document;return e.activeElement.shadowRoot?o(e.activeElement.shadowRoot):e.activeElement}e.exports=t.default},2411:function(e,t){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default=function e(t){var n=[].slice.call(t.querySelectorAll("*"),0).reduce((function(t,n){return t.concat(n.shadowRoot?e(n.shadowRoot):[n])}),[]);return n.filter(s)};var n="none",r="contents",a=/input|select|textarea|button|object|iframe/;function i(e){var t=e.offsetWidth<=0&&e.offsetHeight<=0;if(t&&!e.innerHTML)return!0;try{var a=window.getComputedStyle(e),i=a.getPropertyValue("display");return t?i!==r&&function(e,t){return"visible"!==t.getPropertyValue("overflow")||e.scrollWidth<=0&&e.scrollHeight<=0}(e,a):i===n}catch(o){return console.warn("Failed to inspect element style"),!1}}function o(e,t){var n=e.nodeName.toLowerCase();return(a.test(n)&&!e.disabled||"a"===n&&e.href||t)&&function(e){for(var t=e,n=e.getRootNode&&e.getRootNode();t&&t!==document.body;){if(n&&t===n&&(t=n.host.parentNode),i(t))return!1;t=t.parentNode}return!0}(e)}function s(e){var t=e.getAttribute("tabindex");null===t&&(t=void 0);var n=isNaN(t);return(n||t>=0)&&o(e,!n)}e.exports=t.default},312:function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var r,a=n(1720),i=(r=a)&&r.__esModule?r:{default:r};t.default=i.default,e.exports=t.default},2098:function(e,t,n){"use strict";var r,a=n(6540),i=(r=a)&&"object"==typeof r&&"default"in r?r.default:r;function o(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}var s=!("undefined"==typeof window||!window.document||!window.document.createElement);e.exports=function(e,t,n){if("function"!=typeof e)throw new Error("Expected reducePropsToState to be a function.");if("function"!=typeof t)throw new Error("Expected handleStateChangeOnClient to be a function.");if(void 0!==n&&"function"!=typeof n)throw new Error("Expected mapStateOnServer to either be undefined or a function.");return function(r){if("function"!=typeof r)throw new Error("Expected WrappedComponent to be a React component.");var l,c=[];function u(){l=e(c.map((function(e){return e.props}))),d.canUseDOM?t(l):n&&(l=n(l))}var d=function(e){var t,n;function a(){return e.apply(this,arguments)||this}n=e,(t=a).prototype=Object.create(n.prototype),t.prototype.constructor=t,t.__proto__=n,a.peek=function(){return l},a.rewind=function(){if(a.canUseDOM)throw new Error("You may only call rewind() on the server. Call peek() to read the current state.");var e=l;return l=void 0,c=[],e};var o=a.prototype;return o.UNSAFE_componentWillMount=function(){c.push(this),u()},o.componentDidUpdate=function(){u()},o.componentWillUnmount=function(){var e=c.indexOf(this);c.splice(e,1),u()},o.render=function(){return i.createElement(r,this.props)},a}(a.PureComponent);return o(d,"displayName","SideEffect("+function(e){return e.displayName||e.name||"Component"}(r)+")"),o(d,"canUseDOM",s),d}}},9771:function(e){"use strict";var t=function(){};e.exports=t},6942:function(e,t){var n;!function(){"use strict";var r={}.hasOwnProperty;function a(){for(var e="",t=0;t= 0) {\r\n this.changeListeners.splice(idx, 1);\r\n }\r\n };\r\n return Cookies;\r\n}());\r\nexport default Cookies;\r\n","import Cookies from 'universal-cookie';\r\nexport default Cookies;\r\n","import * as React from 'react';\r\nimport Cookies from './Cookies';\r\nvar CookiesContext = React.createContext(new Cookies());\r\nexport var Provider = CookiesContext.Provider, Consumer = CookiesContext.Consumer;\r\nexport default CookiesContext;\r\n","import React, { Component } from 'react';\nimport PropTypes from 'prop-types';\nimport Modal from 'react-modal';\n\nfunction ownKeys(object, enumerableOnly) {\n var keys = Object.keys(object);\n\n if (Object.getOwnPropertySymbols) {\n var symbols = Object.getOwnPropertySymbols(object);\n\n if (enumerableOnly) {\n symbols = symbols.filter(function (sym) {\n return Object.getOwnPropertyDescriptor(object, sym).enumerable;\n });\n }\n\n keys.push.apply(keys, symbols);\n }\n\n return keys;\n}\n\nfunction _objectSpread2(target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i] != null ? arguments[i] : {};\n\n if (i % 2) {\n ownKeys(Object(source), true).forEach(function (key) {\n _defineProperty(target, key, source[key]);\n });\n } else if (Object.getOwnPropertyDescriptors) {\n Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));\n } else {\n ownKeys(Object(source)).forEach(function (key) {\n Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));\n });\n }\n }\n\n return target;\n}\n\nfunction _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}\n\nfunction _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n}\n\nfunction _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n return Constructor;\n}\n\nfunction _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n}\n\nfunction _extends() {\n _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n };\n\n return _extends.apply(this, arguments);\n}\n\nfunction _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n writable: true,\n configurable: true\n }\n });\n if (superClass) _setPrototypeOf(subClass, superClass);\n}\n\nfunction _getPrototypeOf(o) {\n _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) {\n return o.__proto__ || Object.getPrototypeOf(o);\n };\n return _getPrototypeOf(o);\n}\n\nfunction _setPrototypeOf(o, p) {\n _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n };\n\n return _setPrototypeOf(o, p);\n}\n\nfunction _isNativeReflectConstruct() {\n if (typeof Reflect === \"undefined\" || !Reflect.construct) return false;\n if (Reflect.construct.sham) return false;\n if (typeof Proxy === \"function\") return true;\n\n try {\n Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {}));\n return true;\n } catch (e) {\n return false;\n }\n}\n\nfunction _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return self;\n}\n\nfunction _possibleConstructorReturn(self, call) {\n if (call && (typeof call === \"object\" || typeof call === \"function\")) {\n return call;\n }\n\n return _assertThisInitialized(self);\n}\n\nfunction _createSuper(Derived) {\n var hasNativeReflectConstruct = _isNativeReflectConstruct();\n\n return function _createSuperInternal() {\n var Super = _getPrototypeOf(Derived),\n result;\n\n if (hasNativeReflectConstruct) {\n var NewTarget = _getPrototypeOf(this).constructor;\n\n result = Reflect.construct(Super, arguments, NewTarget);\n } else {\n result = Super.apply(this, arguments);\n }\n\n return _possibleConstructorReturn(this, result);\n };\n}\n\nfunction _slicedToArray(arr, i) {\n return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest();\n}\n\nfunction _toConsumableArray(arr) {\n return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread();\n}\n\nfunction _arrayWithoutHoles(arr) {\n if (Array.isArray(arr)) return _arrayLikeToArray(arr);\n}\n\nfunction _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}\n\nfunction _iterableToArray(iter) {\n if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter);\n}\n\nfunction _iterableToArrayLimit(arr, i) {\n var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"];\n\n if (_i == null) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n\n var _s, _e;\n\n try {\n for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {\n _arr.push(_s.value);\n\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally {\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally {\n if (_d) throw _e;\n }\n }\n\n return _arr;\n}\n\nfunction _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return _arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);\n}\n\nfunction _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n\n for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];\n\n return arr2;\n}\n\nfunction _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\n\nfunction _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\n\n/**\n * Placeholder for future translate functionality\n */\nfunction translate(str) {\n var replaceStrings = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;\n\n if (!str) {\n return '';\n }\n\n var translated = str;\n\n if (replaceStrings) {\n Object.keys(replaceStrings).forEach(function (placeholder) {\n translated = translated.replace(placeholder, replaceStrings[placeholder]);\n });\n }\n\n return translated;\n}\nfunction getWindowWidth() {\n return typeof global.window !== 'undefined' ? global.window.innerWidth : 0;\n}\nfunction getWindowHeight() {\n return typeof global.window !== 'undefined' ? global.window.innerHeight : 0;\n}\n\nvar isCrossOriginFrame = function isCrossOriginFrame() {\n try {\n return global.window.location.hostname !== global.window.parent.location.hostname;\n } catch (e) {\n return true;\n }\n}; // Get the highest window context that isn't cross-origin\n// (When in an iframe)\n\n\nfunction getHighestSafeWindowContext() {\n var self = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : global.window.self;\n\n // If we reached the top level, return self\n if (self === global.window.top) {\n return self;\n } // If parent is the same origin, we can move up one context\n // Reference: https://stackoverflow.com/a/21965342/1601953\n\n\n if (!isCrossOriginFrame()) {\n return getHighestSafeWindowContext(self.parent);\n } // If a different origin, we consider the current level\n // as the top reachable one\n\n\n return self;\n}\n\n// Min image zoom level\nvar MIN_ZOOM_LEVEL = 0; // Max image zoom level\n\nvar MAX_ZOOM_LEVEL = 300; // Size ratio between previous and next zoom levels\n\nvar ZOOM_RATIO = 1.007; // How much to increase/decrease the zoom level when the zoom buttons are clicked\n\nvar ZOOM_BUTTON_INCREMENT_SIZE = 100; // Used to judge the amount of horizontal scroll needed to initiate a image move\n\nvar WHEEL_MOVE_X_THRESHOLD = 200; // Used to judge the amount of vertical scroll needed to initiate a zoom action\n\nvar WHEEL_MOVE_Y_THRESHOLD = 1;\nvar KEYS = {\n ESC: 27,\n LEFT_ARROW: 37,\n RIGHT_ARROW: 39\n}; // Actions\n\nvar ACTION_NONE = 0;\nvar ACTION_MOVE = 1;\nvar ACTION_SWIPE = 2;\nvar ACTION_PINCH = 3;\n\nvar SOURCE_ANY = 0;\nvar SOURCE_MOUSE = 1;\nvar SOURCE_TOUCH = 2;\nvar SOURCE_POINTER = 3; // Minimal swipe distance\n\nvar MIN_SWIPE_DISTANCE = 200;\n\nvar ReactImageLightbox = /*#__PURE__*/function (_Component) {\n _inherits(ReactImageLightbox, _Component);\n\n var _super = _createSuper(ReactImageLightbox);\n\n function ReactImageLightbox(props) {\n var _this;\n\n _classCallCheck(this, ReactImageLightbox);\n\n _this = _super.call(this, props);\n _this.state = {\n //-----------------------------\n // Animation\n //-----------------------------\n // Lightbox is closing\n // When Lightbox is mounted, if animation is enabled it will open with the reverse of the closing animation\n isClosing: !props.animationDisabled,\n // Component parts should animate (e.g., when images are moving, or image is being zoomed)\n shouldAnimate: false,\n //-----------------------------\n // Zoom settings\n //-----------------------------\n // Zoom level of image\n zoomLevel: MIN_ZOOM_LEVEL,\n //-----------------------------\n // Image position settings\n //-----------------------------\n // Horizontal offset from center\n offsetX: 0,\n // Vertical offset from center\n offsetY: 0,\n // image load error for srcType\n loadErrorStatus: {}\n }; // Refs\n\n _this.outerEl = /*#__PURE__*/React.createRef();\n _this.zoomInBtn = /*#__PURE__*/React.createRef();\n _this.zoomOutBtn = /*#__PURE__*/React.createRef();\n _this.caption = /*#__PURE__*/React.createRef();\n _this.closeIfClickInner = _this.closeIfClickInner.bind(_assertThisInitialized(_this));\n _this.handleImageDoubleClick = _this.handleImageDoubleClick.bind(_assertThisInitialized(_this));\n _this.handleImageMouseWheel = _this.handleImageMouseWheel.bind(_assertThisInitialized(_this));\n _this.handleKeyInput = _this.handleKeyInput.bind(_assertThisInitialized(_this));\n _this.handleMouseUp = _this.handleMouseUp.bind(_assertThisInitialized(_this));\n _this.handleMouseDown = _this.handleMouseDown.bind(_assertThisInitialized(_this));\n _this.handleMouseMove = _this.handleMouseMove.bind(_assertThisInitialized(_this));\n _this.handleOuterMousewheel = _this.handleOuterMousewheel.bind(_assertThisInitialized(_this));\n _this.handleTouchStart = _this.handleTouchStart.bind(_assertThisInitialized(_this));\n _this.handleTouchMove = _this.handleTouchMove.bind(_assertThisInitialized(_this));\n _this.handleTouchEnd = _this.handleTouchEnd.bind(_assertThisInitialized(_this));\n _this.handlePointerEvent = _this.handlePointerEvent.bind(_assertThisInitialized(_this));\n _this.handleCaptionMousewheel = _this.handleCaptionMousewheel.bind(_assertThisInitialized(_this));\n _this.handleWindowResize = _this.handleWindowResize.bind(_assertThisInitialized(_this));\n _this.handleZoomInButtonClick = _this.handleZoomInButtonClick.bind(_assertThisInitialized(_this));\n _this.handleZoomOutButtonClick = _this.handleZoomOutButtonClick.bind(_assertThisInitialized(_this));\n _this.requestClose = _this.requestClose.bind(_assertThisInitialized(_this));\n _this.requestMoveNext = _this.requestMoveNext.bind(_assertThisInitialized(_this));\n _this.requestMovePrev = _this.requestMovePrev.bind(_assertThisInitialized(_this)); // Timeouts - always clear it before umount\n\n _this.timeouts = []; // Current action\n\n _this.currentAction = ACTION_NONE; // Events source\n\n _this.eventsSource = SOURCE_ANY; // Empty pointers list\n\n _this.pointerList = []; // Prevent inner close\n\n _this.preventInnerClose = false;\n _this.preventInnerCloseTimeout = null; // Used to disable animation when changing props.mainSrc|nextSrc|prevSrc\n\n _this.keyPressed = false; // Used to store load state / dimensions of images\n\n _this.imageCache = {}; // Time the last keydown event was called (used in keyboard action rate limiting)\n\n _this.lastKeyDownTime = 0; // Used for debouncing window resize event\n\n _this.resizeTimeout = null; // Used to determine when actions are triggered by the scroll wheel\n\n _this.wheelActionTimeout = null;\n _this.resetScrollTimeout = null;\n _this.scrollX = 0;\n _this.scrollY = 0; // Used in panning zoomed images\n\n _this.moveStartX = 0;\n _this.moveStartY = 0;\n _this.moveStartOffsetX = 0;\n _this.moveStartOffsetY = 0; // Used to swipe\n\n _this.swipeStartX = 0;\n _this.swipeStartY = 0;\n _this.swipeEndX = 0;\n _this.swipeEndY = 0; // Used to pinch\n\n _this.pinchTouchList = null;\n _this.pinchDistance = 0; // Used to differentiate between images with identical src\n\n _this.keyCounter = 0; // Used to detect a move when all src's remain unchanged (four or more of the same image in a row)\n\n _this.moveRequested = false;\n return _this;\n }\n\n _createClass(ReactImageLightbox, [{\n key: \"componentDidMount\",\n value: function componentDidMount() {\n var _this2 = this;\n\n if (!this.props.animationDisabled) {\n // Make opening animation play\n this.setState({\n isClosing: false\n });\n } // Prevents cross-origin errors when using a cross-origin iframe\n\n\n this.windowContext = getHighestSafeWindowContext();\n this.listeners = {\n resize: this.handleWindowResize,\n mouseup: this.handleMouseUp,\n touchend: this.handleTouchEnd,\n touchcancel: this.handleTouchEnd,\n pointerdown: this.handlePointerEvent,\n pointermove: this.handlePointerEvent,\n pointerup: this.handlePointerEvent,\n pointercancel: this.handlePointerEvent\n };\n Object.keys(this.listeners).forEach(function (type) {\n _this2.windowContext.addEventListener(type, _this2.listeners[type]);\n });\n this.loadAllImages();\n }\n }, {\n key: \"shouldComponentUpdate\",\n value: function shouldComponentUpdate(nextProps) {\n var _this3 = this;\n\n this.getSrcTypes().forEach(function (srcType) {\n if (_this3.props[srcType.name] !== nextProps[srcType.name]) {\n _this3.moveRequested = false;\n }\n }); // Wait for move...\n\n return !this.moveRequested;\n }\n }, {\n key: \"componentDidUpdate\",\n value: function componentDidUpdate(prevProps) {\n var _this4 = this;\n\n var sourcesChanged = false;\n var prevSrcDict = {};\n var nextSrcDict = {};\n this.getSrcTypes().forEach(function (srcType) {\n if (prevProps[srcType.name] !== _this4.props[srcType.name]) {\n sourcesChanged = true;\n prevSrcDict[prevProps[srcType.name]] = true;\n nextSrcDict[_this4.props[srcType.name]] = true;\n }\n });\n\n if (sourcesChanged || this.moveRequested) {\n // Reset the loaded state for images not rendered next\n Object.keys(prevSrcDict).forEach(function (prevSrc) {\n if (!(prevSrc in nextSrcDict) && prevSrc in _this4.imageCache) {\n _this4.imageCache[prevSrc].loaded = false;\n }\n });\n this.moveRequested = false; // Load any new images\n\n this.loadAllImages(this.props);\n }\n }\n }, {\n key: \"componentWillUnmount\",\n value: function componentWillUnmount() {\n var _this5 = this;\n\n this.didUnmount = true;\n Object.keys(this.listeners).forEach(function (type) {\n _this5.windowContext.removeEventListener(type, _this5.listeners[type]);\n });\n this.timeouts.forEach(function (tid) {\n return clearTimeout(tid);\n });\n }\n }, {\n key: \"setTimeout\",\n value: function (_setTimeout) {\n function setTimeout(_x, _x2) {\n return _setTimeout.apply(this, arguments);\n }\n\n setTimeout.toString = function () {\n return _setTimeout.toString();\n };\n\n return setTimeout;\n }(function (func, time) {\n var _this6 = this;\n\n var id = setTimeout(function () {\n _this6.timeouts = _this6.timeouts.filter(function (tid) {\n return tid !== id;\n });\n func();\n }, time);\n this.timeouts.push(id);\n return id;\n })\n }, {\n key: \"setPreventInnerClose\",\n value: function setPreventInnerClose() {\n var _this7 = this;\n\n if (this.preventInnerCloseTimeout) {\n this.clearTimeout(this.preventInnerCloseTimeout);\n }\n\n this.preventInnerClose = true;\n this.preventInnerCloseTimeout = this.setTimeout(function () {\n _this7.preventInnerClose = false;\n _this7.preventInnerCloseTimeout = null;\n }, 100);\n } // Get info for the best suited image to display with the given srcType\n\n }, {\n key: \"getBestImageForType\",\n value: function getBestImageForType(srcType) {\n var imageSrc = this.props[srcType];\n var fitSizes = {};\n\n if (this.isImageLoaded(imageSrc)) {\n // Use full-size image if available\n fitSizes = this.getFitSizes(this.imageCache[imageSrc].width, this.imageCache[imageSrc].height);\n } else if (this.isImageLoaded(this.props[\"\".concat(srcType, \"Thumbnail\")])) {\n // Fall back to using thumbnail if the image has not been loaded\n imageSrc = this.props[\"\".concat(srcType, \"Thumbnail\")];\n fitSizes = this.getFitSizes(this.imageCache[imageSrc].width, this.imageCache[imageSrc].height, true);\n } else {\n return null;\n }\n\n return {\n src: imageSrc,\n height: this.imageCache[imageSrc].height,\n width: this.imageCache[imageSrc].width,\n targetHeight: fitSizes.height,\n targetWidth: fitSizes.width\n };\n } // Get sizing for when an image is larger than the window\n\n }, {\n key: \"getFitSizes\",\n value: function getFitSizes(width, height, stretch) {\n var boxSize = this.getLightboxRect();\n var maxHeight = boxSize.height - this.props.imagePadding * 2;\n var maxWidth = boxSize.width - this.props.imagePadding * 2;\n\n if (!stretch) {\n maxHeight = Math.min(maxHeight, height);\n maxWidth = Math.min(maxWidth, width);\n }\n\n var maxRatio = maxWidth / maxHeight;\n var srcRatio = width / height;\n\n if (maxRatio > srcRatio) {\n // height is the constraining dimension of the photo\n return {\n width: width * maxHeight / height,\n height: maxHeight\n };\n }\n\n return {\n width: maxWidth,\n height: height * maxWidth / width\n };\n }\n }, {\n key: \"getMaxOffsets\",\n value: function getMaxOffsets() {\n var zoomLevel = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.state.zoomLevel;\n var currentImageInfo = this.getBestImageForType('mainSrc');\n\n if (currentImageInfo === null) {\n return {\n maxX: 0,\n minX: 0,\n maxY: 0,\n minY: 0\n };\n }\n\n var boxSize = this.getLightboxRect();\n var zoomMultiplier = this.getZoomMultiplier(zoomLevel);\n var maxX = 0;\n\n if (zoomMultiplier * currentImageInfo.width - boxSize.width < 0) {\n // if there is still blank space in the X dimension, don't limit except to the opposite edge\n maxX = (boxSize.width - zoomMultiplier * currentImageInfo.width) / 2;\n } else {\n maxX = (zoomMultiplier * currentImageInfo.width - boxSize.width) / 2;\n }\n\n var maxY = 0;\n\n if (zoomMultiplier * currentImageInfo.height - boxSize.height < 0) {\n // if there is still blank space in the Y dimension, don't limit except to the opposite edge\n maxY = (boxSize.height - zoomMultiplier * currentImageInfo.height) / 2;\n } else {\n maxY = (zoomMultiplier * currentImageInfo.height - boxSize.height) / 2;\n }\n\n return {\n maxX: maxX,\n maxY: maxY,\n minX: -1 * maxX,\n minY: -1 * maxY\n };\n } // Get image src types\n\n }, {\n key: \"getSrcTypes\",\n value: function getSrcTypes() {\n return [{\n name: 'mainSrc',\n keyEnding: \"i\".concat(this.keyCounter)\n }, {\n name: 'mainSrcThumbnail',\n keyEnding: \"t\".concat(this.keyCounter)\n }, {\n name: 'nextSrc',\n keyEnding: \"i\".concat(this.keyCounter + 1)\n }, {\n name: 'nextSrcThumbnail',\n keyEnding: \"t\".concat(this.keyCounter + 1)\n }, {\n name: 'prevSrc',\n keyEnding: \"i\".concat(this.keyCounter - 1)\n }, {\n name: 'prevSrcThumbnail',\n keyEnding: \"t\".concat(this.keyCounter - 1)\n }];\n }\n /**\n * Get sizing when the image is scaled\n */\n\n }, {\n key: \"getZoomMultiplier\",\n value: function getZoomMultiplier() {\n var zoomLevel = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.state.zoomLevel;\n return Math.pow(ZOOM_RATIO, zoomLevel);\n }\n /**\n * Get the size of the lightbox in pixels\n */\n\n }, {\n key: \"getLightboxRect\",\n value: function getLightboxRect() {\n if (this.outerEl.current) {\n return this.outerEl.current.getBoundingClientRect();\n }\n\n return {\n width: getWindowWidth(),\n height: getWindowHeight(),\n top: 0,\n right: 0,\n bottom: 0,\n left: 0\n };\n }\n }, {\n key: \"clearTimeout\",\n value: function (_clearTimeout) {\n function clearTimeout(_x3) {\n return _clearTimeout.apply(this, arguments);\n }\n\n clearTimeout.toString = function () {\n return _clearTimeout.toString();\n };\n\n return clearTimeout;\n }(function (id) {\n this.timeouts = this.timeouts.filter(function (tid) {\n return tid !== id;\n });\n clearTimeout(id);\n } // Change zoom level\n )\n }, {\n key: \"changeZoom\",\n value: function changeZoom(zoomLevel, clientX, clientY) {\n // Ignore if zoom disabled\n if (!this.props.enableZoom) {\n return;\n } // Constrain zoom level to the set bounds\n\n\n var nextZoomLevel = Math.max(MIN_ZOOM_LEVEL, Math.min(MAX_ZOOM_LEVEL, zoomLevel)); // Ignore requests that don't change the zoom level\n\n if (nextZoomLevel === this.state.zoomLevel) {\n return;\n }\n\n if (nextZoomLevel === MIN_ZOOM_LEVEL) {\n // Snap back to center if zoomed all the way out\n this.setState({\n zoomLevel: nextZoomLevel,\n offsetX: 0,\n offsetY: 0\n });\n return;\n }\n\n var imageBaseSize = this.getBestImageForType('mainSrc');\n\n if (imageBaseSize === null) {\n return;\n }\n\n var currentZoomMultiplier = this.getZoomMultiplier();\n var nextZoomMultiplier = this.getZoomMultiplier(nextZoomLevel); // Default to the center of the image to zoom when no mouse position specified\n\n var boxRect = this.getLightboxRect();\n var pointerX = typeof clientX !== 'undefined' ? clientX - boxRect.left : boxRect.width / 2;\n var pointerY = typeof clientY !== 'undefined' ? clientY - boxRect.top : boxRect.height / 2;\n var currentImageOffsetX = (boxRect.width - imageBaseSize.width * currentZoomMultiplier) / 2;\n var currentImageOffsetY = (boxRect.height - imageBaseSize.height * currentZoomMultiplier) / 2;\n var currentImageRealOffsetX = currentImageOffsetX - this.state.offsetX;\n var currentImageRealOffsetY = currentImageOffsetY - this.state.offsetY;\n var currentPointerXRelativeToImage = (pointerX - currentImageRealOffsetX) / currentZoomMultiplier;\n var currentPointerYRelativeToImage = (pointerY - currentImageRealOffsetY) / currentZoomMultiplier;\n var nextImageRealOffsetX = pointerX - currentPointerXRelativeToImage * nextZoomMultiplier;\n var nextImageRealOffsetY = pointerY - currentPointerYRelativeToImage * nextZoomMultiplier;\n var nextImageOffsetX = (boxRect.width - imageBaseSize.width * nextZoomMultiplier) / 2;\n var nextImageOffsetY = (boxRect.height - imageBaseSize.height * nextZoomMultiplier) / 2;\n var nextOffsetX = nextImageOffsetX - nextImageRealOffsetX;\n var nextOffsetY = nextImageOffsetY - nextImageRealOffsetY; // When zooming out, limit the offset so things don't get left askew\n\n if (this.currentAction !== ACTION_PINCH) {\n var maxOffsets = this.getMaxOffsets();\n\n if (this.state.zoomLevel > nextZoomLevel) {\n nextOffsetX = Math.max(maxOffsets.minX, Math.min(maxOffsets.maxX, nextOffsetX));\n nextOffsetY = Math.max(maxOffsets.minY, Math.min(maxOffsets.maxY, nextOffsetY));\n }\n }\n\n this.setState({\n zoomLevel: nextZoomLevel,\n offsetX: nextOffsetX,\n offsetY: nextOffsetY\n });\n }\n }, {\n key: \"closeIfClickInner\",\n value: function closeIfClickInner(event) {\n if (!this.preventInnerClose && event.target.className.search(/\\bril-inner\\b/) > -1) {\n this.requestClose(event);\n }\n }\n /**\n * Handle user keyboard actions\n */\n\n }, {\n key: \"handleKeyInput\",\n value: function handleKeyInput(event) {\n event.stopPropagation(); // Ignore key input during animations\n\n if (this.isAnimating()) {\n return;\n } // Allow slightly faster navigation through the images when user presses keys repeatedly\n\n\n if (event.type === 'keyup') {\n this.lastKeyDownTime -= this.props.keyRepeatKeyupBonus;\n return;\n }\n\n var keyCode = event.which || event.keyCode; // Ignore key presses that happen too close to each other (when rapid fire key pressing or holding down the key)\n // But allow it if it's a lightbox closing action\n\n var currentTime = new Date();\n\n if (currentTime.getTime() - this.lastKeyDownTime < this.props.keyRepeatLimit && keyCode !== KEYS.ESC) {\n return;\n }\n\n this.lastKeyDownTime = currentTime.getTime();\n\n switch (keyCode) {\n // ESC key closes the lightbox\n case KEYS.ESC:\n event.preventDefault();\n this.requestClose(event);\n break;\n // Left arrow key moves to previous image\n\n case KEYS.LEFT_ARROW:\n if (!this.props.prevSrc) {\n return;\n }\n\n event.preventDefault();\n this.keyPressed = true;\n this.requestMovePrev(event);\n break;\n // Right arrow key moves to next image\n\n case KEYS.RIGHT_ARROW:\n if (!this.props.nextSrc) {\n return;\n }\n\n event.preventDefault();\n this.keyPressed = true;\n this.requestMoveNext(event);\n break;\n }\n }\n /**\n * Handle a mouse wheel event over the lightbox container\n */\n\n }, {\n key: \"handleOuterMousewheel\",\n value: function handleOuterMousewheel(event) {\n var _this8 = this;\n\n // Prevent scrolling of the background\n event.stopPropagation();\n var xThreshold = WHEEL_MOVE_X_THRESHOLD;\n var actionDelay = 0;\n var imageMoveDelay = 500;\n this.clearTimeout(this.resetScrollTimeout);\n this.resetScrollTimeout = this.setTimeout(function () {\n _this8.scrollX = 0;\n _this8.scrollY = 0;\n }, 300); // Prevent rapid-fire zoom behavior\n\n if (this.wheelActionTimeout !== null || this.isAnimating()) {\n return;\n }\n\n if (Math.abs(event.deltaY) < Math.abs(event.deltaX)) {\n // handle horizontal scrolls with image moves\n this.scrollY = 0;\n this.scrollX += event.deltaX;\n var bigLeapX = xThreshold / 2; // If the scroll amount has accumulated sufficiently, or a large leap was taken\n\n if (this.scrollX >= xThreshold || event.deltaX >= bigLeapX) {\n // Scroll right moves to next\n this.requestMoveNext(event);\n actionDelay = imageMoveDelay;\n this.scrollX = 0;\n } else if (this.scrollX <= -1 * xThreshold || event.deltaX <= -1 * bigLeapX) {\n // Scroll left moves to previous\n this.requestMovePrev(event);\n actionDelay = imageMoveDelay;\n this.scrollX = 0;\n }\n } // Allow successive actions after the set delay\n\n\n if (actionDelay !== 0) {\n this.wheelActionTimeout = this.setTimeout(function () {\n _this8.wheelActionTimeout = null;\n }, actionDelay);\n }\n }\n }, {\n key: \"handleImageMouseWheel\",\n value: function handleImageMouseWheel(event) {\n var yThreshold = WHEEL_MOVE_Y_THRESHOLD;\n\n if (Math.abs(event.deltaY) >= Math.abs(event.deltaX)) {\n event.stopPropagation(); // If the vertical scroll amount was large enough, perform a zoom\n\n if (Math.abs(event.deltaY) < yThreshold) {\n return;\n }\n\n this.scrollX = 0;\n this.scrollY += event.deltaY;\n this.changeZoom(this.state.zoomLevel - event.deltaY, event.clientX, event.clientY);\n }\n }\n /**\n * Handle a double click on the current image\n */\n\n }, {\n key: \"handleImageDoubleClick\",\n value: function handleImageDoubleClick(event) {\n if (this.state.zoomLevel > MIN_ZOOM_LEVEL) {\n // A double click when zoomed in zooms all the way out\n this.changeZoom(MIN_ZOOM_LEVEL, event.clientX, event.clientY);\n } else {\n // A double click when zoomed all the way out zooms in\n this.changeZoom(this.state.zoomLevel + ZOOM_BUTTON_INCREMENT_SIZE, event.clientX, event.clientY);\n }\n }\n }, {\n key: \"shouldHandleEvent\",\n value: function shouldHandleEvent(source) {\n if (this.eventsSource === source) {\n return true;\n }\n\n if (this.eventsSource === SOURCE_ANY) {\n this.eventsSource = source;\n return true;\n }\n\n switch (source) {\n case SOURCE_MOUSE:\n return false;\n\n case SOURCE_TOUCH:\n this.eventsSource = SOURCE_TOUCH;\n this.filterPointersBySource();\n return true;\n\n case SOURCE_POINTER:\n if (this.eventsSource === SOURCE_MOUSE) {\n this.eventsSource = SOURCE_POINTER;\n this.filterPointersBySource();\n return true;\n }\n\n return false;\n\n default:\n return false;\n }\n }\n }, {\n key: \"addPointer\",\n value: function addPointer(pointer) {\n this.pointerList.push(pointer);\n }\n }, {\n key: \"removePointer\",\n value: function removePointer(pointer) {\n this.pointerList = this.pointerList.filter(function (_ref) {\n var id = _ref.id;\n return id !== pointer.id;\n });\n }\n }, {\n key: \"filterPointersBySource\",\n value: function filterPointersBySource() {\n var _this9 = this;\n\n this.pointerList = this.pointerList.filter(function (_ref2) {\n var source = _ref2.source;\n return source === _this9.eventsSource;\n });\n }\n }, {\n key: \"handleMouseDown\",\n value: function handleMouseDown(event) {\n if (this.shouldHandleEvent(SOURCE_MOUSE) && ReactImageLightbox.isTargetMatchImage(event.target)) {\n this.addPointer(ReactImageLightbox.parseMouseEvent(event));\n this.multiPointerStart(event);\n }\n }\n }, {\n key: \"handleMouseMove\",\n value: function handleMouseMove(event) {\n if (this.shouldHandleEvent(SOURCE_MOUSE)) {\n this.multiPointerMove(event, [ReactImageLightbox.parseMouseEvent(event)]);\n }\n }\n }, {\n key: \"handleMouseUp\",\n value: function handleMouseUp(event) {\n if (this.shouldHandleEvent(SOURCE_MOUSE)) {\n this.removePointer(ReactImageLightbox.parseMouseEvent(event));\n this.multiPointerEnd(event);\n }\n }\n }, {\n key: \"handlePointerEvent\",\n value: function handlePointerEvent(event) {\n if (this.shouldHandleEvent(SOURCE_POINTER)) {\n switch (event.type) {\n case 'pointerdown':\n if (ReactImageLightbox.isTargetMatchImage(event.target)) {\n this.addPointer(ReactImageLightbox.parsePointerEvent(event));\n this.multiPointerStart(event);\n }\n\n break;\n\n case 'pointermove':\n this.multiPointerMove(event, [ReactImageLightbox.parsePointerEvent(event)]);\n break;\n\n case 'pointerup':\n case 'pointercancel':\n this.removePointer(ReactImageLightbox.parsePointerEvent(event));\n this.multiPointerEnd(event);\n break;\n }\n }\n }\n }, {\n key: \"handleTouchStart\",\n value: function handleTouchStart(event) {\n var _this10 = this;\n\n if (this.shouldHandleEvent(SOURCE_TOUCH) && ReactImageLightbox.isTargetMatchImage(event.target)) {\n [].forEach.call(event.changedTouches, function (eventTouch) {\n return _this10.addPointer(ReactImageLightbox.parseTouchPointer(eventTouch));\n });\n this.multiPointerStart(event);\n }\n }\n }, {\n key: \"handleTouchMove\",\n value: function handleTouchMove(event) {\n if (this.shouldHandleEvent(SOURCE_TOUCH)) {\n this.multiPointerMove(event, [].map.call(event.changedTouches, function (eventTouch) {\n return ReactImageLightbox.parseTouchPointer(eventTouch);\n }));\n }\n }\n }, {\n key: \"handleTouchEnd\",\n value: function handleTouchEnd(event) {\n var _this11 = this;\n\n if (this.shouldHandleEvent(SOURCE_TOUCH)) {\n [].map.call(event.changedTouches, function (touch) {\n return _this11.removePointer(ReactImageLightbox.parseTouchPointer(touch));\n });\n this.multiPointerEnd(event);\n }\n }\n }, {\n key: \"decideMoveOrSwipe\",\n value: function decideMoveOrSwipe(pointer) {\n if (this.state.zoomLevel <= MIN_ZOOM_LEVEL) {\n this.handleSwipeStart(pointer);\n } else {\n this.handleMoveStart(pointer);\n }\n }\n }, {\n key: \"multiPointerStart\",\n value: function multiPointerStart(event) {\n this.handleEnd(null);\n\n switch (this.pointerList.length) {\n case 1:\n {\n event.preventDefault();\n this.decideMoveOrSwipe(this.pointerList[0]);\n break;\n }\n\n case 2:\n {\n event.preventDefault();\n this.handlePinchStart(this.pointerList);\n break;\n }\n }\n }\n }, {\n key: \"multiPointerMove\",\n value: function multiPointerMove(event, pointerList) {\n switch (this.currentAction) {\n case ACTION_MOVE:\n {\n event.preventDefault();\n this.handleMove(pointerList[0]);\n break;\n }\n\n case ACTION_SWIPE:\n {\n event.preventDefault();\n this.handleSwipe(pointerList[0]);\n break;\n }\n\n case ACTION_PINCH:\n {\n event.preventDefault();\n this.handlePinch(pointerList);\n break;\n }\n }\n }\n }, {\n key: \"multiPointerEnd\",\n value: function multiPointerEnd(event) {\n if (this.currentAction !== ACTION_NONE) {\n this.setPreventInnerClose();\n this.handleEnd(event);\n }\n\n switch (this.pointerList.length) {\n case 0:\n {\n this.eventsSource = SOURCE_ANY;\n break;\n }\n\n case 1:\n {\n event.preventDefault();\n this.decideMoveOrSwipe(this.pointerList[0]);\n break;\n }\n\n case 2:\n {\n event.preventDefault();\n this.handlePinchStart(this.pointerList);\n break;\n }\n }\n }\n }, {\n key: \"handleEnd\",\n value: function handleEnd(event) {\n switch (this.currentAction) {\n case ACTION_MOVE:\n this.handleMoveEnd(event);\n break;\n\n case ACTION_SWIPE:\n this.handleSwipeEnd(event);\n break;\n\n case ACTION_PINCH:\n this.handlePinchEnd(event);\n break;\n }\n } // Handle move start over the lightbox container\n // This happens:\n // - On a mouseDown event\n // - On a touchstart event\n\n }, {\n key: \"handleMoveStart\",\n value: function handleMoveStart(_ref3) {\n var clientX = _ref3.x,\n clientY = _ref3.y;\n\n if (!this.props.enableZoom) {\n return;\n }\n\n this.currentAction = ACTION_MOVE;\n this.moveStartX = clientX;\n this.moveStartY = clientY;\n this.moveStartOffsetX = this.state.offsetX;\n this.moveStartOffsetY = this.state.offsetY;\n } // Handle dragging over the lightbox container\n // This happens:\n // - After a mouseDown and before a mouseUp event\n // - After a touchstart and before a touchend event\n\n }, {\n key: \"handleMove\",\n value: function handleMove(_ref4) {\n var clientX = _ref4.x,\n clientY = _ref4.y;\n var newOffsetX = this.moveStartX - clientX + this.moveStartOffsetX;\n var newOffsetY = this.moveStartY - clientY + this.moveStartOffsetY;\n\n if (this.state.offsetX !== newOffsetX || this.state.offsetY !== newOffsetY) {\n this.setState({\n offsetX: newOffsetX,\n offsetY: newOffsetY\n });\n }\n }\n }, {\n key: \"handleMoveEnd\",\n value: function handleMoveEnd() {\n var _this12 = this;\n\n this.currentAction = ACTION_NONE;\n this.moveStartX = 0;\n this.moveStartY = 0;\n this.moveStartOffsetX = 0;\n this.moveStartOffsetY = 0; // Snap image back into frame if outside max offset range\n\n var maxOffsets = this.getMaxOffsets();\n var nextOffsetX = Math.max(maxOffsets.minX, Math.min(maxOffsets.maxX, this.state.offsetX));\n var nextOffsetY = Math.max(maxOffsets.minY, Math.min(maxOffsets.maxY, this.state.offsetY));\n\n if (nextOffsetX !== this.state.offsetX || nextOffsetY !== this.state.offsetY) {\n this.setState({\n offsetX: nextOffsetX,\n offsetY: nextOffsetY,\n shouldAnimate: true\n });\n this.setTimeout(function () {\n _this12.setState({\n shouldAnimate: false\n });\n }, this.props.animationDuration);\n }\n }\n }, {\n key: \"handleSwipeStart\",\n value: function handleSwipeStart(_ref5) {\n var clientX = _ref5.x,\n clientY = _ref5.y;\n this.currentAction = ACTION_SWIPE;\n this.swipeStartX = clientX;\n this.swipeStartY = clientY;\n this.swipeEndX = clientX;\n this.swipeEndY = clientY;\n }\n }, {\n key: \"handleSwipe\",\n value: function handleSwipe(_ref6) {\n var clientX = _ref6.x,\n clientY = _ref6.y;\n this.swipeEndX = clientX;\n this.swipeEndY = clientY;\n }\n }, {\n key: \"handleSwipeEnd\",\n value: function handleSwipeEnd(event) {\n var xDiff = this.swipeEndX - this.swipeStartX;\n var xDiffAbs = Math.abs(xDiff);\n var yDiffAbs = Math.abs(this.swipeEndY - this.swipeStartY);\n this.currentAction = ACTION_NONE;\n this.swipeStartX = 0;\n this.swipeStartY = 0;\n this.swipeEndX = 0;\n this.swipeEndY = 0;\n\n if (!event || this.isAnimating() || xDiffAbs < yDiffAbs * 1.5) {\n return;\n }\n\n if (xDiffAbs < MIN_SWIPE_DISTANCE) {\n var boxRect = this.getLightboxRect();\n\n if (xDiffAbs < boxRect.width / 4) {\n return;\n }\n }\n\n if (xDiff > 0 && this.props.prevSrc) {\n event.preventDefault();\n this.requestMovePrev();\n } else if (xDiff < 0 && this.props.nextSrc) {\n event.preventDefault();\n this.requestMoveNext();\n }\n }\n }, {\n key: \"calculatePinchDistance\",\n value: function calculatePinchDistance() {\n var _ref7 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.pinchTouchList,\n _ref8 = _slicedToArray(_ref7, 2),\n a = _ref8[0],\n b = _ref8[1];\n\n return Math.sqrt(Math.pow(a.x - b.x, 2) + Math.pow(a.y - b.y, 2));\n }\n }, {\n key: \"calculatePinchCenter\",\n value: function calculatePinchCenter() {\n var _ref9 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.pinchTouchList,\n _ref10 = _slicedToArray(_ref9, 2),\n a = _ref10[0],\n b = _ref10[1];\n\n return {\n x: a.x - (a.x - b.x) / 2,\n y: a.y - (a.y - b.y) / 2\n };\n }\n }, {\n key: \"handlePinchStart\",\n value: function handlePinchStart(pointerList) {\n if (!this.props.enableZoom) {\n return;\n }\n\n this.currentAction = ACTION_PINCH;\n this.pinchTouchList = pointerList.map(function (_ref11) {\n var id = _ref11.id,\n x = _ref11.x,\n y = _ref11.y;\n return {\n id: id,\n x: x,\n y: y\n };\n });\n this.pinchDistance = this.calculatePinchDistance();\n }\n }, {\n key: \"handlePinch\",\n value: function handlePinch(pointerList) {\n this.pinchTouchList = this.pinchTouchList.map(function (oldPointer) {\n for (var i = 0; i < pointerList.length; i += 1) {\n if (pointerList[i].id === oldPointer.id) {\n return pointerList[i];\n }\n }\n\n return oldPointer;\n });\n var newDistance = this.calculatePinchDistance();\n var zoomLevel = this.state.zoomLevel + newDistance - this.pinchDistance;\n this.pinchDistance = newDistance;\n\n var _this$calculatePinchC = this.calculatePinchCenter(this.pinchTouchList),\n clientX = _this$calculatePinchC.x,\n clientY = _this$calculatePinchC.y;\n\n this.changeZoom(zoomLevel, clientX, clientY);\n }\n }, {\n key: \"handlePinchEnd\",\n value: function handlePinchEnd() {\n this.currentAction = ACTION_NONE;\n this.pinchTouchList = null;\n this.pinchDistance = 0;\n } // Handle the window resize event\n\n }, {\n key: \"handleWindowResize\",\n value: function handleWindowResize() {\n this.clearTimeout(this.resizeTimeout);\n this.resizeTimeout = this.setTimeout(this.forceUpdate.bind(this), 100);\n }\n }, {\n key: \"handleZoomInButtonClick\",\n value: function handleZoomInButtonClick() {\n var nextZoomLevel = this.state.zoomLevel + ZOOM_BUTTON_INCREMENT_SIZE;\n this.changeZoom(nextZoomLevel);\n\n if (nextZoomLevel === MAX_ZOOM_LEVEL) {\n this.zoomOutBtn.current.focus();\n }\n }\n }, {\n key: \"handleZoomOutButtonClick\",\n value: function handleZoomOutButtonClick() {\n var nextZoomLevel = this.state.zoomLevel - ZOOM_BUTTON_INCREMENT_SIZE;\n this.changeZoom(nextZoomLevel);\n\n if (nextZoomLevel === MIN_ZOOM_LEVEL) {\n this.zoomInBtn.current.focus();\n }\n }\n }, {\n key: \"handleCaptionMousewheel\",\n value: function handleCaptionMousewheel(event) {\n event.stopPropagation();\n\n if (!this.caption.current) {\n return;\n }\n\n var _this$caption$current = this.caption.current.getBoundingClientRect(),\n height = _this$caption$current.height;\n\n var _this$caption$current2 = this.caption.current,\n scrollHeight = _this$caption$current2.scrollHeight,\n scrollTop = _this$caption$current2.scrollTop;\n\n if (event.deltaY > 0 && height + scrollTop >= scrollHeight || event.deltaY < 0 && scrollTop <= 0) {\n event.preventDefault();\n }\n } // Detach key and mouse input events\n\n }, {\n key: \"isAnimating\",\n value: function isAnimating() {\n return this.state.shouldAnimate || this.state.isClosing;\n } // Check if image is loaded\n\n }, {\n key: \"isImageLoaded\",\n value: function isImageLoaded(imageSrc) {\n return imageSrc && imageSrc in this.imageCache && this.imageCache[imageSrc].loaded;\n } // Load image from src and call callback with image width and height on load\n\n }, {\n key: \"loadImage\",\n value: function loadImage(srcType, imageSrc, done) {\n var _this13 = this;\n\n // Return the image info if it is already cached\n if (this.isImageLoaded(imageSrc)) {\n this.setTimeout(function () {\n done();\n }, 1);\n return;\n }\n\n var inMemoryImage = new global.Image();\n\n if (this.props.imageCrossOrigin) {\n inMemoryImage.crossOrigin = this.props.imageCrossOrigin;\n }\n\n inMemoryImage.onerror = function (errorEvent) {\n _this13.props.onImageLoadError(imageSrc, srcType, errorEvent); // failed to load so set the state loadErrorStatus\n\n\n _this13.setState(function (prevState) {\n return {\n loadErrorStatus: _objectSpread2(_objectSpread2({}, prevState.loadErrorStatus), {}, _defineProperty({}, srcType, true))\n };\n });\n\n done(errorEvent);\n };\n\n inMemoryImage.onload = function () {\n _this13.props.onImageLoad(imageSrc, srcType, inMemoryImage);\n\n _this13.imageCache[imageSrc] = {\n loaded: true,\n width: inMemoryImage.width,\n height: inMemoryImage.height\n };\n done();\n };\n\n inMemoryImage.src = imageSrc;\n } // Load all images and their thumbnails\n\n }, {\n key: \"loadAllImages\",\n value: function loadAllImages() {\n var _this14 = this;\n\n var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.props;\n\n var generateLoadDoneCallback = function generateLoadDoneCallback(srcType, imageSrc) {\n return function (err) {\n // Give up showing image on error\n if (err) {\n return;\n } // Don't rerender if the src is not the same as when the load started\n // or if the component has unmounted\n\n\n if (_this14.props[srcType] !== imageSrc || _this14.didUnmount) {\n return;\n } // Force rerender with the new image\n\n\n _this14.forceUpdate();\n };\n }; // Load the images\n\n\n this.getSrcTypes().forEach(function (srcType) {\n var type = srcType.name; // there is no error when we try to load it initially\n\n if (props[type] && _this14.state.loadErrorStatus[type]) {\n _this14.setState(function (prevState) {\n return {\n loadErrorStatus: _objectSpread2(_objectSpread2({}, prevState.loadErrorStatus), {}, _defineProperty({}, type, false))\n };\n });\n } // Load unloaded images\n\n\n if (props[type] && !_this14.isImageLoaded(props[type])) {\n _this14.loadImage(type, props[type], generateLoadDoneCallback(type, props[type]));\n }\n });\n } // Request that the lightbox be closed\n\n }, {\n key: \"requestClose\",\n value: function requestClose(event) {\n var _this15 = this;\n\n // Call the parent close request\n var closeLightbox = function closeLightbox() {\n return _this15.props.onCloseRequest(event);\n };\n\n if (this.props.animationDisabled || event.type === 'keydown' && !this.props.animationOnKeyInput) {\n // No animation\n closeLightbox();\n return;\n } // With animation\n // Start closing animation\n\n\n this.setState({\n isClosing: true\n }); // Perform the actual closing at the end of the animation\n\n this.setTimeout(closeLightbox, this.props.animationDuration);\n }\n }, {\n key: \"requestMove\",\n value: function requestMove(direction, event) {\n var _this16 = this;\n\n // Reset the zoom level on image move\n var nextState = {\n zoomLevel: MIN_ZOOM_LEVEL,\n offsetX: 0,\n offsetY: 0\n }; // Enable animated states\n\n if (!this.props.animationDisabled && (!this.keyPressed || this.props.animationOnKeyInput)) {\n nextState.shouldAnimate = true;\n this.setTimeout(function () {\n return _this16.setState({\n shouldAnimate: false\n });\n }, this.props.animationDuration);\n }\n\n this.keyPressed = false;\n this.moveRequested = true;\n\n if (direction === 'prev') {\n this.keyCounter -= 1;\n this.setState(nextState);\n this.props.onMovePrevRequest(event);\n } else {\n this.keyCounter += 1;\n this.setState(nextState);\n this.props.onMoveNextRequest(event);\n }\n } // Request to transition to the next image\n\n }, {\n key: \"requestMoveNext\",\n value: function requestMoveNext(event) {\n this.requestMove('next', event);\n } // Request to transition to the previous image\n\n }, {\n key: \"requestMovePrev\",\n value: function requestMovePrev(event) {\n this.requestMove('prev', event);\n }\n }, {\n key: \"render\",\n value: function render() {\n var _this17 = this;\n\n var _this$props = this.props,\n animationDisabled = _this$props.animationDisabled,\n animationDuration = _this$props.animationDuration,\n clickOutsideToClose = _this$props.clickOutsideToClose,\n discourageDownloads = _this$props.discourageDownloads,\n enableZoom = _this$props.enableZoom,\n imageTitle = _this$props.imageTitle,\n nextSrc = _this$props.nextSrc,\n prevSrc = _this$props.prevSrc,\n toolbarButtons = _this$props.toolbarButtons,\n reactModalStyle = _this$props.reactModalStyle,\n _onAfterOpen = _this$props.onAfterOpen,\n imageCrossOrigin = _this$props.imageCrossOrigin,\n reactModalProps = _this$props.reactModalProps,\n loader = _this$props.loader;\n var _this$state = this.state,\n zoomLevel = _this$state.zoomLevel,\n offsetX = _this$state.offsetX,\n offsetY = _this$state.offsetY,\n isClosing = _this$state.isClosing,\n loadErrorStatus = _this$state.loadErrorStatus;\n var boxSize = this.getLightboxRect();\n var transitionStyle = {}; // Transition settings for sliding animations\n\n if (!animationDisabled && this.isAnimating()) {\n transitionStyle = _objectSpread2(_objectSpread2({}, transitionStyle), {}, {\n transition: \"transform \".concat(animationDuration, \"ms\")\n });\n } // Key endings to differentiate between images with the same src\n\n\n var keyEndings = {};\n this.getSrcTypes().forEach(function (_ref12) {\n var name = _ref12.name,\n keyEnding = _ref12.keyEnding;\n keyEndings[name] = keyEnding;\n }); // Images to be displayed\n\n var images = [];\n\n var addImage = function addImage(srcType, imageClass, transforms) {\n // Ignore types that have no source defined for their full size image\n if (!_this17.props[srcType]) {\n return;\n }\n\n var bestImageInfo = _this17.getBestImageForType(srcType);\n\n var imageStyle = _objectSpread2(_objectSpread2({}, transitionStyle), ReactImageLightbox.getTransform(_objectSpread2(_objectSpread2({}, transforms), bestImageInfo)));\n\n if (zoomLevel > MIN_ZOOM_LEVEL) {\n imageStyle.cursor = 'move';\n } // support IE 9 and 11\n\n\n var hasTrueValue = function hasTrueValue(object) {\n return Object.keys(object).some(function (key) {\n return object[key];\n });\n }; // when error on one of the loads then push custom error stuff\n\n\n if (bestImageInfo === null && hasTrueValue(loadErrorStatus)) {\n images.push( /*#__PURE__*/React.createElement(\"div\", {\n className: \"\".concat(imageClass, \" ril__image ril-errored\"),\n style: imageStyle,\n key: _this17.props[srcType] + keyEndings[srcType]\n }, /*#__PURE__*/React.createElement(\"div\", {\n className: \"ril__errorContainer\"\n }, _this17.props.imageLoadErrorMessage)));\n return;\n }\n\n if (bestImageInfo === null) {\n var loadingIcon = loader !== undefined ? loader : /*#__PURE__*/React.createElement(\"div\", {\n className: \"ril-loading-circle ril__loadingCircle ril__loadingContainer__icon\"\n }, _toConsumableArray(new Array(12)).map(function (_, index) {\n return /*#__PURE__*/React.createElement(\"div\", {\n // eslint-disable-next-line react/no-array-index-key\n key: index,\n className: \"ril-loading-circle-point ril__loadingCirclePoint\"\n });\n })); // Fall back to loading icon if the thumbnail has not been loaded\n\n images.push( /*#__PURE__*/React.createElement(\"div\", {\n className: \"\".concat(imageClass, \" ril__image ril-not-loaded\"),\n style: imageStyle,\n key: _this17.props[srcType] + keyEndings[srcType]\n }, /*#__PURE__*/React.createElement(\"div\", {\n className: \"ril__loadingContainer\"\n }, loadingIcon)));\n return;\n }\n\n var imageSrc = bestImageInfo.src;\n\n if (discourageDownloads) {\n imageStyle.backgroundImage = \"url('\".concat(imageSrc, \"')\");\n images.push( /*#__PURE__*/React.createElement(\"div\", {\n className: \"\".concat(imageClass, \" ril__image ril__imageDiscourager\"),\n onDoubleClick: _this17.handleImageDoubleClick,\n onWheel: _this17.handleImageMouseWheel,\n style: imageStyle,\n key: imageSrc + keyEndings[srcType]\n }, /*#__PURE__*/React.createElement(\"div\", {\n className: \"ril-download-blocker ril__downloadBlocker\"\n })));\n } else {\n images.push( /*#__PURE__*/React.createElement(\"img\", _extends({}, imageCrossOrigin ? {\n crossOrigin: imageCrossOrigin\n } : {}, {\n className: \"\".concat(imageClass, \" ril__image\"),\n onDoubleClick: _this17.handleImageDoubleClick,\n onWheel: _this17.handleImageMouseWheel,\n onDragStart: function onDragStart(e) {\n return e.preventDefault();\n },\n style: imageStyle,\n src: imageSrc,\n key: imageSrc + keyEndings[srcType],\n alt: typeof imageTitle === 'string' ? imageTitle : translate('Image'),\n draggable: false\n })));\n }\n };\n\n var zoomMultiplier = this.getZoomMultiplier(); // Next Image (displayed on the right)\n\n addImage('nextSrc', 'ril-image-next ril__imageNext', {\n x: boxSize.width\n }); // Main Image\n\n addImage('mainSrc', 'ril-image-current', {\n x: -1 * offsetX,\n y: -1 * offsetY,\n zoom: zoomMultiplier\n }); // Previous Image (displayed on the left)\n\n addImage('prevSrc', 'ril-image-prev ril__imagePrev', {\n x: -1 * boxSize.width\n });\n var modalStyle = {\n overlay: _objectSpread2({\n zIndex: 1000,\n backgroundColor: 'transparent'\n }, reactModalStyle.overlay),\n content: _objectSpread2({\n backgroundColor: 'transparent',\n overflow: 'hidden',\n // Needed, otherwise keyboard shortcuts scroll the page\n border: 'none',\n borderRadius: 0,\n padding: 0,\n top: 0,\n left: 0,\n right: 0,\n bottom: 0\n }, reactModalStyle.content)\n };\n return /*#__PURE__*/React.createElement(Modal, _extends({\n isOpen: true,\n onRequestClose: clickOutsideToClose ? this.requestClose : undefined,\n onAfterOpen: function onAfterOpen() {\n // Focus on the div with key handlers\n if (_this17.outerEl.current) {\n _this17.outerEl.current.focus();\n }\n\n _onAfterOpen();\n },\n style: modalStyle,\n contentLabel: translate('Lightbox'),\n appElement: typeof global.window !== 'undefined' ? global.window.document.body : undefined\n }, reactModalProps), /*#__PURE__*/React.createElement(\"div\", {\n // eslint-disable-line jsx-a11y/no-static-element-interactions\n // Floating modal with closing animations\n className: \"ril-outer ril__outer ril__outerAnimating \".concat(this.props.wrapperClassName, \" \").concat(isClosing ? 'ril-closing ril__outerClosing' : ''),\n style: {\n transition: \"opacity \".concat(animationDuration, \"ms\"),\n animationDuration: \"\".concat(animationDuration, \"ms\"),\n animationDirection: isClosing ? 'normal' : 'reverse'\n },\n ref: this.outerEl,\n onWheel: this.handleOuterMousewheel,\n onMouseMove: this.handleMouseMove,\n onMouseDown: this.handleMouseDown,\n onTouchStart: this.handleTouchStart,\n onTouchMove: this.handleTouchMove,\n tabIndex: \"-1\" // Enables key handlers on div\n ,\n onKeyDown: this.handleKeyInput,\n onKeyUp: this.handleKeyInput\n }, /*#__PURE__*/React.createElement(\"div\", {\n // eslint-disable-line jsx-a11y/no-static-element-interactions, jsx-a11y/click-events-have-key-events\n // Image holder\n className: \"ril-inner ril__inner\",\n onClick: clickOutsideToClose ? this.closeIfClickInner : undefined\n }, images), prevSrc && /*#__PURE__*/React.createElement(\"button\", {\n // Move to previous image button\n type: \"button\",\n className: \"ril-prev-button ril__navButtons ril__navButtonPrev\",\n key: \"prev\",\n \"aria-label\": this.props.prevLabel,\n title: this.props.prevLabel,\n onClick: !this.isAnimating() ? this.requestMovePrev : undefined // Ignore clicks during animation\n\n }), nextSrc && /*#__PURE__*/React.createElement(\"button\", {\n // Move to next image button\n type: \"button\",\n className: \"ril-next-button ril__navButtons ril__navButtonNext\",\n key: \"next\",\n \"aria-label\": this.props.nextLabel,\n title: this.props.nextLabel,\n onClick: !this.isAnimating() ? this.requestMoveNext : undefined // Ignore clicks during animation\n\n }), /*#__PURE__*/React.createElement(\"div\", {\n // Lightbox toolbar\n className: \"ril-toolbar ril__toolbar\"\n }, /*#__PURE__*/React.createElement(\"ul\", {\n className: \"ril-toolbar-left ril__toolbarSide ril__toolbarLeftSide\"\n }, /*#__PURE__*/React.createElement(\"li\", {\n className: \"ril-toolbar__item ril__toolbarItem\"\n }, /*#__PURE__*/React.createElement(\"span\", {\n className: \"ril-toolbar__item__child ril__toolbarItemChild\"\n }, imageTitle))), /*#__PURE__*/React.createElement(\"ul\", {\n className: \"ril-toolbar-right ril__toolbarSide ril__toolbarRightSide\"\n }, toolbarButtons && toolbarButtons.map(function (button, i) {\n return /*#__PURE__*/React.createElement(\"li\", {\n key: \"button_\".concat(i + 1),\n className: \"ril-toolbar__item ril__toolbarItem\"\n }, button);\n }), enableZoom && /*#__PURE__*/React.createElement(\"li\", {\n className: \"ril-toolbar__item ril__toolbarItem\"\n }, /*#__PURE__*/React.createElement(\"button\", {\n // Lightbox zoom in button\n type: \"button\",\n key: \"zoom-in\",\n \"aria-label\": this.props.zoomInLabel,\n title: this.props.zoomInLabel,\n className: ['ril-zoom-in', 'ril__toolbarItemChild', 'ril__builtinButton', 'ril__zoomInButton'].concat(_toConsumableArray(zoomLevel === MAX_ZOOM_LEVEL ? ['ril__builtinButtonDisabled'] : [])).join(' '),\n ref: this.zoomInBtn,\n disabled: this.isAnimating() || zoomLevel === MAX_ZOOM_LEVEL,\n onClick: !this.isAnimating() && zoomLevel !== MAX_ZOOM_LEVEL ? this.handleZoomInButtonClick : undefined\n })), enableZoom && /*#__PURE__*/React.createElement(\"li\", {\n className: \"ril-toolbar__item ril__toolbarItem\"\n }, /*#__PURE__*/React.createElement(\"button\", {\n // Lightbox zoom out button\n type: \"button\",\n key: \"zoom-out\",\n \"aria-label\": this.props.zoomOutLabel,\n title: this.props.zoomOutLabel,\n className: ['ril-zoom-out', 'ril__toolbarItemChild', 'ril__builtinButton', 'ril__zoomOutButton'].concat(_toConsumableArray(zoomLevel === MIN_ZOOM_LEVEL ? ['ril__builtinButtonDisabled'] : [])).join(' '),\n ref: this.zoomOutBtn,\n disabled: this.isAnimating() || zoomLevel === MIN_ZOOM_LEVEL,\n onClick: !this.isAnimating() && zoomLevel !== MIN_ZOOM_LEVEL ? this.handleZoomOutButtonClick : undefined\n })), /*#__PURE__*/React.createElement(\"li\", {\n className: \"ril-toolbar__item ril__toolbarItem\"\n }, /*#__PURE__*/React.createElement(\"button\", {\n // Lightbox close button\n type: \"button\",\n key: \"close\",\n \"aria-label\": this.props.closeLabel,\n title: this.props.closeLabel,\n className: \"ril-close ril-toolbar__item__child ril__toolbarItemChild ril__builtinButton ril__closeButton\",\n onClick: !this.isAnimating() ? this.requestClose : undefined // Ignore clicks during animation\n\n })))), this.props.imageCaption &&\n /*#__PURE__*/\n // eslint-disable-next-line jsx-a11y/no-static-element-interactions\n React.createElement(\"div\", {\n // Image caption\n onWheel: this.handleCaptionMousewheel,\n onMouseDown: function onMouseDown(event) {\n return event.stopPropagation();\n },\n className: \"ril-caption ril__caption\",\n ref: this.caption\n }, /*#__PURE__*/React.createElement(\"div\", {\n className: \"ril-caption-content ril__captionContent\"\n }, this.props.imageCaption))));\n }\n }], [{\n key: \"isTargetMatchImage\",\n value: function isTargetMatchImage(target) {\n return target && /ril-image-current/.test(target.className);\n }\n }, {\n key: \"parseMouseEvent\",\n value: function parseMouseEvent(mouseEvent) {\n return {\n id: 'mouse',\n source: SOURCE_MOUSE,\n x: parseInt(mouseEvent.clientX, 10),\n y: parseInt(mouseEvent.clientY, 10)\n };\n }\n }, {\n key: \"parseTouchPointer\",\n value: function parseTouchPointer(touchPointer) {\n return {\n id: touchPointer.identifier,\n source: SOURCE_TOUCH,\n x: parseInt(touchPointer.clientX, 10),\n y: parseInt(touchPointer.clientY, 10)\n };\n }\n }, {\n key: \"parsePointerEvent\",\n value: function parsePointerEvent(pointerEvent) {\n return {\n id: pointerEvent.pointerId,\n source: SOURCE_POINTER,\n x: parseInt(pointerEvent.clientX, 10),\n y: parseInt(pointerEvent.clientY, 10)\n };\n } // Request to transition to the previous image\n\n }, {\n key: \"getTransform\",\n value: function getTransform(_ref13) {\n var _ref13$x = _ref13.x,\n x = _ref13$x === void 0 ? 0 : _ref13$x,\n _ref13$y = _ref13.y,\n y = _ref13$y === void 0 ? 0 : _ref13$y,\n _ref13$zoom = _ref13.zoom,\n zoom = _ref13$zoom === void 0 ? 1 : _ref13$zoom,\n width = _ref13.width,\n targetWidth = _ref13.targetWidth;\n var nextX = x;\n var windowWidth = getWindowWidth();\n\n if (width > windowWidth) {\n nextX += (windowWidth - width) / 2;\n }\n\n var scaleFactor = zoom * (targetWidth / width);\n return {\n transform: \"translate3d(\".concat(nextX, \"px,\").concat(y, \"px,0) scale3d(\").concat(scaleFactor, \",\").concat(scaleFactor, \",1)\")\n };\n }\n }]);\n\n return ReactImageLightbox;\n}(Component);\n\nReactImageLightbox.propTypes = {\n //-----------------------------\n // Image sources\n //-----------------------------\n // Main display image url\n mainSrc: PropTypes.string.isRequired,\n // eslint-disable-line react/no-unused-prop-types\n // Previous display image url (displayed to the left)\n // If left undefined, movePrev actions will not be performed, and the button not displayed\n prevSrc: PropTypes.string,\n // Next display image url (displayed to the right)\n // If left undefined, moveNext actions will not be performed, and the button not displayed\n nextSrc: PropTypes.string,\n //-----------------------------\n // Image thumbnail sources\n //-----------------------------\n // Thumbnail image url corresponding to props.mainSrc\n mainSrcThumbnail: PropTypes.string,\n // eslint-disable-line react/no-unused-prop-types\n // Thumbnail image url corresponding to props.prevSrc\n prevSrcThumbnail: PropTypes.string,\n // eslint-disable-line react/no-unused-prop-types\n // Thumbnail image url corresponding to props.nextSrc\n nextSrcThumbnail: PropTypes.string,\n // eslint-disable-line react/no-unused-prop-types\n //-----------------------------\n // Event Handlers\n //-----------------------------\n // Close window event\n // Should change the parent state such that the lightbox is not rendered\n onCloseRequest: PropTypes.func.isRequired,\n // Move to previous image event\n // Should change the parent state such that props.prevSrc becomes props.mainSrc,\n // props.mainSrc becomes props.nextSrc, etc.\n onMovePrevRequest: PropTypes.func,\n // Move to next image event\n // Should change the parent state such that props.nextSrc becomes props.mainSrc,\n // props.mainSrc becomes props.prevSrc, etc.\n onMoveNextRequest: PropTypes.func,\n // Called when an image fails to load\n // (imageSrc: string, srcType: string, errorEvent: object): void\n onImageLoadError: PropTypes.func,\n // Called when image successfully loads\n onImageLoad: PropTypes.func,\n // Open window event\n onAfterOpen: PropTypes.func,\n //-----------------------------\n // Download discouragement settings\n //-----------------------------\n // Enable download discouragement (prevents [right-click -> Save Image As...])\n discourageDownloads: PropTypes.bool,\n //-----------------------------\n // Animation settings\n //-----------------------------\n // Disable all animation\n animationDisabled: PropTypes.bool,\n // Disable animation on actions performed with keyboard shortcuts\n animationOnKeyInput: PropTypes.bool,\n // Animation duration (ms)\n animationDuration: PropTypes.number,\n //-----------------------------\n // Keyboard shortcut settings\n //-----------------------------\n // Required interval of time (ms) between key actions\n // (prevents excessively fast navigation of images)\n keyRepeatLimit: PropTypes.number,\n // Amount of time (ms) restored after each keyup\n // (makes rapid key presses slightly faster than holding down the key to navigate images)\n keyRepeatKeyupBonus: PropTypes.number,\n //-----------------------------\n // Image info\n //-----------------------------\n // Image title\n imageTitle: PropTypes.node,\n // Image caption\n imageCaption: PropTypes.node,\n // Optional crossOrigin attribute\n imageCrossOrigin: PropTypes.string,\n //-----------------------------\n // Lightbox style\n //-----------------------------\n // Set z-index style, etc., for the parent react-modal (format: https://github.com/reactjs/react-modal#styles )\n reactModalStyle: PropTypes.shape({}),\n // Padding (px) between the edge of the window and the lightbox\n imagePadding: PropTypes.number,\n wrapperClassName: PropTypes.string,\n //-----------------------------\n // Other\n //-----------------------------\n // Array of custom toolbar buttons\n toolbarButtons: PropTypes.arrayOf(PropTypes.node),\n // When true, clicks outside of the image close the lightbox\n clickOutsideToClose: PropTypes.bool,\n // Set to false to disable zoom functionality and hide zoom buttons\n enableZoom: PropTypes.bool,\n // Override props set on react-modal (https://github.com/reactjs/react-modal)\n reactModalProps: PropTypes.shape({}),\n // Aria-labels\n nextLabel: PropTypes.string,\n prevLabel: PropTypes.string,\n zoomInLabel: PropTypes.string,\n zoomOutLabel: PropTypes.string,\n closeLabel: PropTypes.string,\n imageLoadErrorMessage: PropTypes.node,\n // custom loader\n loader: PropTypes.node\n};\nReactImageLightbox.defaultProps = {\n imageTitle: null,\n imageCaption: null,\n toolbarButtons: null,\n reactModalProps: {},\n animationDisabled: false,\n animationDuration: 300,\n animationOnKeyInput: false,\n clickOutsideToClose: true,\n closeLabel: 'Close lightbox',\n discourageDownloads: false,\n enableZoom: true,\n imagePadding: 10,\n imageCrossOrigin: null,\n keyRepeatKeyupBonus: 40,\n keyRepeatLimit: 180,\n mainSrcThumbnail: null,\n nextLabel: 'Next image',\n nextSrc: null,\n nextSrcThumbnail: null,\n onAfterOpen: function onAfterOpen() {},\n onImageLoadError: function onImageLoadError() {},\n onImageLoad: function onImageLoad() {},\n onMoveNextRequest: function onMoveNextRequest() {},\n onMovePrevRequest: function onMovePrevRequest() {},\n prevLabel: 'Previous image',\n prevSrc: null,\n prevSrcThumbnail: null,\n reactModalStyle: {},\n wrapperClassName: '',\n zoomInLabel: 'Zoom in',\n zoomOutLabel: 'Zoom out',\n imageLoadErrorMessage: 'This image failed to load',\n loader: undefined\n};\n\nexport default ReactImageLightbox;\n","import e from\"prop-types\";import n,{useState as t,useEffect as a,useCallback as i,createContext as r,useLayoutEffect as o,useRef as l}from\"react\";import s from\"classnames\";import c from\"prismjs\";import\"prismjs/components/prism-clike\";import\"prismjs/components/prism-csharp\";import\"prismjs/components/prism-css\";import\"prismjs/components/prism-javascript\";import\"prismjs/components/prism-markup\";import{createPortal as m}from\"react-dom\";import{useCookies as d}from\"react-cookie\";import u from\"react-image-lightbox\";import\"react-image-lightbox/style.css\";var p=n.createElement(\"svg\",{focusable:\"false\",role:\"img\",viewBox:\"0 0 24 24\",width:\"24px\",height:\"24px\",xmlns:\"http://www.w3.org/2000/svg\"},n.createElement(\"title\",null,\"Discord\"),n.createElement(\"path\",{d:\"M20.222 0c1.406 0 2.54 1.137 2.607 2.475V24l-2.677-2.273-1.47-1.338-1.604-1.398.67 2.205H3.71c-1.402 0-2.54-1.065-2.54-2.476V2.48C1.17 1.142 2.31.003 3.715.003h16.5L20.222 0zm-6.118 5.683h-.03l-.202.2c2.073.6 3.076 1.537 3.076 1.537-1.336-.668-2.54-1.002-3.744-1.137-.87-.135-1.74-.064-2.475 0h-.2c-.47 0-1.47.2-2.81.735-.467.203-.735.336-.735.336s1.002-1.002 3.21-1.537l-.135-.135s-1.672-.064-3.477 1.27c0 0-1.805 3.144-1.805 7.02 0 0 1 1.74 3.743 1.806 0 0 .4-.533.805-1.002-1.54-.468-2.14-1.404-2.14-1.404s.134.066.335.2h.06c.03 0 .044.015.06.03v.006c.016.016.03.03.06.03.33.136.66.27.93.4.466.202 1.065.403 1.8.536.93.135 1.996.2 3.21 0 .6-.135 1.2-.267 1.8-.535.39-.2.87-.4 1.397-.737 0 0-.6.936-2.205 1.404.33.466.795 1 .795 1 2.744-.06 3.81-1.8 3.87-1.726 0-3.87-1.815-7.02-1.815-7.02-1.635-1.214-3.165-1.26-3.435-1.26l.056-.02zm.168 4.413c.703 0 1.27.6 1.27 1.335 0 .74-.57 1.34-1.27 1.34-.7 0-1.27-.6-1.27-1.334.002-.74.573-1.338 1.27-1.338zm-4.543 0c.7 0 1.266.6 1.266 1.335 0 .74-.57 1.34-1.27 1.34-.7 0-1.27-.6-1.27-1.334 0-.74.57-1.338 1.27-1.338z\"})),g=n.createElement(\"svg\",{focusable:\"false\",role:\"img\",viewBox:\"0 0 184 184\",width:\"24px\",height:\"24px\",xmlns:\"http://www.w3.org/2000/svg\"},n.createElement(\"title\",null,\"Email\"),n.createElement(\"path\",{d:\"M160.746,24.61H23.254C10.432,24.61,0,35.042,0,47.864v88.271c0,12.822,10.432,23.254,23.254,23.254h137.492c12.822,0,23.254-10.432,23.254-23.254V47.864C184,35.042,173.568,24.61,160.746,24.61z M157.113,39.61L92,89.909L26.887,39.61H157.113z M160.746,144.39H23.254c-4.551,0-8.254-3.703-8.254-8.254V49.382l72.415,55.94c1.35,1.043,2.968,1.564,4.585,1.564s3.235-0.521,4.585-1.564L169,49.382v86.753C169,140.687,165.297,144.39,160.746,144.39z\"})),h=n.createElement(\"svg\",{focusable:\"false\",role:\"img\",viewBox:\"0 0 24 24\",width:\"24px\",height:\"24px\",xmlns:\"http://www.w3.org/2000/svg\"},n.createElement(\"title\",null,\"Facebook\"),n.createElement(\"path\",{d:\"M23.9981 11.9991C23.9981 5.37216 18.626 0 11.9991 0C5.37216 0 0 5.37216 0 11.9991C0 17.9882 4.38789 22.9522 10.1242 23.8524V15.4676H7.07758V11.9991H10.1242V9.35553C10.1242 6.34826 11.9156 4.68714 14.6564 4.68714C15.9692 4.68714 17.3424 4.92149 17.3424 4.92149V7.87439H15.8294C14.3388 7.87439 13.8739 8.79933 13.8739 9.74824V11.9991H17.2018L16.6698 15.4676H13.8739V23.8524C19.6103 22.9522 23.9981 17.9882 23.9981 11.9991Z\"})),f=n.createElement(\"svg\",{focusable:\"false\",role:\"img\",viewBox:\"0 0 24 24\",width:\"24px\",height:\"24px\",xmlns:\"http://www.w3.org/2000/svg\"},n.createElement(\"title\",null,\"GitHub\"),n.createElement(\"path\",{d:\"M12 .297c-6.63 0-12 5.373-12 12 0 5.303 3.438 9.8 8.205 11.385.6.113.82-.258.82-.577 0-.285-.01-1.04-.015-2.04-3.338.724-4.042-1.61-4.042-1.61C4.422 18.07 3.633 17.7 3.633 17.7c-1.087-.744.084-.729.084-.729 1.205.084 1.838 1.236 1.838 1.236 1.07 1.835 2.809 1.305 3.495.998.108-.776.417-1.305.76-1.605-2.665-.3-5.466-1.332-5.466-5.93 0-1.31.465-2.38 1.235-3.22-.135-.303-.54-1.523.105-3.176 0 0 1.005-.322 3.3 1.23.96-.267 1.98-.399 3-.405 1.02.006 2.04.138 3 .405 2.28-1.552 3.285-1.23 3.285-1.23.645 1.653.24 2.873.12 3.176.765.84 1.23 1.91 1.23 3.22 0 4.61-2.805 5.625-5.475 5.92.42.36.81 1.096.81 2.22 0 1.606-.015 2.896-.015 3.286 0 .315.21.69.825.57C20.565 22.092 24 17.592 24 12.297c0-6.627-5.373-12-12-12\"})),v=n.createElement(\"svg\",{focusable:\"false\",role:\"img\",viewBox:\"0 0 24 24\",width:\"24px\",height:\"24px\",xmlns:\"http://www.w3.org/2000/svg\"},n.createElement(\"title\",null,\"Instagram\"),n.createElement(\"path\",{d:\"M12 0C8.74 0 8.333.015 7.053.072 5.775.132 4.905.333 4.14.63c-.789.306-1.459.717-2.126 1.384S.935 3.35.63 4.14C.333 4.905.131 5.775.072 7.053.012 8.333 0 8.74 0 12s.015 3.667.072 4.947c.06 1.277.261 2.148.558 2.913.306.788.717 1.459 1.384 2.126.667.666 1.336 1.079 2.126 1.384.766.296 1.636.499 2.913.558C8.333 23.988 8.74 24 12 24s3.667-.015 4.947-.072c1.277-.06 2.148-.262 2.913-.558.788-.306 1.459-.718 2.126-1.384.666-.667 1.079-1.335 1.384-2.126.296-.765.499-1.636.558-2.913.06-1.28.072-1.687.072-4.947s-.015-3.667-.072-4.947c-.06-1.277-.262-2.149-.558-2.913-.306-.789-.718-1.459-1.384-2.126C21.319 1.347 20.651.935 19.86.63c-.765-.297-1.636-.499-2.913-.558C15.667.012 15.26 0 12 0zm0 2.16c3.203 0 3.585.016 4.85.071 1.17.055 1.805.249 2.227.415.562.217.96.477 1.382.896.419.42.679.819.896 1.381.164.422.36 1.057.413 2.227.057 1.266.07 1.646.07 4.85s-.015 3.585-.074 4.85c-.061 1.17-.256 1.805-.421 2.227-.224.562-.479.96-.899 1.382-.419.419-.824.679-1.38.896-.42.164-1.065.36-2.235.413-1.274.057-1.649.07-4.859.07-3.211 0-3.586-.015-4.859-.074-1.171-.061-1.816-.256-2.236-.421-.569-.224-.96-.479-1.379-.899-.421-.419-.69-.824-.9-1.38-.165-.42-.359-1.065-.42-2.235-.045-1.26-.061-1.649-.061-4.844 0-3.196.016-3.586.061-4.861.061-1.17.255-1.814.42-2.234.21-.57.479-.96.9-1.381.419-.419.81-.689 1.379-.898.42-.166 1.051-.361 2.221-.421 1.275-.045 1.65-.06 4.859-.06l.045.03zm0 3.678c-3.405 0-6.162 2.76-6.162 6.162 0 3.405 2.76 6.162 6.162 6.162 3.405 0 6.162-2.76 6.162-6.162 0-3.405-2.76-6.162-6.162-6.162zM12 16c-2.21 0-4-1.79-4-4s1.79-4 4-4 4 1.79 4 4-1.79 4-4 4zm7.846-10.405c0 .795-.646 1.44-1.44 1.44-.795 0-1.44-.646-1.44-1.44 0-.794.646-1.439 1.44-1.439.793-.001 1.44.645 1.44 1.439z\"})),y=n.createElement(\"svg\",{focusable:\"false\",role:\"img\",viewBox:\"0 0 24 24\",width:\"24px\",height:\"24px\",xmlns:\"http://www.w3.org/2000/svg\"},n.createElement(\"title\",null,\"LinkedIn\"),n.createElement(\"path\",{d:\"M20.447 20.452h-3.554v-5.569c0-1.328-.027-3.037-1.852-3.037-1.853 0-2.136 1.445-2.136 2.939v5.667H9.351V9h3.414v1.561h.046c.477-.9 1.637-1.85 3.37-1.85 3.601 0 4.267 2.37 4.267 5.455v6.286zM5.337 7.433c-1.144 0-2.063-.926-2.063-2.065 0-1.138.92-2.063 2.063-2.063 1.14 0 2.064.925 2.064 2.063 0 1.139-.925 2.065-2.064 2.065zm1.782 13.019H3.555V9h3.564v11.452zM22.225 0H1.771C.792 0 0 .774 0 1.729v20.542C0 23.227.792 24 1.771 24h20.451C23.2 24 24 23.227 24 22.271V1.729C24 .774 23.2 0 22.222 0h.003z\"})),b=n.createElement(\"svg\",{focusable:\"false\",role:\"img\",viewBox:\"0 0 24 24\",width:\"24px\",height:\"24px\",xmlns:\"http://www.w3.org/2000/svg\"},n.createElement(\"title\",null,\"Patreon\"),n.createElement(\"path\",{d:\"M0 .48v23.04h4.22V.48zm15.385 0c-4.764 0-8.641 3.88-8.641 8.65 0 4.755 3.877 8.623 8.641 8.623 4.75 0 8.615-3.868 8.615-8.623C24 4.36 20.136.48 15.385.48z\"})),E=n.createElement(\"svg\",{focusable:\"false\",viewBox:\"0 0 25.576 30.177\",width:\"25.576px\",height:\"30.177px\",xmlns:\"http://www.w3.org/2000/svg\"},n.createElement(\"path\",{d:\"M7.266 29.154l.523-3.322-1.165-.027H1.061L4.927 1.292a.316.316 0 01.314-.268h9.38c3.114 0 5.263.648 6.385 1.927.526.6.861 1.227 1.023 1.917.17.724.173 1.589.007 2.644l-.012.077v.676l.526.298a3.69 3.69 0 011.065.812c.45.513.741 1.165.864 1.938.127.795.085 1.741-.123 2.812-.24 1.232-.628 2.305-1.152 3.183a6.547 6.547 0 01-1.825 2c-.696.494-1.523.869-2.458 1.109-.906.236-1.939.355-3.072.355h-.73c-.522 0-1.029.188-1.427.525a2.21 2.21 0 00-.744 1.328l-.055.299-.924 5.855-.042.215c-.011.068-.03.102-.058.125a.155.155 0 01-.096.035H7.266z\",fill:\"#253b80\"}),n.createElement(\"path\",{d:\"M23.048 7.667c-.028.179-.06.362-.096.55-1.237 6.351-5.469 8.545-10.874 8.545H9.326c-.661 0-1.218.48-1.321 1.132L6.596 26.83l-.399 2.533a.704.704 0 00.695.814h4.881c.578 0 1.069-.42 1.16-.99l.048-.248.919-5.832.059-.32c.09-.572.582-.992 1.16-.992h.73c4.729 0 8.431-1.92 9.513-7.476.452-2.321.218-4.259-.978-5.622a4.667 4.667 0 00-1.336-1.03z\",fill:\"#179bd7\"}),n.createElement(\"path\",{d:\"M21.754 7.151a9.757 9.757 0 00-1.203-.267 15.284 15.284 0 00-2.426-.177h-7.352a1.172 1.172 0 00-1.159.992L8.05 17.605l-.045.289a1.336 1.336 0 011.321-1.132h2.752c5.405 0 9.637-2.195 10.874-8.545.037-.188.068-.371.096-.55a6.594 6.594 0 00-1.017-.429 9.045 9.045 0 00-.277-.087z\",fill:\"#222d65\"}),n.createElement(\"path\",{d:\"M9.614 7.699a1.169 1.169 0 011.159-.991h7.352c.871 0 1.684.057 2.426.177a9.757 9.757 0 011.481.353c.365.121.704.264 1.017.429.368-2.347-.003-3.945-1.272-5.392C20.378.682 17.853 0 14.622 0h-9.38c-.66 0-1.223.48-1.325 1.133L.01 25.898a.806.806 0 00.795.932h5.791l1.454-9.225 1.564-9.906z\",fill:\"#253b80\"})),w=n.createElement(\"svg\",{focusable:\"false\",role:\"img\",style:{transform:\"translateY(1px)\"},viewBox:\"0 0 24 24\",width:\"24px\",height:\"24px\",xmlns:\"http://www.w3.org/2000/svg\"},n.createElement(\"title\",null,\"Twitch\"),n.createElement(\"path\",{d:\"M11.571 4.714h1.715v5.143H11.57zm4.715 0H18v5.143h-1.714zM6 0L1.714 4.286v15.428h5.143V24l4.286-4.286h3.428L22.286 12V0zm14.571 11.143l-3.428 3.428h-3.429l-3 3v-3H6.857V1.714h13.714Z\"})),N=n.createElement(\"svg\",{focusable:\"false\",role:\"img\",style:{transform:\"scale(1.1)\"},viewBox:\"0 0 24 24\",width:\"24px\",height:\"24px\",xmlns:\"http://www.w3.org/2000/svg\"},n.createElement(\"title\",null,\"Twitter\"),n.createElement(\"path\",{d:\"M23.954 4.569c-.885.389-1.83.654-2.825.775 1.014-.611 1.794-1.574 2.163-2.723-.951.555-2.005.959-3.127 1.184-.896-.959-2.173-1.559-3.591-1.559-2.717 0-4.92 2.203-4.92 4.917 0 .39.045.765.127 1.124C7.691 8.094 4.066 6.13 1.64 3.161c-.427.722-.666 1.561-.666 2.475 0 1.71.87 3.213 2.188 4.096-.807-.026-1.566-.248-2.228-.616v.061c0 2.385 1.693 4.374 3.946 4.827-.413.111-.849.171-1.296.171-.314 0-.615-.03-.916-.086.631 1.953 2.445 3.377 4.604 3.417-1.68 1.319-3.809 2.105-6.102 2.105-.39 0-.779-.023-1.17-.067 2.189 1.394 4.768 2.209 7.557 2.209 9.054 0 13.999-7.496 13.999-13.986 0-.209 0-.42-.015-.63.961-.689 1.8-1.56 2.46-2.548l-.047-.02z\"})),k=n.createElement(\"svg\",{focusable:\"false\",role:\"img\",viewBox:\"0 0 24 24\",width:\"24px\",height:\"24px\",xmlns:\"http://www.w3.org/2000/svg\"},n.createElement(\"title\",null,\"Unity\"),n.createElement(\"path\",{d:\"M24 9.533L21.374 0 11.57 2.555l-1.45 2.49-2.945-.022L0 12l7.176 6.978 2.943-.023 1.454 2.49 9.8 2.554L24 14.47 22.508 12 24 9.533zM10.356 5.445l7.499-1.874-4.304 7.251H4.94l5.416-5.377zm0 13.11L4.94 13.18h8.61l4.305 7.251-7.5-1.874zm9.598.696l-4.307-7.25 4.307-7.253L22.033 12l-2.08 7.25z\"})),x=n.createElement(\"svg\",{focusable:\"false\",role:\"img\",style:{transform:\"scale(1.125)\"},viewBox:\"0 0 24 24\",width:\"24px\",height:\"24px\",xmlns:\"http://www.w3.org/2000/svg\"},n.createElement(\"title\",null,\"YouTube\"),n.createElement(\"path\",{d:\"M23.495 6.205a3.007 3.007 0 0 0-2.088-2.088c-1.87-.501-9.396-.501-9.396-.501s-7.507-.01-9.396.501A3.007 3.007 0 0 0 .527 6.205a31.247 31.247 0 0 0-.522 5.805 31.247 31.247 0 0 0 .522 5.783 3.007 3.007 0 0 0 2.088 2.088c1.868.502 9.396.502 9.396.502s7.506 0 9.396-.502a3.007 3.007 0 0 0 2.088-2.088 31.247 31.247 0 0 0 .5-5.783 31.247 31.247 0 0 0-.5-5.805zM9.609 15.601V8.408l6.264 3.602z\"})),T={discord:p,email:g,facebook:h,github:f,instagram:v,linkedIn:y,patreon:b,paypal:E,twitch:w,twitter:N,unity:k,youtube:x},C=e.oneOfType([e.string,e.shape({key:e.string,name:e.string,color:e.string,url:e.string,icon:e.element})]),z={discord:{key:\"discord\",name:\"Discord\",color:\"#7289da\",url:\"https://discord.gg/DdYyWVb\",icon:p},email:{key:\"email\",name:\"Email\",url:\"mailto:support@zigurous.com\",icon:g},facebook:{key:\"facebook\",name:\"Facebook\",color:\"#1877f2\",url:\"https://facebook.com/zigurous\",icon:h},github:{key:\"github\",name:\"GitHub\",url:\"https://github.com/zigurous\",icon:f},instagram:{key:\"instagram\",name:\"Instagram\",color:\"#e4405f\",url:\"https://instagram.com/zigurous\",icon:v},patreon:{key:\"patreon\",name:\"Patreon\",color:\"#ff424d\",url:\"https://patreon.com/zigurous\",icon:b},paypal:{key:\"paypal\",name:\"PayPal\",color:\"#00457c\",url:\"https://paypal.com/donate?hosted_button_id=BGS8Y9U798JS8\",icon:E},twitch:{key:\"twitch\",name:\"Twitch\",color:\"#9146ff\",url:\"https://twitch.tv/zigurous\",icon:w},twitter:{key:\"twitter\",name:\"Twitter\",color:\"#1da1f2\",url:\"https://twitter.com/zigurous\",icon:N},unity:{key:\"unity\",name:\"Unity\",url:\"https://assetstore.unity.com/publishers/51884\",icon:k},youtube:{key:\"youtube\",name:\"YouTube\",color:\"#ff0000\",url:\"https://youtube.com/c/zigurous?sub_confirmation=1\",icon:x}},O={wordmark:n.createElement(\"svg\",{xmlns:\"http://www.w3.org/2000/svg\",viewBox:\"0 0 596 192\"},n.createElement(\"path\",{d:\"M528.71,98.72a18.85,18.85,0,0,0-7.36-5.56,92.48,92.48,0,0,0-10.88-3.52A43,43,0,0,1,501.91,87a4.28,4.28,0,0,1-2.76-4,4.21,4.21,0,0,1,1.72-3.52,8.33,8.33,0,0,1,5-1.28A9.36,9.36,0,0,1,511.91,80a7.68,7.68,0,0,1,2.76,5.16h17c-.64-6.4-3.12-11.56-7.48-15.4S513.91,64,506.39,64a31,31,0,0,0-13.2,2.56,19.26,19.26,0,0,0-8.4,7A17.5,17.5,0,0,0,482,83.28q0,6.36,3.12,10.08a18.58,18.58,0,0,0,7.4,5.48,79.1,79.1,0,0,0,10.8,3.28A55.41,55.41,0,0,1,512,105a4.27,4.27,0,0,1,2.68,4,4.37,4.37,0,0,1-1.88,3.64,9,9,0,0,1-5.32,1.4,9.94,9.94,0,0,1-6.36-2,7.23,7.23,0,0,1-2.92-5.2H480a20.18,20.18,0,0,0,4,10.84,23.8,23.8,0,0,0,9.68,7.64,33.14,33.14,0,0,0,14,2.8,32.3,32.3,0,0,0,12.88-2.44A19.55,19.55,0,0,0,529,118.8a16.93,16.93,0,0,0,3-9.76C531.91,104.72,530.83,101.28,528.71,98.72Z\"}),n.createElement(\"polygon\",{points:\"64 40.01 64 58.01 101.8 58.01 97.6 64.01 65.4 110.01 64 112.01 64 128.01 77.6 128.01 128 128.01 128 110.01 90.2 110.01 122.4 64.01 126.6 58.01 128 56.01 128 40.01 114.4 40.01 64 40.01\"}),n.createElement(\"path\",{d:\"M368,64a32,32,0,1,0,32,32.16v-.24A32,32,0,0,0,368,64Zm0,48a16,16,0,1,1,16-16A16,16,0,0,1,368,112Z\"}),n.createElement(\"path\",{d:\"M312,71.23V64H292v36.24a12,12,0,0,1-24,0V64H248v38a26,26,0,0,0,20,25.28,24.65,24.65,0,0,0,6,.72,25.92,25.92,0,0,0,18-7.24V128h20V96a16,16,0,0,1,16-16h4V64.07c-.68,0-1.32-.08-2-.08A25.92,25.92,0,0,0,312,71.23Z\"}),n.createElement(\"path\",{d:\"M452,83.23v17a12,12,0,0,1-24,0V64H408v38a26,26,0,0,0,20,25.28,24.65,24.65,0,0,0,6,.72,25.92,25.92,0,0,0,18-7.24V128h20V64H452Z\"}),n.createElement(\"path\",{d:\"M216,69.76A25.37,25.37,0,0,0,200,64c-15.48,0-28,14.32-28,32a35.72,35.72,0,0,0,3.4,15.32,30.58,30.58,0,0,0,10.4,12.24,24.93,24.93,0,0,0,28.4,0,18.85,18.85,0,0,0,1.8-1.32V130c0,7.72-7.16,14-16,14a17,17,0,0,1-10.4-3.4l-8.92,12.72a37.37,37.37,0,0,0,35.32,4c11.8-4.64,20-15.12,20-27.28V64H216ZM204,112a15.93,15.93,0,0,1-14.72-9.8A15.22,15.22,0,0,1,188,96a16,16,0,1,1,30.08,7.6,17.11,17.11,0,0,1-2.08,3A15.93,15.93,0,0,1,204,112Z\"}),n.createElement(\"rect\",{x:\"140.01\",y:\"64.01\",width:\"20\",height:\"64\"}),n.createElement(\"path\",{d:\"M150,36a11,11,0,0,0-10,6.16,9.83,9.83,0,0,0,0,8.64,11.16,11.16,0,0,0,20,0,9.83,9.83,0,0,0,0-8.64A11,11,0,0,0,150,36Z\"})),lettermark:n.createElement(\"svg\",{xmlns:\"http://www.w3.org/2000/svg\",viewBox:\"0 0 512 512\"},n.createElement(\"polygon\",{points:\"382.81 331.67 382.81 384.03 311.24 384.03 347.9 331.67 382.81 331.67\"}),n.createElement(\"polygon\",{points:\"380.48 128.03 237.93 331.67 312.99 331.67 276.33 384.03 129.13 384.03 271.68 180.39 308.33 128.03 380.48 128.03\"}),n.createElement(\"polygon\",{points:\"272.26 128.03 235.6 180.39 150.08 180.39 150.08 128.03 272.26 128.03\"})),logomark:n.createElement(\"svg\",{xmlns:\"http://www.w3.org/2000/svg\",viewBox:\"0 0 512 512\"},n.createElement(\"polygon\",{points:\"368.46 177.61 256 112.68 143.54 177.61 256 242.54 368.46 177.61\"}),n.createElement(\"polygon\",{points:\"128 334.39 240.46 399.32 240.46 269.46 128 204.53 128 334.39\"}),n.createElement(\"polygon\",{points:\"384 204.53 271.54 269.46 271.54 399.32 384 334.39 384 204.53\"}))};function L(){return(L=Object.assign?Object.assign.bind():function(e){for(var n=1;n=0||(i[t]=e[t]);return i}var j=[\"activeClassName\",\"children\",\"className\",\"ElementType\",\"external\",\"href\",\"path\",\"rel\",\"target\",\"to\",\"underlined\",\"unstyled\"];function S(e){var t=e.activeClassName,a=e.children,i=e.className,r=e.ElementType,o=void 0===r?\"a\":r,l=e.external,c=void 0!==l&&l,m=e.href,d=e.path,u=e.rel,p=e.target,g=e.to,h=e.underlined,f=void 0!==h&&h,v=e.unstyled,y=void 0!==v&&v,b=_(e,j);return n.createElement(o,L({},b,\"a\"===o?{href:m||d||g,rel:u||(c?\"noopener noreferrer\":void 0),target:p||(c?\"_blank\":void 0)}:{to:g||d||m,href:m||d||g,activeClassName:t},{className:s({link:!y},{\"link--underlined\":f&&!y},i)}),a)}function I(e,t){return e?n.createElement(\"img\",{alt:\"Logo\",src:e}):O[t]}function M(e){var t=e.fill,a=e.image,i=e.onClick,r=e.size,o=e.style,l=e.variant,c=void 0===l?\"wordmark\":l;return n.createElement(\"div\",{className:s(\"logo\",c,void 0===r?\"medium\":r,e.className),style:L({},o,{fill:t})},i?n.createElement(\"button\",{\"aria-label\":\"Logo\",onClick:function(e){e.target.blur(),i()}},I(a,c)):I(a,c))}function P(e){var t=e.bordered,a=e.copyright,i=e.hideLogo,r=void 0!==i&&i,o=e.LinkElementType,l=void 0===o?\"a\":o,c=e.links,m=void 0===c?[]:c,d=e.onLinkClick,u=e.onLogoClick,p=e.sticky,g=e.theme,h=e.transparent;return n.createElement(\"footer\",{className:s(\"app-footer\",{\"app-footer--bordered\":void 0!==t&&t},{\"app-footer--transparent\":void 0!==h&&h},{\"app-footer--sticky\":void 0!==p&&p},e.className),\"data-theme\":g},n.createElement(\"div\",{className:\"container\"},n.createElement(\"div\",{className:\"row align-items-center margin-top-lg margin-bottom-lg\"},n.createElement(\"div\",{className:\"col font-xs font-weight-500\"},n.createElement(\"span\",null,!r&&n.createElement(M,{onClick:u,size:\"xs\"}),a&&n.createElement(\"span\",{className:\"copyright margin-left-xl margin-right-xl\"},a)),m&&m.length>0&&n.createElement(\"span\",{className:\"links\"},m.map(function(e){return n.createElement(S,{\"aria-label\":e.name,className:\"color-inherit margin-left-md margin-right-md\",ElementType:e.ElementType||l,external:e.external,key:e.id||e.to,onClick:function(){d&&d(e)},to:e.to},e.name)}))))))}S.propTypes={activeClassName:e.string,children:e.node,className:e.string,ElementType:e.elementType,external:e.bool,href:e.string,path:e.string,rel:e.string,target:e.string,to:e.string,underlined:e.bool,unstyled:e.bool},M.size=Object.freeze({xs:\"xs\",extraSmall:\"extraSmall\",sm:\"sm\",small:\"small\",md:\"md\",medium:\"medium\",lg:\"lg\",large:\"large\",xl:\"xl\",extraLarge:\"extraLarge\"}),M.variant=Object.freeze({wordmark:\"wordmark\",lettermark:\"lettermark\",logomark:\"logomark\"}),M.propTypes={className:e.string,fill:e.string,image:e.string,onClick:e.func,size:e.oneOf(Object.values(M.size)),style:e.object,variant:e.oneOf(Object.values(M.variant))},P.propTypes={bordered:e.bool,className:e.string,copyright:e.node,hideLogo:e.bool,LinkElementType:e.elementType,links:e.arrayOf(e.shape(S.propTypes)),onLinkClick:e.func,onLogoClick:e.func,sticky:e.bool,theme:e.string,transparent:e.bool};var V=[\"ariaHidden\",\"children\",\"className\",\"inactive\",\"material\",\"name\",\"size\",\"theme\"];function H(e){var t,a,i=e.ariaHidden,r=void 0===i||i,o=e.children,l=e.className,c=e.inactive,m=e.material,d=void 0===m||m,u=e.name,p=e.size,g=void 0===p?\"medium\":p,h=e.theme,f=_(e,V);return n.createElement(\"i\",L({\"aria-hidden\":r,className:s(\"icon\",(t={},t[\"icon--\"+g]=g,t),(a={},a[\"icon--\"+h]=h,a),{\"icon--active\":!c},{\"icon--inactive\":c},{\"icon--material\":d},l)},f),u||o)}function A(e){if(null===e)return 0;var n=e.map(function(e){return(e/=255)<=.03928?e/12.92:Math.pow((e+.055)/1.055,2.4)});return.2126*n[0]+.7152*n[1]+.0722*n[2]}function B(e,n){var t=A(e),a=A(n),i=Math.min(t,a);return(Math.max(t,a)+.05)/(i+.05)}function q(e){var n=/^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i.exec(e);return n?[parseInt(n[1],16),parseInt(n[2],16),parseInt(n[3],16)]:null}function R(e){function n(e){var n=e.toString(16);return 1===n.length?\"0\"+n:n}return\"#\"+n(e[0])+n(e[1])+n(e[2])}function F(e,n){var t;return function(){var a=this,i=arguments;clearTimeout(t),t=setTimeout(function(){return e.apply(a,i)},n)}}function W(e,n,t){e.addEventListener?e.addEventListener(n,t):e.attachEvent&&e.attachEvent(\"on\"+n,t)}function D(e,n,t){e.removeEventListener?e.removeEventListener(n,t):e.detachEvent&&e.detachEvent(\"on\"+n,t)}function Z(e){return void 0===e&&(e=function(){}),function(n){if(!n.defaultPrevented){var t=!1;\"Enter\"===n.key&&(t=!0,e(n)),t&&n.preventDefault()}}}function Y(e,n){return!!n&&(\"/\"===e?e===n.pathname:n.pathname.includes(e))}function U(e,n){return Object.keys(e).reduce(function(t,a){return Array.isArray(n)?n.includes(a)||(t[a]=e[a]):a!==n&&(t[a]=e[a]),t},{})}function G(e){void 0===e&&(e=\"smooth\"),\"undefined\"!=typeof window&&window.scrollTo({top:0,behavior:e})}function J(){return\"undefined\"!=typeof window&&\"undefined\"!=typeof document?(window.innerWidth||0)-(document.documentElement.clientWidth||0):0}function K(e){return(e.scrollHeight||0)>(e.clientHeight||0)}function $(e){return(e.scrollWidth||0)>(e.clientWidth||0)}function Q(e,n){var t,a;return function(){var i=this,r=arguments;a?(clearTimeout(t),t=setTimeout(function(){Date.now()-a>=n&&(e.apply(i,r),a=Date.now())},n-(Date.now()-a))):(e.apply(i,r),a=Date.now())}}function X(e,n,t){c.highlight(e,n,t)}function ee(e,n){c.highlightAll(e,n)}function ne(e,n,t){c.highlightAllUnder(e,n,t)}function te(e,n,t){c.highlightElement(e,n,t)}function ae(e){var t=e.hidden,a=e.LinkElementType,i=void 0===a?\"a\":a,r=e.links,o=void 0===r?[]:r,l=e.location,c=void 0===l?\"undefined\"!=typeof window&&window.location:l,m=e.onLinkClick;return n.createElement(\"nav\",{className:s(\"navbar\",{\"display-none\":void 0!==t&&t},e.className)},n.createElement(\"ul\",null,o.map(function(e){var t=e.to||e.path||e.href,a=Y(t,c);return n.createElement(\"li\",{key:t},n.createElement(S,L({},U(e,[\"leftIcon\",\"rightIcon\"]),{activeClassName:\"\",\"aria-current\":a?\"page\":\"false\",\"aria-label\":e.name,className:s({active:a}),ElementType:e.ElementType||i,onClick:function(){m&&m(e)},unstyled:!0}),e.leftIcon&&n.createElement(H,{className:\"margin-right-md\",name:e.leftIcon,size:\"small\"}),e.name,e.rightIcon&&n.createElement(H,{className:\"margin-left-md\",name:e.rightIcon,size:\"small\"})))})))}function ie(e){var n=e.children,i=e.rootElement,r=void 0===i?\"#root\":i,o=t(null),l=o[0],s=o[1];return a(function(){s(\"undefined\"!=typeof document?document.querySelector(r):null)},[r]),l?m(n,l):null}H.size=Object.freeze({inherit:\"inherit\",sm:\"sm\",small:\"small\",md:\"md\",medium:\"medium\",lg:\"lg\",large:\"large\",xl:\"xl\",extraLarge:\"extraLarge\"}),H.theme=Object.freeze({light:\"light\",dark:\"dark\"}),H.propTypes={ariaHidden:e.bool,children:e.node,className:e.string,inactive:e.bool,material:e.bool,name:e.string,size:e.oneOf(Object.keys(H.size)),theme:e.oneOf(Object.values(H.theme))},ae.propTypes={className:e.string,hidden:e.bool,LinkElementType:e.elementType,links:e.arrayOf(e.shape(S.propTypes)),location:e.object,onLinkClick:e.func},ie.propTypes={children:e.node.isRequired,rootElement:e.string};var re=[\"altText\",\"backgroundColor\",\"className\",\"ElementType\",\"foregroundColor\",\"icon\",\"iconName\",\"innerPadding\",\"rounded\",\"size\"];function oe(e){var t=e.backgroundColor,a=e.className,i=e.ElementType,r=void 0===i?\"i\":i,o=e.foregroundColor,l=e.icon,c=e.iconName,m=e.innerPadding,d=void 0===m?8:m,u=e.rounded,p=void 0!==u&&u,g=e.size,h=void 0===g?24:g,f=_(e,re);return n.createElement(r,L({},f,{className:s(\"icon\",\"social-icon\",{\"social-icon--rounded\":p},c,a),style:{backgroundColor:t,fill:o,width:h,height:h,padding:d}}),l||T[c])}function le(e){var t=e.backgroundColor,a=e.foregroundColor,i=e.hidden,r=e.iconInnerPadding,o=void 0===r?16:r,l=e.iconSize,c=void 0===l?32:l,m=e.iconSpacing,d=e.links,u=void 0===d?[]:d,p=e.onLinkClick,g=e.rounded,h=void 0!==g&&g,f=e.wrap,v=void 0!==f&&f;return n.createElement(\"div\",{className:s(\"social-nav-links\",{\"display-none\":void 0!==i&&i},e.className)},n.createElement(\"ul\",{className:s(\"social-nav-links__list\",{\"flex-wrap\":v})},u.map(function(e){var i=\"string\"==typeof e?z[e]:e;return n.createElement(\"li\",{className:\"social-nav-links__item\",key:i.key,style:{margin:m}},n.createElement(oe,{\"aria-label\":i.name,backgroundColor:t,ElementType:\"a\",foregroundColor:a||i.color,href:i.url,icon:i.icon,iconName:i.key,innerPadding:o,onClick:function(){p&&p(i)},rel:\"noopener noreferrer\",rounded:h,size:c,target:\"_blank\"}))})))}function se(e,n){var i=\"undefined\"!=typeof window?window.matchMedia(e):null,r=t(i),o=r[0],l=r[1],s=t(Boolean(o&&o.matches)),c=s[0],m=s[1];return a(function(){\"undefined\"!=typeof window&&l(window.matchMedia(e))},[e]),a(function(){var e,t=o;return t&&W(t,\"change\",e=function(){m(t.matches),n&&n(t.matches)}),function(){t&&e&&D(t,\"change\",e)}},[o,n]),c}oe.propTypes={altText:e.string,backgroundColor:e.string,className:e.string,ElementType:e.elementType,foregroundColor:e.string,icon:e.element,iconName:e.oneOf(Object.keys(T)),innerPadding:e.oneOfType([e.number,e.string]),rounded:e.bool,size:e.oneOfType([e.number,e.string])},le.propTypes={backgroundColor:e.string,className:e.string,foregroundColor:e.string,hidden:e.bool,iconInnerPadding:e.oneOfType([e.number,e.string]),iconSize:e.oneOfType([e.number,e.string]),iconSpacing:e.oneOfType([e.number,e.string]),links:e.arrayOf(C),onLinkClick:e.func,rounded:e.bool,wrap:e.bool};var ce={sm:576,small:576,md:768,medium:768,lg:992,large:992,xl:1200,extraLarge:1200};function me(e){return se(\"(min-width: \"+e+\")\")}function de(e){return se(\"(max-width: \"+e+\")\")}function ue(e){return se(\"(min-width: \"+ce[e]+\"px)\")}function pe(e){return se(\"(max-width: \"+(ce[e]-1)+\"px)\")}function ge(e,n,t){void 0===e&&(e=[]),void 0===t&&(t=function(){return null});var a=e.find(function(e){return t(n,e)});return a?a.documentTitle:null}function he(e){var n=t(!0),i=n[0],r=n[1],o=function(){r(!1)};return a(function(){var n=e.current;return n&&i&&(n.complete?o():W(n,\"load\",o)),function(){n&&D(n,\"load\",o)}},[e,i]),i}function fe(e,n){void 0===n&&(n=function(){});var t=!he(e);return a(function(){t&&n()},[t,n]),t}function ve(e,n){var i=t(function(){return function(e,n){if(\"undefined\"==typeof window||!localStorage)return n;var t=localStorage.getItem(e);return t&&JSON.parse(t)||n}(e,n)}),r=i[0],o=i[1];return a(function(){\"undefined\"!=typeof window&&localStorage&&localStorage.setItem(e,JSON.stringify(r))},[e,r]),[r,o]}function ye(e,n){void 0===e&&(e=!1),void 0===n&&(n=!0),a(function(){if(\"undefined\"!=typeof document)if(e){if(n){var t=J();t>0&&(document.body.style.paddingRight=t+\"px\")}document.body.classList.add(\"overflow-hidden\")}else document.body.classList.remove(\"overflow-hidden\"),n&&(document.body.style.paddingRight=null)},[e,n])}function be(){var e=t(!1),n=e[0],i=e[1];return a(function(){i(!0)},[]),n}function Ee(e,n,i){void 0===n&&(n=6),void 0===i&&(i=void 0);var r=t(0),o=r[0],l=r[1],s=o*n,c=s+n,m=Math.ceil(e.length/n);return a(function(){if(i&&\"undefined\"!=typeof sessionStorage){var e=sessionStorage.getItem(i),n=parseInt(e,10);Number.isNaN(n)||l(n),sessionStorage.removeItem(i)}},[i,e]),[{page:o,paginated:m>1,currentPage:o,totalPages:m,itemsPerPage:n,items:e.slice(s,c)},l]}function we(e,n,r){void 0===r&&(r=void 0);var o=t(\"\"),l=o[0],s=o[1],c=t(null),m=c[0],d=c[1],u=i(function(t){var a=t.toLowerCase().replace(\" \",\"\").trim();return e.filter(function(e){return n(e,a)})},[e,n]);return a(function(){if(r&&e.length>0&&\"undefined\"!=typeof sessionStorage){var n=sessionStorage.getItem(r);n&&(s(n),d(u(n))),sessionStorage.removeItem(r)}},[r,e,u]),[{query:l,results:m,value:l,onChange:function(e){s(e.target.value)},onSearch:function(e){d(e?u(e):null)}},s,d]}var Ne=r({theme:\"dark\",setTheme:function(){},toggleTheme:function(){}});function ke(e){void 0===e&&(e=\"light\");var n=ve(\"theme\",e),t=n[0],a=n[1],r=i(function(){a(\"dark\"===t?\"light\":\"dark\")},[t,a]);return\"undefined\"!=typeof window&&document&&document.documentElement&&document.documentElement.style.setProperty(\"color-scheme\",t),[t,a,r]}function xe(){var e=t((\"undefined\"!=typeof document?document.querySelector('link[rel*=\"icon\"]'):null)||function(){if(\"undefined\"!=typeof document){var e=document.createElement(\"link\");return e.setAttribute(\"rel\",\"favicon icon\"),document.head.appendChild(e),e}return null}())[0],n=se(\"(prefers-color-scheme:light)\"),a=se(\"(prefers-color-scheme:dark)\"),i=null;if(\"undefined\"!=typeof document&&(n?i=document.querySelector('link[rel*=\"icon\"][media=\"(prefers-color-scheme:light)\"]'):a&&(i=document.querySelector('link[rel*=\"icon\"][media=\"(prefers-color-scheme:dark)\"]'))),i&&e){var r=new URL(i.href);e.setAttribute(\"type\",i.type),e.setAttribute(\"href\",r.pathname)}return e}function Te(e){var i=e.animated,r=void 0!==i&&i,o=e.className,l=e.hideSocialLinks,c=void 0===l||l,m=e.LinkElementType,d=void 0===m?\"a\":m,u=e.links,p=void 0===u?[]:u,g=e.location,h=void 0===g?\"undefined\"!=typeof window&&window.location:g,f=e.onLinkClick,v=e.rootElement,y=e.socialLinks,b=void 0===y?[]:y,E=e.theme,w=t(!1),N=w[0],k=w[1];return ye(N,!0),a(function(){k(!1)},[h]),n.createElement(n.Fragment,null,n.createElement(\"button\",{\"aria-label\":N?\"Close\":\"Open\",className:\"navmenu__button\",onClick:function(){return k(!N)},size:\"small\",style:{zIndex:N?1055:void 0}},n.createElement(H,{name:N?\"close\":\"menu\",material:!0})),N&&n.createElement(ie,{rootElement:v},n.createElement(\"div\",{className:s(\"navmenu\",{\"navmenu--open\":N,\"navmenu--closed\":!N},{\"navmenu--animated\":r},o),\"data-theme\":E},n.createElement(\"div\",{className:\"navmenu__overlay\"}),n.createElement(\"div\",{className:\"navmenu__container container\"},n.createElement(\"div\",{className:\"navmenu__wrapper\"},n.createElement(\"ul\",{className:\"navmenu__list\"},p.map(function(e){var t=e.to||e.path||e.href,a=Y(t,h);return n.createElement(\"li\",{className:\"navmenu__item\",key:t},n.createElement(S,L({},U(e,[\"leftIcon\",\"rightIcon\"]),{activeClassName:\"\",\"aria-current\":a?\"page\":\"false\",\"aria-label\":e.name,className:s({active:a}),ElementType:e.ElementType||d,onClick:function(){f&&f(e)},unstyled:!0}),e.name))})),!c&&n.createElement(le,{foregroundColor:\"inherit\",iconInnerPadding:10,iconSize:20,links:Object.values(b)}))))))}function Ce(e){var t=e.bordered,a=e.fluid,i=void 0!==a&&a,r=e.hideLogo,o=void 0!==r&&r,l=e.hideNavigation,c=void 0!==l&&l,m=e.hideSocialLinks,d=void 0!==m&&m,u=e.LinkElementType,p=void 0===u?\"a\":u,g=e.links,h=void 0===g?[]:g,f=e.location,v=void 0===f?\"undefined\"!=typeof window&&window.location:f,y=e.logoSize,b=void 0===y?M.size.small:y,E=e.logoVariant,w=void 0===E?M.variant.wordmark:E,N=e.onLogoClick,k=e.onLinkClick,x=e.onSocialLinkClick,T=e.rootElement,C=e.socialLinks,z=void 0===C?[]:C,O=e.sticky,L=e.theme,_=e.transparent;return n.createElement(\"header\",{className:s(\"app-header\",{\"app-header--bordered\":void 0!==t&&t},{\"app-header--transparent\":void 0!==_&&_},{\"app-header--sticky\":void 0!==O&&O},e.className),\"data-theme\":L},n.createElement(\"div\",{className:s({container:!i,\"container-fluid\":i})},n.createElement(\"div\",{className:\"app-header__content left\"},!o&&n.createElement(M,{onClick:N,size:b,variant:w}),!c&&n.createElement(ae,{LinkElementType:p,links:h,location:v,onLinkClick:k,theme:L})),n.createElement(\"div\",{className:\"app-header__content right\"},!d&&z&&z.length>0&&n.createElement(le,{iconInnerPadding:10,iconSize:20,links:z,onLinkClick:x}),!c&&n.createElement(Te,{hideSocialLinks:d,LinkElementType:p,links:h,location:v,logoSize:b,logoVariant:w,onLinkClick:k,onLogoClick:N,rootElement:T,socialLinks:z,theme:L}))))}function ze(e,n){return void 0===e&&(e=\"en-us\"),void 0===n&&(n=e),{ios:\"https://linkmaker.itunes.apple.com/images/badges/\"+e+\"/badge_appstore-lrg.svg\",android:\"https://raw.github.com/yjb94/google-play-badge-svg/master/img/\"+n+\"_get.svg?sanitize=true\"}}function Oe(e){var a=e.alt,i=void 0===a?\"Download on the App Store\":a,r=e.className,l=e.defaultLocale,c=void 0===l?\"en-us\":l,m=e.locale,d=void 0===m?\"undefined\"!=typeof navigator&&navigator.language||c:m,u=e.platform,p=e.width,g=void 0===p?200:p,h=e.height,f=void 0===h?g/3.375:h,v=e.target,y=void 0===v?\"_blank\":v,b=e.url,E=d=d.toLowerCase();-1===[\"zh-cn\",\"zh-tw\"].indexOf(d)&&(E=d.split(/[_-]/)[0]);var w=t(ze(d,E)),N=w[0],k=w[1];return o(function(){k(ze(d,E))},[d,E]),n.createElement(\"a\",{className:s(\"app-store-badge\",r),href:b,target:y,style:{width:g,height:f}},n.createElement(\"img\",{alt:i||\"\",src:N[u],onError:function(){k(ze(c,E))}}))}function Le(e){var t,a=e.className,i=e.direction,r=void 0===i?\"right\":i,o=e.LinkElementType,l=void 0===o?\"a\":o,c=e.links,m=void 0===c?[]:c,d=e.theme;return n.createElement(\"div\",{className:s(\"app-utility-bar\",(t={},t[\"app-utility-bar--\"+r]=r,t),a),\"data-theme\":d},n.createElement(\"div\",{className:\"container\"},n.createElement(\"div\",{className:\"row\"},n.createElement(\"div\",{className:\"col font-xs font-weight-500\"},m.map(function(e){return n.createElement(S,L({},e,{\"aria-label\":e.name,className:\"color-inherit margin-left-md margin-right-md\",ElementType:e.ElementType||l,key:e.to||e.path||e.href}),e.name)})))))}function _e(e){var t,a=e.children,i=e.className,r=e.pill,o=void 0!==r&&r,l=e.type,c=void 0===l?\"solid\":l;return n.createElement(\"div\",{className:s(\"badge\",(t={},t[\"badge--\"+c]=c,t),{\"badge--pill\":o},i)},a)}Te.propTypes={animated:e.bool,className:e.string,hideSocialLinks:e.bool,LinkElementType:e.elementType,links:e.arrayOf(e.shape(S.propTypes)),location:e.object,onLinkClick:e.func,rootElement:e.string,socialLinks:e.arrayOf(C),theme:e.string},Ce.propTypes={bordered:e.bool,className:e.string,fluid:e.bool,hideLogo:e.bool,hideNavigation:e.bool,hideSocialLinks:e.bool,LinkElementType:e.elementType,links:e.arrayOf(e.shape(S.propTypes)),location:e.object,logoSize:e.oneOf(Object.values(M.size)),logoVariant:e.oneOf(Object.values(M.variant)),onLogoClick:e.func,onLinkClick:e.func,onSocialLinkClick:e.func,rootElement:e.string,socialLinks:e.arrayOf(C),sticky:e.bool,theme:e.string,transparent:e.bool},Oe.platform=Object.freeze({ios:\"ios\",android:\"android\"}),Oe.propTypes={alt:e.string,className:e.string,defaultLocale:e.string,locale:e.string,platform:e.oneOf(Object.values(Oe.platform)).isRequired,width:e.number,height:e.number,target:e.string,url:e.string.isRequired},Le.propTypes={className:e.string,direction:e.oneOf([\"left\",\"right\"]),LinkElementType:e.elementType,links:e.arrayOf(e.shape(S.propTypes)),theme:e.string},_e.type=Object.freeze({solid:\"solid\",outline:\"outline\"}),_e.propTypes={children:e.node,className:e.string,pill:e.bool,type:e.oneOf(Object.values(_e.type))};var je=[\"children\",\"className\",\"color\",\"icon\",\"iconElement\",\"iconName\",\"onClick\",\"shape\",\"size\",\"style\",\"styles\"];function Se(e){var t,a,i,r,o=e.children,l=e.className,c=e.color,m=void 0===c?\"default\":c,d=e.icon,u=e.iconElement,p=e.iconName,g=e.onClick,h=e.shape,f=void 0===h?\"rounded-corners\":h,v=e.size,y=void 0===v?\"small\":v,b=e.style,E=void 0===b?\"solid\":b,w=e.styles,N=_(e,je);return n.createElement(\"button\",L({className:s(\"btn\",(t={},t[\"btn--\"+m]=m,t),(a={},a[\"btn--\"+f]=f,a),(i={},i[\"btn--\"+E]=E,i),(r={},r[\"btn--\"+y]=y,r),{\"btn--icon-only\":\"only\"===d},l),onClick:g,style:w},N),\"left\"===d&&n.createElement(\"span\",{\"aria-hidden\":!0,className:\"icon-wrapper margin-right-md\"},u||n.createElement(H,{name:p,size:\"inherit\"})),\"only\"===d?n.createElement(\"span\",{\"aria-hidden\":!0,className:\"icon-wrapper\"},n.createElement(H,{name:p,size:\"inherit\"})):o,\"right\"===d&&n.createElement(\"span\",{\"aria-hidden\":!0,className:\"icon-wrapper margin-left-md\"},u||n.createElement(H,{name:p,size:\"inherit\"})))}function Ie(e){var t,a=e.children,i=e.className,r=e.layout,o=void 0===r?\"horizontal\":r,l=e.spacing,c=void 0===l||l;return n.createElement(\"div\",{className:s(\"btn-group\",(t={},t[\"btn-group--\"+o]=o,t),{\"btn-group--spacing\":c},i)},a)}Se.color=Object.freeze({default:\"default\",primary:\"primary\",secondary:\"secondary\",tertiary:\"tertiary\",success:\"success\",danger:\"danger\",warning:\"warning\",info:\"info\"}),Se.shape=Object.freeze({square:\"square\",roundedCorners:\"rounded-corners\",rounded:\"rounded\",circle:\"circle\"}),Se.size=Object.freeze({sm:\"sm\",small:\"small\",md:\"md\",medium:\"medium\",lg:\"lg\",large:\"large\"}),Se.style=Object.freeze({solid:\"solid\",outline:\"outline\",text:\"text\",none:\"unstyled\"}),Se.propTypes={children:e.node,className:e.string,color:e.oneOf(Object.values(Se.color)),icon:e.oneOf([\"left\",\"right\",\"only\"]),iconElement:e.element,iconName:e.string,onClick:e.func,shape:e.oneOf(Object.values(Se.shape)),size:e.oneOf(Object.values(Se.size)),style:e.oneOf(Object.values(Se.style)),styles:e.object},Ie.layout=Object.freeze({horizontal:\"horizontal\",vertical:\"vertical\"}),Ie.propTypes={children:e.node,className:e.string,layout:e.oneOf(Object.values(Ie.layout)),spacing:e.bool};var Me=[\"children\",\"className\",\"external\",\"history\",\"link\",\"linkTarget\",\"onClick\"];function Pe(e){var t=e.children,a=e.className,i=e.external,r=e.history,o=e.link,l=e.linkTarget,c=void 0===l?\"_blank\":l,m=e.onClick,d=_(e,Me);return n.createElement(\"div\",L({},d,{className:s(a,\"cursor-pointer\"),onClick:function(e){r&&o&&!i?r.push(o):\"undefined\"!=typeof window&&o&&i&&window.open(o,c),m&&m(e)},onKeyDown:Z(m),role:\"button\",tabIndex:\"0\"}),t)}function Ve(e){var t,i=e.children,r=e.language,o=void 0===r?\"none\":r,c=s(((t={})[\"language-\"+o]=o,t)),m=l();return a(function(){m.current&&m.current.querySelectorAll(\"pre code\").forEach(function(e){return te(e)})},[i,o,m]),n.createElement(\"pre\",{className:c,ref:m},n.createElement(\"code\",{className:c},i))}function He(e,n){var t,a;if(\"boolean\"==typeof n)return(t={})[\"col-\"+e]=n,t;if(\"number\"==typeof n||\"string\"==typeof n)return(a={})[\"col-\"+e+\"-\"+n]=!0,a;if(\"object\"==typeof n&&n){var i,r=n.size,o=n.order,l=n.offset;return(i={})[\"col-\"+e]=void 0===r,i[\"col-\"+e+\"-\"+r]=void 0!==r,i[\"order-\"+e+\"-\"+o]=void 0!==o,i[\"offset-\"+e+\"-\"+l]=void 0!==l,i}return null}function Ae(e){var t,a=e.children,i=e.className,r=e.gutters,o=e.sm,l=e.md,c=e.lg,m=e.xl;return n.createElement(\"div\",{className:s({col:!(o||l||c||m)},He(\"sm\",o),He(\"md\",l),He(\"lg\",c),He(\"xl\",m),(t={},t[\"gutters-\"+r]=r,t),i)},a)}Pe.propTypes={children:e.node,className:e.string,external:e.bool,history:e.shape({push:e.func.isRequired}),link:e.string,linkTarget:e.string,onClick:e.func},Ve.propTypes={children:e.node,language:e.string.isRequired};var Be=e.oneOfType([e.bool,e.number,e.string,e.shape({offset:e.oneOfType([e.number,e.string]),order:e.oneOfType([e.number,e.string]),size:e.oneOfType([e.number,e.string])})]);Ae.propTypes={children:e.node,className:e.string,gutters:e.oneOf([\"sm\",\"md\",\"lg\",\"none\"]),sm:Be,md:Be,lg:Be,xl:Be};var qe=n.forwardRef(function(e,t){var a=e.onSubmit,i=void 0===a?function(){}:a;return n.createElement(\"form\",{className:s(\"contact-form\",e.className),onSubmit:i,ref:t},n.createElement(\"input\",{\"aria-label\":\"Name\",id:\"contactName\",name:\"name\",placeholder:\"Name\",required:!0,type:\"text\"}),n.createElement(\"input\",{\"aria-label\":\"Email\",id:\"contactEmail\",name:\"email\",placeholder:\"Email\",required:!0,type:\"email\"}),n.createElement(\"textarea\",{\"aria-label\":\"Message\",id:\"contactMessage\",name:\"message\",placeholder:\"Message\",required:!0}),n.createElement(\"input\",{\"aria-label\":\"Send\",id:\"contactSubmit\",type:\"submit\",value:\"Send\"}))});function Re(e){var t,a=e.children,i=e.className,r=e.fluid;return n.createElement(\"div\",{className:s({container:!r},(t={},t[\"container-\"+r]=r&&\"string\"==typeof r,t),{\"container-fluid\":r&&\"boolean\"==typeof r},i)},a)}function Fe(e){var t=e.buttonText,a=void 0===t?\"Agree\":t,i=e.className,r=e.learnMoreLink,o=void 0===r?\"https://www.cookiesandyou.com/\":r,l=e.onConsent,c=void 0===l?function(){}:l,m=e.rootElement,u=e.theme,p=void 0===u?\"high-contrast\":u,g=d([\"cookieconsent_status\"]),h=g[1];return\"accepted\"===g[0].cookieconsent_status?null:n.createElement(ie,{rootElement:m},n.createElement(\"div\",{className:s(\"cookie-consent\",i),\"data-theme\":p},n.createElement(\"div\",{className:\"cookie-consent__container\"},n.createElement(\"span\",{className:\"cookie-consent__text font-sm\"},n.createElement(\"span\",{className:\"margin-right-md\"},\"This website uses cookies to ensure you get the best experience on our website.\"),o&&n.createElement(S,{className:\"color-inherit\",to:o,external:!0,underlined:!0},\"Learn more\")),n.createElement(Se,{className:\"cookie-consent__button\",color:Se.color.default,shape:Se.shape.square,size:Se.size.medium,onClick:function(){h(\"cookieconsent_status\",\"accepted\",{path:\"/\"}),c(!0)}},a))))}function We(e){var t=e.loading,a=e.size;return n.createElement(\"div\",{\"aria-hidden\":!0,className:s(\"loading-spinner\",{loading:void 0===t||t},void 0===a?\"medium\":a,e.className)},n.createElement(\"div\",{className:\"loading-spinner__animation\"},n.createElement(\"div\",null),n.createElement(\"div\",null),n.createElement(\"div\",null),n.createElement(\"div\",null)))}qe.displayName=\"ContactForm\",qe.propTypes={className:e.string,onSubmit:e.func},Re.propTypes={children:e.node,className:e.string,fluid:e.oneOfType([e.bool,e.oneOf([\"sm\",\"md\",\"lg\",\"xl\",\"fluid\"])])},Fe.propTypes={buttonText:e.string,className:e.string,learnMoreLink:e.string,onAgree:e.func,rootElement:e.string,theme:e.string},We.size=Object.freeze({sm:\"sm\",small:\"small\",md:\"md\",medium:\"medium\",lg:\"lg\",large:\"large\"}),We.propTypes={className:e.string,loading:e.bool,size:e.oneOf(Object.values(We.size))};var De=Object.freeze({xs:{width:320,height:180},extraSmall:{width:320,height:180},sm:{width:480,height:270},small:{width:480,height:270},md:{width:640,height:360},medium:{width:640,height:360},lg:{width:960,height:540},large:{width:960,height:540},xl:{width:1280,height:720},extraLarge:{width:1280,height:720}});function Ze(e){return null==e||\"string\"==typeof e&&(e.endsWith(\"%\")||e.endsWith(\"px\"))?e:e+\"px\"}function Ye(e){var t=e.allowFullScreen,a=void 0===t||t,i=e.className,r=e.frameBorder,o=void 0===r?\"0\":r,c=e.height,m=e.id,d=void 0===m?\"video-player\":m,u=e.scrolling,p=void 0===u?\"no\":u,g=e.size,h=e.src,f=e.title,v=void 0===f?\"Video Player\":f,y=e.width,b=l(),E=he(b),w=\"undefined\"!=typeof navigator&&!navigator.onLine,N=y||g&&De[g].width,k=c||g&&De[g].height;return n.createElement(\"div\",{className:s(\"embedded-video\",{loading:E},g,i),style:{width:Ze(N),height:Ze(k)}},n.createElement(\"div\",{className:s(\"embedded-video__wrapper\",\"transition\",\"fade-in\",{visible:!E})},n.createElement(\"iframe\",{allowFullScreen:a,frameBorder:o,height:k||\"100%\",id:d,ref:b,scrolling:p,src:h,title:v,width:N||\"100%\"})),E&&!w&&n.createElement(We,null))}Ye.size=De,Ye.propTypes={allowFullScreen:e.bool,className:e.string,frameBorder:e.string,height:e.oneOfType([e.string,e.number]),id:e.string,scrolling:e.string,size:e.oneOf(Object.keys(Ye.size)),src:e.string.isRequired,title:e.string,width:e.oneOfType([e.string,e.number])};var Ue=[\"channel\",\"className\",\"id\",\"muted\",\"secure\",\"title\"];function Ge(e){var t=e.channel,a=void 0===t?\"zigurous\":t,i=e.className,r=e.id,o=void 0===r?\"twitch-player\":r,l=e.muted,c=void 0===l||l,m=e.secure,d=void 0===m||m,u=e.title,p=void 0===u?\"Twitch\":u,g=_(e,Ue),h=d?\"https\":\"http\",f=[\"zigurous.com\",\"www.zigurous.com\"];return\"development\"===process.env.NODE_ENV&&f.push(\"localhost\"),n.createElement(Ye,L({className:s(\"twitch\",i),id:o,src:h+\"://player.twitch.tv/?channel=\"+a+\"&parent=\"+f.join(\"&parent=\")+\"&muted=\"+c,title:p},g))}Ge.propTypes={channel:e.string.isRequired,className:e.string,id:e.string,muted:e.bool,secure:e.bool,title:e.string};var Je=[\"autoplay\",\"captions\",\"className\",\"hideBranding\",\"hideControls\",\"hideInfo\",\"hideRelated\",\"id\",\"muted\",\"origin\",\"secure\",\"startTime\",\"title\",\"videoId\"];function Ke(e){var t=e.autoplay,a=void 0!==t&&t,i=e.captions,r=void 0!==i&&i,o=e.className,l=e.hideBranding,c=void 0!==l&&l,m=e.hideControls,d=void 0!==m&&m,u=e.hideInfo,p=void 0!==u&&u,g=e.hideRelated,h=void 0===g||g,f=e.id,v=void 0===f?\"youtube-player\":f,y=e.muted,b=void 0!==y&&y,E=e.origin,w=e.secure,N=void 0===w||w,k=e.startTime,x=e.title,T=void 0===x?\"YouTube\":x,C=e.videoId,z=_(e,Je),O=\"enablejsapi=1\";O+=\"&origin=\"+E,h&&(O+=\"&rel=0\"),d&&(O+=\"&controls=0\"),p&&(O+=\"&showinfo=0\"),c&&(O+=\"&modestbranding=1\"),r&&(O+=\"&cc_load_policy=1\"),a&&(O+=\"&autoplay=1\"),b&&(O+=\"&mute=1\"),k&&(O+=\"&start=\"+k);var j=N?\"https\":\"http\";return n.createElement(Ye,L({className:s(\"youtube\",o),id:v,src:j+\"://www.youtube.com/embed/\"+C+\"?\"+O,title:T},z))}Ke.propTypes={autoplay:e.bool,captions:e.bool,className:e.string,hideBranding:e.bool,hideControls:e.bool,hideInfo:e.bool,hideRelated:e.bool,id:e.string,muted:e.bool,origin:e.string.isRequired,secure:e.bool,startTime:e.oneOf([e.number,e.string]),title:e.string,videoId:e.string.isRequired};var $e=[\"className\",\"disabled\",\"icon\",\"iconAlignment\",\"onBlur\",\"onChange\",\"onFocus\",\"placeholder\",\"size\",\"type\",\"value\"];function Qe(e){var a,i,r=e.className,o=e.disabled,l=e.icon,c=e.iconAlignment,m=void 0===c?\"right\":c,d=e.onBlur,u=void 0===d?function(){}:d,p=e.onChange,g=void 0===p?function(){}:p,h=e.onFocus,f=void 0===h?function(){}:h,v=e.placeholder,y=e.size,b=e.type,E=e.value,w=_(e,$e),N=t(!1),k=N[0],x=N[1];return n.createElement(\"div\",{className:s(\"input-wrapper\",(a={},a[\"input-wrapper--\"+y]=y,a),(i={},i[\"input-wrapper--icon-\"+m]=l&&m,i),{focus:k,disabled:o},r)},n.createElement(\"input\",L({className:\"input-wrapper__input\",disabled:o,onBlur:function(){x(!1),u()},onChange:g,onFocus:function(){x(!0),f()},placeholder:v,type:b,value:E},w)),l&&n.createElement(H,{className:\"input-wrapper__icon\",name:l,size:\"md\"}))}function Xe(e){var t=e.alt,a=e.animated,i=void 0===a||a,r=e.className,o=e.height,c=e.imageClassName,m=e.ImageElementType,d=void 0===m?\"img\":m,u=e.imageProps,p=void 0===u?{}:u,g=e.onLoad,h=void 0===g?function(){}:g,f=e.placeholder,v=e.placeholderClassName,y=e.placeholderProps,b=void 0===y?{}:y,E=e.showLoadingSpinner,w=void 0!==E&&E,N=e.src,k=e.width,x=l(),T=fe(x,h);return n.createElement(\"picture\",{className:s(\"progressive-image\",{\"progressive-image--loaded\":T},{\"progressive-image--animated\":i},{\"progressive-image--no-placeholder\":!f},r)},n.createElement(d,L({},p,{alt:p.alt||t,className:s(\"progressive-image__source\",\"img-fluid\",c,p.className),width:k||p.width,height:o||p.height,ref:x,src:N})),f&&n.createElement(d,L({},b,{alt:b.alt||t,className:s(\"progressive-image__placeholder\",\"img-fluid\",v,b.className),width:k||b.width||p.width,height:o||b.height||p.height,src:f})),w&&!T&&n.createElement(We,null))}function en(e){return\"string\"==typeof e?e:e.src}function nn(e){return e?e+\"px\":void 0}function tn(e,n,t){return\"repeat(\"+(e||\"auto-fit\")+\", minmax(\"+(nn(n)||0)+\", \"+(nn(t)||\"1fr\")+\"))\"}function an(e){var a=e.animated,i=void 0!==a&&a,r=e.animation,o=void 0===r?\"fade-in-up\":r,l=e.className,c=e.columns,m=e.fullWidthFirstItem,d=void 0!==m&&m,p=e.images,g=void 0===p?[]:p,h=e.maxWidth,f=e.minWidth,v=t(!1),y=v[0],b=v[1],E=t(0),w=E[0],N=E[1];return n.createElement(\"div\",{className:s(\"image-gallery\",l)},n.createElement(\"div\",{className:\"image-gallery__thumbnails\",style:{gridTemplateColumns:tn(c,f,h)}},g.map(function(e,t){var a,r=\"object\"==typeof e,l=r?e.src:e,c=r&&e.id||l;return n.createElement(\"button\",{\"aria-label\":\"Image Thumbnail\",className:s(\"image-gallery__thumbnail\",{\"image-gallery__thumbnail--full-width\":0===t&&d},(a={\"animation-short\":i},a[\"animation-delay-\"+(t+1)]=i,a[o]=i,a),r&&e.className),key:c,onClick:function(){N(t),b(!0)}},n.createElement(Xe,{imageProps:r?U(e,\"className\"):{},src:l}))})),y&&n.createElement(u,{enableZoom:!1,mainSrc:en(g[w]),nextSrc:en(g[(w+1)%g.length]),prevSrc:en(g[(w+g.length-1)%g.length]),onCloseRequest:function(){b(!1)},onMovePrevRequest:function(){N((w+g.length-1)%g.length)},onMoveNextRequest:function(){N((w+1)%g.length)},wrapperClassName:\"image-gallery__lightbox\"}))}function rn(e){var t,a=e.children,i=e.className,r=e.footer,o=e.footerAlignment,l=void 0===o?\"left\":o,c=e.id,m=e.onRequestClose,d=void 0===m?function(){}:m,u=e.open,p=void 0!==u&&u,g=e.rootElement,h=e.theme,f=e.title;return ye(p,!0),p?n.createElement(ie,{rootElement:g},n.createElement(\"div\",{className:s(\"modal\",{\"modal--open\":p},i),id:c,role:\"dialog\",tabIndex:\"-1\",\"data-theme\":h},n.createElement(\"div\",{className:\"modal__dialog\",role:\"document\"},n.createElement(\"div\",{className:\"modal__content\"},n.createElement(\"div\",{className:\"modal__header\"},n.createElement(\"div\",{className:\"modal__title h5\"},f),n.createElement(Se,{className:\"modal__close-button\",icon:\"only\",iconName:\"close\",onClick:d,size:Se.size.medium,style:Se.style.none})),n.createElement(\"div\",{className:\"modal__body\"},a),r&&n.createElement(\"div\",{className:s(\"modal__footer\",(t={},t[\"modal__footer--\"+l+\"-aligned\"]=l,t))},r))))):null}function on(e){var t,a=e.backgroundColor,i=e.children,r=e.className,o=e.size,l=void 0===o?\"medium\":o,c=e.style,m=e.theme,d=e.transparent,u=void 0!==d&&d;return n.createElement(\"div\",{className:s(\"page-banner\",(t={},t[\"page-banner--\"+l]=l,t),{\"page-banner--transparent\":u},r),\"data-theme\":m,style:L({backgroundColor:a},c)},i)}function ln(e){for(var t=e.className,a=e.currentPage,i=void 0===a?0:a,r=e.onPageChange,o=void 0===r?function(){}:r,l=e.totalPages,c=[],m=function(e){c.push(n.createElement(Se,{className:s({active:i===e}),key:e,onClick:function(){return o(e)},size:\"md\",style:Se.style.outline},e+1))},d=0;d=l-1,icon:\"only\",iconName:\"chevron_right\",onClick:function(){return o(i+1)},size:\"md\",style:Se.style.outline}))}function sn(e){var t,a=e.children,i=e.className,r=e.gutters;return n.createElement(\"div\",{className:s(\"row\",(t={},t[\"gutters-\"+r]=r,t),i)},a)}Qe.size=Object.freeze({sm:\"sm\",small:\"small\",md:\"md\",medium:\"medium\",lg:\"lg\",large:\"large\"}),Qe.iconAlignment=Object.freeze({left:\"left\",right:\"right\"}),Qe.propTypes={className:e.string,disabled:e.bool,icon:e.string,iconAlignment:e.oneOf(Object.values(Qe.iconAlignment)),onBlur:e.func,onChange:e.func,onFocus:e.func,placeholder:e.string,size:e.oneOf(Object.values(Qe.size)),type:e.string,value:e.any},Xe.propTypes={alt:e.string,animated:e.bool,className:e.string,height:e.oneOfType([e.string,e.number]),imageClassName:e.string,ImageElementType:e.elementType,imageProps:e.object,onLoad:e.func,placeholder:e.string,placeholderClassName:e.string,placeholderProps:e.object,showLoadingSpinner:e.bool,src:e.string,width:e.oneOfType([e.string,e.number])},an.propTypes={animated:e.bool,animation:e.string,className:e.string,columns:e.number,fullWidthFirstItem:e.bool,images:e.arrayOf(e.oneOfType([e.shape({alt:e.string,className:e.string,id:e.string,src:e.string.isRequired}),e.string])),maxWidth:e.number,minWidth:e.number},rn.propTypes={children:e.node,className:e.string,footer:e.element,footerAlignment:e.oneOf([\"left\",\"right\"]),id:e.string,onRequestClose:e.func,open:e.bool,rootElement:e.string,theme:e.string,title:e.string},on.size=Object.freeze({xs:\"xs\",extraSmall:\"extraSmall\",sm:\"sm\",small:\"small\",md:\"md\",medium:\"medium\",lg:\"lg\",large:\"large\",xl:\"xl\",extraLarge:\"extraLarge\"}),on.propTypes={backgroundColor:e.string,children:e.node,className:e.string,size:e.oneOf(Object.values(on.size)),style:e.object,theme:e.string,transparent:e.bool},ln.propTypes={className:e.string,currentPage:e.number,onPageChange:e.func,totalPages:e.number.isRequired},sn.propTypes={children:e.node,className:e.string,gutters:e.oneOf([\"sm\",\"md\",\"lg\",\"none\"])};var cn=[\"className\",\"debounceRate\",\"disabled\",\"onChange\",\"onSearch\",\"placeholder\"];function mn(e){var t=e.className,a=e.debounceRate,r=void 0===a?500:a,o=e.disabled,l=e.onChange,c=void 0===l?function(){}:l,m=e.onSearch,d=void 0===m?function(){}:m,u=e.placeholder,p=_(e,cn),g=i(F(function(e){return d(e)},r),[r,d]);return n.createElement(Qe,L({\"aria-label\":\"Search\",className:s(\"search-input\",t),disabled:o,icon:\"search\",iconAlignment:\"left\",onChange:function(e){var n=e.target.value;c(e),g(n)},onKeyDown:Z(function(e){return e.target.blur()}),placeholder:u||\"Search\"},p))}function dn(e){var i=e.animated,r=void 0===i||i,o=e.children,l=e.className,c=e.hideOverlay,m=void 0!==c&&c,d=e.location,u=e.rootElement,p=e.theme,g=t(!1),h=g[0],f=g[1];return ye(h,!0),a(function(){f(!1)},[d]),n.createElement(n.Fragment,null,n.createElement(\"button\",{\"aria-label\":h?\"Close\":\"Open\",className:s(\"sidedrawer__button\"),onClick:function(){return f(!h)},size:\"small\"},n.createElement(H,{name:h?\"close\":\"menu\",material:!0})),n.createElement(ie,{rootElement:u},n.createElement(\"div\",{className:s(\"sidedrawer\",{\"sidedrawer--open\":h,\"sidedrawer--closed\":!h},{\"sidedrawer--animated\":r},l),\"data-theme\":p},!m&&n.createElement(Pe,{className:\"sidedrawer__overlay\",onClick:function(){return f(!1)}}),n.createElement(\"div\",{className:\"sidedrawer__container\"},o))))}mn.propTypes={className:e.string,debounceRate:e.number,disabled:e.bool,onChange:e.func,onSearch:e.func,placeholder:e.string},dn.propTypes={animated:e.bool,className:e.string,children:e.node,hideOverlay:e.bool,location:e.object,rootElement:e.string,theme:e.string};var un=[\"children\",\"className\",\"link\",\"LinkElementType\",\"primaryColor\",\"secondaryColor\",\"size\",\"url\"];function pn(e){var t=e.children,a=e.className,i=e.link,r=e.LinkElementType,o=e.primaryColor,l=e.secondaryColor,c=e.size,m=void 0===c?Se.size.medium:c,d=e.url,u=_(e,un),p=\"string\"==typeof i?z[i]:i,g=o||p.color;return n.createElement(S,{ElementType:r,external:!0,to:d||p.url,unstyled:!0},n.createElement(Se,L({className:s(\"social-button\",p.key,a),icon:\"left\",iconElement:p.icon&&n.createElement(oe,{\"aria-hidden\":!0,ElementType:\"i\",icon:p.icon,iconName:p.key,innerPadding:0,size:\"100%\"}),size:m,styles:{\"--btn-color-primary\":g,\"--btn-color-secondary\":l,\"--btn-color-emphasis\":g},tabIndex:-1},u),t||p.name))}function gn(e){var t,a=e.alignItems,i=e.children,r=e.direction,o=void 0===r?\"column\":r,l=e.justifyContent,c=e.reversed,m=void 0!==c&&c,d=e.wrap;return n.createElement(\"div\",{className:s(\"display-flex\",{\"flex-row\":\"row\"===o&&!m,\"flex-row-reverse\":\"row\"===o&&m,\"flex-column\":\"column\"===o&&!m,\"flex-column-reverse\":\"column\"===o&&m,\"flex-wrap\":void 0!==d&&d},(t={},t[\"justify-content-\"+l]=l,t[\"align-items-\"+a]=a,t))},i)}pn.shape=Se.shape,pn.size=Se.size,pn.style=Se.style,pn.propTypes={children:e.node,className:e.string,link:C.isRequired,LinkElementType:e.elementType,primaryColor:e.string,secondaryColor:e.string,size:e.oneOf(Object.values(Se.size)),url:e.string},gn.direction=Object.freeze({row:\"row\",column:\"column\"}),gn.alignItems=Object.freeze({start:\"start\",end:\"end\",center:\"center\",stretch:\"stretch\",baseline:\"baseline\"}),gn.justifyContent=Object.freeze({start:\"start\",end:\"end\",center:\"center\",between:\"between\",around:\"around\",evenly:\"evenly\"}),gn.propTypes={alignItems:e.oneOf(Object.values(gn.alignItems)),children:e.node,direction:e.oneOf(Object.values(gn.direction)),justifyContent:e.oneOf(Object.values(gn.justifyContent)),reversed:e.bool,wrap:e.bool};var hn=e.oneOf([\"inherit\",\"transparent\",\"black\",\"white\",\"foreground\",\"foreground-muted\",\"foreground-subtle\",\"background\",\"surface-0\",\"surface-1\",\"surface-2\",\"surface-3\",\"surface-4\",\"surface-5\",\"surface-6\",\"surface-7\",\"surface-8\",\"surface-9\",\"border\",\"default\",\"primary\",\"secondary\",\"tertiary\",\"success\",\"danger\",\"warning\",\"info\"]),fn=e.oneOf([1,2,3,4,5,6,\"1\",\"2\",\"3\",\"4\",\"5\",\"6\"]),vn=e.oneOf([\"xxxl\",\"xxl\",\"xl\",\"lg\",\"md\",\"sm\",\"xs\",\"xxs\",\"xxxs\"]),yn=e.oneOf([100,200,300,400,500,600,700,800,900,\"100\",\"200\",\"300\",\"400\",\"500\",\"600\",\"700\",\"800\",\"900\"]),bn=e.oneOf([\"0\",\"none\",\"xs\",\"sm\",\"md\",\"lg\",\"xl\",\"xxl\",\"xxxl\",\"2xl\",\"2xxl\",\"2xxxl\",\"1em\",\"2em\",\"3em\",\"4em\",\"5em\",\"6em\",\"7em\",\"8em\"]);function En(e){var t,a,i,r,o=e.bold,l=e.children,c=e.className,m=e.color,d=e.italic,u=e.marginBottom,p=e.marginTop,g=e.size,h=e.tag;return n.createElement(void 0===h?\"p\":h,{className:s((t={},t[\"font-\"+g]=g,t),(a={},a[\"color-\"+m]=m,a),(i={},i[\"margin-top-\"+p]=p,i),(r={},r[\"margin-bottom-\"+u]=u,r),c)},o?n.createElement(\"b\",null,d?n.createElement(\"em\",null,l):l):d?n.createElement(\"em\",null,l):l)}En.propTypes={bold:e.bool,children:e.node,className:e.string,color:hn,italic:e.bool,marginBottom:bn,marginTop:bn,size:vn,tag:e.elementType};var wn=[\"alt\",\"animated\",\"animation\",\"children\",\"className\",\"ElementType\",\"height\",\"image\",\"imageClassName\",\"ImageElementType\",\"imageProps\",\"index\",\"placeholder\",\"placeholderClassName\",\"placeholderProps\",\"rounded\",\"shadow\",\"style\",\"width\"];function Nn(e){var i,r=e.alt,o=e.animated,c=void 0!==o&&o,m=e.animation,d=void 0===m?\"fade-translate-in\":m,u=e.children,p=e.className,g=e.ElementType,h=void 0===g?\"a\":g,f=e.height,v=e.image,y=e.imageClassName,b=e.ImageElementType,E=void 0===b?\"img\":b,w=e.imageProps,N=void 0===w?{}:w,k=e.index,x=e.placeholder,T=e.placeholderClassName,C=e.placeholderProps,z=void 0===C?{}:C,O=e.rounded,j=void 0===O||O,S=e.shadow,I=void 0===S||S,M=e.width,P=_(e,wn),V=l(),H=t(!1),A=H[0],B=H[1];return a(function(){var e;return c&&A&&(e=setTimeout(function(){V&&V.current&&(V.current.style.animation=0)},600)),function(){e&&clearTimeout(e)}},[c,A,V]),n.createElement(h,L({},P,{className:s(\"thumbnail\",(i={\"animation-short\":c&&A},i[\"animation-delay-\"+(k+1)]=c&&A&&k>=0,i[d]=c&&A,i),{rounded:j,shadow:I},p),ref:V}),E&&n.createElement(Xe,{alt:r,height:f,imageClassName:y,ImageElementType:E,imageProps:N,onLoad:function(){return B(!0)},placeholder:x,placeholderClassName:T,placeholderProps:z,src:v,width:M}),u)}function kn(e){var t,a,i,r,o,l,c=e.bold,m=e.children,d=e.className,u=e.color,p=e.display,g=e.eyebrow,h=e.italic,f=e.marginBottom,v=e.marginTop,y=e.nowrap,b=e.size,E=e.subtitle,w=e.tag,N=e.weight;return n.createElement(void 0===w?\"div\":w,{className:s((t={},t[\"h\"+b]=!p&&void 0!==b,t),(a={},a[\"display-\"+b]=p&&void 0!==b,a),(i={},i[\"font-weight-\"+N]=void 0!==N,i),(r={},r[\"color-\"+u]=u,r),(o={},o[\"margin-top-\"+v]=v,o),(l={},l[\"margin-bottom-\"+f]=f,l),{\"text-nowrap\":y},{subtitle:E},{eyebrow:g},d)},c?n.createElement(\"b\",null,h?n.createElement(\"em\",null,m):m):h?n.createElement(\"em\",null,m):m)}function xn(e){return e.displayName||e.name||\"Component\"}function Tn(e,n){return e+\"(\"+xn(n)+\")\"}function Cn(e,t){void 0===t&&(t=\"smooth\");var i=function(i){return a(function(){G(t)},[]),n.createElement(e,i)};return i.displayName=Tn(\"ScrollToTop\",e),i}function zn(e){var t=function(t){return a(function(){ee()}),n.createElement(e,t)};return t.displayName=Tn(\"SyntaxHighlighting\",e),t}function On(e){var t=function(t){return xe(),n.createElement(e,t)};return t.displayName=Tn(\"ThemedFavicon\",e),t}Nn.propTypes={alt:e.string,animated:e.bool,animation:e.string,children:e.node,className:e.string,ElementType:e.elementType,height:e.oneOfType([e.string,e.number]),image:e.string,imageClassName:e.string,ImageElementType:e.elementType,imageProps:e.object,index:e.number,placeholder:e.string,placeholderClassName:e.string,placeholderProps:e.object,rounded:e.bool,shadow:e.bool,style:e.object,width:e.oneOfType([e.string,e.number])},kn.propTypes={bold:e.bool,children:e.node,className:e.string,color:hn,display:e.bool,eyebrow:e.bool,italic:e.bool,marginBottom:bn,marginTop:bn,nowrap:e.bool,size:fn,subtitle:e.bool,tag:e.elementType,weight:yn};var Ln={\"fade-in\":\"visible\",\"fade-out\":\"hidden\",\"translate-up\":\"hidden\",\"translate-down\":\"hidden\",\"translate-left\":\"hidden\",\"translate-right\":\"hidden\"};function _n(t){var a=function(e){var a=be();return n.createElement(t,L({},e,{className:s(e.className,\"transition\",\"fade-in\",{visible:a})}))};return a.displayName=Tn(\"FadeIn\",t),a.propTypes={className:e.string},a}function jn(t,a,i,r){var o=function(e){var o,l=Boolean(e[i]);return n.createElement(t,L({},e,{className:s(e.className,\"transition\",a,(o={},o[r||Ln[a]]=l,o))}))};return o.displayName=Tn(\"Transition\",t),o.propTypes={className:e.string},o}export{P as AppFooter,Ce as AppHeader,Oe as AppStoreBadge,Le as AppUtilityBar,_e as Badge,Se as Button,Ie as ButtonGroup,Pe as ClickableDiv,Ve as CodeBlock,Ae as Col,qe as ContactForm,Re as Container,Fe as CookieConsent,Ge as EmbeddedTwitch,Ye as EmbeddedVideo,Ke as EmbeddedYouTube,H as Icon,an as ImageGallery,Qe as Input,S as Link,We as LoadingSpinner,M as Logo,rn as Modal,ae as NavBar,Te as NavMenu,on as PageBanner,ln as Pagination,Xe as ProgressiveImage,ie as ReactPortal,sn as Row,mn as SearchInput,dn as SideDrawer,pn as SocialButton,oe as SocialIcon,C as SocialLinkProps,le as SocialNavLinks,gn as Stack,En as Text,Ne as ThemeContext,Nn as Thumbnail,kn as Title,W as bindEvent,ce as breakpoints,B as contrastRatio,F as debounce,Z as enterKeyHandler,_n as fadeIn,Tn as getDisplayName,J as getScrollbarWidth,xn as getWrappedDisplayName,$ as hasHorizontalScroll,K as hasVerticalScroll,q as hexToRgb,X as highlight,ee as highlightAll,ne as highlightAllUnder,te as highlightElement,T as icons,O as logo,A as luminance,U as omit,R as rgbToHex,G as scrollToTop,z as socialLinks,Q as throttle,D as unbindEvent,me as useBreakpoint,de as useBreakpointMax,ge as useDocumentTitle,fe as useLoaded,he as useLoading,ve as useLocalStorage,se as useMediaQuery,ye as useModalOverlay,be as useMounted,Ee as usePagination,we as useSearch,ue as useSizeClass,pe as useSizeClassMax,ke as useTheme,xe as useThemedFavicon,Cn as withScrollToTop,zn as withSyntaxHighlighting,On as withThemedFavicon,jn as withTransition};\n//# sourceMappingURL=index.modern.js.map\n","/*!\n * cookie\n * Copyright(c) 2012-2014 Roman Shtylman\n * Copyright(c) 2015 Douglas Christopher Wilson\n * MIT Licensed\n */\n\n'use strict';\n\n/**\n * Module exports.\n * @public\n */\n\nexports.parse = parse;\nexports.serialize = serialize;\n\n/**\n * Module variables.\n * @private\n */\n\nvar decode = decodeURIComponent;\nvar encode = encodeURIComponent;\n\n/**\n * RegExp to match field-content in RFC 7230 sec 3.2\n *\n * field-content = field-vchar [ 1*( SP / HTAB ) field-vchar ]\n * field-vchar = VCHAR / obs-text\n * obs-text = %x80-FF\n */\n\nvar fieldContentRegExp = /^[\\u0009\\u0020-\\u007e\\u0080-\\u00ff]+$/;\n\n/**\n * Parse a cookie header.\n *\n * Parse the given cookie header string into an object\n * The object has the various cookies as keys(names) => values\n *\n * @param {string} str\n * @param {object} [options]\n * @return {object}\n * @public\n */\n\nfunction parse(str, options) {\n if (typeof str !== 'string') {\n throw new TypeError('argument str must be a string');\n }\n\n var obj = {}\n var opt = options || {};\n var pairs = str.split(';')\n var dec = opt.decode || decode;\n\n for (var i = 0; i < pairs.length; i++) {\n var pair = pairs[i];\n var index = pair.indexOf('=')\n\n // skip things that don't look like key=value\n if (index < 0) {\n continue;\n }\n\n var key = pair.substring(0, index).trim()\n\n // only assign once\n if (undefined == obj[key]) {\n var val = pair.substring(index + 1, pair.length).trim()\n\n // quoted values\n if (val[0] === '\"') {\n val = val.slice(1, -1)\n }\n\n obj[key] = tryDecode(val, dec);\n }\n }\n\n return obj;\n}\n\n/**\n * Serialize data into a cookie header.\n *\n * Serialize the a name value pair into a cookie string suitable for\n * http headers. An optional options object specified cookie parameters.\n *\n * serialize('foo', 'bar', { httpOnly: true })\n * => \"foo=bar; httpOnly\"\n *\n * @param {string} name\n * @param {string} val\n * @param {object} [options]\n * @return {string}\n * @public\n */\n\nfunction serialize(name, val, options) {\n var opt = options || {};\n var enc = opt.encode || encode;\n\n if (typeof enc !== 'function') {\n throw new TypeError('option encode is invalid');\n }\n\n if (!fieldContentRegExp.test(name)) {\n throw new TypeError('argument name is invalid');\n }\n\n var value = enc(val);\n\n if (value && !fieldContentRegExp.test(value)) {\n throw new TypeError('argument val is invalid');\n }\n\n var str = name + '=' + value;\n\n if (null != opt.maxAge) {\n var maxAge = opt.maxAge - 0;\n\n if (isNaN(maxAge) || !isFinite(maxAge)) {\n throw new TypeError('option maxAge is invalid')\n }\n\n str += '; Max-Age=' + Math.floor(maxAge);\n }\n\n if (opt.domain) {\n if (!fieldContentRegExp.test(opt.domain)) {\n throw new TypeError('option domain is invalid');\n }\n\n str += '; Domain=' + opt.domain;\n }\n\n if (opt.path) {\n if (!fieldContentRegExp.test(opt.path)) {\n throw new TypeError('option path is invalid');\n }\n\n str += '; Path=' + opt.path;\n }\n\n if (opt.expires) {\n if (typeof opt.expires.toUTCString !== 'function') {\n throw new TypeError('option expires is invalid');\n }\n\n str += '; Expires=' + opt.expires.toUTCString();\n }\n\n if (opt.httpOnly) {\n str += '; HttpOnly';\n }\n\n if (opt.secure) {\n str += '; Secure';\n }\n\n if (opt.sameSite) {\n var sameSite = typeof opt.sameSite === 'string'\n ? opt.sameSite.toLowerCase() : opt.sameSite;\n\n switch (sameSite) {\n case true:\n str += '; SameSite=Strict';\n break;\n case 'lax':\n str += '; SameSite=Lax';\n break;\n case 'strict':\n str += '; SameSite=Strict';\n break;\n case 'none':\n str += '; SameSite=None';\n break;\n default:\n throw new TypeError('option sameSite is invalid');\n }\n }\n\n return str;\n}\n\n/**\n * Try decoding a string using a decoding function.\n *\n * @param {string} str\n * @param {function} decode\n * @private\n */\n\nfunction tryDecode(str, decode) {\n try {\n return decode(str);\n } catch (e) {\n return str;\n }\n}\n","/*!\n Copyright (c) 2015 Jed Watson.\n Based on code that is Copyright 2013-2015, Facebook, Inc.\n All rights reserved.\n*/\n/* global define */\n\n(function () {\n\t'use strict';\n\n\tvar canUseDOM = !!(\n\t\ttypeof window !== 'undefined' &&\n\t\twindow.document &&\n\t\twindow.document.createElement\n\t);\n\n\tvar ExecutionEnvironment = {\n\n\t\tcanUseDOM: canUseDOM,\n\n\t\tcanUseWorkers: typeof Worker !== 'undefined',\n\n\t\tcanUseEventListeners:\n\t\t\tcanUseDOM && !!(window.addEventListener || window.attachEvent),\n\n\t\tcanUseViewport: canUseDOM && !!window.screen\n\n\t};\n\n\tif (typeof define === 'function' && typeof define.amd === 'object' && define.amd) {\n\t\tdefine(function () {\n\t\t\treturn ExecutionEnvironment;\n\t\t});\n\t} else if (typeof module !== 'undefined' && module.exports) {\n\t\tmodule.exports = ExecutionEnvironment;\n\t} else {\n\t\twindow.ExecutionEnvironment = ExecutionEnvironment;\n\t}\n\n}());\n","\"use strict\";\n\nmodule.exports = Object.assign;\n//# sourceMappingURL=object-assign.js.map","import '../styles/dock.css';\nimport { Icon, Link, SocialIcon } from '@zigurous/react-components';\nimport { Link as GatsbyLink } from 'gatsby';\nimport React from 'react';\nimport { dockLinks, socialLinks } from '../links';\n\nconst Dock = ({ theme, toggleTheme, secondaryLinks }) => {\n return (\n
\n
\n
\n {dockLinks.map((link) => (\n \n ))}\n
\n
\n {socialLinks.map((link) => (\n \n ))}\n
\n
\n
\n {\n if (!document) return;\n const e = new Event('previous_slide');\n document.dispatchEvent(e);\n }}\n >\n \n \n
Previous
\n
\n
\n {\n if (!document) return;\n const e = new Event('next_slide');\n document.dispatchEvent(e);\n }}\n >\n \n \n
Next
\n
\n
\n
\n
\n \n
\n {theme === 'dark' ? 'Light Mode' : 'Dark Mode'}\n
\n
\n
\n
\n {secondaryLinks && (\n
\n {secondaryLinks.map((link) => (\n \n ))}\n
\n )}\n
\n );\n};\n\nconst DockItem = ({ link, external = false }) => {\n return (\n
\n \n {link.icon ? (\n \n ) : (\n \n )}\n \n
{link.name}
\n
\n );\n};\n\nexport default Dock;\n","import '../styles/shadow-button.css';\nimport { Button } from '@zigurous/react-components';\nimport React from 'react';\n\nconst ShadowButton = ({ children, ...rest }) => {\n return (\n \n {children}\n \n );\n};\n\nexport default ShadowButton;\n","import PropTypes from 'prop-types';\n\nexport const ImageProps = PropTypes.shape({\n sharp: PropTypes.shape({\n original: PropTypes.shape({\n src: PropTypes.string.isRequired,\n width: PropTypes.number,\n height: PropTypes.number,\n }),\n }),\n});\n","import '../styles/slide.css';\nimport { Link, ProgressiveImage } from '@zigurous/react-components';\nimport classNames from 'classnames';\nimport { Link as GatsbyLink } from 'gatsby';\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport ShadowButton from './ShadowButton';\nimport { ImageProps } from '../types/image';\n\nconst Slide = ({ className, slide }) => {\n const offline = typeof navigator !== 'undefined' && !navigator.onLine;\n const projectPath = `/${slide.category}/${slide.id}`;\n return (\n
\n
\n \n \n \n
\n
\n
\n

{slide.date}

\n

{slide.title}

\n

\n {slide.description_short || slide.description}\n

\n \n More Details\n \n
\n
\n
\n );\n};\n\nexport const SlideProps = PropTypes.shape({\n category: PropTypes.string.isRequired,\n date: PropTypes.string,\n description: PropTypes.string,\n description_short: PropTypes.string,\n id: PropTypes.string.isRequired,\n image: ImageProps.isRequired,\n imageAltText: PropTypes.string,\n imageBorder: PropTypes.string,\n title: PropTypes.string.isRequired,\n});\n\nSlide.propTypes = {\n className: PropTypes.string,\n slide: SlideProps,\n};\n\nexport default Slide;\n","import '../styles/gallery.css';\nimport { useMediaQuery } from '@zigurous/react-components';\nimport classNames from 'classnames';\nimport { navigate } from 'gatsby';\nimport PropTypes from 'prop-types';\nimport React, { useCallback, useEffect } from 'react';\nimport Slide, { SlideProps } from './Slide';\nimport { getSessionIndex, setSessionIndex } from '../utils/session';\n\nconst Gallery = ({ category, location, slides = [] }) => {\n const vertical = useMediaQuery('(max-width: 1365px)');\n\n const urlParams = new URLSearchParams(location?.search);\n const slideIndex =\n (urlParams.has('index')\n ? Number.parseInt(urlParams.get('index')) || 0\n : getSessionIndex(category)) % slides.length;\n\n const currentSlide =\n slideIndex >= 0 && slideIndex < slides.length && slides[slideIndex];\n\n const setSlideIndex = useCallback(\n (index) => {\n if (index >= slides.length) index = 0;\n if (index < 0) index = slides.length - 1;\n setSessionIndex(category, index);\n navigate(`/${category}?index=${index}`, { replace: true });\n },\n [category, slides, slideIndex]\n );\n\n useEffect(() => {\n if (!document) return;\n const prev = () => setSlideIndex(slideIndex - 1);\n const next = () => setSlideIndex(slideIndex + 1);\n document.addEventListener('previous_slide', prev);\n document.addEventListener('next_slide', next);\n return () => {\n document.removeEventListener('previous_slide', prev);\n document.removeEventListener('next_slide', next);\n };\n }, [slideIndex]);\n\n return (\n \n setSlideIndex(slideIndex - 1)}\n >\n \n \n \n \n
\n {currentSlide && }\n
\n setSlideIndex(slideIndex + 1)}\n >\n \n \n \n \n \n );\n};\n\nGallery.propTypes = {\n category: PropTypes.string,\n location: PropTypes.object,\n slides: PropTypes.arrayOf(SlideProps),\n};\n\nexport default Gallery;\n","export function getSessionIndex(category) {\n if (category && typeof sessionStorage !== 'undefined') {\n return Number.parseInt(sessionStorage.getItem(`${category}-slide`)) || 0;\n } else {\n return 0;\n }\n}\n\nexport function setSessionIndex(category, slideIndex) {\n if (category && typeof sessionStorage !== 'undefined') {\n sessionStorage.setItem(`${category}-slide`, slideIndex);\n }\n}\n","import '../styles/logo.css';\nimport { Link } from '@zigurous/react-components';\nimport classNames from 'classnames';\nimport { Link as GatsbyLink } from 'gatsby';\nimport PropTypes from 'prop-types';\nimport React from 'react';\n\nconst Logo = ({ rounded = false, size = 48 }) => {\n return (\n \n \n
\n \n \n \n \n \n
\n );\n};\n\nLogo.propTypes = {\n rounded: PropTypes.bool,\n};\n\nexport default Logo;\n","import '../styles/menu-gallery.css';\nimport { Button, Link, Thumbnail, useModalOverlay } from '@zigurous/react-components'; // prettier-ignore\nimport classNames from 'classnames';\nimport { Link as GatsbyLink, graphql, StaticQuery } from 'gatsby';\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport { headerLinks } from '../links';\n\nconst query = graphql`\n query Menu {\n games: allGamesJson {\n nodes {\n id: jsonId\n category\n title\n image {\n sharp: childImageSharp {\n original {\n src\n width\n height\n }\n }\n }\n imageAltText\n imageBorder\n }\n }\n art: allArtJson {\n nodes {\n id: jsonId\n category\n title\n image {\n sharp: childImageSharp {\n original {\n src\n width\n height\n }\n }\n }\n imageAltText\n imageBorder\n }\n }\n websites: allWebsitesJson {\n nodes {\n id: jsonId\n category\n title\n image {\n sharp: childImageSharp {\n original {\n src\n width\n height\n }\n }\n }\n imageAltText\n imageBorder\n }\n }\n tech: allTechJson {\n nodes {\n id: jsonId\n category\n title\n image {\n sharp: childImageSharp {\n original {\n src\n width\n height\n }\n }\n }\n imageAltText\n imageBorder\n }\n }\n presentations: allPresentationsJson {\n nodes {\n id: jsonId\n category\n title\n image {\n sharp: childImageSharp {\n original {\n src\n width\n height\n }\n }\n }\n imageAltText\n imageBorder\n }\n }\n }\n`;\n\nconst MenuGallery = ({ open, onRequestClose = () => {} }) => {\n useModalOverlay(open, true);\n return (\n \n \n
    \n {open && (\n {\n return headerLinks.map((link) => {\n const gallery = data[link.key] || { nodes: [] };\n return (\n
  • \n \n {link.name}\n \n \n
    \n {gallery.nodes.map((item, index) => (\n \n ))}\n
    \n
  • \n );\n });\n }}\n />\n )}\n
\n \n \n );\n};\n\nMenuGallery.propTypes = {\n open: PropTypes.bool,\n onRequestClose: PropTypes.func,\n};\n\nexport default MenuGallery;\n","import '../styles/header.css';\nimport { Button, NavBar } from '@zigurous/react-components';\nimport { Link as GatsbyLink, navigate } from 'gatsby';\nimport PropTypes from 'prop-types';\nimport React, { useState } from 'react';\nimport Logo from './Logo';\nimport MenuGallery from './MenuGallery';\nimport { headerLinks } from '../links';\n\nconst Header = ({ location, pageTitle }) => {\n const [isMenuOpen, setIsMenuOpen] = useState(false);\n return (\n \n
\n
\n \n \n {pageTitle && (\n {\n const link = headerLinks.find(\n (link) => link.name === pageTitle\n );\n if (link) {\n navigate(link.to);\n } else {\n setIsMenuOpen(true);\n }\n }}\n style={Button.style.none}\n >\n {pageTitle}\n \n )}\n setIsMenuOpen(!isMenuOpen)}\n >\n {isMenuOpen ? (\n \n \n \n ) : (\n \n \n \n )}\n \n
\n
\n setIsMenuOpen(false)}\n />\n
\n );\n};\n\nHeader.propType = {\n location: PropTypes.object,\n pageTitle: PropTypes.string,\n};\n\nexport default Header;\n","import PropTypes from 'prop-types';\nimport withSideEffect from 'react-side-effect';\nimport isEqual from 'react-fast-compare';\nimport React from 'react';\nimport objectAssign from 'object-assign';\n\nvar ATTRIBUTE_NAMES = {\n BODY: \"bodyAttributes\",\n HTML: \"htmlAttributes\",\n TITLE: \"titleAttributes\"\n};\n\nvar TAG_NAMES = {\n BASE: \"base\",\n BODY: \"body\",\n HEAD: \"head\",\n HTML: \"html\",\n LINK: \"link\",\n META: \"meta\",\n NOSCRIPT: \"noscript\",\n SCRIPT: \"script\",\n STYLE: \"style\",\n TITLE: \"title\"\n};\n\nvar VALID_TAG_NAMES = Object.keys(TAG_NAMES).map(function (name) {\n return TAG_NAMES[name];\n});\n\nvar TAG_PROPERTIES = {\n CHARSET: \"charset\",\n CSS_TEXT: \"cssText\",\n HREF: \"href\",\n HTTPEQUIV: \"http-equiv\",\n INNER_HTML: \"innerHTML\",\n ITEM_PROP: \"itemprop\",\n NAME: \"name\",\n PROPERTY: \"property\",\n REL: \"rel\",\n SRC: \"src\",\n TARGET: \"target\"\n};\n\nvar REACT_TAG_MAP = {\n accesskey: \"accessKey\",\n charset: \"charSet\",\n class: \"className\",\n contenteditable: \"contentEditable\",\n contextmenu: \"contextMenu\",\n \"http-equiv\": \"httpEquiv\",\n itemprop: \"itemProp\",\n tabindex: \"tabIndex\"\n};\n\nvar HELMET_PROPS = {\n DEFAULT_TITLE: \"defaultTitle\",\n DEFER: \"defer\",\n ENCODE_SPECIAL_CHARACTERS: \"encodeSpecialCharacters\",\n ON_CHANGE_CLIENT_STATE: \"onChangeClientState\",\n TITLE_TEMPLATE: \"titleTemplate\"\n};\n\nvar HTML_TAG_MAP = Object.keys(REACT_TAG_MAP).reduce(function (obj, key) {\n obj[REACT_TAG_MAP[key]] = key;\n return obj;\n}, {});\n\nvar SELF_CLOSING_TAGS = [TAG_NAMES.NOSCRIPT, TAG_NAMES.SCRIPT, TAG_NAMES.STYLE];\n\nvar HELMET_ATTRIBUTE = \"data-react-helmet\";\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) {\n return typeof obj;\n} : function (obj) {\n return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n};\n\nvar classCallCheck = function (instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n};\n\nvar createClass = function () {\n function defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n }\n\n return function (Constructor, protoProps, staticProps) {\n if (protoProps) defineProperties(Constructor.prototype, protoProps);\n if (staticProps) defineProperties(Constructor, staticProps);\n return Constructor;\n };\n}();\n\nvar _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n};\n\nvar inherits = function (subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass);\n }\n\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n enumerable: false,\n writable: true,\n configurable: true\n }\n });\n if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass;\n};\n\nvar objectWithoutProperties = function (obj, keys) {\n var target = {};\n\n for (var i in obj) {\n if (keys.indexOf(i) >= 0) continue;\n if (!Object.prototype.hasOwnProperty.call(obj, i)) continue;\n target[i] = obj[i];\n }\n\n return target;\n};\n\nvar possibleConstructorReturn = function (self, call) {\n if (!self) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self;\n};\n\nvar encodeSpecialCharacters = function encodeSpecialCharacters(str) {\n var encode = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n\n if (encode === false) {\n return String(str);\n }\n\n return String(str).replace(/&/g, \"&\").replace(//g, \">\").replace(/\"/g, \""\").replace(/'/g, \"'\");\n};\n\nvar getTitleFromPropsList = function getTitleFromPropsList(propsList) {\n var innermostTitle = getInnermostProperty(propsList, TAG_NAMES.TITLE);\n var innermostTemplate = getInnermostProperty(propsList, HELMET_PROPS.TITLE_TEMPLATE);\n\n if (innermostTemplate && innermostTitle) {\n // use function arg to avoid need to escape $ characters\n return innermostTemplate.replace(/%s/g, function () {\n return Array.isArray(innermostTitle) ? innermostTitle.join(\"\") : innermostTitle;\n });\n }\n\n var innermostDefaultTitle = getInnermostProperty(propsList, HELMET_PROPS.DEFAULT_TITLE);\n\n return innermostTitle || innermostDefaultTitle || undefined;\n};\n\nvar getOnChangeClientState = function getOnChangeClientState(propsList) {\n return getInnermostProperty(propsList, HELMET_PROPS.ON_CHANGE_CLIENT_STATE) || function () {};\n};\n\nvar getAttributesFromPropsList = function getAttributesFromPropsList(tagType, propsList) {\n return propsList.filter(function (props) {\n return typeof props[tagType] !== \"undefined\";\n }).map(function (props) {\n return props[tagType];\n }).reduce(function (tagAttrs, current) {\n return _extends({}, tagAttrs, current);\n }, {});\n};\n\nvar getBaseTagFromPropsList = function getBaseTagFromPropsList(primaryAttributes, propsList) {\n return propsList.filter(function (props) {\n return typeof props[TAG_NAMES.BASE] !== \"undefined\";\n }).map(function (props) {\n return props[TAG_NAMES.BASE];\n }).reverse().reduce(function (innermostBaseTag, tag) {\n if (!innermostBaseTag.length) {\n var keys = Object.keys(tag);\n\n for (var i = 0; i < keys.length; i++) {\n var attributeKey = keys[i];\n var lowerCaseAttributeKey = attributeKey.toLowerCase();\n\n if (primaryAttributes.indexOf(lowerCaseAttributeKey) !== -1 && tag[lowerCaseAttributeKey]) {\n return innermostBaseTag.concat(tag);\n }\n }\n }\n\n return innermostBaseTag;\n }, []);\n};\n\nvar getTagsFromPropsList = function getTagsFromPropsList(tagName, primaryAttributes, propsList) {\n // Calculate list of tags, giving priority innermost component (end of the propslist)\n var approvedSeenTags = {};\n\n return propsList.filter(function (props) {\n if (Array.isArray(props[tagName])) {\n return true;\n }\n if (typeof props[tagName] !== \"undefined\") {\n warn(\"Helmet: \" + tagName + \" should be of type \\\"Array\\\". Instead found type \\\"\" + _typeof(props[tagName]) + \"\\\"\");\n }\n return false;\n }).map(function (props) {\n return props[tagName];\n }).reverse().reduce(function (approvedTags, instanceTags) {\n var instanceSeenTags = {};\n\n instanceTags.filter(function (tag) {\n var primaryAttributeKey = void 0;\n var keys = Object.keys(tag);\n for (var i = 0; i < keys.length; i++) {\n var attributeKey = keys[i];\n var lowerCaseAttributeKey = attributeKey.toLowerCase();\n\n // Special rule with link tags, since rel and href are both primary tags, rel takes priority\n if (primaryAttributes.indexOf(lowerCaseAttributeKey) !== -1 && !(primaryAttributeKey === TAG_PROPERTIES.REL && tag[primaryAttributeKey].toLowerCase() === \"canonical\") && !(lowerCaseAttributeKey === TAG_PROPERTIES.REL && tag[lowerCaseAttributeKey].toLowerCase() === \"stylesheet\")) {\n primaryAttributeKey = lowerCaseAttributeKey;\n }\n // Special case for innerHTML which doesn't work lowercased\n if (primaryAttributes.indexOf(attributeKey) !== -1 && (attributeKey === TAG_PROPERTIES.INNER_HTML || attributeKey === TAG_PROPERTIES.CSS_TEXT || attributeKey === TAG_PROPERTIES.ITEM_PROP)) {\n primaryAttributeKey = attributeKey;\n }\n }\n\n if (!primaryAttributeKey || !tag[primaryAttributeKey]) {\n return false;\n }\n\n var value = tag[primaryAttributeKey].toLowerCase();\n\n if (!approvedSeenTags[primaryAttributeKey]) {\n approvedSeenTags[primaryAttributeKey] = {};\n }\n\n if (!instanceSeenTags[primaryAttributeKey]) {\n instanceSeenTags[primaryAttributeKey] = {};\n }\n\n if (!approvedSeenTags[primaryAttributeKey][value]) {\n instanceSeenTags[primaryAttributeKey][value] = true;\n return true;\n }\n\n return false;\n }).reverse().forEach(function (tag) {\n return approvedTags.push(tag);\n });\n\n // Update seen tags with tags from this instance\n var keys = Object.keys(instanceSeenTags);\n for (var i = 0; i < keys.length; i++) {\n var attributeKey = keys[i];\n var tagUnion = objectAssign({}, approvedSeenTags[attributeKey], instanceSeenTags[attributeKey]);\n\n approvedSeenTags[attributeKey] = tagUnion;\n }\n\n return approvedTags;\n }, []).reverse();\n};\n\nvar getInnermostProperty = function getInnermostProperty(propsList, property) {\n for (var i = propsList.length - 1; i >= 0; i--) {\n var props = propsList[i];\n\n if (props.hasOwnProperty(property)) {\n return props[property];\n }\n }\n\n return null;\n};\n\nvar reducePropsToState = function reducePropsToState(propsList) {\n return {\n baseTag: getBaseTagFromPropsList([TAG_PROPERTIES.HREF, TAG_PROPERTIES.TARGET], propsList),\n bodyAttributes: getAttributesFromPropsList(ATTRIBUTE_NAMES.BODY, propsList),\n defer: getInnermostProperty(propsList, HELMET_PROPS.DEFER),\n encode: getInnermostProperty(propsList, HELMET_PROPS.ENCODE_SPECIAL_CHARACTERS),\n htmlAttributes: getAttributesFromPropsList(ATTRIBUTE_NAMES.HTML, propsList),\n linkTags: getTagsFromPropsList(TAG_NAMES.LINK, [TAG_PROPERTIES.REL, TAG_PROPERTIES.HREF], propsList),\n metaTags: getTagsFromPropsList(TAG_NAMES.META, [TAG_PROPERTIES.NAME, TAG_PROPERTIES.CHARSET, TAG_PROPERTIES.HTTPEQUIV, TAG_PROPERTIES.PROPERTY, TAG_PROPERTIES.ITEM_PROP], propsList),\n noscriptTags: getTagsFromPropsList(TAG_NAMES.NOSCRIPT, [TAG_PROPERTIES.INNER_HTML], propsList),\n onChangeClientState: getOnChangeClientState(propsList),\n scriptTags: getTagsFromPropsList(TAG_NAMES.SCRIPT, [TAG_PROPERTIES.SRC, TAG_PROPERTIES.INNER_HTML], propsList),\n styleTags: getTagsFromPropsList(TAG_NAMES.STYLE, [TAG_PROPERTIES.CSS_TEXT], propsList),\n title: getTitleFromPropsList(propsList),\n titleAttributes: getAttributesFromPropsList(ATTRIBUTE_NAMES.TITLE, propsList)\n };\n};\n\nvar rafPolyfill = function () {\n var clock = Date.now();\n\n return function (callback) {\n var currentTime = Date.now();\n\n if (currentTime - clock > 16) {\n clock = currentTime;\n callback(currentTime);\n } else {\n setTimeout(function () {\n rafPolyfill(callback);\n }, 0);\n }\n };\n}();\n\nvar cafPolyfill = function cafPolyfill(id) {\n return clearTimeout(id);\n};\n\nvar requestAnimationFrame = typeof window !== \"undefined\" ? window.requestAnimationFrame && window.requestAnimationFrame.bind(window) || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || rafPolyfill : global.requestAnimationFrame || rafPolyfill;\n\nvar cancelAnimationFrame = typeof window !== \"undefined\" ? window.cancelAnimationFrame || window.webkitCancelAnimationFrame || window.mozCancelAnimationFrame || cafPolyfill : global.cancelAnimationFrame || cafPolyfill;\n\nvar warn = function warn(msg) {\n return console && typeof console.warn === \"function\" && console.warn(msg);\n};\n\nvar _helmetCallback = null;\n\nvar handleClientStateChange = function handleClientStateChange(newState) {\n if (_helmetCallback) {\n cancelAnimationFrame(_helmetCallback);\n }\n\n if (newState.defer) {\n _helmetCallback = requestAnimationFrame(function () {\n commitTagChanges(newState, function () {\n _helmetCallback = null;\n });\n });\n } else {\n commitTagChanges(newState);\n _helmetCallback = null;\n }\n};\n\nvar commitTagChanges = function commitTagChanges(newState, cb) {\n var baseTag = newState.baseTag,\n bodyAttributes = newState.bodyAttributes,\n htmlAttributes = newState.htmlAttributes,\n linkTags = newState.linkTags,\n metaTags = newState.metaTags,\n noscriptTags = newState.noscriptTags,\n onChangeClientState = newState.onChangeClientState,\n scriptTags = newState.scriptTags,\n styleTags = newState.styleTags,\n title = newState.title,\n titleAttributes = newState.titleAttributes;\n\n updateAttributes(TAG_NAMES.BODY, bodyAttributes);\n updateAttributes(TAG_NAMES.HTML, htmlAttributes);\n\n updateTitle(title, titleAttributes);\n\n var tagUpdates = {\n baseTag: updateTags(TAG_NAMES.BASE, baseTag),\n linkTags: updateTags(TAG_NAMES.LINK, linkTags),\n metaTags: updateTags(TAG_NAMES.META, metaTags),\n noscriptTags: updateTags(TAG_NAMES.NOSCRIPT, noscriptTags),\n scriptTags: updateTags(TAG_NAMES.SCRIPT, scriptTags),\n styleTags: updateTags(TAG_NAMES.STYLE, styleTags)\n };\n\n var addedTags = {};\n var removedTags = {};\n\n Object.keys(tagUpdates).forEach(function (tagType) {\n var _tagUpdates$tagType = tagUpdates[tagType],\n newTags = _tagUpdates$tagType.newTags,\n oldTags = _tagUpdates$tagType.oldTags;\n\n\n if (newTags.length) {\n addedTags[tagType] = newTags;\n }\n if (oldTags.length) {\n removedTags[tagType] = tagUpdates[tagType].oldTags;\n }\n });\n\n cb && cb();\n\n onChangeClientState(newState, addedTags, removedTags);\n};\n\nvar flattenArray = function flattenArray(possibleArray) {\n return Array.isArray(possibleArray) ? possibleArray.join(\"\") : possibleArray;\n};\n\nvar updateTitle = function updateTitle(title, attributes) {\n if (typeof title !== \"undefined\" && document.title !== title) {\n document.title = flattenArray(title);\n }\n\n updateAttributes(TAG_NAMES.TITLE, attributes);\n};\n\nvar updateAttributes = function updateAttributes(tagName, attributes) {\n var elementTag = document.getElementsByTagName(tagName)[0];\n\n if (!elementTag) {\n return;\n }\n\n var helmetAttributeString = elementTag.getAttribute(HELMET_ATTRIBUTE);\n var helmetAttributes = helmetAttributeString ? helmetAttributeString.split(\",\") : [];\n var attributesToRemove = [].concat(helmetAttributes);\n var attributeKeys = Object.keys(attributes);\n\n for (var i = 0; i < attributeKeys.length; i++) {\n var attribute = attributeKeys[i];\n var value = attributes[attribute] || \"\";\n\n if (elementTag.getAttribute(attribute) !== value) {\n elementTag.setAttribute(attribute, value);\n }\n\n if (helmetAttributes.indexOf(attribute) === -1) {\n helmetAttributes.push(attribute);\n }\n\n var indexToSave = attributesToRemove.indexOf(attribute);\n if (indexToSave !== -1) {\n attributesToRemove.splice(indexToSave, 1);\n }\n }\n\n for (var _i = attributesToRemove.length - 1; _i >= 0; _i--) {\n elementTag.removeAttribute(attributesToRemove[_i]);\n }\n\n if (helmetAttributes.length === attributesToRemove.length) {\n elementTag.removeAttribute(HELMET_ATTRIBUTE);\n } else if (elementTag.getAttribute(HELMET_ATTRIBUTE) !== attributeKeys.join(\",\")) {\n elementTag.setAttribute(HELMET_ATTRIBUTE, attributeKeys.join(\",\"));\n }\n};\n\nvar updateTags = function updateTags(type, tags) {\n var headElement = document.head || document.querySelector(TAG_NAMES.HEAD);\n var tagNodes = headElement.querySelectorAll(type + \"[\" + HELMET_ATTRIBUTE + \"]\");\n var oldTags = Array.prototype.slice.call(tagNodes);\n var newTags = [];\n var indexToDelete = void 0;\n\n if (tags && tags.length) {\n tags.forEach(function (tag) {\n var newElement = document.createElement(type);\n\n for (var attribute in tag) {\n if (tag.hasOwnProperty(attribute)) {\n if (attribute === TAG_PROPERTIES.INNER_HTML) {\n newElement.innerHTML = tag.innerHTML;\n } else if (attribute === TAG_PROPERTIES.CSS_TEXT) {\n if (newElement.styleSheet) {\n newElement.styleSheet.cssText = tag.cssText;\n } else {\n newElement.appendChild(document.createTextNode(tag.cssText));\n }\n } else {\n var value = typeof tag[attribute] === \"undefined\" ? \"\" : tag[attribute];\n newElement.setAttribute(attribute, value);\n }\n }\n }\n\n newElement.setAttribute(HELMET_ATTRIBUTE, \"true\");\n\n // Remove a duplicate tag from domTagstoRemove, so it isn't cleared.\n if (oldTags.some(function (existingTag, index) {\n indexToDelete = index;\n return newElement.isEqualNode(existingTag);\n })) {\n oldTags.splice(indexToDelete, 1);\n } else {\n newTags.push(newElement);\n }\n });\n }\n\n oldTags.forEach(function (tag) {\n return tag.parentNode.removeChild(tag);\n });\n newTags.forEach(function (tag) {\n return headElement.appendChild(tag);\n });\n\n return {\n oldTags: oldTags,\n newTags: newTags\n };\n};\n\nvar generateElementAttributesAsString = function generateElementAttributesAsString(attributes) {\n return Object.keys(attributes).reduce(function (str, key) {\n var attr = typeof attributes[key] !== \"undefined\" ? key + \"=\\\"\" + attributes[key] + \"\\\"\" : \"\" + key;\n return str ? str + \" \" + attr : attr;\n }, \"\");\n};\n\nvar generateTitleAsString = function generateTitleAsString(type, title, attributes, encode) {\n var attributeString = generateElementAttributesAsString(attributes);\n var flattenedTitle = flattenArray(title);\n return attributeString ? \"<\" + type + \" \" + HELMET_ATTRIBUTE + \"=\\\"true\\\" \" + attributeString + \">\" + encodeSpecialCharacters(flattenedTitle, encode) + \"\" : \"<\" + type + \" \" + HELMET_ATTRIBUTE + \"=\\\"true\\\">\" + encodeSpecialCharacters(flattenedTitle, encode) + \"\";\n};\n\nvar generateTagsAsString = function generateTagsAsString(type, tags, encode) {\n return tags.reduce(function (str, tag) {\n var attributeHtml = Object.keys(tag).filter(function (attribute) {\n return !(attribute === TAG_PROPERTIES.INNER_HTML || attribute === TAG_PROPERTIES.CSS_TEXT);\n }).reduce(function (string, attribute) {\n var attr = typeof tag[attribute] === \"undefined\" ? attribute : attribute + \"=\\\"\" + encodeSpecialCharacters(tag[attribute], encode) + \"\\\"\";\n return string ? string + \" \" + attr : attr;\n }, \"\");\n\n var tagContent = tag.innerHTML || tag.cssText || \"\";\n\n var isSelfClosing = SELF_CLOSING_TAGS.indexOf(type) === -1;\n\n return str + \"<\" + type + \" \" + HELMET_ATTRIBUTE + \"=\\\"true\\\" \" + attributeHtml + (isSelfClosing ? \"/>\" : \">\" + tagContent + \"\");\n }, \"\");\n};\n\nvar convertElementAttributestoReactProps = function convertElementAttributestoReactProps(attributes) {\n var initProps = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n return Object.keys(attributes).reduce(function (obj, key) {\n obj[REACT_TAG_MAP[key] || key] = attributes[key];\n return obj;\n }, initProps);\n};\n\nvar convertReactPropstoHtmlAttributes = function convertReactPropstoHtmlAttributes(props) {\n var initAttributes = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n return Object.keys(props).reduce(function (obj, key) {\n obj[HTML_TAG_MAP[key] || key] = props[key];\n return obj;\n }, initAttributes);\n};\n\nvar generateTitleAsReactComponent = function generateTitleAsReactComponent(type, title, attributes) {\n var _initProps;\n\n // assigning into an array to define toString function on it\n var initProps = (_initProps = {\n key: title\n }, _initProps[HELMET_ATTRIBUTE] = true, _initProps);\n var props = convertElementAttributestoReactProps(attributes, initProps);\n\n return [React.createElement(TAG_NAMES.TITLE, props, title)];\n};\n\nvar generateTagsAsReactComponent = function generateTagsAsReactComponent(type, tags) {\n return tags.map(function (tag, i) {\n var _mappedTag;\n\n var mappedTag = (_mappedTag = {\n key: i\n }, _mappedTag[HELMET_ATTRIBUTE] = true, _mappedTag);\n\n Object.keys(tag).forEach(function (attribute) {\n var mappedAttribute = REACT_TAG_MAP[attribute] || attribute;\n\n if (mappedAttribute === TAG_PROPERTIES.INNER_HTML || mappedAttribute === TAG_PROPERTIES.CSS_TEXT) {\n var content = tag.innerHTML || tag.cssText;\n mappedTag.dangerouslySetInnerHTML = { __html: content };\n } else {\n mappedTag[mappedAttribute] = tag[attribute];\n }\n });\n\n return React.createElement(type, mappedTag);\n });\n};\n\nvar getMethodsForTag = function getMethodsForTag(type, tags, encode) {\n switch (type) {\n case TAG_NAMES.TITLE:\n return {\n toComponent: function toComponent() {\n return generateTitleAsReactComponent(type, tags.title, tags.titleAttributes, encode);\n },\n toString: function toString() {\n return generateTitleAsString(type, tags.title, tags.titleAttributes, encode);\n }\n };\n case ATTRIBUTE_NAMES.BODY:\n case ATTRIBUTE_NAMES.HTML:\n return {\n toComponent: function toComponent() {\n return convertElementAttributestoReactProps(tags);\n },\n toString: function toString() {\n return generateElementAttributesAsString(tags);\n }\n };\n default:\n return {\n toComponent: function toComponent() {\n return generateTagsAsReactComponent(type, tags);\n },\n toString: function toString() {\n return generateTagsAsString(type, tags, encode);\n }\n };\n }\n};\n\nvar mapStateOnServer = function mapStateOnServer(_ref) {\n var baseTag = _ref.baseTag,\n bodyAttributes = _ref.bodyAttributes,\n encode = _ref.encode,\n htmlAttributes = _ref.htmlAttributes,\n linkTags = _ref.linkTags,\n metaTags = _ref.metaTags,\n noscriptTags = _ref.noscriptTags,\n scriptTags = _ref.scriptTags,\n styleTags = _ref.styleTags,\n _ref$title = _ref.title,\n title = _ref$title === undefined ? \"\" : _ref$title,\n titleAttributes = _ref.titleAttributes;\n return {\n base: getMethodsForTag(TAG_NAMES.BASE, baseTag, encode),\n bodyAttributes: getMethodsForTag(ATTRIBUTE_NAMES.BODY, bodyAttributes, encode),\n htmlAttributes: getMethodsForTag(ATTRIBUTE_NAMES.HTML, htmlAttributes, encode),\n link: getMethodsForTag(TAG_NAMES.LINK, linkTags, encode),\n meta: getMethodsForTag(TAG_NAMES.META, metaTags, encode),\n noscript: getMethodsForTag(TAG_NAMES.NOSCRIPT, noscriptTags, encode),\n script: getMethodsForTag(TAG_NAMES.SCRIPT, scriptTags, encode),\n style: getMethodsForTag(TAG_NAMES.STYLE, styleTags, encode),\n title: getMethodsForTag(TAG_NAMES.TITLE, { title: title, titleAttributes: titleAttributes }, encode)\n };\n};\n\nvar Helmet = function Helmet(Component) {\n var _class, _temp;\n\n return _temp = _class = function (_React$Component) {\n inherits(HelmetWrapper, _React$Component);\n\n function HelmetWrapper() {\n classCallCheck(this, HelmetWrapper);\n return possibleConstructorReturn(this, _React$Component.apply(this, arguments));\n }\n\n HelmetWrapper.prototype.shouldComponentUpdate = function shouldComponentUpdate(nextProps) {\n return !isEqual(this.props, nextProps);\n };\n\n HelmetWrapper.prototype.mapNestedChildrenToProps = function mapNestedChildrenToProps(child, nestedChildren) {\n if (!nestedChildren) {\n return null;\n }\n\n switch (child.type) {\n case TAG_NAMES.SCRIPT:\n case TAG_NAMES.NOSCRIPT:\n return {\n innerHTML: nestedChildren\n };\n\n case TAG_NAMES.STYLE:\n return {\n cssText: nestedChildren\n };\n }\n\n throw new Error(\"<\" + child.type + \" /> elements are self-closing and can not contain children. Refer to our API for more information.\");\n };\n\n HelmetWrapper.prototype.flattenArrayTypeChildren = function flattenArrayTypeChildren(_ref) {\n var _babelHelpers$extends;\n\n var child = _ref.child,\n arrayTypeChildren = _ref.arrayTypeChildren,\n newChildProps = _ref.newChildProps,\n nestedChildren = _ref.nestedChildren;\n\n return _extends({}, arrayTypeChildren, (_babelHelpers$extends = {}, _babelHelpers$extends[child.type] = [].concat(arrayTypeChildren[child.type] || [], [_extends({}, newChildProps, this.mapNestedChildrenToProps(child, nestedChildren))]), _babelHelpers$extends));\n };\n\n HelmetWrapper.prototype.mapObjectTypeChildren = function mapObjectTypeChildren(_ref2) {\n var _babelHelpers$extends2, _babelHelpers$extends3;\n\n var child = _ref2.child,\n newProps = _ref2.newProps,\n newChildProps = _ref2.newChildProps,\n nestedChildren = _ref2.nestedChildren;\n\n switch (child.type) {\n case TAG_NAMES.TITLE:\n return _extends({}, newProps, (_babelHelpers$extends2 = {}, _babelHelpers$extends2[child.type] = nestedChildren, _babelHelpers$extends2.titleAttributes = _extends({}, newChildProps), _babelHelpers$extends2));\n\n case TAG_NAMES.BODY:\n return _extends({}, newProps, {\n bodyAttributes: _extends({}, newChildProps)\n });\n\n case TAG_NAMES.HTML:\n return _extends({}, newProps, {\n htmlAttributes: _extends({}, newChildProps)\n });\n }\n\n return _extends({}, newProps, (_babelHelpers$extends3 = {}, _babelHelpers$extends3[child.type] = _extends({}, newChildProps), _babelHelpers$extends3));\n };\n\n HelmetWrapper.prototype.mapArrayTypeChildrenToProps = function mapArrayTypeChildrenToProps(arrayTypeChildren, newProps) {\n var newFlattenedProps = _extends({}, newProps);\n\n Object.keys(arrayTypeChildren).forEach(function (arrayChildName) {\n var _babelHelpers$extends4;\n\n newFlattenedProps = _extends({}, newFlattenedProps, (_babelHelpers$extends4 = {}, _babelHelpers$extends4[arrayChildName] = arrayTypeChildren[arrayChildName], _babelHelpers$extends4));\n });\n\n return newFlattenedProps;\n };\n\n HelmetWrapper.prototype.warnOnInvalidChildren = function warnOnInvalidChildren(child, nestedChildren) {\n if (process.env.NODE_ENV !== \"production\") {\n if (!VALID_TAG_NAMES.some(function (name) {\n return child.type === name;\n })) {\n if (typeof child.type === \"function\") {\n return warn(\"You may be attempting to nest components within each other, which is not allowed. Refer to our API for more information.\");\n }\n\n return warn(\"Only elements types \" + VALID_TAG_NAMES.join(\", \") + \" are allowed. Helmet does not support rendering <\" + child.type + \"> elements. Refer to our API for more information.\");\n }\n\n if (nestedChildren && typeof nestedChildren !== \"string\" && (!Array.isArray(nestedChildren) || nestedChildren.some(function (nestedChild) {\n return typeof nestedChild !== \"string\";\n }))) {\n throw new Error(\"Helmet expects a string as a child of <\" + child.type + \">. Did you forget to wrap your children in braces? ( <\" + child.type + \">{``} ) Refer to our API for more information.\");\n }\n }\n\n return true;\n };\n\n HelmetWrapper.prototype.mapChildrenToProps = function mapChildrenToProps(children, newProps) {\n var _this2 = this;\n\n var arrayTypeChildren = {};\n\n React.Children.forEach(children, function (child) {\n if (!child || !child.props) {\n return;\n }\n\n var _child$props = child.props,\n nestedChildren = _child$props.children,\n childProps = objectWithoutProperties(_child$props, [\"children\"]);\n\n var newChildProps = convertReactPropstoHtmlAttributes(childProps);\n\n _this2.warnOnInvalidChildren(child, nestedChildren);\n\n switch (child.type) {\n case TAG_NAMES.LINK:\n case TAG_NAMES.META:\n case TAG_NAMES.NOSCRIPT:\n case TAG_NAMES.SCRIPT:\n case TAG_NAMES.STYLE:\n arrayTypeChildren = _this2.flattenArrayTypeChildren({\n child: child,\n arrayTypeChildren: arrayTypeChildren,\n newChildProps: newChildProps,\n nestedChildren: nestedChildren\n });\n break;\n\n default:\n newProps = _this2.mapObjectTypeChildren({\n child: child,\n newProps: newProps,\n newChildProps: newChildProps,\n nestedChildren: nestedChildren\n });\n break;\n }\n });\n\n newProps = this.mapArrayTypeChildrenToProps(arrayTypeChildren, newProps);\n return newProps;\n };\n\n HelmetWrapper.prototype.render = function render() {\n var _props = this.props,\n children = _props.children,\n props = objectWithoutProperties(_props, [\"children\"]);\n\n var newProps = _extends({}, props);\n\n if (children) {\n newProps = this.mapChildrenToProps(children, newProps);\n }\n\n return React.createElement(Component, newProps);\n };\n\n createClass(HelmetWrapper, null, [{\n key: \"canUseDOM\",\n\n\n // Component.peek comes from react-side-effect:\n // For testing, you may use a static peek() method available on the returned component.\n // It lets you get the current state without resetting the mounted instance stack.\n // Don’t use it for anything other than testing.\n\n /**\n * @param {Object} base: {\"target\": \"_blank\", \"href\": \"http://mysite.com/\"}\n * @param {Object} bodyAttributes: {\"className\": \"root\"}\n * @param {String} defaultTitle: \"Default Title\"\n * @param {Boolean} defer: true\n * @param {Boolean} encodeSpecialCharacters: true\n * @param {Object} htmlAttributes: {\"lang\": \"en\", \"amp\": undefined}\n * @param {Array} link: [{\"rel\": \"canonical\", \"href\": \"http://mysite.com/example\"}]\n * @param {Array} meta: [{\"name\": \"description\", \"content\": \"Test description\"}]\n * @param {Array} noscript: [{\"innerHTML\": \" console.log(newState)\"\n * @param {Array} script: [{\"type\": \"text/javascript\", \"src\": \"http://mysite.com/js/test.js\"}]\n * @param {Array} style: [{\"type\": \"text/css\", \"cssText\": \"div { display: block; color: blue; }\"}]\n * @param {String} title: \"Title\"\n * @param {Object} titleAttributes: {\"itemprop\": \"name\"}\n * @param {String} titleTemplate: \"MySite.com - %s\"\n */\n set: function set$$1(canUseDOM) {\n Component.canUseDOM = canUseDOM;\n }\n }]);\n return HelmetWrapper;\n }(React.Component), _class.propTypes = {\n base: PropTypes.object,\n bodyAttributes: PropTypes.object,\n children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node]),\n defaultTitle: PropTypes.string,\n defer: PropTypes.bool,\n encodeSpecialCharacters: PropTypes.bool,\n htmlAttributes: PropTypes.object,\n link: PropTypes.arrayOf(PropTypes.object),\n meta: PropTypes.arrayOf(PropTypes.object),\n noscript: PropTypes.arrayOf(PropTypes.object),\n onChangeClientState: PropTypes.func,\n script: PropTypes.arrayOf(PropTypes.object),\n style: PropTypes.arrayOf(PropTypes.object),\n title: PropTypes.string,\n titleAttributes: PropTypes.object,\n titleTemplate: PropTypes.string\n }, _class.defaultProps = {\n defer: true,\n encodeSpecialCharacters: true\n }, _class.peek = Component.peek, _class.rewind = function () {\n var mappedState = Component.rewind();\n if (!mappedState) {\n // provide fallback if mappedState is undefined\n mappedState = mapStateOnServer({\n baseTag: [],\n bodyAttributes: {},\n encodeSpecialCharacters: true,\n htmlAttributes: {},\n linkTags: [],\n metaTags: [],\n noscriptTags: [],\n scriptTags: [],\n styleTags: [],\n title: \"\",\n titleAttributes: {}\n });\n }\n\n return mappedState;\n }, _temp;\n};\n\nvar NullComponent = function NullComponent() {\n return null;\n};\n\nvar HelmetSideEffects = withSideEffect(reducePropsToState, handleClientStateChange, mapStateOnServer)(NullComponent);\n\nvar HelmetExport = Helmet(HelmetSideEffects);\nHelmetExport.renderStatic = HelmetExport.rewind;\n\nexport default HelmetExport;\nexport { HelmetExport as Helmet };\n","import { graphql, useStaticQuery } from 'gatsby';\nimport PropTypes from 'prop-types';\nimport * as React from 'react';\nimport { Helmet } from 'react-helmet';\n\nconst query = graphql`\n query Metadata {\n site {\n metadata: siteMetadata {\n title\n description\n }\n }\n }\n`;\n\nconst Metadata = (props) => {\n const queryData = useStaticQuery(query);\n const { metadata: siteMetadata } = queryData.site;\n const metadata = { ...siteMetadata, ...props };\n return (\n \n {metadata.title}\n \n {metadata.image && }\n\n {metadata.url && }\n \n \n \n {metadata.image && }\n\n \n \n \n \n {metadata.image && }\n \n );\n};\n\nMetadata.propTypes = {\n description: PropTypes.string,\n image: PropTypes.string,\n title: PropTypes.string,\n url: PropTypes.string,\n};\n\nexport default Metadata;\n","import { useTheme } from '@zigurous/react-components';\nimport classNames from 'classnames';\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport Dock from './Dock';\nimport Header from './Header';\nimport Metadata from './Metadata';\n\nconst Page = ({\n children,\n className,\n dockLinks,\n hideDock = false,\n hideHeader = false,\n id,\n location,\n metadata,\n title,\n}) => {\n const [theme, _, toggleTheme] = useTheme('light');\n return (\n
\n \n {!hideHeader &&
}\n
\n {children}\n
\n {!hideDock && (\n \n )}\n
\n );\n};\n\nPage.propTypes = {\n children: PropTypes.node,\n className: PropTypes.string,\n hideDock: PropTypes.bool,\n hideHeader: PropTypes.bool,\n id: PropTypes.string,\n location: PropTypes.object,\n metadata: PropTypes.object,\n title: PropTypes.string,\n};\n\nexport default Page;\n","import '../styles/project.css';\nimport { Badge, EmbeddedYouTube, ImageGallery, Link, ProgressiveImage } from '@zigurous/react-components'; // prettier-ignore\nimport classNames from 'classnames';\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport { ImageProps } from '../types/image';\n\nconst Project = ({ className, project }) => (\n
\n
\n

{project.title}

\n
\n {project.date}\n |\n {project.role}\n
\n {project.tech && (\n
\n {project.tech.map((tech) => (\n \n {tech}\n \n ))}\n
\n )}\n
\n {project.description && (\n

{project.description}

\n )}\n {project.description_long &&\n project.description_long.map((description) => (\n

\n {description}\n

\n ))}\n
\n
\n {project.sections &&\n project.sections.map((section, index) => (\n
\n {section.title && (\n

\n {section.link ? (\n \n {section.title}\n \n ) : (\n {section.title}\n )}\n

\n )}\n {section.mainImage &&\n (section.mainImageLink ? (\n \n \n \n ) : (\n \n ))}\n {section.mainVideo && (\n \n )}\n {section.paragraphs &&\n section.paragraphs.map((paragraph, paragraphIndex) => (\n \n {paragraph}\n

\n ))}\n {section.gallery && (\n ({\n width: image.sharp.original.width,\n height: image.sharp.original.height,\n src: image.sharp.original.src,\n }))}\n minWidth={132}\n />\n )}\n {section.videos &&\n section.videos.map((video) => (\n \n ))}\n
\n ))}\n
\n);\n\nexport const ProjectProps = PropTypes.shape({\n buttons: PropTypes.arrayOf(\n PropTypes.shape({\n name: PropTypes.string.isRequired,\n url: PropTypes.string.isRequired,\n icon: PropTypes.string.isRequired,\n })\n ),\n category: PropTypes.string.isRequired,\n date: PropTypes.string,\n description: PropTypes.string,\n description_short: PropTypes.string,\n description_long: PropTypes.arrayOf(PropTypes.string),\n id: PropTypes.string.isRequired,\n image: ImageProps.isRequired,\n role: PropTypes.string,\n sections: PropTypes.arrayOf(\n PropTypes.shape({\n title: PropTypes.string,\n link: PropTypes.string,\n mainImage: ImageProps,\n mainImageLink: PropTypes.string,\n mainVideo: PropTypes.string,\n paragraphs: PropTypes.arrayOf(PropTypes.string),\n gallery: PropTypes.arrayOf(ImageProps),\n videos: PropTypes.arrayOf(PropTypes.string),\n })\n ),\n tech: PropTypes.arrayOf(PropTypes.string),\n title: PropTypes.string.isRequired,\n});\n\nProject.propTypes = {\n className: PropTypes.string,\n project: ProjectProps,\n};\n\nexport default Project;\n","export const baseUri = 'https://adamgraham.github.io';\nexport const email = 'mailto:adam@zigurous.com';\nexport const resume = 'https://docs.google.com/document/d/1qLHBV7Ry11O-pd0XC3HvALBIKJ8YDBmSafP0Z5c4dww/edit?usp=drive_link'; // prettier-ignore\nexport const github = 'https://github.com/adamgraham';\nexport const linkedIn = 'https://www.linkedin.com/in/adamzigurous';\nexport const instagram = 'http://instagram.com/adam.zigurous';\nexport const twitter = 'https://twitter.com/zigurous';\n\nexport const headerLinks = [\n {\n key: 'games',\n name: 'Games',\n to: '/games',\n },\n {\n key: 'websites',\n name: 'Websites',\n to: '/websites',\n },\n {\n key: 'art',\n name: 'Interactive Art',\n to: '/art',\n },\n {\n key: 'tech',\n name: 'Tech Showcases',\n to: '/tech',\n },\n {\n key: 'presentations',\n name: 'Presentations',\n to: '/presentations',\n },\n];\n\nexport const dockLinks = [\n {\n key: 'home',\n name: 'Home',\n icon: 'home',\n to: '/',\n },\n {\n key: 'gallery',\n name: 'Gallery',\n icon: 'collections',\n to: '/games',\n },\n {\n key: 'projects',\n name: 'Projects',\n icon: 'menu',\n to: '/projects',\n },\n];\n\nexport const socialLinks = [\n {\n key: 'github',\n name: 'GitHub',\n url: github,\n },\n {\n key: 'linkedIn',\n name: 'LinkedIn',\n url: linkedIn,\n },\n {\n key: 'resume',\n name: 'Resume',\n icon: 'description',\n url: resume,\n },\n {\n key: 'email',\n name: 'Email',\n icon: 'mail',\n url: email,\n },\n];\n","Prism.languages.clike = {\n\t'comment': [\n\t\t{\n\t\t\tpattern: /(^|[^\\\\])\\/\\*[\\s\\S]*?(?:\\*\\/|$)/,\n\t\t\tlookbehind: true,\n\t\t\tgreedy: true\n\t\t},\n\t\t{\n\t\t\tpattern: /(^|[^\\\\:])\\/\\/.*/,\n\t\t\tlookbehind: true,\n\t\t\tgreedy: true\n\t\t}\n\t],\n\t'string': {\n\t\tpattern: /([\"'])(?:\\\\(?:\\r\\n|[\\s\\S])|(?!\\1)[^\\\\\\r\\n])*\\1/,\n\t\tgreedy: true\n\t},\n\t'class-name': {\n\t\tpattern: /(\\b(?:class|extends|implements|instanceof|interface|new|trait)\\s+|\\bcatch\\s+\\()[\\w.\\\\]+/i,\n\t\tlookbehind: true,\n\t\tinside: {\n\t\t\t'punctuation': /[.\\\\]/\n\t\t}\n\t},\n\t'keyword': /\\b(?:break|catch|continue|do|else|finally|for|function|if|in|instanceof|new|null|return|throw|try|while)\\b/,\n\t'boolean': /\\b(?:false|true)\\b/,\n\t'function': /\\b\\w+(?=\\()/,\n\t'number': /\\b0x[\\da-f]+\\b|(?:\\b\\d+(?:\\.\\d*)?|\\B\\.\\d+)(?:e[+-]?\\d+)?/i,\n\t'operator': /[<>]=?|[!=]=?=?|--?|\\+\\+?|&&?|\\|\\|?|[?*/~^%]/,\n\t'punctuation': /[{}[\\];(),.:]/\n};\n","(function (Prism) {\n\n\t/**\n\t * Replaces all placeholders \"<>\" of given pattern with the n-th replacement (zero based).\n\t *\n\t * Note: This is a simple text based replacement. Be careful when using backreferences!\n\t *\n\t * @param {string} pattern the given pattern.\n\t * @param {string[]} replacements a list of replacement which can be inserted into the given pattern.\n\t * @returns {string} the pattern with all placeholders replaced with their corresponding replacements.\n\t * @example replace(/a<<0>>a/.source, [/b+/.source]) === /a(?:b+)a/.source\n\t */\n\tfunction replace(pattern, replacements) {\n\t\treturn pattern.replace(/<<(\\d+)>>/g, function (m, index) {\n\t\t\treturn '(?:' + replacements[+index] + ')';\n\t\t});\n\t}\n\t/**\n\t * @param {string} pattern\n\t * @param {string[]} replacements\n\t * @param {string} [flags]\n\t * @returns {RegExp}\n\t */\n\tfunction re(pattern, replacements, flags) {\n\t\treturn RegExp(replace(pattern, replacements), flags || '');\n\t}\n\n\t/**\n\t * Creates a nested pattern where all occurrences of the string `<>` are replaced with the pattern itself.\n\t *\n\t * @param {string} pattern\n\t * @param {number} depthLog2\n\t * @returns {string}\n\t */\n\tfunction nested(pattern, depthLog2) {\n\t\tfor (var i = 0; i < depthLog2; i++) {\n\t\t\tpattern = pattern.replace(/<>/g, function () { return '(?:' + pattern + ')'; });\n\t\t}\n\t\treturn pattern.replace(/<>/g, '[^\\\\s\\\\S]');\n\t}\n\n\t// https://docs.microsoft.com/en-us/dotnet/csharp/language-reference/keywords/\n\tvar keywordKinds = {\n\t\t// keywords which represent a return or variable type\n\t\ttype: 'bool byte char decimal double dynamic float int long object sbyte short string uint ulong ushort var void',\n\t\t// keywords which are used to declare a type\n\t\ttypeDeclaration: 'class enum interface record struct',\n\t\t// contextual keywords\n\t\t// (\"var\" and \"dynamic\" are missing because they are used like types)\n\t\tcontextual: 'add alias and ascending async await by descending from(?=\\\\s*(?:\\\\w|$)) get global group into init(?=\\\\s*;) join let nameof not notnull on or orderby partial remove select set unmanaged value when where with(?=\\\\s*{)',\n\t\t// all other keywords\n\t\tother: 'abstract as base break case catch checked const continue default delegate do else event explicit extern finally fixed for foreach goto if implicit in internal is lock namespace new null operator out override params private protected public readonly ref return sealed sizeof stackalloc static switch this throw try typeof unchecked unsafe using virtual volatile while yield'\n\t};\n\n\t// keywords\n\tfunction keywordsToPattern(words) {\n\t\treturn '\\\\b(?:' + words.trim().replace(/ /g, '|') + ')\\\\b';\n\t}\n\tvar typeDeclarationKeywords = keywordsToPattern(keywordKinds.typeDeclaration);\n\tvar keywords = RegExp(keywordsToPattern(keywordKinds.type + ' ' + keywordKinds.typeDeclaration + ' ' + keywordKinds.contextual + ' ' + keywordKinds.other));\n\tvar nonTypeKeywords = keywordsToPattern(keywordKinds.typeDeclaration + ' ' + keywordKinds.contextual + ' ' + keywordKinds.other);\n\tvar nonContextualKeywords = keywordsToPattern(keywordKinds.type + ' ' + keywordKinds.typeDeclaration + ' ' + keywordKinds.other);\n\n\t// types\n\tvar generic = nested(/<(?:[^<>;=+\\-*/%&|^]|<>)*>/.source, 2); // the idea behind the other forbidden characters is to prevent false positives. Same for tupleElement.\n\tvar nestedRound = nested(/\\((?:[^()]|<>)*\\)/.source, 2);\n\tvar name = /@?\\b[A-Za-z_]\\w*\\b/.source;\n\tvar genericName = replace(/<<0>>(?:\\s*<<1>>)?/.source, [name, generic]);\n\tvar identifier = replace(/(?!<<0>>)<<1>>(?:\\s*\\.\\s*<<1>>)*/.source, [nonTypeKeywords, genericName]);\n\tvar array = /\\[\\s*(?:,\\s*)*\\]/.source;\n\tvar typeExpressionWithoutTuple = replace(/<<0>>(?:\\s*(?:\\?\\s*)?<<1>>)*(?:\\s*\\?)?/.source, [identifier, array]);\n\tvar tupleElement = replace(/[^,()<>[\\];=+\\-*/%&|^]|<<0>>|<<1>>|<<2>>/.source, [generic, nestedRound, array]);\n\tvar tuple = replace(/\\(<<0>>+(?:,<<0>>+)+\\)/.source, [tupleElement]);\n\tvar typeExpression = replace(/(?:<<0>>|<<1>>)(?:\\s*(?:\\?\\s*)?<<2>>)*(?:\\s*\\?)?/.source, [tuple, identifier, array]);\n\n\tvar typeInside = {\n\t\t'keyword': keywords,\n\t\t'punctuation': /[<>()?,.:[\\]]/\n\t};\n\n\t// strings & characters\n\t// https://docs.microsoft.com/en-us/dotnet/csharp/language-reference/language-specification/lexical-structure#character-literals\n\t// https://docs.microsoft.com/en-us/dotnet/csharp/language-reference/language-specification/lexical-structure#string-literals\n\tvar character = /'(?:[^\\r\\n'\\\\]|\\\\.|\\\\[Uux][\\da-fA-F]{1,8})'/.source; // simplified pattern\n\tvar regularString = /\"(?:\\\\.|[^\\\\\"\\r\\n])*\"/.source;\n\tvar verbatimString = /@\"(?:\"\"|\\\\[\\s\\S]|[^\\\\\"])*\"(?!\")/.source;\n\n\n\tPrism.languages.csharp = Prism.languages.extend('clike', {\n\t\t'string': [\n\t\t\t{\n\t\t\t\tpattern: re(/(^|[^$\\\\])<<0>>/.source, [verbatimString]),\n\t\t\t\tlookbehind: true,\n\t\t\t\tgreedy: true\n\t\t\t},\n\t\t\t{\n\t\t\t\tpattern: re(/(^|[^@$\\\\])<<0>>/.source, [regularString]),\n\t\t\t\tlookbehind: true,\n\t\t\t\tgreedy: true\n\t\t\t}\n\t\t],\n\t\t'class-name': [\n\t\t\t{\n\t\t\t\t// Using static\n\t\t\t\t// using static System.Math;\n\t\t\t\tpattern: re(/(\\busing\\s+static\\s+)<<0>>(?=\\s*;)/.source, [identifier]),\n\t\t\t\tlookbehind: true,\n\t\t\t\tinside: typeInside\n\t\t\t},\n\t\t\t{\n\t\t\t\t// Using alias (type)\n\t\t\t\t// using Project = PC.MyCompany.Project;\n\t\t\t\tpattern: re(/(\\busing\\s+<<0>>\\s*=\\s*)<<1>>(?=\\s*;)/.source, [name, typeExpression]),\n\t\t\t\tlookbehind: true,\n\t\t\t\tinside: typeInside\n\t\t\t},\n\t\t\t{\n\t\t\t\t// Using alias (alias)\n\t\t\t\t// using Project = PC.MyCompany.Project;\n\t\t\t\tpattern: re(/(\\busing\\s+)<<0>>(?=\\s*=)/.source, [name]),\n\t\t\t\tlookbehind: true\n\t\t\t},\n\t\t\t{\n\t\t\t\t// Type declarations\n\t\t\t\t// class Foo\n\t\t\t\t// interface Foo\n\t\t\t\tpattern: re(/(\\b<<0>>\\s+)<<1>>/.source, [typeDeclarationKeywords, genericName]),\n\t\t\t\tlookbehind: true,\n\t\t\t\tinside: typeInside\n\t\t\t},\n\t\t\t{\n\t\t\t\t// Single catch exception declaration\n\t\t\t\t// catch(Foo)\n\t\t\t\t// (things like catch(Foo e) is covered by variable declaration)\n\t\t\t\tpattern: re(/(\\bcatch\\s*\\(\\s*)<<0>>/.source, [identifier]),\n\t\t\t\tlookbehind: true,\n\t\t\t\tinside: typeInside\n\t\t\t},\n\t\t\t{\n\t\t\t\t// Name of the type parameter of generic constraints\n\t\t\t\t// where Foo : class\n\t\t\t\tpattern: re(/(\\bwhere\\s+)<<0>>/.source, [name]),\n\t\t\t\tlookbehind: true\n\t\t\t},\n\t\t\t{\n\t\t\t\t// Casts and checks via as and is.\n\t\t\t\t// as Foo, is Bar\n\t\t\t\t// (things like if(a is Foo b) is covered by variable declaration)\n\t\t\t\tpattern: re(/(\\b(?:is(?:\\s+not)?|as)\\s+)<<0>>/.source, [typeExpressionWithoutTuple]),\n\t\t\t\tlookbehind: true,\n\t\t\t\tinside: typeInside\n\t\t\t},\n\t\t\t{\n\t\t\t\t// Variable, field and parameter declaration\n\t\t\t\t// (Foo bar, Bar baz, Foo[,,] bay, Foo> bax)\n\t\t\t\tpattern: re(/\\b<<0>>(?=\\s+(?!<<1>>|with\\s*\\{)<<2>>(?:\\s*[=,;:{)\\]]|\\s+(?:in|when)\\b))/.source, [typeExpression, nonContextualKeywords, name]),\n\t\t\t\tinside: typeInside\n\t\t\t}\n\t\t],\n\t\t'keyword': keywords,\n\t\t// https://docs.microsoft.com/en-us/dotnet/csharp/language-reference/language-specification/lexical-structure#literals\n\t\t'number': /(?:\\b0(?:x[\\da-f_]*[\\da-f]|b[01_]*[01])|(?:\\B\\.\\d+(?:_+\\d+)*|\\b\\d+(?:_+\\d+)*(?:\\.\\d+(?:_+\\d+)*)?)(?:e[-+]?\\d+(?:_+\\d+)*)?)(?:[dflmu]|lu|ul)?\\b/i,\n\t\t'operator': />>=?|<<=?|[-=]>|([-+&|])\\1|~|\\?\\?=?|[-+*/%&|^!=<>]=?/,\n\t\t'punctuation': /\\?\\.?|::|[{}[\\];(),.:]/\n\t});\n\n\tPrism.languages.insertBefore('csharp', 'number', {\n\t\t'range': {\n\t\t\tpattern: /\\.\\./,\n\t\t\talias: 'operator'\n\t\t}\n\t});\n\n\tPrism.languages.insertBefore('csharp', 'punctuation', {\n\t\t'named-parameter': {\n\t\t\tpattern: re(/([(,]\\s*)<<0>>(?=\\s*:)/.source, [name]),\n\t\t\tlookbehind: true,\n\t\t\talias: 'punctuation'\n\t\t}\n\t});\n\n\tPrism.languages.insertBefore('csharp', 'class-name', {\n\t\t'namespace': {\n\t\t\t// namespace Foo.Bar {}\n\t\t\t// using Foo.Bar;\n\t\t\tpattern: re(/(\\b(?:namespace|using)\\s+)<<0>>(?:\\s*\\.\\s*<<0>>)*(?=\\s*[;{])/.source, [name]),\n\t\t\tlookbehind: true,\n\t\t\tinside: {\n\t\t\t\t'punctuation': /\\./\n\t\t\t}\n\t\t},\n\t\t'type-expression': {\n\t\t\t// default(Foo), typeof(Foo), sizeof(int)\n\t\t\tpattern: re(/(\\b(?:default|sizeof|typeof)\\s*\\(\\s*(?!\\s))(?:[^()\\s]|\\s(?!\\s)|<<0>>)*(?=\\s*\\))/.source, [nestedRound]),\n\t\t\tlookbehind: true,\n\t\t\talias: 'class-name',\n\t\t\tinside: typeInside\n\t\t},\n\t\t'return-type': {\n\t\t\t// Foo ForBar(); Foo IFoo.Bar() => 0\n\t\t\t// int this[int index] => 0; T IReadOnlyList.this[int index] => this[index];\n\t\t\t// int Foo => 0; int Foo { get; set } = 0;\n\t\t\tpattern: re(/<<0>>(?=\\s+(?:<<1>>\\s*(?:=>|[({]|\\.\\s*this\\s*\\[)|this\\s*\\[))/.source, [typeExpression, identifier]),\n\t\t\tinside: typeInside,\n\t\t\talias: 'class-name'\n\t\t},\n\t\t'constructor-invocation': {\n\t\t\t// new List> { }\n\t\t\tpattern: re(/(\\bnew\\s+)<<0>>(?=\\s*[[({])/.source, [typeExpression]),\n\t\t\tlookbehind: true,\n\t\t\tinside: typeInside,\n\t\t\talias: 'class-name'\n\t\t},\n\t\t/*'explicit-implementation': {\n\t\t\t// int IFoo.Bar => 0; void IFoo>.Foo();\n\t\t\tpattern: replace(/\\b<<0>>(?=\\.<<1>>)/, className, methodOrPropertyDeclaration),\n\t\t\tinside: classNameInside,\n\t\t\talias: 'class-name'\n\t\t},*/\n\t\t'generic-method': {\n\t\t\t// foo()\n\t\t\tpattern: re(/<<0>>\\s*<<1>>(?=\\s*\\()/.source, [name, generic]),\n\t\t\tinside: {\n\t\t\t\t'function': re(/^<<0>>/.source, [name]),\n\t\t\t\t'generic': {\n\t\t\t\t\tpattern: RegExp(generic),\n\t\t\t\t\talias: 'class-name',\n\t\t\t\t\tinside: typeInside\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\t\t'type-list': {\n\t\t\t// The list of types inherited or of generic constraints\n\t\t\t// class Foo : Bar, IList\n\t\t\t// where F : Bar, IList\n\t\t\tpattern: re(\n\t\t\t\t/\\b((?:<<0>>\\s+<<1>>|record\\s+<<1>>\\s*<<5>>|where\\s+<<2>>)\\s*:\\s*)(?:<<3>>|<<4>>|<<1>>\\s*<<5>>|<<6>>)(?:\\s*,\\s*(?:<<3>>|<<4>>|<<6>>))*(?=\\s*(?:where|[{;]|=>|$))/.source,\n\t\t\t\t[typeDeclarationKeywords, genericName, name, typeExpression, keywords.source, nestedRound, /\\bnew\\s*\\(\\s*\\)/.source]\n\t\t\t),\n\t\t\tlookbehind: true,\n\t\t\tinside: {\n\t\t\t\t'record-arguments': {\n\t\t\t\t\tpattern: re(/(^(?!new\\s*\\()<<0>>\\s*)<<1>>/.source, [genericName, nestedRound]),\n\t\t\t\t\tlookbehind: true,\n\t\t\t\t\tgreedy: true,\n\t\t\t\t\tinside: Prism.languages.csharp\n\t\t\t\t},\n\t\t\t\t'keyword': keywords,\n\t\t\t\t'class-name': {\n\t\t\t\t\tpattern: RegExp(typeExpression),\n\t\t\t\t\tgreedy: true,\n\t\t\t\t\tinside: typeInside\n\t\t\t\t},\n\t\t\t\t'punctuation': /[,()]/\n\t\t\t}\n\t\t},\n\t\t'preprocessor': {\n\t\t\tpattern: /(^[\\t ]*)#.*/m,\n\t\t\tlookbehind: true,\n\t\t\talias: 'property',\n\t\t\tinside: {\n\t\t\t\t// highlight preprocessor directives as keywords\n\t\t\t\t'directive': {\n\t\t\t\t\tpattern: /(#)\\b(?:define|elif|else|endif|endregion|error|if|line|nullable|pragma|region|undef|warning)\\b/,\n\t\t\t\t\tlookbehind: true,\n\t\t\t\t\talias: 'keyword'\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t});\n\n\t// attributes\n\tvar regularStringOrCharacter = regularString + '|' + character;\n\tvar regularStringCharacterOrComment = replace(/\\/(?![*/])|\\/\\/[^\\r\\n]*[\\r\\n]|\\/\\*(?:[^*]|\\*(?!\\/))*\\*\\/|<<0>>/.source, [regularStringOrCharacter]);\n\tvar roundExpression = nested(replace(/[^\"'/()]|<<0>>|\\(<>*\\)/.source, [regularStringCharacterOrComment]), 2);\n\n\t// https://docs.microsoft.com/en-us/dotnet/csharp/programming-guide/concepts/attributes/#attribute-targets\n\tvar attrTarget = /\\b(?:assembly|event|field|method|module|param|property|return|type)\\b/.source;\n\tvar attr = replace(/<<0>>(?:\\s*\\(<<1>>*\\))?/.source, [identifier, roundExpression]);\n\n\tPrism.languages.insertBefore('csharp', 'class-name', {\n\t\t'attribute': {\n\t\t\t// Attributes\n\t\t\t// [Foo], [Foo(1), Bar(2, Prop = \"foo\")], [return: Foo(1), Bar(2)], [assembly: Foo(Bar)]\n\t\t\tpattern: re(/((?:^|[^\\s\\w>)?])\\s*\\[\\s*)(?:<<0>>\\s*:\\s*)?<<1>>(?:\\s*,\\s*<<1>>)*(?=\\s*\\])/.source, [attrTarget, attr]),\n\t\t\tlookbehind: true,\n\t\t\tgreedy: true,\n\t\t\tinside: {\n\t\t\t\t'target': {\n\t\t\t\t\tpattern: re(/^<<0>>(?=\\s*:)/.source, [attrTarget]),\n\t\t\t\t\talias: 'keyword'\n\t\t\t\t},\n\t\t\t\t'attribute-arguments': {\n\t\t\t\t\tpattern: re(/\\(<<0>>*\\)/.source, [roundExpression]),\n\t\t\t\t\tinside: Prism.languages.csharp\n\t\t\t\t},\n\t\t\t\t'class-name': {\n\t\t\t\t\tpattern: RegExp(identifier),\n\t\t\t\t\tinside: {\n\t\t\t\t\t\t'punctuation': /\\./\n\t\t\t\t\t}\n\t\t\t\t},\n\t\t\t\t'punctuation': /[:,]/\n\t\t\t}\n\t\t}\n\t});\n\n\n\t// string interpolation\n\tvar formatString = /:[^}\\r\\n]+/.source;\n\t// multi line\n\tvar mInterpolationRound = nested(replace(/[^\"'/()]|<<0>>|\\(<>*\\)/.source, [regularStringCharacterOrComment]), 2);\n\tvar mInterpolation = replace(/\\{(?!\\{)(?:(?![}:])<<0>>)*<<1>>?\\}/.source, [mInterpolationRound, formatString]);\n\t// single line\n\tvar sInterpolationRound = nested(replace(/[^\"'/()]|\\/(?!\\*)|\\/\\*(?:[^*]|\\*(?!\\/))*\\*\\/|<<0>>|\\(<>*\\)/.source, [regularStringOrCharacter]), 2);\n\tvar sInterpolation = replace(/\\{(?!\\{)(?:(?![}:])<<0>>)*<<1>>?\\}/.source, [sInterpolationRound, formatString]);\n\n\tfunction createInterpolationInside(interpolation, interpolationRound) {\n\t\treturn {\n\t\t\t'interpolation': {\n\t\t\t\tpattern: re(/((?:^|[^{])(?:\\{\\{)*)<<0>>/.source, [interpolation]),\n\t\t\t\tlookbehind: true,\n\t\t\t\tinside: {\n\t\t\t\t\t'format-string': {\n\t\t\t\t\t\tpattern: re(/(^\\{(?:(?![}:])<<0>>)*)<<1>>(?=\\}$)/.source, [interpolationRound, formatString]),\n\t\t\t\t\t\tlookbehind: true,\n\t\t\t\t\t\tinside: {\n\t\t\t\t\t\t\t'punctuation': /^:/\n\t\t\t\t\t\t}\n\t\t\t\t\t},\n\t\t\t\t\t'punctuation': /^\\{|\\}$/,\n\t\t\t\t\t'expression': {\n\t\t\t\t\t\tpattern: /[\\s\\S]+/,\n\t\t\t\t\t\talias: 'language-csharp',\n\t\t\t\t\t\tinside: Prism.languages.csharp\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t},\n\t\t\t'string': /[\\s\\S]+/\n\t\t};\n\t}\n\n\tPrism.languages.insertBefore('csharp', 'string', {\n\t\t'interpolation-string': [\n\t\t\t{\n\t\t\t\tpattern: re(/(^|[^\\\\])(?:\\$@|@\\$)\"(?:\"\"|\\\\[\\s\\S]|\\{\\{|<<0>>|[^\\\\{\"])*\"/.source, [mInterpolation]),\n\t\t\t\tlookbehind: true,\n\t\t\t\tgreedy: true,\n\t\t\t\tinside: createInterpolationInside(mInterpolation, mInterpolationRound),\n\t\t\t},\n\t\t\t{\n\t\t\t\tpattern: re(/(^|[^@\\\\])\\$\"(?:\\\\.|\\{\\{|<<0>>|[^\\\\\"{])*\"/.source, [sInterpolation]),\n\t\t\t\tlookbehind: true,\n\t\t\t\tgreedy: true,\n\t\t\t\tinside: createInterpolationInside(sInterpolation, sInterpolationRound),\n\t\t\t}\n\t\t],\n\t\t'char': {\n\t\t\tpattern: RegExp(character),\n\t\t\tgreedy: true\n\t\t}\n\t});\n\n\tPrism.languages.dotnet = Prism.languages.cs = Prism.languages.csharp;\n\n}(Prism));\n","(function (Prism) {\n\n\tvar string = /(?:\"(?:\\\\(?:\\r\\n|[\\s\\S])|[^\"\\\\\\r\\n])*\"|'(?:\\\\(?:\\r\\n|[\\s\\S])|[^'\\\\\\r\\n])*')/;\n\n\tPrism.languages.css = {\n\t\t'comment': /\\/\\*[\\s\\S]*?\\*\\//,\n\t\t'atrule': {\n\t\t\tpattern: RegExp('@[\\\\w-](?:' + /[^;{\\s\"']|\\s+(?!\\s)/.source + '|' + string.source + ')*?' + /(?:;|(?=\\s*\\{))/.source),\n\t\t\tinside: {\n\t\t\t\t'rule': /^@[\\w-]+/,\n\t\t\t\t'selector-function-argument': {\n\t\t\t\t\tpattern: /(\\bselector\\s*\\(\\s*(?![\\s)]))(?:[^()\\s]|\\s+(?![\\s)])|\\((?:[^()]|\\([^()]*\\))*\\))+(?=\\s*\\))/,\n\t\t\t\t\tlookbehind: true,\n\t\t\t\t\talias: 'selector'\n\t\t\t\t},\n\t\t\t\t'keyword': {\n\t\t\t\t\tpattern: /(^|[^\\w-])(?:and|not|only|or)(?![\\w-])/,\n\t\t\t\t\tlookbehind: true\n\t\t\t\t}\n\t\t\t\t// See rest below\n\t\t\t}\n\t\t},\n\t\t'url': {\n\t\t\t// https://drafts.csswg.org/css-values-3/#urls\n\t\t\tpattern: RegExp('\\\\burl\\\\((?:' + string.source + '|' + /(?:[^\\\\\\r\\n()\"']|\\\\[\\s\\S])*/.source + ')\\\\)', 'i'),\n\t\t\tgreedy: true,\n\t\t\tinside: {\n\t\t\t\t'function': /^url/i,\n\t\t\t\t'punctuation': /^\\(|\\)$/,\n\t\t\t\t'string': {\n\t\t\t\t\tpattern: RegExp('^' + string.source + '$'),\n\t\t\t\t\talias: 'url'\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\t\t'selector': {\n\t\t\tpattern: RegExp('(^|[{}\\\\s])[^{}\\\\s](?:[^{};\"\\'\\\\s]|\\\\s+(?![\\\\s{])|' + string.source + ')*(?=\\\\s*\\\\{)'),\n\t\t\tlookbehind: true\n\t\t},\n\t\t'string': {\n\t\t\tpattern: string,\n\t\t\tgreedy: true\n\t\t},\n\t\t'property': {\n\t\t\tpattern: /(^|[^-\\w\\xA0-\\uFFFF])(?!\\s)[-_a-z\\xA0-\\uFFFF](?:(?!\\s)[-\\w\\xA0-\\uFFFF])*(?=\\s*:)/i,\n\t\t\tlookbehind: true\n\t\t},\n\t\t'important': /!important\\b/i,\n\t\t'function': {\n\t\t\tpattern: /(^|[^-a-z0-9])[-a-z0-9]+(?=\\()/i,\n\t\t\tlookbehind: true\n\t\t},\n\t\t'punctuation': /[(){};:,]/\n\t};\n\n\tPrism.languages.css['atrule'].inside.rest = Prism.languages.css;\n\n\tvar markup = Prism.languages.markup;\n\tif (markup) {\n\t\tmarkup.tag.addInlined('style', 'css');\n\t\tmarkup.tag.addAttribute('style', 'css');\n\t}\n\n}(Prism));\n","Prism.languages.javascript = Prism.languages.extend('clike', {\n\t'class-name': [\n\t\tPrism.languages.clike['class-name'],\n\t\t{\n\t\t\tpattern: /(^|[^$\\w\\xA0-\\uFFFF])(?!\\s)[_$A-Z\\xA0-\\uFFFF](?:(?!\\s)[$\\w\\xA0-\\uFFFF])*(?=\\.(?:constructor|prototype))/,\n\t\t\tlookbehind: true\n\t\t}\n\t],\n\t'keyword': [\n\t\t{\n\t\t\tpattern: /((?:^|\\})\\s*)catch\\b/,\n\t\t\tlookbehind: true\n\t\t},\n\t\t{\n\t\t\tpattern: /(^|[^.]|\\.\\.\\.\\s*)\\b(?:as|assert(?=\\s*\\{)|async(?=\\s*(?:function\\b|\\(|[$\\w\\xA0-\\uFFFF]|$))|await|break|case|class|const|continue|debugger|default|delete|do|else|enum|export|extends|finally(?=\\s*(?:\\{|$))|for|from(?=\\s*(?:['\"]|$))|function|(?:get|set)(?=\\s*(?:[#\\[$\\w\\xA0-\\uFFFF]|$))|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|static|super|switch|this|throw|try|typeof|undefined|var|void|while|with|yield)\\b/,\n\t\t\tlookbehind: true\n\t\t},\n\t],\n\t// Allow for all non-ASCII characters (See http://stackoverflow.com/a/2008444)\n\t'function': /#?(?!\\s)[_$a-zA-Z\\xA0-\\uFFFF](?:(?!\\s)[$\\w\\xA0-\\uFFFF])*(?=\\s*(?:\\.\\s*(?:apply|bind|call)\\s*)?\\()/,\n\t'number': {\n\t\tpattern: RegExp(\n\t\t\t/(^|[^\\w$])/.source +\n\t\t\t'(?:' +\n\t\t\t(\n\t\t\t\t// constant\n\t\t\t\t/NaN|Infinity/.source +\n\t\t\t\t'|' +\n\t\t\t\t// binary integer\n\t\t\t\t/0[bB][01]+(?:_[01]+)*n?/.source +\n\t\t\t\t'|' +\n\t\t\t\t// octal integer\n\t\t\t\t/0[oO][0-7]+(?:_[0-7]+)*n?/.source +\n\t\t\t\t'|' +\n\t\t\t\t// hexadecimal integer\n\t\t\t\t/0[xX][\\dA-Fa-f]+(?:_[\\dA-Fa-f]+)*n?/.source +\n\t\t\t\t'|' +\n\t\t\t\t// decimal bigint\n\t\t\t\t/\\d+(?:_\\d+)*n/.source +\n\t\t\t\t'|' +\n\t\t\t\t// decimal number (integer or float) but no bigint\n\t\t\t\t/(?:\\d+(?:_\\d+)*(?:\\.(?:\\d+(?:_\\d+)*)?)?|\\.\\d+(?:_\\d+)*)(?:[Ee][+-]?\\d+(?:_\\d+)*)?/.source\n\t\t\t) +\n\t\t\t')' +\n\t\t\t/(?![\\w$])/.source\n\t\t),\n\t\tlookbehind: true\n\t},\n\t'operator': /--|\\+\\+|\\*\\*=?|=>|&&=?|\\|\\|=?|[!=]==|<<=?|>>>?=?|[-+*/%&|^!=<>]=?|\\.{3}|\\?\\?=?|\\?\\.?|[~:]/\n});\n\nPrism.languages.javascript['class-name'][0].pattern = /(\\b(?:class|extends|implements|instanceof|interface|new)\\s+)[\\w.\\\\]+/;\n\nPrism.languages.insertBefore('javascript', 'keyword', {\n\t'regex': {\n\t\tpattern: RegExp(\n\t\t\t// lookbehind\n\t\t\t// eslint-disable-next-line regexp/no-dupe-characters-character-class\n\t\t\t/((?:^|[^$\\w\\xA0-\\uFFFF.\"'\\])\\s]|\\b(?:return|yield))\\s*)/.source +\n\t\t\t// Regex pattern:\n\t\t\t// There are 2 regex patterns here. The RegExp set notation proposal added support for nested character\n\t\t\t// classes if the `v` flag is present. Unfortunately, nested CCs are both context-free and incompatible\n\t\t\t// with the only syntax, so we have to define 2 different regex patterns.\n\t\t\t/\\//.source +\n\t\t\t'(?:' +\n\t\t\t/(?:\\[(?:[^\\]\\\\\\r\\n]|\\\\.)*\\]|\\\\.|[^/\\\\\\[\\r\\n])+\\/[dgimyus]{0,7}/.source +\n\t\t\t'|' +\n\t\t\t// `v` flag syntax. This supports 3 levels of nested character classes.\n\t\t\t/(?:\\[(?:[^[\\]\\\\\\r\\n]|\\\\.|\\[(?:[^[\\]\\\\\\r\\n]|\\\\.|\\[(?:[^[\\]\\\\\\r\\n]|\\\\.)*\\])*\\])*\\]|\\\\.|[^/\\\\\\[\\r\\n])+\\/[dgimyus]{0,7}v[dgimyus]{0,7}/.source +\n\t\t\t')' +\n\t\t\t// lookahead\n\t\t\t/(?=(?:\\s|\\/\\*(?:[^*]|\\*(?!\\/))*\\*\\/)*(?:$|[\\r\\n,.;:})\\]]|\\/\\/))/.source\n\t\t),\n\t\tlookbehind: true,\n\t\tgreedy: true,\n\t\tinside: {\n\t\t\t'regex-source': {\n\t\t\t\tpattern: /^(\\/)[\\s\\S]+(?=\\/[a-z]*$)/,\n\t\t\t\tlookbehind: true,\n\t\t\t\talias: 'language-regex',\n\t\t\t\tinside: Prism.languages.regex\n\t\t\t},\n\t\t\t'regex-delimiter': /^\\/|\\/$/,\n\t\t\t'regex-flags': /^[a-z]+$/,\n\t\t}\n\t},\n\t// This must be declared before keyword because we use \"function\" inside the look-forward\n\t'function-variable': {\n\t\tpattern: /#?(?!\\s)[_$a-zA-Z\\xA0-\\uFFFF](?:(?!\\s)[$\\w\\xA0-\\uFFFF])*(?=\\s*[=:]\\s*(?:async\\s*)?(?:\\bfunction\\b|(?:\\((?:[^()]|\\([^()]*\\))*\\)|(?!\\s)[_$a-zA-Z\\xA0-\\uFFFF](?:(?!\\s)[$\\w\\xA0-\\uFFFF])*)\\s*=>))/,\n\t\talias: 'function'\n\t},\n\t'parameter': [\n\t\t{\n\t\t\tpattern: /(function(?:\\s+(?!\\s)[_$a-zA-Z\\xA0-\\uFFFF](?:(?!\\s)[$\\w\\xA0-\\uFFFF])*)?\\s*\\(\\s*)(?!\\s)(?:[^()\\s]|\\s+(?![\\s)])|\\([^()]*\\))+(?=\\s*\\))/,\n\t\t\tlookbehind: true,\n\t\t\tinside: Prism.languages.javascript\n\t\t},\n\t\t{\n\t\t\tpattern: /(^|[^$\\w\\xA0-\\uFFFF])(?!\\s)[_$a-z\\xA0-\\uFFFF](?:(?!\\s)[$\\w\\xA0-\\uFFFF])*(?=\\s*=>)/i,\n\t\t\tlookbehind: true,\n\t\t\tinside: Prism.languages.javascript\n\t\t},\n\t\t{\n\t\t\tpattern: /(\\(\\s*)(?!\\s)(?:[^()\\s]|\\s+(?![\\s)])|\\([^()]*\\))+(?=\\s*\\)\\s*=>)/,\n\t\t\tlookbehind: true,\n\t\t\tinside: Prism.languages.javascript\n\t\t},\n\t\t{\n\t\t\tpattern: /((?:\\b|\\s|^)(?!(?:as|async|await|break|case|catch|class|const|continue|debugger|default|delete|do|else|enum|export|extends|finally|for|from|function|get|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|set|static|super|switch|this|throw|try|typeof|undefined|var|void|while|with|yield)(?![$\\w\\xA0-\\uFFFF]))(?:(?!\\s)[_$a-zA-Z\\xA0-\\uFFFF](?:(?!\\s)[$\\w\\xA0-\\uFFFF])*\\s*)\\(\\s*|\\]\\s*\\(\\s*)(?!\\s)(?:[^()\\s]|\\s+(?![\\s)])|\\([^()]*\\))+(?=\\s*\\)\\s*\\{)/,\n\t\t\tlookbehind: true,\n\t\t\tinside: Prism.languages.javascript\n\t\t}\n\t],\n\t'constant': /\\b[A-Z](?:[A-Z_]|\\dx?)*\\b/\n});\n\nPrism.languages.insertBefore('javascript', 'string', {\n\t'hashbang': {\n\t\tpattern: /^#!.*/,\n\t\tgreedy: true,\n\t\talias: 'comment'\n\t},\n\t'template-string': {\n\t\tpattern: /`(?:\\\\[\\s\\S]|\\$\\{(?:[^{}]|\\{(?:[^{}]|\\{[^}]*\\})*\\})+\\}|(?!\\$\\{)[^\\\\`])*`/,\n\t\tgreedy: true,\n\t\tinside: {\n\t\t\t'template-punctuation': {\n\t\t\t\tpattern: /^`|`$/,\n\t\t\t\talias: 'string'\n\t\t\t},\n\t\t\t'interpolation': {\n\t\t\t\tpattern: /((?:^|[^\\\\])(?:\\\\{2})*)\\$\\{(?:[^{}]|\\{(?:[^{}]|\\{[^}]*\\})*\\})+\\}/,\n\t\t\t\tlookbehind: true,\n\t\t\t\tinside: {\n\t\t\t\t\t'interpolation-punctuation': {\n\t\t\t\t\t\tpattern: /^\\$\\{|\\}$/,\n\t\t\t\t\t\talias: 'punctuation'\n\t\t\t\t\t},\n\t\t\t\t\trest: Prism.languages.javascript\n\t\t\t\t}\n\t\t\t},\n\t\t\t'string': /[\\s\\S]+/\n\t\t}\n\t},\n\t'string-property': {\n\t\tpattern: /((?:^|[,{])[ \\t]*)([\"'])(?:\\\\(?:\\r\\n|[\\s\\S])|(?!\\2)[^\\\\\\r\\n])*\\2(?=\\s*:)/m,\n\t\tlookbehind: true,\n\t\tgreedy: true,\n\t\talias: 'property'\n\t}\n});\n\nPrism.languages.insertBefore('javascript', 'operator', {\n\t'literal-property': {\n\t\tpattern: /((?:^|[,{])[ \\t]*)(?!\\s)[_$a-zA-Z\\xA0-\\uFFFF](?:(?!\\s)[$\\w\\xA0-\\uFFFF])*(?=\\s*:)/m,\n\t\tlookbehind: true,\n\t\talias: 'property'\n\t},\n});\n\nif (Prism.languages.markup) {\n\tPrism.languages.markup.tag.addInlined('script', 'javascript');\n\n\t// add attribute support for all DOM events.\n\t// https://developer.mozilla.org/en-US/docs/Web/Events#Standard_events\n\tPrism.languages.markup.tag.addAttribute(\n\t\t/on(?:abort|blur|change|click|composition(?:end|start|update)|dblclick|error|focus(?:in|out)?|key(?:down|up)|load|mouse(?:down|enter|leave|move|out|over|up)|reset|resize|scroll|select|slotchange|submit|unload|wheel)/.source,\n\t\t'javascript'\n\t);\n}\n\nPrism.languages.js = Prism.languages.javascript;\n","Prism.languages.markup = {\n\t'comment': {\n\t\tpattern: //,\n\t\tgreedy: true\n\t},\n\t'prolog': {\n\t\tpattern: /<\\?[\\s\\S]+?\\?>/,\n\t\tgreedy: true\n\t},\n\t'doctype': {\n\t\t// https://www.w3.org/TR/xml/#NT-doctypedecl\n\t\tpattern: /\"'[\\]]|\"[^\"]*\"|'[^']*')+(?:\\[(?:[^<\"'\\]]|\"[^\"]*\"|'[^']*'|<(?!!--)|)*\\]\\s*)?>/i,\n\t\tgreedy: true,\n\t\tinside: {\n\t\t\t'internal-subset': {\n\t\t\t\tpattern: /(^[^\\[]*\\[)[\\s\\S]+(?=\\]>$)/,\n\t\t\t\tlookbehind: true,\n\t\t\t\tgreedy: true,\n\t\t\t\tinside: null // see below\n\t\t\t},\n\t\t\t'string': {\n\t\t\t\tpattern: /\"[^\"]*\"|'[^']*'/,\n\t\t\t\tgreedy: true\n\t\t\t},\n\t\t\t'punctuation': /^$|[[\\]]/,\n\t\t\t'doctype-tag': /^DOCTYPE/i,\n\t\t\t'name': /[^\\s<>'\"]+/\n\t\t}\n\t},\n\t'cdata': {\n\t\tpattern: //i,\n\t\tgreedy: true\n\t},\n\t'tag': {\n\t\tpattern: /<\\/?(?!\\d)[^\\s>\\/=$<%]+(?:\\s(?:\\s*[^\\s>\\/=]+(?:\\s*=\\s*(?:\"[^\"]*\"|'[^']*'|[^\\s'\">=]+(?=[\\s>]))|(?=[\\s/>])))+)?\\s*\\/?>/,\n\t\tgreedy: true,\n\t\tinside: {\n\t\t\t'tag': {\n\t\t\t\tpattern: /^<\\/?[^\\s>\\/]+/,\n\t\t\t\tinside: {\n\t\t\t\t\t'punctuation': /^<\\/?/,\n\t\t\t\t\t'namespace': /^[^\\s>\\/:]+:/\n\t\t\t\t}\n\t\t\t},\n\t\t\t'special-attr': [],\n\t\t\t'attr-value': {\n\t\t\t\tpattern: /=\\s*(?:\"[^\"]*\"|'[^']*'|[^\\s'\">=]+)/,\n\t\t\t\tinside: {\n\t\t\t\t\t'punctuation': [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tpattern: /^=/,\n\t\t\t\t\t\t\talias: 'attr-equals'\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tpattern: /^(\\s*)[\"']|[\"']$/,\n\t\t\t\t\t\t\tlookbehind: true\n\t\t\t\t\t\t}\n\t\t\t\t\t]\n\t\t\t\t}\n\t\t\t},\n\t\t\t'punctuation': /\\/?>/,\n\t\t\t'attr-name': {\n\t\t\t\tpattern: /[^\\s>\\/]+/,\n\t\t\t\tinside: {\n\t\t\t\t\t'namespace': /^[^\\s>\\/:]+:/\n\t\t\t\t}\n\t\t\t}\n\n\t\t}\n\t},\n\t'entity': [\n\t\t{\n\t\t\tpattern: /&[\\da-z]{1,8};/i,\n\t\t\talias: 'named-entity'\n\t\t},\n\t\t/&#x?[\\da-f]{1,8};/i\n\t]\n};\n\nPrism.languages.markup['tag'].inside['attr-value'].inside['entity'] =\n\tPrism.languages.markup['entity'];\nPrism.languages.markup['doctype'].inside['internal-subset'].inside = Prism.languages.markup;\n\n// Plugin to make entity title show the real entity, idea by Roman Komarov\nPrism.hooks.add('wrap', function (env) {\n\n\tif (env.type === 'entity') {\n\t\tenv.attributes['title'] = env.content.replace(/&/, '&');\n\t}\n});\n\nObject.defineProperty(Prism.languages.markup.tag, 'addInlined', {\n\t/**\n\t * Adds an inlined language to markup.\n\t *\n\t * An example of an inlined language is CSS with `
\ No newline at end of file +Adam Graham • Blackhole

Blackhole

January 2015|Solo Project
Adobe Flash
ActionScript 3.0

Blackhole is a free-form, avant-garde game that enables players to control particles in unique ways. Individuals explore their own creative design within the art piece, loosely making their own objectives and discovering new ways of controlling this "creative chaos" - a new type of game genre.

Media

GitHub
LinkedIn
Email
Dark Mode
Download
Source Code
\ No newline at end of file diff --git a/art/canvas/index.html b/art/canvas/index.html index 4ad9299..6f94c79 100644 --- a/art/canvas/index.html +++ b/art/canvas/index.html @@ -1 +1 @@ -Adam Graham • Canvas

Canvas

March 2015|Solo Project
Adobe Flash
ActionScript 3.0

Canvas is a never-ending, interactive painting. Alter the direction of the brushes to influence the painting or sit back and watch. Every thirty seconds the canvas is cleared and a new set of design principles are created. Learn to let go and design with the flow.

Media

GitHub
LinkedIn
Email
Dark Mode
Download
Source Code
\ No newline at end of file +Adam Graham • Canvas

Canvas

March 2015|Solo Project
Adobe Flash
ActionScript 3.0

Canvas is a never-ending, interactive painting. Alter the direction of the brushes to influence the painting or sit back and watch. Every thirty seconds the canvas is cleared and a new set of design principles are created. Learn to let go and design with the flow.

Media

GitHub
LinkedIn
Email
Dark Mode
Download
Source Code
\ No newline at end of file diff --git a/art/hexahedroniks/index.html b/art/hexahedroniks/index.html index e45fb1d..c7f4985 100644 --- a/art/hexahedroniks/index.html +++ b/art/hexahedroniks/index.html @@ -1 +1 @@ -Adam Graham • Hexahedroniks

Hexahedroniks

June 2015|Solo Project
Unity
C#
Oculus Rift

Hexahedroniks is a virtual reality, puzzle-like toy inspired by Rubik cubes. Paint the cube various colors by looking around and shooting colored orbs at the many faces. Avoid turning the cube all black while enjoying the calming experience of this art piece.

Media

GitHub
LinkedIn
Email
Dark Mode
Download
Source Code
\ No newline at end of file +Adam Graham • Hexahedroniks

Hexahedroniks

June 2015|Solo Project
Unity
C#
Oculus Rift

Hexahedroniks is a virtual reality, puzzle-like toy inspired by Rubik cubes. Paint the cube various colors by looking around and shooting colored orbs at the many faces. Avoid turning the cube all black while enjoying the calming experience of this art piece.

Media

GitHub
LinkedIn
Email
Dark Mode
Download
Source Code
\ No newline at end of file diff --git a/art/index.html b/art/index.html index b36521b..0f4f9b2 100644 --- a/art/index.html +++ b/art/index.html @@ -1 +1 @@ -Adam Graham • Interactive Art
GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file +Adam Graham • Interactive Art
GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file diff --git a/art/mixed/index.html b/art/mixed/index.html index dfde485..37533b0 100644 --- a/art/mixed/index.html +++ b/art/mixed/index.html @@ -1 +1 @@ -Adam Graham • Mixed

Mixed

February 2015|Solo Project
Adobe Flash
ActionScript 3.0

Mixed is an interactive, avant-garde experiment touching on the topics of diversity, racism, and interracial relationships. Navigate around in an abstract space, mixing with different colors to create AI-controlled players. Explore the effects of cultural diversity and see how diversity is (im)balanced in the world. What impact can you leave on the world?

Media

GitHub
LinkedIn
Email
Dark Mode
Download
Source Code
\ No newline at end of file +Adam Graham • Mixed

Mixed

February 2015|Solo Project
Adobe Flash
ActionScript 3.0

Mixed is an interactive, avant-garde experiment touching on the topics of diversity, racism, and interracial relationships. Navigate around in an abstract space, mixing with different colors to create AI-controlled players. Explore the effects of cultural diversity and see how diversity is (im)balanced in the world. What impact can you leave on the world?

Media

GitHub
LinkedIn
Email
Dark Mode
Download
Source Code
\ No newline at end of file diff --git a/bb2a438c5d749940577b6da90d079ffc6be879e5-d46bc632d9a40ea835fc.js b/bb2a438c5d749940577b6da90d079ffc6be879e5-d46bc632d9a40ea835fc.js new file mode 100644 index 0000000..02ea07a --- /dev/null +++ b/bb2a438c5d749940577b6da90d079ffc6be879e5-d46bc632d9a40ea835fc.js @@ -0,0 +1,3 @@ +/*! For license information please see bb2a438c5d749940577b6da90d079ffc6be879e5-d46bc632d9a40ea835fc.js.LICENSE.txt */ +(self.webpackChunk_adamgraham_portfolio=self.webpackChunk_adamgraham_portfolio||[]).push([[713],{5043:function(e,t,n){"use strict";n.d(t,{Ex:function(){return le},$n:function(){return G},e2:function(){return ce},QN:function(){return ge},In:function(){return D},i_:function(){return be},N_:function(){return I},jq:function(){return V},vb:function(){return ye},b6:function(){return Q},Vz:function(){return Oe},qE:function(){return q},Io:function(){return X},U4:function(){return Y},Cc:function(){return H},Lh:function(){return te},Ub:function(){return ee},ln:function(){return ie},kB:function(){return ae},DP:function(){return oe}});var r=n(6942),i=n.n(r),a=n(6540),o=(n(8848),n(5624),n(5651),n(1113),n(5723),n(4312),n(961),n(5556)),s=n.n(o),l=n(312),u=n.n(l);function c(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function d(e){for(var t=1;te.length)&&(t=e.length);for(var n=0,r=new Array(t);n1&&void 0!==arguments[1]?arguments[1]:null;if(!e)return"";var n=e;return t&&Object.keys(t).forEach((function(e){n=n.replace(e,t[e])})),n}function C(){return void 0!==n.g.window?n.g.window.innerWidth:0}function S(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:n.g.window.self;return e===n.g.window.top||function(){try{return n.g.window.location.hostname!==n.g.window.parent.location.hostname}catch(e){return!0}}()?e:S(e.parent)}var _=300,O=27,A=37,T=39,j=function(e){!function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function");e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,writable:!0,configurable:!0}}),t&&g(e,t)}(s,e);var t,r,i,o=y(s);function s(e){var t;return function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,s),(t=o.call(this,e)).state={isClosing:!e.animationDisabled,shouldAnimate:!1,zoomLevel:0,offsetX:0,offsetY:0,loadErrorStatus:{}},t.outerEl=a.createRef(),t.zoomInBtn=a.createRef(),t.zoomOutBtn=a.createRef(),t.caption=a.createRef(),t.closeIfClickInner=t.closeIfClickInner.bind(v(t)),t.handleImageDoubleClick=t.handleImageDoubleClick.bind(v(t)),t.handleImageMouseWheel=t.handleImageMouseWheel.bind(v(t)),t.handleKeyInput=t.handleKeyInput.bind(v(t)),t.handleMouseUp=t.handleMouseUp.bind(v(t)),t.handleMouseDown=t.handleMouseDown.bind(v(t)),t.handleMouseMove=t.handleMouseMove.bind(v(t)),t.handleOuterMousewheel=t.handleOuterMousewheel.bind(v(t)),t.handleTouchStart=t.handleTouchStart.bind(v(t)),t.handleTouchMove=t.handleTouchMove.bind(v(t)),t.handleTouchEnd=t.handleTouchEnd.bind(v(t)),t.handlePointerEvent=t.handlePointerEvent.bind(v(t)),t.handleCaptionMousewheel=t.handleCaptionMousewheel.bind(v(t)),t.handleWindowResize=t.handleWindowResize.bind(v(t)),t.handleZoomInButtonClick=t.handleZoomInButtonClick.bind(v(t)),t.handleZoomOutButtonClick=t.handleZoomOutButtonClick.bind(v(t)),t.requestClose=t.requestClose.bind(v(t)),t.requestMoveNext=t.requestMoveNext.bind(v(t)),t.requestMovePrev=t.requestMovePrev.bind(v(t)),t.timeouts=[],t.currentAction=0,t.eventsSource=0,t.pointerList=[],t.preventInnerClose=!1,t.preventInnerCloseTimeout=null,t.keyPressed=!1,t.imageCache={},t.lastKeyDownTime=0,t.resizeTimeout=null,t.wheelActionTimeout=null,t.resetScrollTimeout=null,t.scrollX=0,t.scrollY=0,t.moveStartX=0,t.moveStartY=0,t.moveStartOffsetX=0,t.moveStartOffsetY=0,t.swipeStartX=0,t.swipeStartY=0,t.swipeEndX=0,t.swipeEndY=0,t.pinchTouchList=null,t.pinchDistance=0,t.keyCounter=0,t.moveRequested=!1,t}return t=s,r=[{key:"componentDidMount",value:function(){var e=this;this.props.animationDisabled||this.setState({isClosing:!1}),this.windowContext=S(),this.listeners={resize:this.handleWindowResize,mouseup:this.handleMouseUp,touchend:this.handleTouchEnd,touchcancel:this.handleTouchEnd,pointerdown:this.handlePointerEvent,pointermove:this.handlePointerEvent,pointerup:this.handlePointerEvent,pointercancel:this.handlePointerEvent},Object.keys(this.listeners).forEach((function(t){e.windowContext.addEventListener(t,e.listeners[t])})),this.loadAllImages()}},{key:"shouldComponentUpdate",value:function(e){var t=this;return this.getSrcTypes().forEach((function(n){t.props[n.name]!==e[n.name]&&(t.moveRequested=!1)})),!this.moveRequested}},{key:"componentDidUpdate",value:function(e){var t=this,n=!1,r={},i={};this.getSrcTypes().forEach((function(a){e[a.name]!==t.props[a.name]&&(n=!0,r[e[a.name]]=!0,i[t.props[a.name]]=!0)})),(n||this.moveRequested)&&(Object.keys(r).forEach((function(e){!(e in i)&&e in t.imageCache&&(t.imageCache[e].loaded=!1)})),this.moveRequested=!1,this.loadAllImages(this.props))}},{key:"componentWillUnmount",value:function(){var e=this;this.didUnmount=!0,Object.keys(this.listeners).forEach((function(t){e.windowContext.removeEventListener(t,e.listeners[t])})),this.timeouts.forEach((function(e){return clearTimeout(e)}))}},{key:"setTimeout",value:function(e){function t(t,n){return e.apply(this,arguments)}return t.toString=function(){return e.toString()},t}((function(e,t){var n=this,r=setTimeout((function(){n.timeouts=n.timeouts.filter((function(e){return e!==r})),e()}),t);return this.timeouts.push(r),r}))},{key:"setPreventInnerClose",value:function(){var e=this;this.preventInnerCloseTimeout&&this.clearTimeout(this.preventInnerCloseTimeout),this.preventInnerClose=!0,this.preventInnerCloseTimeout=this.setTimeout((function(){e.preventInnerClose=!1,e.preventInnerCloseTimeout=null}),100)}},{key:"getBestImageForType",value:function(e){var t=this.props[e],n={};if(this.isImageLoaded(t))n=this.getFitSizes(this.imageCache[t].width,this.imageCache[t].height);else{if(!this.isImageLoaded(this.props["".concat(e,"Thumbnail")]))return null;t=this.props["".concat(e,"Thumbnail")],n=this.getFitSizes(this.imageCache[t].width,this.imageCache[t].height,!0)}return{src:t,height:this.imageCache[t].height,width:this.imageCache[t].width,targetHeight:n.height,targetWidth:n.width}}},{key:"getFitSizes",value:function(e,t,n){var r=this.getLightboxRect(),i=r.height-2*this.props.imagePadding,a=r.width-2*this.props.imagePadding;return n||(i=Math.min(i,t),a=Math.min(a,e)),a/i>e/t?{width:e*i/t,height:i}:{width:a,height:t*a/e}}},{key:"getMaxOffsets",value:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.state.zoomLevel,t=this.getBestImageForType("mainSrc");if(null===t)return{maxX:0,minX:0,maxY:0,minY:0};var n=this.getLightboxRect(),r=this.getZoomMultiplier(e),i=0,a=0;return{maxX:i=r*t.width-n.width<0?(n.width-r*t.width)/2:(r*t.width-n.width)/2,maxY:a=r*t.height-n.height<0?(n.height-r*t.height)/2:(r*t.height-n.height)/2,minX:-1*i,minY:-1*a}}},{key:"getSrcTypes",value:function(){return[{name:"mainSrc",keyEnding:"i".concat(this.keyCounter)},{name:"mainSrcThumbnail",keyEnding:"t".concat(this.keyCounter)},{name:"nextSrc",keyEnding:"i".concat(this.keyCounter+1)},{name:"nextSrcThumbnail",keyEnding:"t".concat(this.keyCounter+1)},{name:"prevSrc",keyEnding:"i".concat(this.keyCounter-1)},{name:"prevSrcThumbnail",keyEnding:"t".concat(this.keyCounter-1)}]}},{key:"getZoomMultiplier",value:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.state.zoomLevel;return Math.pow(1.007,e)}},{key:"getLightboxRect",value:function(){return this.outerEl.current?this.outerEl.current.getBoundingClientRect():{width:C(),height:void 0!==n.g.window?n.g.window.innerHeight:0,top:0,right:0,bottom:0,left:0}}},{key:"clearTimeout",value:function(e){function t(t){return e.apply(this,arguments)}return t.toString=function(){return e.toString()},t}((function(e){this.timeouts=this.timeouts.filter((function(t){return t!==e})),clearTimeout(e)}))},{key:"changeZoom",value:function(e,t,n){if(this.props.enableZoom){var r=Math.max(0,Math.min(_,e));if(r!==this.state.zoomLevel)if(0!==r){var i=this.getBestImageForType("mainSrc");if(null!==i){var a=this.getZoomMultiplier(),o=this.getZoomMultiplier(r),s=this.getLightboxRect(),l=void 0!==t?t-s.left:s.width/2,u=void 0!==n?n-s.top:s.height/2,c=(s.width-i.width*a)/2,d=(s.height-i.height*a)/2,h=l-(l-(c-this.state.offsetX))/a*o,p=u-(u-(d-this.state.offsetY))/a*o,f=(s.width-i.width*o)/2-h,m=(s.height-i.height*o)/2-p;if(3!==this.currentAction){var g=this.getMaxOffsets();this.state.zoomLevel>r&&(f=Math.max(g.minX,Math.min(g.maxX,f)),m=Math.max(g.minY,Math.min(g.maxY,m)))}this.setState({zoomLevel:r,offsetX:f,offsetY:m})}}else this.setState({zoomLevel:r,offsetX:0,offsetY:0})}}},{key:"closeIfClickInner",value:function(e){!this.preventInnerClose&&e.target.className.search(/\bril-inner\b/)>-1&&this.requestClose(e)}},{key:"handleKeyInput",value:function(e){if(e.stopPropagation(),!this.isAnimating())if("keyup"!==e.type){var t=e.which||e.keyCode,n=new Date;if(!(n.getTime()-this.lastKeyDownTime=200||e.deltaX>=100?(this.requestMoveNext(e),n=500,this.scrollX=0):(this.scrollX<=-200||e.deltaX<=-100)&&(this.requestMovePrev(e),n=500,this.scrollX=0)),0!==n&&(this.wheelActionTimeout=this.setTimeout((function(){t.wheelActionTimeout=null}),n)))}},{key:"handleImageMouseWheel",value:function(e){if(Math.abs(e.deltaY)>=Math.abs(e.deltaX)){if(e.stopPropagation(),Math.abs(e.deltaY)<1)return;this.scrollX=0,this.scrollY+=e.deltaY,this.changeZoom(this.state.zoomLevel-e.deltaY,e.clientX,e.clientY)}}},{key:"handleImageDoubleClick",value:function(e){this.state.zoomLevel>0?this.changeZoom(0,e.clientX,e.clientY):this.changeZoom(this.state.zoomLevel+100,e.clientX,e.clientY)}},{key:"shouldHandleEvent",value:function(e){if(this.eventsSource===e)return!0;if(0===this.eventsSource)return this.eventsSource=e,!0;switch(e){case 1:default:return!1;case 2:return this.eventsSource=2,this.filterPointersBySource(),!0;case 3:return 1===this.eventsSource&&(this.eventsSource=3,this.filterPointersBySource(),!0)}}},{key:"addPointer",value:function(e){this.pointerList.push(e)}},{key:"removePointer",value:function(e){this.pointerList=this.pointerList.filter((function(t){return t.id!==e.id}))}},{key:"filterPointersBySource",value:function(){var e=this;this.pointerList=this.pointerList.filter((function(t){return t.source===e.eventsSource}))}},{key:"handleMouseDown",value:function(e){this.shouldHandleEvent(1)&&s.isTargetMatchImage(e.target)&&(this.addPointer(s.parseMouseEvent(e)),this.multiPointerStart(e))}},{key:"handleMouseMove",value:function(e){this.shouldHandleEvent(1)&&this.multiPointerMove(e,[s.parseMouseEvent(e)])}},{key:"handleMouseUp",value:function(e){this.shouldHandleEvent(1)&&(this.removePointer(s.parseMouseEvent(e)),this.multiPointerEnd(e))}},{key:"handlePointerEvent",value:function(e){if(this.shouldHandleEvent(3))switch(e.type){case"pointerdown":s.isTargetMatchImage(e.target)&&(this.addPointer(s.parsePointerEvent(e)),this.multiPointerStart(e));break;case"pointermove":this.multiPointerMove(e,[s.parsePointerEvent(e)]);break;case"pointerup":case"pointercancel":this.removePointer(s.parsePointerEvent(e)),this.multiPointerEnd(e)}}},{key:"handleTouchStart",value:function(e){var t=this;this.shouldHandleEvent(2)&&s.isTargetMatchImage(e.target)&&([].forEach.call(e.changedTouches,(function(e){return t.addPointer(s.parseTouchPointer(e))})),this.multiPointerStart(e))}},{key:"handleTouchMove",value:function(e){this.shouldHandleEvent(2)&&this.multiPointerMove(e,[].map.call(e.changedTouches,(function(e){return s.parseTouchPointer(e)})))}},{key:"handleTouchEnd",value:function(e){var t=this;this.shouldHandleEvent(2)&&([].map.call(e.changedTouches,(function(e){return t.removePointer(s.parseTouchPointer(e))})),this.multiPointerEnd(e))}},{key:"decideMoveOrSwipe",value:function(e){this.state.zoomLevel<=0?this.handleSwipeStart(e):this.handleMoveStart(e)}},{key:"multiPointerStart",value:function(e){switch(this.handleEnd(null),this.pointerList.length){case 1:e.preventDefault(),this.decideMoveOrSwipe(this.pointerList[0]);break;case 2:e.preventDefault(),this.handlePinchStart(this.pointerList)}}},{key:"multiPointerMove",value:function(e,t){switch(this.currentAction){case 1:e.preventDefault(),this.handleMove(t[0]);break;case 2:e.preventDefault(),this.handleSwipe(t[0]);break;case 3:e.preventDefault(),this.handlePinch(t)}}},{key:"multiPointerEnd",value:function(e){switch(0!==this.currentAction&&(this.setPreventInnerClose(),this.handleEnd(e)),this.pointerList.length){case 0:this.eventsSource=0;break;case 1:e.preventDefault(),this.decideMoveOrSwipe(this.pointerList[0]);break;case 2:e.preventDefault(),this.handlePinchStart(this.pointerList)}}},{key:"handleEnd",value:function(e){switch(this.currentAction){case 1:this.handleMoveEnd(e);break;case 2:this.handleSwipeEnd(e);break;case 3:this.handlePinchEnd(e)}}},{key:"handleMoveStart",value:function(e){var t=e.x,n=e.y;this.props.enableZoom&&(this.currentAction=1,this.moveStartX=t,this.moveStartY=n,this.moveStartOffsetX=this.state.offsetX,this.moveStartOffsetY=this.state.offsetY)}},{key:"handleMove",value:function(e){var t=e.x,n=e.y,r=this.moveStartX-t+this.moveStartOffsetX,i=this.moveStartY-n+this.moveStartOffsetY;this.state.offsetX===r&&this.state.offsetY===i||this.setState({offsetX:r,offsetY:i})}},{key:"handleMoveEnd",value:function(){var e=this;this.currentAction=0,this.moveStartX=0,this.moveStartY=0,this.moveStartOffsetX=0,this.moveStartOffsetY=0;var t=this.getMaxOffsets(),n=Math.max(t.minX,Math.min(t.maxX,this.state.offsetX)),r=Math.max(t.minY,Math.min(t.maxY,this.state.offsetY));n===this.state.offsetX&&r===this.state.offsetY||(this.setState({offsetX:n,offsetY:r,shouldAnimate:!0}),this.setTimeout((function(){e.setState({shouldAnimate:!1})}),this.props.animationDuration))}},{key:"handleSwipeStart",value:function(e){var t=e.x,n=e.y;this.currentAction=2,this.swipeStartX=t,this.swipeStartY=n,this.swipeEndX=t,this.swipeEndY=n}},{key:"handleSwipe",value:function(e){var t=e.x,n=e.y;this.swipeEndX=t,this.swipeEndY=n}},{key:"handleSwipeEnd",value:function(e){var t=this.swipeEndX-this.swipeStartX,n=Math.abs(t),r=Math.abs(this.swipeEndY-this.swipeStartY);if(this.currentAction=0,this.swipeStartX=0,this.swipeStartY=0,this.swipeEndX=0,this.swipeEndY=0,!(!e||this.isAnimating()||n<1.5*r)){if(n<200&&n0&&this.props.prevSrc?(e.preventDefault(),this.requestMovePrev()):t<0&&this.props.nextSrc&&(e.preventDefault(),this.requestMoveNext())}}},{key:"calculatePinchDistance",value:function(){var e=b(arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.pinchTouchList,2),t=e[0],n=e[1];return Math.sqrt(Math.pow(t.x-n.x,2)+Math.pow(t.y-n.y,2))}},{key:"calculatePinchCenter",value:function(){var e=b(arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.pinchTouchList,2),t=e[0],n=e[1];return{x:t.x-(t.x-n.x)/2,y:t.y-(t.y-n.y)/2}}},{key:"handlePinchStart",value:function(e){this.props.enableZoom&&(this.currentAction=3,this.pinchTouchList=e.map((function(e){return{id:e.id,x:e.x,y:e.y}})),this.pinchDistance=this.calculatePinchDistance())}},{key:"handlePinch",value:function(e){this.pinchTouchList=this.pinchTouchList.map((function(t){for(var n=0;n0&&t+i>=r||e.deltaY<0&&i<=0)&&e.preventDefault()}}},{key:"isAnimating",value:function(){return this.state.shouldAnimate||this.state.isClosing}},{key:"isImageLoaded",value:function(e){return e&&e in this.imageCache&&this.imageCache[e].loaded}},{key:"loadImage",value:function(e,t,r){var i=this;if(this.isImageLoaded(t))this.setTimeout((function(){r()}),1);else{var a=new n.g.Image;this.props.imageCrossOrigin&&(a.crossOrigin=this.props.imageCrossOrigin),a.onerror=function(n){i.props.onImageLoadError(t,e,n),i.setState((function(t){return{loadErrorStatus:d(d({},t.loadErrorStatus),{},p({},e,!0))}})),r(n)},a.onload=function(){i.props.onImageLoad(t,e,a),i.imageCache[t]={loaded:!0,width:a.width,height:a.height},r()},a.src=t}}},{key:"loadAllImages",value:function(){var e=this,t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.props;this.getSrcTypes().forEach((function(n){var r=n.name;t[r]&&e.state.loadErrorStatus[r]&&e.setState((function(e){return{loadErrorStatus:d(d({},e.loadErrorStatus),{},p({},r,!1))}})),t[r]&&!e.isImageLoaded(t[r])&&e.loadImage(r,t[r],function(t,n){return function(r){r||e.props[t]!==n||e.didUnmount||e.forceUpdate()}}(r,t[r]))}))}},{key:"requestClose",value:function(e){var t=this,n=function(){return t.props.onCloseRequest(e)};this.props.animationDisabled||"keydown"===e.type&&!this.props.animationOnKeyInput?n():(this.setState({isClosing:!0}),this.setTimeout(n,this.props.animationDuration))}},{key:"requestMove",value:function(e,t){var n=this,r={zoomLevel:0,offsetX:0,offsetY:0};this.props.animationDisabled||this.keyPressed&&!this.props.animationOnKeyInput||(r.shouldAnimate=!0,this.setTimeout((function(){return n.setState({shouldAnimate:!1})}),this.props.animationDuration)),this.keyPressed=!1,this.moveRequested=!0,"prev"===e?(this.keyCounter-=1,this.setState(r),this.props.onMovePrevRequest(t)):(this.keyCounter+=1,this.setState(r),this.props.onMoveNextRequest(t))}},{key:"requestMoveNext",value:function(e){this.requestMove("next",e)}},{key:"requestMovePrev",value:function(e){this.requestMove("prev",e)}},{key:"render",value:function(){var e=this,t=this.props,r=t.animationDisabled,i=t.animationDuration,o=t.clickOutsideToClose,l=t.discourageDownloads,c=t.enableZoom,h=t.imageTitle,p=t.nextSrc,m=t.prevSrc,g=t.toolbarButtons,v=t.reactModalStyle,y=t.onAfterOpen,b=t.imageCrossOrigin,x=t.reactModalProps,k=t.loader,C=this.state,S=C.zoomLevel,O=C.offsetX,A=C.offsetY,T=C.isClosing,j=C.loadErrorStatus,P=this.getLightboxRect(),M={};!r&&this.isAnimating()&&(M=d(d({},M),{},{transition:"transform ".concat(i,"ms")}));var N={};this.getSrcTypes().forEach((function(e){var t=e.name,n=e.keyEnding;N[t]=n}));var F=[],L=function(t,n,r){if(e.props[t]){var i,o=e.getBestImageForType(t),u=d(d({},M),s.getTransform(d(d({},r),o)));if(S>0&&(u.cursor="move"),null===o&&(i=j,Object.keys(i).some((function(e){return i[e]}))))F.push(a.createElement("div",{className:"".concat(n," ril__image ril-errored"),style:u,key:e.props[t]+N[t]},a.createElement("div",{className:"ril__errorContainer"},e.props.imageLoadErrorMessage)));else if(null!==o){var c=o.src;l?(u.backgroundImage="url('".concat(c,"')"),F.push(a.createElement("div",{className:"".concat(n," ril__image ril__imageDiscourager"),onDoubleClick:e.handleImageDoubleClick,onWheel:e.handleImageMouseWheel,style:u,key:c+N[t]},a.createElement("div",{className:"ril-download-blocker ril__downloadBlocker"})))):F.push(a.createElement("img",f({},b?{crossOrigin:b}:{},{className:"".concat(n," ril__image"),onDoubleClick:e.handleImageDoubleClick,onWheel:e.handleImageMouseWheel,onDragStart:function(e){return e.preventDefault()},style:u,src:c,key:c+N[t],alt:"string"==typeof h?h:E("Image"),draggable:!1})))}else{var p=void 0!==k?k:a.createElement("div",{className:"ril-loading-circle ril__loadingCircle ril__loadingContainer__icon"},w(new Array(12)).map((function(e,t){return a.createElement("div",{key:t,className:"ril-loading-circle-point ril__loadingCirclePoint"})})));F.push(a.createElement("div",{className:"".concat(n," ril__image ril-not-loaded"),style:u,key:e.props[t]+N[t]},a.createElement("div",{className:"ril__loadingContainer"},p)))}}},I=this.getZoomMultiplier();L("nextSrc","ril-image-next ril__imageNext",{x:P.width}),L("mainSrc","ril-image-current",{x:-1*O,y:-1*A,zoom:I}),L("prevSrc","ril-image-prev ril__imagePrev",{x:-1*P.width});var z={overlay:d({zIndex:1e3,backgroundColor:"transparent"},v.overlay),content:d({backgroundColor:"transparent",overflow:"hidden",border:"none",borderRadius:0,padding:0,top:0,left:0,right:0,bottom:0},v.content)};return a.createElement(u(),f({isOpen:!0,onRequestClose:o?this.requestClose:void 0,onAfterOpen:function(){e.outerEl.current&&e.outerEl.current.focus(),y()},style:z,contentLabel:E("Lightbox"),appElement:void 0!==n.g.window?n.g.window.document.body:void 0},x),a.createElement("div",{className:"ril-outer ril__outer ril__outerAnimating ".concat(this.props.wrapperClassName," ").concat(T?"ril-closing ril__outerClosing":""),style:{transition:"opacity ".concat(i,"ms"),animationDuration:"".concat(i,"ms"),animationDirection:T?"normal":"reverse"},ref:this.outerEl,onWheel:this.handleOuterMousewheel,onMouseMove:this.handleMouseMove,onMouseDown:this.handleMouseDown,onTouchStart:this.handleTouchStart,onTouchMove:this.handleTouchMove,tabIndex:"-1",onKeyDown:this.handleKeyInput,onKeyUp:this.handleKeyInput},a.createElement("div",{className:"ril-inner ril__inner",onClick:o?this.closeIfClickInner:void 0},F),m&&a.createElement("button",{type:"button",className:"ril-prev-button ril__navButtons ril__navButtonPrev",key:"prev","aria-label":this.props.prevLabel,title:this.props.prevLabel,onClick:this.isAnimating()?void 0:this.requestMovePrev}),p&&a.createElement("button",{type:"button",className:"ril-next-button ril__navButtons ril__navButtonNext",key:"next","aria-label":this.props.nextLabel,title:this.props.nextLabel,onClick:this.isAnimating()?void 0:this.requestMoveNext}),a.createElement("div",{className:"ril-toolbar ril__toolbar"},a.createElement("ul",{className:"ril-toolbar-left ril__toolbarSide ril__toolbarLeftSide"},a.createElement("li",{className:"ril-toolbar__item ril__toolbarItem"},a.createElement("span",{className:"ril-toolbar__item__child ril__toolbarItemChild"},h))),a.createElement("ul",{className:"ril-toolbar-right ril__toolbarSide ril__toolbarRightSide"},g&&g.map((function(e,t){return a.createElement("li",{key:"button_".concat(t+1),className:"ril-toolbar__item ril__toolbarItem"},e)})),c&&a.createElement("li",{className:"ril-toolbar__item ril__toolbarItem"},a.createElement("button",{type:"button",key:"zoom-in","aria-label":this.props.zoomInLabel,title:this.props.zoomInLabel,className:["ril-zoom-in","ril__toolbarItemChild","ril__builtinButton","ril__zoomInButton"].concat(w(S===_?["ril__builtinButtonDisabled"]:[])).join(" "),ref:this.zoomInBtn,disabled:this.isAnimating()||S===_,onClick:this.isAnimating()||S===_?void 0:this.handleZoomInButtonClick})),c&&a.createElement("li",{className:"ril-toolbar__item ril__toolbarItem"},a.createElement("button",{type:"button",key:"zoom-out","aria-label":this.props.zoomOutLabel,title:this.props.zoomOutLabel,className:["ril-zoom-out","ril__toolbarItemChild","ril__builtinButton","ril__zoomOutButton"].concat(w(0===S?["ril__builtinButtonDisabled"]:[])).join(" "),ref:this.zoomOutBtn,disabled:this.isAnimating()||0===S,onClick:this.isAnimating()||0===S?void 0:this.handleZoomOutButtonClick})),a.createElement("li",{className:"ril-toolbar__item ril__toolbarItem"},a.createElement("button",{type:"button",key:"close","aria-label":this.props.closeLabel,title:this.props.closeLabel,className:"ril-close ril-toolbar__item__child ril__toolbarItemChild ril__builtinButton ril__closeButton",onClick:this.isAnimating()?void 0:this.requestClose})))),this.props.imageCaption&&a.createElement("div",{onWheel:this.handleCaptionMousewheel,onMouseDown:function(e){return e.stopPropagation()},className:"ril-caption ril__caption",ref:this.caption},a.createElement("div",{className:"ril-caption-content ril__captionContent"},this.props.imageCaption))))}}],i=[{key:"isTargetMatchImage",value:function(e){return e&&/ril-image-current/.test(e.className)}},{key:"parseMouseEvent",value:function(e){return{id:"mouse",source:1,x:parseInt(e.clientX,10),y:parseInt(e.clientY,10)}}},{key:"parseTouchPointer",value:function(e){return{id:e.identifier,source:2,x:parseInt(e.clientX,10),y:parseInt(e.clientY,10)}}},{key:"parsePointerEvent",value:function(e){return{id:e.pointerId,source:3,x:parseInt(e.clientX,10),y:parseInt(e.clientY,10)}}},{key:"getTransform",value:function(e){var t=e.x,n=void 0===t?0:t,r=e.y,i=void 0===r?0:r,a=e.zoom,o=void 0===a?1:a,s=e.width,l=e.targetWidth,u=n,c=C();s>c&&(u+=(c-s)/2);var d=o*(l/s);return{transform:"translate3d(".concat(u,"px,").concat(i,"px,0) scale3d(").concat(d,",").concat(d,",1)")}}}],r&&h(t.prototype,r),i&&h(t,i),s}(a.Component);j.propTypes={mainSrc:s().string.isRequired,prevSrc:s().string,nextSrc:s().string,mainSrcThumbnail:s().string,prevSrcThumbnail:s().string,nextSrcThumbnail:s().string,onCloseRequest:s().func.isRequired,onMovePrevRequest:s().func,onMoveNextRequest:s().func,onImageLoadError:s().func,onImageLoad:s().func,onAfterOpen:s().func,discourageDownloads:s().bool,animationDisabled:s().bool,animationOnKeyInput:s().bool,animationDuration:s().number,keyRepeatLimit:s().number,keyRepeatKeyupBonus:s().number,imageTitle:s().node,imageCaption:s().node,imageCrossOrigin:s().string,reactModalStyle:s().shape({}),imagePadding:s().number,wrapperClassName:s().string,toolbarButtons:s().arrayOf(s().node),clickOutsideToClose:s().bool,enableZoom:s().bool,reactModalProps:s().shape({}),nextLabel:s().string,prevLabel:s().string,zoomInLabel:s().string,zoomOutLabel:s().string,closeLabel:s().string,imageLoadErrorMessage:s().node,loader:s().node},j.defaultProps={imageTitle:null,imageCaption:null,toolbarButtons:null,reactModalProps:{},animationDisabled:!1,animationDuration:300,animationOnKeyInput:!1,clickOutsideToClose:!0,closeLabel:"Close lightbox",discourageDownloads:!1,enableZoom:!0,imagePadding:10,imageCrossOrigin:null,keyRepeatKeyupBonus:40,keyRepeatLimit:180,mainSrcThumbnail:null,nextLabel:"Next image",nextSrc:null,nextSrcThumbnail:null,onAfterOpen:function(){},onImageLoadError:function(){},onImageLoad:function(){},onMoveNextRequest:function(){},onMovePrevRequest:function(){},prevLabel:"Previous image",prevSrc:null,prevSrcThumbnail:null,reactModalStyle:{},wrapperClassName:"",zoomInLabel:"Zoom in",zoomOutLabel:"Zoom out",imageLoadErrorMessage:"This image failed to load",loader:void 0};var P=j;function M(){return M=Object.assign?Object.assign.bind():function(e){for(var t=1;t0&&l.map((function(e){var t=W(e.to,c),n=e.icon;return a.createElement("li",{className:"navbar__item",key:e.id||e.to},a.createElement(I,{activeClassName:"","aria-current":t?"page":"false","aria-label":e.name,as:e.external?"a":s,className:i()({active:t}),external:e.external,onClick:function(){d&&d(e)},to:e.to,unstyled:!0},e.icon&&("left"===e.iconAlignment||!e.iconAlignment)&&a.createElement(D,{className:"margin-right-md",material:"string"==typeof e.icon,size:"sm"},"string"==typeof e.icon?e.icon:n&&a.createElement(n,null)),e.name,e.icon&&"right"===e.iconAlignment&&a.createElement(D,{className:"margin-left-md",material:"string"==typeof e.icon,size:"sm"},"string"==typeof e.icon?e.icon:n&&a.createElement(n,null))))}))))}var K=["children","className","color","customStyles","icon","iconAlignment","iconSize","onClick","shape","size","style"];function G(e){var t,n,r,o,s=e.children,l=e.className,u=e.color,c=void 0===u?"default":u,d=e.customStyles,h=e.icon,p=e.iconAlignment,f=e.iconSize,m=void 0===f?"inherit":f,g=e.onClick,v=e.shape,y=void 0===v?"rounded-corners":v,b=e.size,w=void 0===b?"sm":b,x=e.style,k=void 0===x?"solid":x,E=F(e,K);return a.createElement("button",M({className:i()("btn",(t={},t["btn--"+c]=c,t),(n={},n["btn--"+y]=y,n),(r={},r["btn--"+k]=k,r),(o={},o["btn--"+w]=w&&"intrinsic"!==w,o),{"btn--icon-only":"only"===p},l),onClick:g,style:d},E),"left"===p&&a.createElement("span",{"aria-hidden":!0,className:"icon-wrapper margin-right-md"},"string"==typeof h?a.createElement(D,{name:h,size:m}):h),"only"===p?a.createElement("span",{"aria-hidden":!0,className:"icon-wrapper"},"string"==typeof h?a.createElement(D,{name:h,size:m}):h):s,"right"===p&&a.createElement("span",{"aria-hidden":!0,className:"icon-wrapper margin-left-md"},"string"==typeof h?a.createElement(D,{name:h,size:m}):h))}var J=["as","backgroundColor","className","foregroundColor","icon","innerPadding","rounded","size","style"];function Q(e){var t,n=e.as,r=e.backgroundColor,o=e.className,s=e.foregroundColor,l=e.icon,u=e.innerPadding,c=void 0===u?8:u,d=e.rounded,h=void 0!==d&&d,p=e.size,f=void 0===p?24:p,m=e.style,g=F(e,J),v=l&&"string"==typeof l&&l in z?z[l]:l;return a.createElement(null!=n?n:"i",M({},g,{className:i()("icon","social-icon",{"social-icon--rounded":h},(t={},t[l]="string"==typeof l,t),o),style:M({backgroundColor:r,fill:s,width:"inherit"!==f?f:void 0,height:"inherit"!==f?f:void 0,padding:c},m)}),v&&a.createElement(v,null))}z.discord,z.email,z.facebook,z.github,z.instagram,z.patreon,z.paypal,z.twitch,z.twitter,z.unity,z.youtube;function ee(e,t){var n="undefined"!=typeof window?window.matchMedia(e):null,r=(0,a.useState)(n),i=r[0],o=r[1],s=(0,a.useState)(Boolean(i&&i.matches)),l=s[0],u=s[1];return(0,a.useEffect)((function(){"undefined"!=typeof window&&o(window.matchMedia(e))}),[e]),(0,a.useEffect)((function(){var e,n=i;return n&&$(n,"change",e=function(){u(n.matches),t&&t(n.matches)}),function(){n&&e&&B(n,"change",e)}}),[i,t]),l}function te(e){function t(){var t,n,r,i;return{width:null!=(t=null==(n=e.current)?void 0:n.offsetWidth)?t:0,height:null!=(r=null==(i=e.current)?void 0:i.offsetHeight)?r:0}}var n=(0,a.useState)(t),r=n[0],i=n[1],o=function(){i(t())};return(0,a.useEffect)((function(){if("undefined"!=typeof window)return window.addEventListener("resize",o),function(){return window.removeEventListener("resize",o)}}),[]),(0,a.useLayoutEffect)((function(){o()}),[]),r}function ne(e){var t=(0,a.useState)(!0),n=t[0],r=t[1],i=function(){r(!1)};return(0,a.useEffect)((function(){var t=e.current;return t&&n&&(t instanceof HTMLImageElement&&t.complete?i():$(t,"load",i)),function(){t&&B(t,"load",i)}}),[e,n]),n}function re(e,t){var n=(0,a.useState)((function(){return function(e,t){if("undefined"==typeof window||!localStorage)return t||null;var n=localStorage.getItem(e);return(n?JSON.parse(n):null)||t||null}(e,t)})),r=n[0],i=n[1];return(0,a.useEffect)((function(){"undefined"!=typeof window&&localStorage&&localStorage.setItem(e,JSON.stringify(r))}),[e,r]),[r,i]}function ie(e,t){void 0===e&&(e=!1),void 0===t&&(t=!0),(0,a.useEffect)((function(){if("undefined"!=typeof document)if(e){if(t){var n="undefined"!=typeof window&&"undefined"!=typeof document?(window.innerWidth||0)-(document.documentElement.clientWidth||0):0;n>0&&(document.body.style.paddingRight=n+"px")}document.body.classList.add("overflow-hidden")}else document.body.classList.remove("overflow-hidden"),t&&(document.body.style.paddingRight="")}),[e,t])}function ae(e,t,n,r){void 0===r&&(r=1/0);var i=(0,a.useRef)(),o=(0,a.useRef)(),s=(0,a.useRef)(e),l=(0,a.useRef)(0),u=(0,a.useState)(e),c=u[0],d=u[1];return(0,a.useEffect)((function(){var e=function(a){null!=o.current&&(s.current=function(e,t,n,r,i,a){var o=2/(r=Math.max(1e-4,r)),s=o*a,l=1/(1+s+.48*s*s+.235*s*s*s),u=e-t,c=t,d=i*r;t=e-(u=Math.min(Math.max(u,-d),d));var h=(n.current+o*u)*a;n.current=(n.current-o*h)*l;var p=t+(u+h)*l;return c-e>0==p>c&&(n.current=((p=c)-c)/a),p}(s.current,t.current,l,n/1e3,r,(a-o.current)/1e3),d(s.current)),o.current=a,i.current=requestAnimationFrame(e)};return i.current=requestAnimationFrame(e),function(){void 0!==i.current&&cancelAnimationFrame(i.current)}}),[n,r]),c}(0,a.createContext)({theme:"light",setTheme:function(){},toggleTheme:function(){}});function oe(e){void 0===e&&(e="light");var t=re("theme",e),n=t[0],r=t[1],i=(0,a.useCallback)((function(){r("dark"===n?"light":"dark")}),[n]);return"undefined"!=typeof window&&document&&document.documentElement&&document.documentElement.style.setProperty("color-scheme",n),[null!=n?n:e,r,i]}var se=["children","className","pill","selected","type"];function le(e){var t,n=e.children,r=e.className,o=e.pill,s=void 0!==o&&o,l=e.selected,u=void 0!==l&&l,c=e.type,d=void 0===c?"solid":c,h=F(e,se);return a.createElement("div",M({className:i()("badge",(t={},t["badge--"+d]=d,t),{"badge--pill":s},{"badge--selected":u},r)},h),n)}var ue=["children","className","layout"];function ce(e){var t,n=e.children,r=e.className,o=e.layout,s=void 0===o?"horizontal":o,l=F(e,ue);return a.createElement("div",M({className:i()("btn-group",(t={},t["btn-group--"+s]=s,t),r)},l),n)}function de(e){var t=e.loading,n=e.size;return a.createElement("div",{"aria-hidden":!0,className:i()("loading-spinner",{loading:void 0===t||t},void 0===n?"md":n,e.className)},a.createElement("div",{className:"loading-spinner__animation"},a.createElement("div",null),a.createElement("div",null),a.createElement("div",null),a.createElement("div",null)))}var he=Object.freeze({xs:{width:320,height:180},sm:{width:480,height:270},md:{width:640,height:360},lg:{width:960,height:540},xl:{width:1280,height:720}});function pe(e){var t=e.allowFullScreen,n=void 0===t||t,r=e.className,o=e.frameBorder,s=void 0===o?"0":o,l=e.height,u=e.id,c=void 0===u?"video-player":u,d=e.scrolling,h=void 0===d?"no":d,p=e.size,f=e.src,m=e.title,g=void 0===m?"Video Player":m,v=e.width,y=(0,a.useRef)(null),b=ne(y),w="undefined"!=typeof navigator&&!navigator.onLine,x=v||p&&he[p].width,k=l||p&&he[p].height;return a.createElement("div",{className:i()("embedded-video",{loading:b},p,r),style:{width:fe(x),height:fe(k)}},a.createElement("div",{className:i()("embedded-video__wrapper","transition","fade-in",{visible:!b})},a.createElement("iframe",{allowFullScreen:n,frameBorder:s,height:k||"100%",id:c,ref:y,scrolling:h,src:f,title:g,width:x||"100%"})),b&&!w&&a.createElement(de,null))}function fe(e){if(null!=e)return"string"==typeof e&&(e.endsWith("%")||e.endsWith("px"))?e:e+"px"}var me=["autoplay","captions","className","hideBranding","hideControls","hideInfo","hideRelated","id","muted","origin","secure","startTime","title","videoId"];function ge(e){var t=e.autoplay,n=void 0!==t&&t,r=e.captions,o=void 0!==r&&r,s=e.className,l=e.hideBranding,u=void 0!==l&&l,c=e.hideControls,d=void 0!==c&&c,h=e.hideInfo,p=void 0!==h&&h,f=e.hideRelated,m=void 0===f||f,g=e.id,v=void 0===g?"youtube-player":g,y=e.muted,b=void 0!==y&&y,w=e.origin,x=e.secure,k=void 0===x||x,E=e.startTime,C=e.title,S=void 0===C?"YouTube":C,_=e.videoId,O=F(e,me),A="enablejsapi=1";A+="&origin="+w,m&&(A+="&rel=0"),d&&(A+="&controls=0"),p&&(A+="&showinfo=0"),u&&(A+="&modestbranding=1"),o&&(A+="&cc_load_policy=1"),n&&(A+="&autoplay=1"),b&&(A+="&mute=1"),E&&(A+="&start="+E);var T=k?"https":"http";return a.createElement(pe,M({className:i()("youtube",s),id:v,src:T+"://www.youtube.com/embed/"+_+"?"+A,title:S},O))}var ve=["alt","animated","className","height","imageClassName","imageProps","onLoaded","placeholder","placeholderClassName","placeholderProps","showLoadingSpinner","src","width"];function ye(e){var t=e.alt,n=e.animated,r=void 0===n||n,o=e.className,s=e.height,l=e.imageClassName,u=e.imageProps,c=void 0===u?{}:u,d=e.onLoaded,h=void 0===d?function(){}:d,p=e.placeholder,f=e.placeholderClassName,m=e.placeholderProps,g=void 0===m?{}:m,v=e.showLoadingSpinner,y=void 0!==v&&v,b=e.src,w=e.width,x=F(e,ve),k=(0,a.useRef)(null),E=function(e,t){void 0===t&&(t=function(){});var n=!ne(e);return(0,a.useEffect)((function(){n&&t()}),[n,t]),n}(k,h);return a.createElement("picture",M({className:i()("progressive-image",{"progressive-image--loaded":E},{"progressive-image--animated":r},{"progressive-image--no-placeholder":!p},o)},x),a.createElement("img",M({},c,{alt:c.alt||t,className:i()("progressive-image__source","img-fluid",l,c.className),width:w||c.width,height:s||c.height,ref:k,src:b})),p&&a.createElement("img",M({},g,{alt:g.alt||t,className:i()("progressive-image__placeholder","img-fluid",f,g.className),width:w||g.width||c.width,height:s||g.height||c.height,src:p})),y&&!E&&a.createElement(de,null))}function be(e){var t=e.animated,n=void 0!==t&&t,r=e.animation,o=void 0===r?"fade-in-up":r,s=e.className,l=e.columns,u=e.fullWidthFirstItem,c=void 0!==u&&u,d=e.images,h=void 0===d?[]:d,p=e.maxWidth,f=e.minWidth,m=(0,a.useState)(!1),g=m[0],v=m[1],y=(0,a.useState)(0),b=y[0],w=y[1];return a.createElement("div",{className:i()("image-gallery",s)},a.createElement("div",{className:"image-gallery__thumbnails",style:{gridTemplateColumns:xe(l,f,p)}},h.map((function(e,t){var r,s="object"==typeof e,l=s?e.src:e,u=s?e.key||e.id||e.src:e;return a.createElement("button",{"aria-label":"Image Thumbnail",className:i()("image-gallery__thumbnail",{"image-gallery__thumbnail--full-width":0===t&&c},(r={"animation-short":n},r["animation-delay-"+(t+1)]=n,r[o]=n,r),s&&e.className),key:u,onClick:function(){w(t),v(!0)}},a.createElement(ye,{imageProps:s?U(e,"className"):{},src:l}))}))),g&&a.createElement(P,{enableZoom:!1,mainSrc:we(h[b]),nextSrc:we(h[(b+1)%h.length]),prevSrc:we(h[(b+h.length-1)%h.length]),onCloseRequest:function(){v(!1)},onMovePrevRequest:function(){w((b+h.length-1)%h.length)},onMoveNextRequest:function(){w((b+1)%h.length)},wrapperClassName:"image-gallery__lightbox"}))}function we(e){return"string"==typeof e?e:e.src}function xe(e,t,n){return"repeat("+(e||"auto-fit")+", minmax("+(ke(t)||0)+", "+(ke(n)||"1fr")+"))"}function ke(e){return e?e+"px":void 0}var Ee,Ce,Se,_e=["animated","animation","as","children","className","image","index","ref","rounded","shadow"];function Oe(e){var t,n=e.animated,r=void 0!==n&&n,o=e.animation,s=void 0===o?"fade-translate-in":o,l=e.as,u=e.children,c=e.className,d=e.image,h=e.index,p=void 0===h?-1:h,f=e.rounded,m=void 0===f||f,g=e.shadow,v=void 0===g||g,y=F(e,_e),b=null!=l?l:"a",w="object"==typeof d?d:{src:d},x=(0,a.useRef)(null),k=(0,a.useState)(!1),E=k[0],C=k[1];return(0,a.useEffect)((function(){var e;return r&&E&&(e=setTimeout((function(){x.current&&(x.current.style.animation="none")}),600)),function(){e&&clearTimeout(e)}}),[r,E,x]),a.createElement(b,M({},y,{className:i()("thumbnail",(t={"animation-short":r&&E},t["animation-delay-"+(p+1)]=r&&E&&p>=0,t[s]=r&&E,t),{rounded:m,shadow:v},c),ref:x}),d&&a.createElement(ye,M({},w,{onLoaded:function(){C(!0),"object"==typeof d&&d.onLoaded&&d.onLoaded()}})),u)}!function(e){e[e.sm=576]="sm",e[e.md=768]="md",e[e.lg=992]="lg",e[e.xl=1200]="xl"}(Ee||(Ee={})),function(e){e[e.transparent=0]="transparent",e[e.subtle=.12]="subtle",e[e.disabled=.38]="disabled",e[e.inactive=.62]="inactive",e[e.scrim=.54]="scrim",e[e.active=.87]="active",e[e.opaque=1]="opaque"}(Ce||(Ce={})),function(e){e[e.dropdown=1e3]="dropdown",e[e.sticky=1020]="sticky",e[e.fixed=1030]="fixed",e[e.overlay=1040]="overlay",e[e.menu=1050]="menu",e[e.modal=1060]="modal",e[e.popover=1070]="popover",e[e.tooltip=1080]="tooltip",e[e.toast=1090]="toast",e[e.max=1100]="max"}(Se||(Se={}))},411:function(e,t,n){var r;!function(){"use strict";var i=!("undefined"==typeof window||!window.document||!window.document.createElement),a={canUseDOM:i,canUseWorkers:"undefined"!=typeof Worker,canUseEventListeners:i&&!(!window.addEventListener&&!window.attachEvent),canUseViewport:i&&!!window.screen};void 0===(r=function(){return a}.call(t,n,t,e))||(e.exports=r)}()},8828:function(e){"use strict";e.exports=Object.assign},1885:function(e,t,n){"use strict";n.d(t,{Z2:function(){return m},cG:function(){return g},YW:function(){return Ne},MM:function(){return Fe},Dd:function(){return p},fE:function(){return Le}});var r=n(5043),i=n(6540),a=n(8007),o=n(4848);const s={minSize:44,maxSize:64,minFontSize:20,maxFontSize:30,distance:150,smoothTime:50};function l(e){let{asButton:t=!1,external:n=!1,link:l,mouseState:u,onClick:c}=e;const d=(0,i.useRef)(null),h=(0,i.useRef)(s.minSize),p=(0,r.kB)(s.minSize,h,s.smoothTime),f=.45*p;return(0,i.useEffect)((()=>{d.current&&(u.entered?h.current=function(e,t,n){const i=e.getBoundingClientRect(),a=(0,r.Io)(t,n,i.left+i.width/2,i.top+i.height/2);return(0,r.Cc)(s.minSize,s.maxSize,(0,r.U4)(s.distance,0,a))}(d.current,u.x,u.y):h.current=s.minSize)}),[d,u]),(0,o.jsxs)("div",{className:"dock__item",id:l.id,ref:d,style:{width:`${p}px`,height:`${p}px`,fontSize:`${f}px`,transform:`translateY(${-(p-s.minSize)/2}px)`},children:[t?(0,o.jsxs)("button",{onClick:c,children:[l.icon&&(0,o.jsx)(r.In,{name:l.icon,size:"inherit"}),l.socialIcon&&(0,o.jsx)(r.b6,{icon:l.socialIcon,innerPadding:0,size:f-2})]}):(0,o.jsxs)(r.N_,{as:n?"a":a.Link,external:n,to:l.to,unstyled:!0,children:[l.icon&&(0,o.jsx)(r.In,{name:l.icon,size:"inherit"}),l.socialIcon&&(0,o.jsx)(r.b6,{icon:l.socialIcon,innerPadding:0,size:f-2})]}),(0,o.jsx)("div",{className:"dock__tooltip",children:l.name})]})}var u=n(3815);function c(e){let{theme:t,toggleTheme:n,secondaryLinks:a}=e;const s=(0,i.useRef)(null),c=(0,r.Ub)("(hover: hover)"),{0:d,1:h}=(0,i.useState)({x:0,y:0,entered:!1});return(0,i.useEffect)((()=>{if(!s.current)return;const e=e=>{h({x:e.clientX,y:e.clientY,entered:!1})},t=e=>{h({x:e.clientX,y:e.clientY,entered:!0})};return c&&(s.current.addEventListener("mousemove",t),s.current.addEventListener("mouseleave",e)),()=>{s.current&&(s.current.removeEventListener("mousemove",t),s.current.removeEventListener("mouseleave",e))}}),[s,c]),(0,o.jsxs)("div",{className:"dock",ref:s,children:[(0,o.jsxs)("div",{className:"dock__container",id:"primary",children:[(0,o.jsx)("div",{className:"dock__section",id:"navigation",children:u.R1.map((e=>(0,o.jsx)(l,{link:e,mouseState:d},e.id)))}),(0,o.jsx)("div",{className:"dock__section",id:"socials",children:u.lj.map((e=>(0,o.jsx)(l,{link:e,mouseState:d,external:!0},e.id)))}),(0,o.jsxs)("div",{className:"dock__section",id:"gallery",children:[(0,o.jsx)(l,{asButton:!0,link:{to:"",id:"previous",name:"Previous",icon:"chevron_left"},mouseState:d,onClick:()=>{if(!document)return;const e=new Event("previous_slide");document.dispatchEvent(e)}}),(0,o.jsx)(l,{asButton:!0,link:{to:"",id:"next",name:"Next",icon:"chevron_right"},mouseState:d,onClick:()=>{if(!document)return;const e=new Event("next_slide");document.dispatchEvent(e)}})]}),(0,o.jsx)("div",{className:"dock__section",id:"theme",children:(0,o.jsx)(l,{asButton:!0,link:{to:"",id:"theme",name:"dark"===t?"Light Mode":"Dark Mode",icon:"dark"===t?"light_mode":"dark_mode"},mouseState:d,onClick:n})})]}),a&&(0,o.jsx)("div",{className:"dock__container",id:"secondary",children:a.map((e=>(0,o.jsx)(l,{link:e,mouseState:d,external:!0},e.id||e.name)))})]})}var d=n(6942),h=n.n(d);function p(e){let{children:t,className:n,...i}=e;return(0,o.jsx)(r.$n,{className:h()("shadow-button",n),size:"sm",shape:"rounded",...i,children:t})}function f(e){let{slide:t}=e;const n="undefined"!=typeof navigator&&!navigator.onLine,i=`/${t.category}/${t.id}`;return(0,o.jsxs)("div",{className:"slide",children:[(0,o.jsx)("div",{className:"slide__image-wrapper",children:(0,o.jsx)(r.N_,{as:a.Link,className:"display-inline-flex",to:i,unstyled:!0,children:(0,o.jsx)(r.vb,{alt:t.imageAltText||"",animated:!1,className:h()("slide__image",{"slide__image--no-border":"boolean"==typeof t.imageBorder&&!1===t.imageBorder}),width:t.image.sharp.original.width,height:t.image.sharp.original.height,src:t.image.sharp.original.src,showLoadingSpinner:!n})})}),(0,o.jsx)("div",{className:"slide__text-wrapper",children:(0,o.jsxs)("div",{className:"slide__text-container",children:[(0,o.jsx)("p",{className:"eyebrow",children:t.date}),(0,o.jsx)("h1",{className:"title",children:t.title}),(0,o.jsx)("p",{className:"description opacity-90p",children:t.description_short||t.description}),(0,o.jsx)(r.N_,{as:a.Link,style:{marginLeft:"-4px"},to:i,unstyled:!0,children:(0,o.jsx)(p,{children:"More Details"})})]})})]})}function m(e){let{category:t,location:n,slides:s=[]}=e;const l=(0,r.Ub)("(max-width: 1365px)"),u=new URLSearchParams(null==n?void 0:n.search),c=(u.has("index")?Number.parseInt(u.get("index"))||0:function(e){if(e&&"undefined"!=typeof sessionStorage){const t=sessionStorage.getItem(`${e}-slide`);return t?Number.parseInt(t):0}return 0}(t))%s.length,d=c>=0&&c{e>=s.length&&(e=0),e<0&&(e=s.length-1),function(e,t){e&&"undefined"!=typeof sessionStorage&&sessionStorage.setItem(`${e}-slide`,String(t))}(t,e),(0,a.navigate)(`/${t}?index=${e}`,{replace:!0})}),[t,s,c]);return(0,i.useEffect)((()=>{if(!document)return;const e=()=>p(c-1),t=()=>p(c+1);return document.addEventListener("previous_slide",e),document.addEventListener("next_slide",t),()=>{document.removeEventListener("previous_slide",e),document.removeEventListener("next_slide",t)}}),[c]),(0,o.jsxs)("div",{className:h()("gallery",{"gallery--vertical":l}),id:t,children:[(0,o.jsx)("button",{"aria-label":"Previous Slide",className:"gallery__button previous",onClick:()=>p(c-1),children:(0,o.jsx)("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",width:"48px",height:"48px",children:(0,o.jsx)("path",{d:"M14.71 6.71c-.39-.39-1.02-.39-1.41 0L8.71 11.3c-.39.39-.39 1.02 0 1.41l4.59 4.59c.39.39 1.02.39 1.41 0 .39-.39.39-1.02 0-1.41L10.83 12l3.88-3.88c.39-.39.38-1.03 0-1.41z"})})}),(0,o.jsx)("div",{className:"gallery__slides",children:d&&(0,o.jsx)(f,{slide:d})}),(0,o.jsx)("button",{"aria-label":"Next Slide",className:"gallery__button next",onClick:()=>p(c+1),children:(0,o.jsx)("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",width:"48px",height:"48px",children:(0,o.jsx)("path",{d:"M9.29 6.71c-.39.39-.39 1.02 0 1.41L13.17 12l-3.88 3.88c-.39.39-.39 1.02 0 1.41.39.39 1.02.39 1.41 0l4.59-4.59c.39-.39.39-1.02 0-1.41L10.7 6.7c-.38-.38-1.02-.38-1.41.01z"})})})]})}function g(e){let{width:t=30,height:n=30}=e;const r=[];for(let i=0;ie))})}function v(e){let{rounded:t=!1,size:n=48}=e;return(0,o.jsx)("div",{className:h()("ag-logo",{"ag-logo--rounded":t}),style:{width:`${n}px`,height:`${n}px`,minWidth:`${n}px`,minHeight:`${n}px`},children:(0,o.jsxs)(r.N_,{"aria-label":"Logo",as:a.Link,to:"/",unstyled:!0,children:[(0,o.jsx)("div",{className:"ag-logo__background"}),(0,o.jsxs)("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 512 512",children:[(0,o.jsx)("polygon",{points:"345.17 257.56 233.75 257.56 212.47 294.58 324.06 294.58 382.6 396.41 425 396.41 345.17 257.56"}),(0,o.jsx)("polygon",{points:"168.69 322.35 254.36 173.36 286.8 229.79 329.2 229.79 254.36 99.59 105 359.38 333.5 359.38 312.21 322.35 168.69 322.35"})]})]})})}function y(e){let{open:t=!1,onRequestClose:n=()=>{}}=e;return(0,r.ln)(t,!0),(0,o.jsx)("div",{className:h()("menu-gallery",{open:t,closed:!t}),children:(0,o.jsx)("div",{"aria-hidden":!t,className:"menu-gallery__container container-fluid",children:(0,o.jsx)("ul",{className:"menu-gallery__list",children:t&&(0,o.jsx)(a.StaticQuery,{query:b,render:e=>u.Jm.map((i=>{const s=e[i.id]||{nodes:[]};return(0,o.jsxs)("li",{className:"menu-gallery__section",children:[(0,o.jsxs)(r.N_,{activeClassName:"","aria-disabled":!t,"aria-label":i.name,as:a.Link,onClick:n,tabIndex:t?0:-1,to:i.to,unstyled:!0,children:[(0,o.jsx)("span",{children:i.name}),(0,o.jsx)(r.$n,{className:"margin-top-md margin-left-lg active",icon:"east",iconAlignment:"only",style:"text"})]}),(0,o.jsx)("div",{className:"menu-gallery__grid",children:s.nodes.map(((e,i)=>(0,o.jsx)(r.Vz,{animated:!1,"aria-disabled":!t,"aria-label":e.title,as:a.Link,className:"menu-gallery__thumbnail",image:{src:e.image.sharp.original.src,alt:e.imageAltText||"",width:e.image.sharp.original.width,height:e.image.sharp.original.height,className:"img-fluid"},index:i,onClick:n,shadow:!1,to:`/${e.category}/?index=${i}`},e.id)))})]},i.to)}))})})})})}const b="3709745113";function w(e){let{location:t=("undefined"!=typeof window?window.location:null),pageTitle:n}=e;const{0:s,1:l}=(0,i.useState)(!1);return(0,o.jsxs)(o.Fragment,{children:[(0,o.jsx)("header",{className:"header",children:(0,o.jsxs)("div",{className:"header__container container-fluid",children:[(0,o.jsx)(v,{size:44}),(0,o.jsx)(r.jq,{links:u.Jm,LinkElementType:a.Link,location:t}),n&&(0,o.jsx)(r.$n,{className:"header__title-button",onClick:()=>{const e=u.Jm.find((e=>e.name===n));e?(0,a.navigate)(e.to):l(!0)},style:"unstyled",children:n}),(0,o.jsx)("button",{"aria-label":s?"Close Gallery Menu":"Open Gallery Menu",className:"header__menu-button",onClick:()=>l(!s),children:s?(0,o.jsx)("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",width:"36px",height:"36px",children:(0,o.jsx)("path",{d:"M3 18h13v-2H3v2zm0-5h10v-2H3v2zm0-7v2h13V6H3zm18 9.59L17.42 12 21 8.41 19.59 7l-5 5 5 5L21 15.59z"})}):(0,o.jsx)("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",width:"36px",height:"36px",children:(0,o.jsx)("path",{d:"M3 18h18v-2H3v2zm0-5h18v-2H3v2zm0-7v2h18V6H3z"})})})]})}),(0,o.jsx)(y,{open:s,onRequestClose:()=>l(!1)})]})}var x,k,E,C,S=n(5556),_=n.n(S),O=n(2098),A=n.n(O),T=n(115),j=n.n(T),P=n(8828),M=n.n(P),N="bodyAttributes",F="htmlAttributes",L="titleAttributes",I={BASE:"base",BODY:"body",HEAD:"head",HTML:"html",LINK:"link",META:"meta",NOSCRIPT:"noscript",SCRIPT:"script",STYLE:"style",TITLE:"title"},z=(Object.keys(I).map((function(e){return I[e]})),"charset"),R="cssText",D="href",$="http-equiv",B="innerHTML",q="itemprop",H="name",Y="property",X="rel",U="src",W="target",Z={accesskey:"accessKey",charset:"charSet",class:"className",contenteditable:"contentEditable",contextmenu:"contextMenu","http-equiv":"httpEquiv",itemprop:"itemProp",tabindex:"tabIndex"},V="defaultTitle",K="defer",G="encodeSpecialCharacters",J="onChangeClientState",Q="titleTemplate",ee=Object.keys(Z).reduce((function(e,t){return e[Z[t]]=t,e}),{}),te=[I.NOSCRIPT,I.SCRIPT,I.STYLE],ne="data-react-helmet",re="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},ie=function(){function e(e,t){for(var n=0;n=0||Object.prototype.hasOwnProperty.call(e,r)&&(n[r]=e[r]);return n},se=function(e){return!1===(!(arguments.length>1&&void 0!==arguments[1])||arguments[1])?String(e):String(e).replace(/&/g,"&").replace(//g,">").replace(/"/g,""").replace(/'/g,"'")},le=function(e){var t=pe(e,I.TITLE),n=pe(e,Q);if(n&&t)return n.replace(/%s/g,(function(){return Array.isArray(t)?t.join(""):t}));var r=pe(e,V);return t||r||void 0},ue=function(e){return pe(e,J)||function(){}},ce=function(e,t){return t.filter((function(t){return void 0!==t[e]})).map((function(t){return t[e]})).reduce((function(e,t){return ae({},e,t)}),{})},de=function(e,t){return t.filter((function(e){return void 0!==e[I.BASE]})).map((function(e){return e[I.BASE]})).reverse().reduce((function(t,n){if(!t.length)for(var r=Object.keys(n),i=0;i=0;n--){var r=e[n];if(r.hasOwnProperty(t))return r[t]}return null},fe=(x=Date.now(),function(e){var t=Date.now();t-x>16?(x=t,e(t)):setTimeout((function(){fe(e)}),0)}),me=function(e){return clearTimeout(e)},ge="undefined"!=typeof window?window.requestAnimationFrame&&window.requestAnimationFrame.bind(window)||window.webkitRequestAnimationFrame||window.mozRequestAnimationFrame||fe:n.g.requestAnimationFrame||fe,ve="undefined"!=typeof window?window.cancelAnimationFrame||window.webkitCancelAnimationFrame||window.mozCancelAnimationFrame||me:n.g.cancelAnimationFrame||me,ye=function(e){return console&&"function"==typeof console.warn&&console.warn(e)},be=null,we=function(e,t){var n=e.baseTag,r=e.bodyAttributes,i=e.htmlAttributes,a=e.linkTags,o=e.metaTags,s=e.noscriptTags,l=e.onChangeClientState,u=e.scriptTags,c=e.styleTags,d=e.title,h=e.titleAttributes;Ee(I.BODY,r),Ee(I.HTML,i),ke(d,h);var p={baseTag:Ce(I.BASE,n),linkTags:Ce(I.LINK,a),metaTags:Ce(I.META,o),noscriptTags:Ce(I.NOSCRIPT,s),scriptTags:Ce(I.SCRIPT,u),styleTags:Ce(I.STYLE,c)},f={},m={};Object.keys(p).forEach((function(e){var t=p[e],n=t.newTags,r=t.oldTags;n.length&&(f[e]=n),r.length&&(m[e]=p[e].oldTags)})),t&&t(),l(e,f,m)},xe=function(e){return Array.isArray(e)?e.join(""):e},ke=function(e,t){void 0!==e&&document.title!==e&&(document.title=xe(e)),Ee(I.TITLE,t)},Ee=function(e,t){var n=document.getElementsByTagName(e)[0];if(n){for(var r=n.getAttribute(ne),i=r?r.split(","):[],a=[].concat(i),o=Object.keys(t),s=0;s=0;d--)n.removeAttribute(a[d]);i.length===a.length?n.removeAttribute(ne):n.getAttribute(ne)!==o.join(",")&&n.setAttribute(ne,o.join(","))}},Ce=function(e,t){var n=document.head||document.querySelector(I.HEAD),r=n.querySelectorAll(e+"["+ne+"]"),i=Array.prototype.slice.call(r),a=[],o=void 0;return t&&t.length&&t.forEach((function(t){var n=document.createElement(e);for(var r in t)if(t.hasOwnProperty(r))if(r===B)n.innerHTML=t.innerHTML;else if(r===R)n.styleSheet?n.styleSheet.cssText=t.cssText:n.appendChild(document.createTextNode(t.cssText));else{var s=void 0===t[r]?"":t[r];n.setAttribute(r,s)}n.setAttribute(ne,"true"),i.some((function(e,t){return o=t,n.isEqualNode(e)}))?i.splice(o,1):a.push(n)})),i.forEach((function(e){return e.parentNode.removeChild(e)})),a.forEach((function(e){return n.appendChild(e)})),{oldTags:i,newTags:a}},Se=function(e){return Object.keys(e).reduce((function(t,n){var r=void 0!==e[n]?n+'="'+e[n]+'"':""+n;return t?t+" "+r:r}),"")},_e=function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return Object.keys(e).reduce((function(t,n){return t[Z[n]||n]=e[n],t}),t)},Oe=function(e,t,n){switch(e){case I.TITLE:return{toComponent:function(){return e=t.title,n=t.titleAttributes,(r={key:e})[ne]=!0,a=_e(n,r),[i.createElement(I.TITLE,a,e)];var e,n,r,a},toString:function(){return function(e,t,n,r){var i=Se(n),a=xe(t);return i?"<"+e+" "+ne+'="true" '+i+">"+se(a,r)+"":"<"+e+" "+ne+'="true">'+se(a,r)+""}(e,t.title,t.titleAttributes,n)}};case N:case F:return{toComponent:function(){return _e(t)},toString:function(){return Se(t)}};default:return{toComponent:function(){return function(e,t){return t.map((function(t,n){var r,a=((r={key:n})[ne]=!0,r);return Object.keys(t).forEach((function(e){var n=Z[e]||e;if(n===B||n===R){var r=t.innerHTML||t.cssText;a.dangerouslySetInnerHTML={__html:r}}else a[n]=t[e]})),i.createElement(e,a)}))}(e,t)},toString:function(){return function(e,t,n){return t.reduce((function(t,r){var i=Object.keys(r).filter((function(e){return!(e===B||e===R)})).reduce((function(e,t){var i=void 0===r[t]?t:t+'="'+se(r[t],n)+'"';return e?e+" "+i:i}),""),a=r.innerHTML||r.cssText||"",o=-1===te.indexOf(e);return t+"<"+e+" "+ne+'="true" '+i+(o?"/>":">"+a+"")}),"")}(e,t,n)}}}},Ae=function(e){var t=e.baseTag,n=e.bodyAttributes,r=e.encode,i=e.htmlAttributes,a=e.linkTags,o=e.metaTags,s=e.noscriptTags,l=e.scriptTags,u=e.styleTags,c=e.title,d=void 0===c?"":c,h=e.titleAttributes;return{base:Oe(I.BASE,t,r),bodyAttributes:Oe(N,n,r),htmlAttributes:Oe(F,i,r),link:Oe(I.LINK,a,r),meta:Oe(I.META,o,r),noscript:Oe(I.NOSCRIPT,s,r),script:Oe(I.SCRIPT,l,r),style:Oe(I.STYLE,u,r),title:Oe(I.TITLE,{title:d,titleAttributes:h},r)}},Te=A()((function(e){return{baseTag:de([D,W],e),bodyAttributes:ce(N,e),defer:pe(e,K),encode:pe(e,G),htmlAttributes:ce(F,e),linkTags:he(I.LINK,[X,D],e),metaTags:he(I.META,[H,z,$,Y,q],e),noscriptTags:he(I.NOSCRIPT,[B],e),onChangeClientState:ue(e),scriptTags:he(I.SCRIPT,[U,B],e),styleTags:he(I.STYLE,[R],e),title:le(e),titleAttributes:ce(L,e)}}),(function(e){be&&ve(be),e.defer?be=ge((function(){we(e,(function(){be=null}))})):(we(e),be=null)}),Ae)((function(){return null})),je=(k=Te,C=E=function(e){function t(){return function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,t),function(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}(this,e.apply(this,arguments))}return function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}(t,e),t.prototype.shouldComponentUpdate=function(e){return!j()(this.props,e)},t.prototype.mapNestedChildrenToProps=function(e,t){if(!t)return null;switch(e.type){case I.SCRIPT:case I.NOSCRIPT:return{innerHTML:t};case I.STYLE:return{cssText:t}}throw new Error("<"+e.type+" /> elements are self-closing and can not contain children. Refer to our API for more information.")},t.prototype.flattenArrayTypeChildren=function(e){var t,n=e.child,r=e.arrayTypeChildren,i=e.newChildProps,a=e.nestedChildren;return ae({},r,((t={})[n.type]=[].concat(r[n.type]||[],[ae({},i,this.mapNestedChildrenToProps(n,a))]),t))},t.prototype.mapObjectTypeChildren=function(e){var t,n,r=e.child,i=e.newProps,a=e.newChildProps,o=e.nestedChildren;switch(r.type){case I.TITLE:return ae({},i,((t={})[r.type]=o,t.titleAttributes=ae({},a),t));case I.BODY:return ae({},i,{bodyAttributes:ae({},a)});case I.HTML:return ae({},i,{htmlAttributes:ae({},a)})}return ae({},i,((n={})[r.type]=ae({},a),n))},t.prototype.mapArrayTypeChildrenToProps=function(e,t){var n=ae({},t);return Object.keys(e).forEach((function(t){var r;n=ae({},n,((r={})[t]=e[t],r))})),n},t.prototype.warnOnInvalidChildren=function(e,t){return!0},t.prototype.mapChildrenToProps=function(e,t){var n=this,r={};return i.Children.forEach(e,(function(e){if(e&&e.props){var i=e.props,a=i.children,o=function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return Object.keys(e).reduce((function(t,n){return t[ee[n]||n]=e[n],t}),t)}(oe(i,["children"]));switch(n.warnOnInvalidChildren(e,a),e.type){case I.LINK:case I.META:case I.NOSCRIPT:case I.SCRIPT:case I.STYLE:r=n.flattenArrayTypeChildren({child:e,arrayTypeChildren:r,newChildProps:o,nestedChildren:a});break;default:t=n.mapObjectTypeChildren({child:e,newProps:t,newChildProps:o,nestedChildren:a})}}})),t=this.mapArrayTypeChildrenToProps(r,t)},t.prototype.render=function(){var e=this.props,t=e.children,n=oe(e,["children"]),r=ae({},n);return t&&(r=this.mapChildrenToProps(t,r)),i.createElement(k,r)},ie(t,null,[{key:"canUseDOM",set:function(e){k.canUseDOM=e}}]),t}(i.Component),E.propTypes={base:_().object,bodyAttributes:_().object,children:_().oneOfType([_().arrayOf(_().node),_().node]),defaultTitle:_().string,defer:_().bool,encodeSpecialCharacters:_().bool,htmlAttributes:_().object,link:_().arrayOf(_().object),meta:_().arrayOf(_().object),noscript:_().arrayOf(_().object),onChangeClientState:_().func,script:_().arrayOf(_().object),style:_().arrayOf(_().object),title:_().string,titleAttributes:_().object,titleTemplate:_().string},E.defaultProps={defer:!0,encodeSpecialCharacters:!0},E.peek=k.peek,E.rewind=function(){var e=k.rewind();return e||(e=Ae({baseTag:[],bodyAttributes:{},encodeSpecialCharacters:!0,htmlAttributes:{},linkTags:[],metaTags:[],noscriptTags:[],scriptTags:[],styleTags:[],title:"",titleAttributes:{}})),e},C);je.renderStatic=je.rewind;function Pe(e){const t=(0,a.useStaticQuery)(Me),{metadata:n}=t.site,r={...n,...e};return(0,o.jsxs)(je,{children:[(0,o.jsx)("title",{children:r.title}),(0,o.jsx)("meta",{name:"description",content:r.description}),r.image&&(0,o.jsx)("meta",{name:"image",content:r.image}),r.url&&(0,o.jsx)("meta",{property:"og:url",content:r.url}),(0,o.jsx)("meta",{property:"og:type",content:"website"}),(0,o.jsx)("meta",{property:"og:title",content:r.title}),(0,o.jsx)("meta",{property:"og:description",content:r.description}),r.image&&(0,o.jsx)("meta",{property:"og:image",content:r.image}),(0,o.jsx)("meta",{name:"twitter:card",content:"summary_large_image"}),(0,o.jsx)("meta",{name:"twitter:creator",content:"@zigurous"}),(0,o.jsx)("meta",{name:"twitter:title",content:r.title}),(0,o.jsx)("meta",{name:"twitter:description",content:r.description}),r.image&&(0,o.jsx)("meta",{name:"twitter:image",content:r.image})]})}const Me="1995548873";function Ne(e){let{children:t,className:n,dockLinks:i,hideDock:a=!1,hideHeader:s=!1,id:l,location:u=("undefined"!=typeof window?window.location:null),metadata:d,title:p}=e;const[f,m,g]=(0,r.DP)("light");return(0,o.jsxs)("div",{className:"app","data-theme":f,children:[(0,o.jsx)(Pe,{...d}),!s&&(0,o.jsx)(w,{location:u,pageTitle:p}),(0,o.jsx)("main",{className:h()("page",n),id:l,children:t}),!a&&(0,o.jsx)(c,{theme:f,toggleTheme:g,secondaryLinks:i})]})}function Fe(e){let{project:t}=e;return(0,o.jsxs)("article",{className:"project container-md",children:[(0,o.jsxs)("section",{children:[(0,o.jsx)("h1",{className:"display-4 project__title",children:t.title}),(0,o.jsxs)("div",{className:"project__subtitle",children:[t.date,(0,o.jsx)("span",{className:"separator",children:"|"}),t.role]}),t.tech&&(0,o.jsx)("div",{className:"project__badges",children:t.tech.map((e=>(0,o.jsx)(r.Ex,{pill:!0,children:e},e)))}),(0,o.jsxs)("div",{className:"project__description",children:[t.description&&(0,o.jsx)("p",{className:"opacity-90p",children:t.description}),t.description_long&&t.description_long.map((e=>(0,o.jsx)("p",{className:"opacity-90p",children:e},e)))]})]}),t.sections&&t.sections.map(((e,n)=>(0,o.jsxs)("section",{children:[e.title&&(0,o.jsx)("h2",{className:"subtitle font-xl",children:e.link?(0,o.jsx)(r.N_,{external:!0,href:e.link,children:(0,o.jsx)("b",{children:e.title})}):(0,o.jsx)("b",{children:e.title})}),e.mainImage&&(e.mainImageLink?(0,o.jsx)(r.N_,{external:!0,to:e.mainImageLink,unstyled:!0,children:(0,o.jsx)(r.vb,{alt:`${t.title} Screenshot`,width:e.mainImage.sharp.original.width,height:e.mainImage.sharp.original.height,src:e.mainImage.sharp.original.src})}):(0,o.jsx)(r.vb,{alt:`${t.title} Screenshot`,width:e.mainImage.sharp.original.width,height:e.mainImage.sharp.original.height,src:e.mainImage.sharp.original.src})),e.mainVideo&&(0,o.jsx)(r.QN,{origin:"https://adamgraham.github.io",videoId:e.mainVideo}),e.paragraphs&&e.paragraphs.map(((e,t)=>(0,o.jsx)("p",{className:"font-sm",children:e},`section-${n}-paragraph-${t}`))),e.gallery&&(0,o.jsx)(r.i_,{images:e.gallery.map((e=>({width:e.sharp.original.width,height:e.sharp.original.height,src:e.sharp.original.src}))),minWidth:132}),e.videos&&e.videos.map((e=>(0,o.jsx)(r.QN,{className:"margin-bottom-lg",origin:"https://adamgraham.github.io",videoId:e},e)))]},`section-${n}`)))]})}function Le(){return(0,o.jsx)("div",{"aria-hidden":"true",className:"vignette"})}},3815:function(e,t,n){"use strict";n.d(t,{Jm:function(){return a},M:function(){return i},R1:function(){return o},lj:function(){return s},wW:function(){return r}});const r="https://adamgraham.github.io",i="https://github.com/adamgraham",a=[{id:"games",to:"/games",name:"Games"},{id:"websites",to:"/websites",name:"Websites"},{id:"art",to:"/art",name:"Interactive Art"},{id:"tech",to:"/tech",name:"Tech Showcases"},{id:"presentations",to:"/presentations",name:"Presentations"}],o=[{id:"home",to:"/",name:"Home",icon:"home"},{id:"gallery",to:"/gallery",name:"Gallery",icon:"collections"},{id:"projects",to:"/projects",name:"Projects",icon:"menu"}],s=[{id:"github",to:i,name:"GitHub",socialIcon:"github"},{id:"linkedIn",to:"https://www.linkedin.com/in/adamzigurous",name:"LinkedIn",socialIcon:"linkedIn"},{id:"resume",to:"https://docs.google.com/document/d/1qLHBV7Ry11O-pd0XC3HvALBIKJ8YDBmSafP0Z5c4dww/edit?usp=drive_link",name:"Resume",icon:"description"},{id:"email",to:"mailto:adam@zigurous.com",name:"Email",icon:"mail"}]},5624:function(){Prism.languages.clike={comment:[{pattern:/(^|[^\\])\/\*[\s\S]*?(?:\*\/|$)/,lookbehind:!0,greedy:!0},{pattern:/(^|[^\\:])\/\/.*/,lookbehind:!0,greedy:!0}],string:{pattern:/(["'])(?:\\(?:\r\n|[\s\S])|(?!\1)[^\\\r\n])*\1/,greedy:!0},"class-name":{pattern:/(\b(?:class|extends|implements|instanceof|interface|new|trait)\s+|\bcatch\s+\()[\w.\\]+/i,lookbehind:!0,inside:{punctuation:/[.\\]/}},keyword:/\b(?:break|catch|continue|do|else|finally|for|function|if|in|instanceof|new|null|return|throw|try|while)\b/,boolean:/\b(?:false|true)\b/,function:/\b\w+(?=\()/,number:/\b0x[\da-f]+\b|(?:\b\d+(?:\.\d*)?|\B\.\d+)(?:e[+-]?\d+)?/i,operator:/[<>]=?|[!=]=?=?|--?|\+\+?|&&?|\|\|?|[?*/~^%]/,punctuation:/[{}[\];(),.:]/}},5651:function(){!function(e){function t(e,t){return e.replace(/<<(\d+)>>/g,(function(e,n){return"(?:"+t[+n]+")"}))}function n(e,n,r){return RegExp(t(e,n),r||"")}function r(e,t){for(var n=0;n>/g,(function(){return"(?:"+e+")"}));return e.replace(/<>/g,"[^\\s\\S]")}var i="bool byte char decimal double dynamic float int long object sbyte short string uint ulong ushort var void",a="class enum interface record struct",o="add alias and ascending async await by descending from(?=\\s*(?:\\w|$)) get global group into init(?=\\s*;) join let nameof not notnull on or orderby partial remove select set unmanaged value when where with(?=\\s*{)",s="abstract as base break case catch checked const continue default delegate do else event explicit extern finally fixed for foreach goto if implicit in internal is lock namespace new null operator out override params private protected public readonly ref return sealed sizeof stackalloc static switch this throw try typeof unchecked unsafe using virtual volatile while yield";function l(e){return"\\b(?:"+e.trim().replace(/ /g,"|")+")\\b"}var u=l(a),c=RegExp(l(i+" "+a+" "+o+" "+s)),d=l(a+" "+o+" "+s),h=l(i+" "+a+" "+s),p=r(/<(?:[^<>;=+\-*/%&|^]|<>)*>/.source,2),f=r(/\((?:[^()]|<>)*\)/.source,2),m=/@?\b[A-Za-z_]\w*\b/.source,g=t(/<<0>>(?:\s*<<1>>)?/.source,[m,p]),v=t(/(?!<<0>>)<<1>>(?:\s*\.\s*<<1>>)*/.source,[d,g]),y=/\[\s*(?:,\s*)*\]/.source,b=t(/<<0>>(?:\s*(?:\?\s*)?<<1>>)*(?:\s*\?)?/.source,[v,y]),w=t(/[^,()<>[\];=+\-*/%&|^]|<<0>>|<<1>>|<<2>>/.source,[p,f,y]),x=t(/\(<<0>>+(?:,<<0>>+)+\)/.source,[w]),k=t(/(?:<<0>>|<<1>>)(?:\s*(?:\?\s*)?<<2>>)*(?:\s*\?)?/.source,[x,v,y]),E={keyword:c,punctuation:/[<>()?,.:[\]]/},C=/'(?:[^\r\n'\\]|\\.|\\[Uux][\da-fA-F]{1,8})'/.source,S=/"(?:\\.|[^\\"\r\n])*"/.source,_=/@"(?:""|\\[\s\S]|[^\\"])*"(?!")/.source;e.languages.csharp=e.languages.extend("clike",{string:[{pattern:n(/(^|[^$\\])<<0>>/.source,[_]),lookbehind:!0,greedy:!0},{pattern:n(/(^|[^@$\\])<<0>>/.source,[S]),lookbehind:!0,greedy:!0}],"class-name":[{pattern:n(/(\busing\s+static\s+)<<0>>(?=\s*;)/.source,[v]),lookbehind:!0,inside:E},{pattern:n(/(\busing\s+<<0>>\s*=\s*)<<1>>(?=\s*;)/.source,[m,k]),lookbehind:!0,inside:E},{pattern:n(/(\busing\s+)<<0>>(?=\s*=)/.source,[m]),lookbehind:!0},{pattern:n(/(\b<<0>>\s+)<<1>>/.source,[u,g]),lookbehind:!0,inside:E},{pattern:n(/(\bcatch\s*\(\s*)<<0>>/.source,[v]),lookbehind:!0,inside:E},{pattern:n(/(\bwhere\s+)<<0>>/.source,[m]),lookbehind:!0},{pattern:n(/(\b(?:is(?:\s+not)?|as)\s+)<<0>>/.source,[b]),lookbehind:!0,inside:E},{pattern:n(/\b<<0>>(?=\s+(?!<<1>>|with\s*\{)<<2>>(?:\s*[=,;:{)\]]|\s+(?:in|when)\b))/.source,[k,h,m]),inside:E}],keyword:c,number:/(?:\b0(?:x[\da-f_]*[\da-f]|b[01_]*[01])|(?:\B\.\d+(?:_+\d+)*|\b\d+(?:_+\d+)*(?:\.\d+(?:_+\d+)*)?)(?:e[-+]?\d+(?:_+\d+)*)?)(?:[dflmu]|lu|ul)?\b/i,operator:/>>=?|<<=?|[-=]>|([-+&|])\1|~|\?\?=?|[-+*/%&|^!=<>]=?/,punctuation:/\?\.?|::|[{}[\];(),.:]/}),e.languages.insertBefore("csharp","number",{range:{pattern:/\.\./,alias:"operator"}}),e.languages.insertBefore("csharp","punctuation",{"named-parameter":{pattern:n(/([(,]\s*)<<0>>(?=\s*:)/.source,[m]),lookbehind:!0,alias:"punctuation"}}),e.languages.insertBefore("csharp","class-name",{namespace:{pattern:n(/(\b(?:namespace|using)\s+)<<0>>(?:\s*\.\s*<<0>>)*(?=\s*[;{])/.source,[m]),lookbehind:!0,inside:{punctuation:/\./}},"type-expression":{pattern:n(/(\b(?:default|sizeof|typeof)\s*\(\s*(?!\s))(?:[^()\s]|\s(?!\s)|<<0>>)*(?=\s*\))/.source,[f]),lookbehind:!0,alias:"class-name",inside:E},"return-type":{pattern:n(/<<0>>(?=\s+(?:<<1>>\s*(?:=>|[({]|\.\s*this\s*\[)|this\s*\[))/.source,[k,v]),inside:E,alias:"class-name"},"constructor-invocation":{pattern:n(/(\bnew\s+)<<0>>(?=\s*[[({])/.source,[k]),lookbehind:!0,inside:E,alias:"class-name"},"generic-method":{pattern:n(/<<0>>\s*<<1>>(?=\s*\()/.source,[m,p]),inside:{function:n(/^<<0>>/.source,[m]),generic:{pattern:RegExp(p),alias:"class-name",inside:E}}},"type-list":{pattern:n(/\b((?:<<0>>\s+<<1>>|record\s+<<1>>\s*<<5>>|where\s+<<2>>)\s*:\s*)(?:<<3>>|<<4>>|<<1>>\s*<<5>>|<<6>>)(?:\s*,\s*(?:<<3>>|<<4>>|<<6>>))*(?=\s*(?:where|[{;]|=>|$))/.source,[u,g,m,k,c.source,f,/\bnew\s*\(\s*\)/.source]),lookbehind:!0,inside:{"record-arguments":{pattern:n(/(^(?!new\s*\()<<0>>\s*)<<1>>/.source,[g,f]),lookbehind:!0,greedy:!0,inside:e.languages.csharp},keyword:c,"class-name":{pattern:RegExp(k),greedy:!0,inside:E},punctuation:/[,()]/}},preprocessor:{pattern:/(^[\t ]*)#.*/m,lookbehind:!0,alias:"property",inside:{directive:{pattern:/(#)\b(?:define|elif|else|endif|endregion|error|if|line|nullable|pragma|region|undef|warning)\b/,lookbehind:!0,alias:"keyword"}}}});var O=S+"|"+C,A=t(/\/(?![*/])|\/\/[^\r\n]*[\r\n]|\/\*(?:[^*]|\*(?!\/))*\*\/|<<0>>/.source,[O]),T=r(t(/[^"'/()]|<<0>>|\(<>*\)/.source,[A]),2),j=/\b(?:assembly|event|field|method|module|param|property|return|type)\b/.source,P=t(/<<0>>(?:\s*\(<<1>>*\))?/.source,[v,T]);e.languages.insertBefore("csharp","class-name",{attribute:{pattern:n(/((?:^|[^\s\w>)?])\s*\[\s*)(?:<<0>>\s*:\s*)?<<1>>(?:\s*,\s*<<1>>)*(?=\s*\])/.source,[j,P]),lookbehind:!0,greedy:!0,inside:{target:{pattern:n(/^<<0>>(?=\s*:)/.source,[j]),alias:"keyword"},"attribute-arguments":{pattern:n(/\(<<0>>*\)/.source,[T]),inside:e.languages.csharp},"class-name":{pattern:RegExp(v),inside:{punctuation:/\./}},punctuation:/[:,]/}}});var M=/:[^}\r\n]+/.source,N=r(t(/[^"'/()]|<<0>>|\(<>*\)/.source,[A]),2),F=t(/\{(?!\{)(?:(?![}:])<<0>>)*<<1>>?\}/.source,[N,M]),L=r(t(/[^"'/()]|\/(?!\*)|\/\*(?:[^*]|\*(?!\/))*\*\/|<<0>>|\(<>*\)/.source,[O]),2),I=t(/\{(?!\{)(?:(?![}:])<<0>>)*<<1>>?\}/.source,[L,M]);function z(t,r){return{interpolation:{pattern:n(/((?:^|[^{])(?:\{\{)*)<<0>>/.source,[t]),lookbehind:!0,inside:{"format-string":{pattern:n(/(^\{(?:(?![}:])<<0>>)*)<<1>>(?=\}$)/.source,[r,M]),lookbehind:!0,inside:{punctuation:/^:/}},punctuation:/^\{|\}$/,expression:{pattern:/[\s\S]+/,alias:"language-csharp",inside:e.languages.csharp}}},string:/[\s\S]+/}}e.languages.insertBefore("csharp","string",{"interpolation-string":[{pattern:n(/(^|[^\\])(?:\$@|@\$)"(?:""|\\[\s\S]|\{\{|<<0>>|[^\\{"])*"/.source,[F]),lookbehind:!0,greedy:!0,inside:z(F,N)},{pattern:n(/(^|[^@\\])\$"(?:\\.|\{\{|<<0>>|[^\\"{])*"/.source,[I]),lookbehind:!0,greedy:!0,inside:z(I,L)}],char:{pattern:RegExp(C),greedy:!0}}),e.languages.dotnet=e.languages.cs=e.languages.csharp}(Prism)},1113:function(){!function(e){var t=/(?:"(?:\\(?:\r\n|[\s\S])|[^"\\\r\n])*"|'(?:\\(?:\r\n|[\s\S])|[^'\\\r\n])*')/;e.languages.css={comment:/\/\*[\s\S]*?\*\//,atrule:{pattern:RegExp("@[\\w-](?:"+/[^;{\s"']|\s+(?!\s)/.source+"|"+t.source+")*?"+/(?:;|(?=\s*\{))/.source),inside:{rule:/^@[\w-]+/,"selector-function-argument":{pattern:/(\bselector\s*\(\s*(?![\s)]))(?:[^()\s]|\s+(?![\s)])|\((?:[^()]|\([^()]*\))*\))+(?=\s*\))/,lookbehind:!0,alias:"selector"},keyword:{pattern:/(^|[^\w-])(?:and|not|only|or)(?![\w-])/,lookbehind:!0}}},url:{pattern:RegExp("\\burl\\((?:"+t.source+"|"+/(?:[^\\\r\n()"']|\\[\s\S])*/.source+")\\)","i"),greedy:!0,inside:{function:/^url/i,punctuation:/^\(|\)$/,string:{pattern:RegExp("^"+t.source+"$"),alias:"url"}}},selector:{pattern:RegExp("(^|[{}\\s])[^{}\\s](?:[^{};\"'\\s]|\\s+(?![\\s{])|"+t.source+")*(?=\\s*\\{)"),lookbehind:!0},string:{pattern:t,greedy:!0},property:{pattern:/(^|[^-\w\xA0-\uFFFF])(?!\s)[-_a-z\xA0-\uFFFF](?:(?!\s)[-\w\xA0-\uFFFF])*(?=\s*:)/i,lookbehind:!0},important:/!important\b/i,function:{pattern:/(^|[^-a-z0-9])[-a-z0-9]+(?=\()/i,lookbehind:!0},punctuation:/[(){};:,]/},e.languages.css.atrule.inside.rest=e.languages.css;var n=e.languages.markup;n&&(n.tag.addInlined("style","css"),n.tag.addAttribute("style","css"))}(Prism)},5723:function(){Prism.languages.javascript=Prism.languages.extend("clike",{"class-name":[Prism.languages.clike["class-name"],{pattern:/(^|[^$\w\xA0-\uFFFF])(?!\s)[_$A-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\.(?:constructor|prototype))/,lookbehind:!0}],keyword:[{pattern:/((?:^|\})\s*)catch\b/,lookbehind:!0},{pattern:/(^|[^.]|\.\.\.\s*)\b(?:as|assert(?=\s*\{)|async(?=\s*(?:function\b|\(|[$\w\xA0-\uFFFF]|$))|await|break|case|class|const|continue|debugger|default|delete|do|else|enum|export|extends|finally(?=\s*(?:\{|$))|for|from(?=\s*(?:['"]|$))|function|(?:get|set)(?=\s*(?:[#\[$\w\xA0-\uFFFF]|$))|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|static|super|switch|this|throw|try|typeof|undefined|var|void|while|with|yield)\b/,lookbehind:!0}],function:/#?(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*(?:\.\s*(?:apply|bind|call)\s*)?\()/,number:{pattern:RegExp(/(^|[^\w$])/.source+"(?:"+/NaN|Infinity/.source+"|"+/0[bB][01]+(?:_[01]+)*n?/.source+"|"+/0[oO][0-7]+(?:_[0-7]+)*n?/.source+"|"+/0[xX][\dA-Fa-f]+(?:_[\dA-Fa-f]+)*n?/.source+"|"+/\d+(?:_\d+)*n/.source+"|"+/(?:\d+(?:_\d+)*(?:\.(?:\d+(?:_\d+)*)?)?|\.\d+(?:_\d+)*)(?:[Ee][+-]?\d+(?:_\d+)*)?/.source+")"+/(?![\w$])/.source),lookbehind:!0},operator:/--|\+\+|\*\*=?|=>|&&=?|\|\|=?|[!=]==|<<=?|>>>?=?|[-+*/%&|^!=<>]=?|\.{3}|\?\?=?|\?\.?|[~:]/}),Prism.languages.javascript["class-name"][0].pattern=/(\b(?:class|extends|implements|instanceof|interface|new)\s+)[\w.\\]+/,Prism.languages.insertBefore("javascript","keyword",{regex:{pattern:RegExp(/((?:^|[^$\w\xA0-\uFFFF."'\])\s]|\b(?:return|yield))\s*)/.source+/\//.source+"(?:"+/(?:\[(?:[^\]\\\r\n]|\\.)*\]|\\.|[^/\\\[\r\n])+\/[dgimyus]{0,7}/.source+"|"+/(?:\[(?:[^[\]\\\r\n]|\\.|\[(?:[^[\]\\\r\n]|\\.|\[(?:[^[\]\\\r\n]|\\.)*\])*\])*\]|\\.|[^/\\\[\r\n])+\/[dgimyus]{0,7}v[dgimyus]{0,7}/.source+")"+/(?=(?:\s|\/\*(?:[^*]|\*(?!\/))*\*\/)*(?:$|[\r\n,.;:})\]]|\/\/))/.source),lookbehind:!0,greedy:!0,inside:{"regex-source":{pattern:/^(\/)[\s\S]+(?=\/[a-z]*$)/,lookbehind:!0,alias:"language-regex",inside:Prism.languages.regex},"regex-delimiter":/^\/|\/$/,"regex-flags":/^[a-z]+$/}},"function-variable":{pattern:/#?(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*[=:]\s*(?:async\s*)?(?:\bfunction\b|(?:\((?:[^()]|\([^()]*\))*\)|(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*)\s*=>))/,alias:"function"},parameter:[{pattern:/(function(?:\s+(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*)?\s*\(\s*)(?!\s)(?:[^()\s]|\s+(?![\s)])|\([^()]*\))+(?=\s*\))/,lookbehind:!0,inside:Prism.languages.javascript},{pattern:/(^|[^$\w\xA0-\uFFFF])(?!\s)[_$a-z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*=>)/i,lookbehind:!0,inside:Prism.languages.javascript},{pattern:/(\(\s*)(?!\s)(?:[^()\s]|\s+(?![\s)])|\([^()]*\))+(?=\s*\)\s*=>)/,lookbehind:!0,inside:Prism.languages.javascript},{pattern:/((?:\b|\s|^)(?!(?:as|async|await|break|case|catch|class|const|continue|debugger|default|delete|do|else|enum|export|extends|finally|for|from|function|get|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|set|static|super|switch|this|throw|try|typeof|undefined|var|void|while|with|yield)(?![$\w\xA0-\uFFFF]))(?:(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*\s*)\(\s*|\]\s*\(\s*)(?!\s)(?:[^()\s]|\s+(?![\s)])|\([^()]*\))+(?=\s*\)\s*\{)/,lookbehind:!0,inside:Prism.languages.javascript}],constant:/\b[A-Z](?:[A-Z_]|\dx?)*\b/}),Prism.languages.insertBefore("javascript","string",{hashbang:{pattern:/^#!.*/,greedy:!0,alias:"comment"},"template-string":{pattern:/`(?:\\[\s\S]|\$\{(?:[^{}]|\{(?:[^{}]|\{[^}]*\})*\})+\}|(?!\$\{)[^\\`])*`/,greedy:!0,inside:{"template-punctuation":{pattern:/^`|`$/,alias:"string"},interpolation:{pattern:/((?:^|[^\\])(?:\\{2})*)\$\{(?:[^{}]|\{(?:[^{}]|\{[^}]*\})*\})+\}/,lookbehind:!0,inside:{"interpolation-punctuation":{pattern:/^\$\{|\}$/,alias:"punctuation"},rest:Prism.languages.javascript}},string:/[\s\S]+/}},"string-property":{pattern:/((?:^|[,{])[ \t]*)(["'])(?:\\(?:\r\n|[\s\S])|(?!\2)[^\\\r\n])*\2(?=\s*:)/m,lookbehind:!0,greedy:!0,alias:"property"}}),Prism.languages.insertBefore("javascript","operator",{"literal-property":{pattern:/((?:^|[,{])[ \t]*)(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*:)/m,lookbehind:!0,alias:"property"}}),Prism.languages.markup&&(Prism.languages.markup.tag.addInlined("script","javascript"),Prism.languages.markup.tag.addAttribute(/on(?:abort|blur|change|click|composition(?:end|start|update)|dblclick|error|focus(?:in|out)?|key(?:down|up)|load|mouse(?:down|enter|leave|move|out|over|up)|reset|resize|scroll|select|slotchange|submit|unload|wheel)/.source,"javascript")),Prism.languages.js=Prism.languages.javascript},4312:function(){Prism.languages.markup={comment:{pattern://,greedy:!0},prolog:{pattern:/<\?[\s\S]+?\?>/,greedy:!0},doctype:{pattern:/"'[\]]|"[^"]*"|'[^']*')+(?:\[(?:[^<"'\]]|"[^"]*"|'[^']*'|<(?!!--)|)*\]\s*)?>/i,greedy:!0,inside:{"internal-subset":{pattern:/(^[^\[]*\[)[\s\S]+(?=\]>$)/,lookbehind:!0,greedy:!0,inside:null},string:{pattern:/"[^"]*"|'[^']*'/,greedy:!0},punctuation:/^$|[[\]]/,"doctype-tag":/^DOCTYPE/i,name:/[^\s<>'"]+/}},cdata:{pattern://i,greedy:!0},tag:{pattern:/<\/?(?!\d)[^\s>\/=$<%]+(?:\s(?:\s*[^\s>\/=]+(?:\s*=\s*(?:"[^"]*"|'[^']*'|[^\s'">=]+(?=[\s>]))|(?=[\s/>])))+)?\s*\/?>/,greedy:!0,inside:{tag:{pattern:/^<\/?[^\s>\/]+/,inside:{punctuation:/^<\/?/,namespace:/^[^\s>\/:]+:/}},"special-attr":[],"attr-value":{pattern:/=\s*(?:"[^"]*"|'[^']*'|[^\s'">=]+)/,inside:{punctuation:[{pattern:/^=/,alias:"attr-equals"},{pattern:/^(\s*)["']|["']$/,lookbehind:!0}]}},punctuation:/\/?>/,"attr-name":{pattern:/[^\s>\/]+/,inside:{namespace:/^[^\s>\/:]+:/}}}},entity:[{pattern:/&[\da-z]{1,8};/i,alias:"named-entity"},/&#x?[\da-f]{1,8};/i]},Prism.languages.markup.tag.inside["attr-value"].inside.entity=Prism.languages.markup.entity,Prism.languages.markup.doctype.inside["internal-subset"].inside=Prism.languages.markup,Prism.hooks.add("wrap",(function(e){"entity"===e.type&&(e.attributes.title=e.content.replace(/&/,"&"))})),Object.defineProperty(Prism.languages.markup.tag,"addInlined",{value:function(e,t){var n={};n["language-"+t]={pattern:/(^$)/i,lookbehind:!0,inside:Prism.languages[t]},n.cdata=/^$/i;var r={"included-cdata":{pattern://i,inside:n}};r["language-"+t]={pattern:/[\s\S]+/,inside:Prism.languages[t]};var i={};i[e]={pattern:RegExp(/(<__[^>]*>)(?:))*\]\]>|(?!)/.source.replace(/__/g,(function(){return e})),"i"),lookbehind:!0,greedy:!0,inside:r},Prism.languages.insertBefore("markup","cdata",i)}}),Object.defineProperty(Prism.languages.markup.tag,"addAttribute",{value:function(e,t){Prism.languages.markup.tag.inside["special-attr"].push({pattern:RegExp(/(^|["'\s])/.source+"(?:"+e+")"+/\s*=\s*(?:"[^"]*"|'[^']*'|[^\s'">=]+(?=[\s>]))/.source,"i"),lookbehind:!0,inside:{"attr-name":/^[^\s=]+/,"attr-value":{pattern:/=[\s\S]+/,inside:{value:{pattern:/(^=\s*(["']|(?!["'])))\S[\s\S]*(?=\2$)/,lookbehind:!0,alias:[t,"language-"+t],inside:Prism.languages[t]},punctuation:[{pattern:/^=/,alias:"attr-equals"},/"|'/]}}}})}}),Prism.languages.html=Prism.languages.markup,Prism.languages.mathml=Prism.languages.markup,Prism.languages.svg=Prism.languages.markup,Prism.languages.xml=Prism.languages.extend("markup",{}),Prism.languages.ssml=Prism.languages.xml,Prism.languages.atom=Prism.languages.xml,Prism.languages.rss=Prism.languages.xml},8848:function(e,t,n){var r=function(e){var t=/(?:^|\s)lang(?:uage)?-([\w-]+)(?=\s|$)/i,n=0,r={},i={manual:e.Prism&&e.Prism.manual,disableWorkerMessageHandler:e.Prism&&e.Prism.disableWorkerMessageHandler,util:{encode:function e(t){return t instanceof a?new a(t.type,e(t.content),t.alias):Array.isArray(t)?t.map(e):t.replace(/&/g,"&").replace(/=d.reach);E+=k.value.length,k=k.next){var C=k.value;if(t.length>e.length)return;if(!(C instanceof a)){var S,_=1;if(y){if(!(S=o(x,E,e,v))||S.index>=e.length)break;var O=S.index,A=S.index+S[0].length,T=E;for(T+=k.value.length;O>=T;)T+=(k=k.next).value.length;if(E=T-=k.value.length,k.value instanceof a)continue;for(var j=k;j!==t.tail&&(Td.reach&&(d.reach=F);var L=k.prev;if(M&&(L=u(t,L,M),E+=M.length),c(t,L,_),k=u(t,L,new a(h,g?i.tokenize(P,g):P,b,P)),N&&u(t,k,N),_>1){var I={cause:h+","+f,reach:F};s(e,t,n,k.prev,E,I),d&&I.reach>d.reach&&(d.reach=I.reach)}}}}}}function l(){var e={value:null,prev:null,next:null},t={value:null,prev:e,next:null};e.next=t,this.head=e,this.tail=t,this.length=0}function u(e,t,n){var r=t.next,i={value:n,prev:t,next:r};return t.next=i,r.prev=i,e.length++,i}function c(e,t,n){for(var r=t.next,i=0;i"+a.content+""},!e.document)return e.addEventListener?(i.disableWorkerMessageHandler||e.addEventListener("message",(function(t){var n=JSON.parse(t.data),r=n.language,a=n.code,o=n.immediateClose;e.postMessage(i.highlight(a,i.languages[r],r)),o&&e.close()}),!1),i):i;var d=i.util.currentScript();function h(){i.manual||i.highlightAll()}if(d&&(i.filename=d.src,d.hasAttribute("data-manual")&&(i.manual=!0)),!i.manual){var p=document.readyState;"loading"===p||"interactive"===p&&d&&d.defer?document.addEventListener("DOMContentLoaded",h):window.requestAnimationFrame?window.requestAnimationFrame(h):window.setTimeout(h,16)}return i}("undefined"!=typeof window?window:"undefined"!=typeof WorkerGlobalScope&&self instanceof WorkerGlobalScope?self:{});e.exports&&(e.exports=r),void 0!==n.g&&(n.g.Prism=r),r.languages.markup={comment:{pattern://,greedy:!0},prolog:{pattern:/<\?[\s\S]+?\?>/,greedy:!0},doctype:{pattern:/"'[\]]|"[^"]*"|'[^']*')+(?:\[(?:[^<"'\]]|"[^"]*"|'[^']*'|<(?!!--)|)*\]\s*)?>/i,greedy:!0,inside:{"internal-subset":{pattern:/(^[^\[]*\[)[\s\S]+(?=\]>$)/,lookbehind:!0,greedy:!0,inside:null},string:{pattern:/"[^"]*"|'[^']*'/,greedy:!0},punctuation:/^$|[[\]]/,"doctype-tag":/^DOCTYPE/i,name:/[^\s<>'"]+/}},cdata:{pattern://i,greedy:!0},tag:{pattern:/<\/?(?!\d)[^\s>\/=$<%]+(?:\s(?:\s*[^\s>\/=]+(?:\s*=\s*(?:"[^"]*"|'[^']*'|[^\s'">=]+(?=[\s>]))|(?=[\s/>])))+)?\s*\/?>/,greedy:!0,inside:{tag:{pattern:/^<\/?[^\s>\/]+/,inside:{punctuation:/^<\/?/,namespace:/^[^\s>\/:]+:/}},"special-attr":[],"attr-value":{pattern:/=\s*(?:"[^"]*"|'[^']*'|[^\s'">=]+)/,inside:{punctuation:[{pattern:/^=/,alias:"attr-equals"},{pattern:/^(\s*)["']|["']$/,lookbehind:!0}]}},punctuation:/\/?>/,"attr-name":{pattern:/[^\s>\/]+/,inside:{namespace:/^[^\s>\/:]+:/}}}},entity:[{pattern:/&[\da-z]{1,8};/i,alias:"named-entity"},/&#x?[\da-f]{1,8};/i]},r.languages.markup.tag.inside["attr-value"].inside.entity=r.languages.markup.entity,r.languages.markup.doctype.inside["internal-subset"].inside=r.languages.markup,r.hooks.add("wrap",(function(e){"entity"===e.type&&(e.attributes.title=e.content.replace(/&/,"&"))})),Object.defineProperty(r.languages.markup.tag,"addInlined",{value:function(e,t){var n={};n["language-"+t]={pattern:/(^$)/i,lookbehind:!0,inside:r.languages[t]},n.cdata=/^$/i;var i={"included-cdata":{pattern://i,inside:n}};i["language-"+t]={pattern:/[\s\S]+/,inside:r.languages[t]};var a={};a[e]={pattern:RegExp(/(<__[^>]*>)(?:))*\]\]>|(?!)/.source.replace(/__/g,(function(){return e})),"i"),lookbehind:!0,greedy:!0,inside:i},r.languages.insertBefore("markup","cdata",a)}}),Object.defineProperty(r.languages.markup.tag,"addAttribute",{value:function(e,t){r.languages.markup.tag.inside["special-attr"].push({pattern:RegExp(/(^|["'\s])/.source+"(?:"+e+")"+/\s*=\s*(?:"[^"]*"|'[^']*'|[^\s'">=]+(?=[\s>]))/.source,"i"),lookbehind:!0,inside:{"attr-name":/^[^\s=]+/,"attr-value":{pattern:/=[\s\S]+/,inside:{value:{pattern:/(^=\s*(["']|(?!["'])))\S[\s\S]*(?=\2$)/,lookbehind:!0,alias:[t,"language-"+t],inside:r.languages[t]},punctuation:[{pattern:/^=/,alias:"attr-equals"},/"|'/]}}}})}}),r.languages.html=r.languages.markup,r.languages.mathml=r.languages.markup,r.languages.svg=r.languages.markup,r.languages.xml=r.languages.extend("markup",{}),r.languages.ssml=r.languages.xml,r.languages.atom=r.languages.xml,r.languages.rss=r.languages.xml,function(e){var t=/(?:"(?:\\(?:\r\n|[\s\S])|[^"\\\r\n])*"|'(?:\\(?:\r\n|[\s\S])|[^'\\\r\n])*')/;e.languages.css={comment:/\/\*[\s\S]*?\*\//,atrule:{pattern:RegExp("@[\\w-](?:"+/[^;{\s"']|\s+(?!\s)/.source+"|"+t.source+")*?"+/(?:;|(?=\s*\{))/.source),inside:{rule:/^@[\w-]+/,"selector-function-argument":{pattern:/(\bselector\s*\(\s*(?![\s)]))(?:[^()\s]|\s+(?![\s)])|\((?:[^()]|\([^()]*\))*\))+(?=\s*\))/,lookbehind:!0,alias:"selector"},keyword:{pattern:/(^|[^\w-])(?:and|not|only|or)(?![\w-])/,lookbehind:!0}}},url:{pattern:RegExp("\\burl\\((?:"+t.source+"|"+/(?:[^\\\r\n()"']|\\[\s\S])*/.source+")\\)","i"),greedy:!0,inside:{function:/^url/i,punctuation:/^\(|\)$/,string:{pattern:RegExp("^"+t.source+"$"),alias:"url"}}},selector:{pattern:RegExp("(^|[{}\\s])[^{}\\s](?:[^{};\"'\\s]|\\s+(?![\\s{])|"+t.source+")*(?=\\s*\\{)"),lookbehind:!0},string:{pattern:t,greedy:!0},property:{pattern:/(^|[^-\w\xA0-\uFFFF])(?!\s)[-_a-z\xA0-\uFFFF](?:(?!\s)[-\w\xA0-\uFFFF])*(?=\s*:)/i,lookbehind:!0},important:/!important\b/i,function:{pattern:/(^|[^-a-z0-9])[-a-z0-9]+(?=\()/i,lookbehind:!0},punctuation:/[(){};:,]/},e.languages.css.atrule.inside.rest=e.languages.css;var n=e.languages.markup;n&&(n.tag.addInlined("style","css"),n.tag.addAttribute("style","css"))}(r),r.languages.clike={comment:[{pattern:/(^|[^\\])\/\*[\s\S]*?(?:\*\/|$)/,lookbehind:!0,greedy:!0},{pattern:/(^|[^\\:])\/\/.*/,lookbehind:!0,greedy:!0}],string:{pattern:/(["'])(?:\\(?:\r\n|[\s\S])|(?!\1)[^\\\r\n])*\1/,greedy:!0},"class-name":{pattern:/(\b(?:class|extends|implements|instanceof|interface|new|trait)\s+|\bcatch\s+\()[\w.\\]+/i,lookbehind:!0,inside:{punctuation:/[.\\]/}},keyword:/\b(?:break|catch|continue|do|else|finally|for|function|if|in|instanceof|new|null|return|throw|try|while)\b/,boolean:/\b(?:false|true)\b/,function:/\b\w+(?=\()/,number:/\b0x[\da-f]+\b|(?:\b\d+(?:\.\d*)?|\B\.\d+)(?:e[+-]?\d+)?/i,operator:/[<>]=?|[!=]=?=?|--?|\+\+?|&&?|\|\|?|[?*/~^%]/,punctuation:/[{}[\];(),.:]/},r.languages.javascript=r.languages.extend("clike",{"class-name":[r.languages.clike["class-name"],{pattern:/(^|[^$\w\xA0-\uFFFF])(?!\s)[_$A-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\.(?:constructor|prototype))/,lookbehind:!0}],keyword:[{pattern:/((?:^|\})\s*)catch\b/,lookbehind:!0},{pattern:/(^|[^.]|\.\.\.\s*)\b(?:as|assert(?=\s*\{)|async(?=\s*(?:function\b|\(|[$\w\xA0-\uFFFF]|$))|await|break|case|class|const|continue|debugger|default|delete|do|else|enum|export|extends|finally(?=\s*(?:\{|$))|for|from(?=\s*(?:['"]|$))|function|(?:get|set)(?=\s*(?:[#\[$\w\xA0-\uFFFF]|$))|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|static|super|switch|this|throw|try|typeof|undefined|var|void|while|with|yield)\b/,lookbehind:!0}],function:/#?(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*(?:\.\s*(?:apply|bind|call)\s*)?\()/,number:{pattern:RegExp(/(^|[^\w$])/.source+"(?:"+/NaN|Infinity/.source+"|"+/0[bB][01]+(?:_[01]+)*n?/.source+"|"+/0[oO][0-7]+(?:_[0-7]+)*n?/.source+"|"+/0[xX][\dA-Fa-f]+(?:_[\dA-Fa-f]+)*n?/.source+"|"+/\d+(?:_\d+)*n/.source+"|"+/(?:\d+(?:_\d+)*(?:\.(?:\d+(?:_\d+)*)?)?|\.\d+(?:_\d+)*)(?:[Ee][+-]?\d+(?:_\d+)*)?/.source+")"+/(?![\w$])/.source),lookbehind:!0},operator:/--|\+\+|\*\*=?|=>|&&=?|\|\|=?|[!=]==|<<=?|>>>?=?|[-+*/%&|^!=<>]=?|\.{3}|\?\?=?|\?\.?|[~:]/}),r.languages.javascript["class-name"][0].pattern=/(\b(?:class|extends|implements|instanceof|interface|new)\s+)[\w.\\]+/,r.languages.insertBefore("javascript","keyword",{regex:{pattern:RegExp(/((?:^|[^$\w\xA0-\uFFFF."'\])\s]|\b(?:return|yield))\s*)/.source+/\//.source+"(?:"+/(?:\[(?:[^\]\\\r\n]|\\.)*\]|\\.|[^/\\\[\r\n])+\/[dgimyus]{0,7}/.source+"|"+/(?:\[(?:[^[\]\\\r\n]|\\.|\[(?:[^[\]\\\r\n]|\\.|\[(?:[^[\]\\\r\n]|\\.)*\])*\])*\]|\\.|[^/\\\[\r\n])+\/[dgimyus]{0,7}v[dgimyus]{0,7}/.source+")"+/(?=(?:\s|\/\*(?:[^*]|\*(?!\/))*\*\/)*(?:$|[\r\n,.;:})\]]|\/\/))/.source),lookbehind:!0,greedy:!0,inside:{"regex-source":{pattern:/^(\/)[\s\S]+(?=\/[a-z]*$)/,lookbehind:!0,alias:"language-regex",inside:r.languages.regex},"regex-delimiter":/^\/|\/$/,"regex-flags":/^[a-z]+$/}},"function-variable":{pattern:/#?(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*[=:]\s*(?:async\s*)?(?:\bfunction\b|(?:\((?:[^()]|\([^()]*\))*\)|(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*)\s*=>))/,alias:"function"},parameter:[{pattern:/(function(?:\s+(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*)?\s*\(\s*)(?!\s)(?:[^()\s]|\s+(?![\s)])|\([^()]*\))+(?=\s*\))/,lookbehind:!0,inside:r.languages.javascript},{pattern:/(^|[^$\w\xA0-\uFFFF])(?!\s)[_$a-z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*=>)/i,lookbehind:!0,inside:r.languages.javascript},{pattern:/(\(\s*)(?!\s)(?:[^()\s]|\s+(?![\s)])|\([^()]*\))+(?=\s*\)\s*=>)/,lookbehind:!0,inside:r.languages.javascript},{pattern:/((?:\b|\s|^)(?!(?:as|async|await|break|case|catch|class|const|continue|debugger|default|delete|do|else|enum|export|extends|finally|for|from|function|get|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|set|static|super|switch|this|throw|try|typeof|undefined|var|void|while|with|yield)(?![$\w\xA0-\uFFFF]))(?:(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*\s*)\(\s*|\]\s*\(\s*)(?!\s)(?:[^()\s]|\s+(?![\s)])|\([^()]*\))+(?=\s*\)\s*\{)/,lookbehind:!0,inside:r.languages.javascript}],constant:/\b[A-Z](?:[A-Z_]|\dx?)*\b/}),r.languages.insertBefore("javascript","string",{hashbang:{pattern:/^#!.*/,greedy:!0,alias:"comment"},"template-string":{pattern:/`(?:\\[\s\S]|\$\{(?:[^{}]|\{(?:[^{}]|\{[^}]*\})*\})+\}|(?!\$\{)[^\\`])*`/,greedy:!0,inside:{"template-punctuation":{pattern:/^`|`$/,alias:"string"},interpolation:{pattern:/((?:^|[^\\])(?:\\{2})*)\$\{(?:[^{}]|\{(?:[^{}]|\{[^}]*\})*\})+\}/,lookbehind:!0,inside:{"interpolation-punctuation":{pattern:/^\$\{|\}$/,alias:"punctuation"},rest:r.languages.javascript}},string:/[\s\S]+/}},"string-property":{pattern:/((?:^|[,{])[ \t]*)(["'])(?:\\(?:\r\n|[\s\S])|(?!\2)[^\\\r\n])*\2(?=\s*:)/m,lookbehind:!0,greedy:!0,alias:"property"}}),r.languages.insertBefore("javascript","operator",{"literal-property":{pattern:/((?:^|[,{])[ \t]*)(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*:)/m,lookbehind:!0,alias:"property"}}),r.languages.markup&&(r.languages.markup.tag.addInlined("script","javascript"),r.languages.markup.tag.addAttribute(/on(?:abort|blur|change|click|composition(?:end|start|update)|dblclick|error|focus(?:in|out)?|key(?:down|up)|load|mouse(?:down|enter|leave|move|out|over|up)|reset|resize|scroll|select|slotchange|submit|unload|wheel)/.source,"javascript")),r.languages.js=r.languages.javascript,function(){if(void 0!==r&&"undefined"!=typeof document){Element.prototype.matches||(Element.prototype.matches=Element.prototype.msMatchesSelector||Element.prototype.webkitMatchesSelector);var e={js:"javascript",py:"python",rb:"ruby",ps1:"powershell",psm1:"powershell",sh:"bash",bat:"batch",h:"c",tex:"latex"},t="data-src-status",n="loading",i="loaded",a="pre[data-src]:not(["+t+'="'+i+'"]):not(['+t+'="'+n+'"])';r.hooks.add("before-highlightall",(function(e){e.selector+=", "+a})),r.hooks.add("before-sanity-check",(function(o){var s=o.element;if(s.matches(a)){o.code="",s.setAttribute(t,n);var l=s.appendChild(document.createElement("CODE"));l.textContent="Loading…";var u=s.getAttribute("data-src"),c=o.language;if("none"===c){var d=(/\.(\w+)$/.exec(u)||[,"none"])[1];c=e[d]||d}r.util.setLanguage(l,c),r.util.setLanguage(s,c);var h=r.plugins.autoloader;h&&h.loadLanguages(c),function(e,t,n){var r=new XMLHttpRequest;r.open("GET",e,!0),r.onreadystatechange=function(){4==r.readyState&&(r.status<400&&r.responseText?t(r.responseText):r.status>=400?n("✖ Error "+r.status+" while fetching file: "+r.statusText):n("✖ Error: File does not exist or is empty"))},r.send(null)}(u,(function(e){s.setAttribute(t,i);var n=function(e){var t=/^\s*(\d+)\s*(?:(,)\s*(?:(\d+)\s*)?)?$/.exec(e||"");if(t){var n=Number(t[1]),r=t[2],i=t[3];return r?i?[n,Number(i)]:[n,void 0]:[n,n]}}(s.getAttribute("data-range"));if(n){var a=e.split(/\r\n?|\n/g),o=n[0],u=null==n[1]?a.length:n[1];o<0&&(o+=a.length),o=Math.max(0,Math.min(o-1,a.length)),u<0&&(u+=a.length),u=Math.max(0,Math.min(u,a.length)),e=a.slice(o,u).join("\n"),s.hasAttribute("data-start")||s.setAttribute("data-start",String(o+1))}l.textContent=e,r.highlightElement(l)}),(function(e){s.setAttribute(t,"failed"),l.textContent=e}))}})),r.plugins.fileHighlight={highlight:function(e){for(var t,n=(e||document).querySelectorAll(a),i=0;t=n[i++];)r.highlightElement(t)}};var o=!1;r.fileHighlight=function(){o||(console.warn("Prism.fileHighlight is deprecated. Use `Prism.plugins.fileHighlight.highlight` instead."),o=!0),r.plugins.fileHighlight.highlight.apply(this,arguments)}}}()},115:function(e){var t="undefined"!=typeof Element,n="function"==typeof Map,r="function"==typeof Set,i="function"==typeof ArrayBuffer&&!!ArrayBuffer.isView;function a(e,o){if(e===o)return!0;if(e&&o&&"object"==typeof e&&"object"==typeof o){if(e.constructor!==o.constructor)return!1;var s,l,u,c;if(Array.isArray(e)){if((s=e.length)!=o.length)return!1;for(l=s;0!=l--;)if(!a(e[l],o[l]))return!1;return!0}if(n&&e instanceof Map&&o instanceof Map){if(e.size!==o.size)return!1;for(c=e.entries();!(l=c.next()).done;)if(!o.has(l.value[0]))return!1;for(c=e.entries();!(l=c.next()).done;)if(!a(l.value[1],o.get(l.value[0])))return!1;return!0}if(r&&e instanceof Set&&o instanceof Set){if(e.size!==o.size)return!1;for(c=e.entries();!(l=c.next()).done;)if(!o.has(l.value[0]))return!1;return!0}if(i&&ArrayBuffer.isView(e)&&ArrayBuffer.isView(o)){if((s=e.length)!=o.length)return!1;for(l=s;0!=l--;)if(e[l]!==o[l])return!1;return!0}if(e.constructor===RegExp)return e.source===o.source&&e.flags===o.flags;if(e.valueOf!==Object.prototype.valueOf&&"function"==typeof e.valueOf&&"function"==typeof o.valueOf)return e.valueOf()===o.valueOf();if(e.toString!==Object.prototype.toString&&"function"==typeof e.toString&&"function"==typeof o.toString)return e.toString()===o.toString();if((s=(u=Object.keys(e)).length)!==Object.keys(o).length)return!1;for(l=s;0!=l--;)if(!Object.prototype.hasOwnProperty.call(o,u[l]))return!1;if(t&&e instanceof Element)return!1;for(l=s;0!=l--;)if(("_owner"!==u[l]&&"__v"!==u[l]&&"__o"!==u[l]||!e.$$typeof)&&!a(e[u[l]],o[u[l]]))return!1;return!0}return e!=e&&o!=o}e.exports=function(e,t){try{return a(e,t)}catch(n){if((n.message||"").match(/stack|recursion/i))return console.warn("react-fast-compare cannot handle circular refs"),!1;throw n}}},1720:function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.bodyOpenClassName=t.portalClassName=void 0;var r=Object.assign||function(e){for(var t=1;t0&&0===(y-=1)&&c.show(t),n.props.shouldFocusAfterRender&&(n.props.shouldReturnFocusAfterClose?(l.returnFocus(n.props.preventScroll),l.teardownScopedFocus()):l.popWithoutFocus()),n.props.onAfterClose&&n.props.onAfterClose(),f.default.deregister(n)},n.open=function(){n.beforeOpen(),n.state.afterOpen&&n.state.beforeClose?(clearTimeout(n.closeTimer),n.setState({beforeClose:!1})):(n.props.shouldFocusAfterRender&&(l.setupScopedFocus(n.node),l.markForFocusLater()),n.setState({isOpen:!0},(function(){n.openAnimationFrame=requestAnimationFrame((function(){n.setState({afterOpen:!0}),n.props.isOpen&&n.props.onAfterOpen&&n.props.onAfterOpen({overlayEl:n.overlay,contentEl:n.content})}))})))},n.close=function(){n.props.closeTimeoutMS>0?n.closeWithTimeout():n.closeWithoutTimeout()},n.focusContent=function(){return n.content&&!n.contentHasFocus()&&n.content.focus({preventScroll:!0})},n.closeWithTimeout=function(){var e=Date.now()+n.props.closeTimeoutMS;n.setState({beforeClose:!0,closesAt:e},(function(){n.closeTimer=setTimeout(n.closeWithoutTimeout,n.state.closesAt-Date.now())}))},n.closeWithoutTimeout=function(){n.setState({beforeClose:!1,isOpen:!1,afterOpen:!1,closesAt:null},n.afterClose)},n.handleKeyDown=function(e){(function(e){return"Tab"===e.code||9===e.keyCode})(e)&&(0,u.default)(n.content,e),n.props.shouldCloseOnEsc&&function(e){return"Escape"===e.code||27===e.keyCode}(e)&&(e.stopPropagation(),n.requestClose(e))},n.handleOverlayOnClick=function(e){null===n.shouldClose&&(n.shouldClose=!0),n.shouldClose&&n.props.shouldCloseOnOverlayClick&&(n.ownerHandlesClose()?n.requestClose(e):n.focusContent()),n.shouldClose=null},n.handleContentOnMouseUp=function(){n.shouldClose=!1},n.handleOverlayOnMouseDown=function(e){n.props.shouldCloseOnOverlayClick||e.target!=n.overlay||e.preventDefault()},n.handleContentOnClick=function(){n.shouldClose=!1},n.handleContentOnMouseDown=function(){n.shouldClose=!1},n.requestClose=function(e){return n.ownerHandlesClose()&&n.props.onRequestClose(e)},n.ownerHandlesClose=function(){return n.props.onRequestClose},n.shouldBeClosed=function(){return!n.state.isOpen&&!n.state.beforeClose},n.contentHasFocus=function(){return document.activeElement===n.content||n.content.contains(document.activeElement)},n.buildClassName=function(e,t){var r="object"===(void 0===t?"undefined":i(t))?t:{base:v[e],afterOpen:v[e]+"--after-open",beforeClose:v[e]+"--before-close"},a=r.base;return n.state.afterOpen&&(a=a+" "+r.afterOpen),n.state.beforeClose&&(a=a+" "+r.beforeClose),"string"==typeof t&&t?a+" "+t:a},n.attributesFromObject=function(e,t){return Object.keys(t).reduce((function(n,r){return n[e+"-"+r]=t[r],n}),{})},n.state={afterOpen:!1,beforeClose:!1},n.shouldClose=null,n.moveFromContentToOverlay=null,n}return function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}(t,e),a(t,[{key:"componentDidMount",value:function(){this.props.isOpen&&this.open()}},{key:"componentDidUpdate",value:function(e,t){this.props.isOpen&&!e.isOpen?this.open():!this.props.isOpen&&e.isOpen&&this.close(),this.props.shouldFocusAfterRender&&this.state.isOpen&&!t.isOpen&&this.focusContent()}},{key:"componentWillUnmount",value:function(){this.state.isOpen&&this.afterClose(),clearTimeout(this.closeTimer),cancelAnimationFrame(this.openAnimationFrame)}},{key:"beforeOpen",value:function(){var e=this.props,t=e.appElement,n=e.ariaHideApp,r=e.htmlOpenClassName,i=e.bodyOpenClassName,a=e.parentSelector,o=a&&a().ownerDocument||document;i&&d.add(o.body,i),r&&d.add(o.getElementsByTagName("html")[0],r),n&&(y+=1,c.hide(t)),f.default.register(this)}},{key:"render",value:function(){var e=this.props,t=e.id,n=e.className,i=e.overlayClassName,a=e.defaultStyles,o=e.children,s=n?{}:a.content,l=i?{}:a.overlay;if(this.shouldBeClosed())return null;var u={ref:this.setOverlayRef,className:this.buildClassName("overlay",i),style:r({},l,this.props.style.overlay),onClick:this.handleOverlayOnClick,onMouseDown:this.handleOverlayOnMouseDown},c=r({id:t,ref:this.setContentRef,style:r({},s,this.props.style.content),className:this.buildClassName("content",n),tabIndex:"-1",onKeyDown:this.handleKeyDown,onMouseDown:this.handleContentOnMouseDown,onMouseUp:this.handleContentOnMouseUp,onClick:this.handleContentOnClick,role:this.props.role,"aria-label":this.props.contentLabel},this.attributesFromObject("aria",r({modal:!0},this.props.aria)),this.attributesFromObject("data",this.props.data||{}),{"data-testid":this.props.testId}),d=this.props.contentElement(c,o);return this.props.overlayElement(u,d)}}]),t}(o.Component);b.defaultProps={style:{overlay:{},content:{}},defaultStyles:{}},b.propTypes={isOpen:s.default.bool.isRequired,defaultStyles:s.default.shape({content:s.default.object,overlay:s.default.object}),style:s.default.shape({content:s.default.object,overlay:s.default.object}),className:s.default.oneOfType([s.default.string,s.default.object]),overlayClassName:s.default.oneOfType([s.default.string,s.default.object]),parentSelector:s.default.func,bodyOpenClassName:s.default.string,htmlOpenClassName:s.default.string,ariaHideApp:s.default.bool,appElement:s.default.oneOfType([s.default.instanceOf(p.default),s.default.instanceOf(h.SafeHTMLCollection),s.default.instanceOf(h.SafeNodeList),s.default.arrayOf(s.default.instanceOf(p.default))]),onAfterOpen:s.default.func,onAfterClose:s.default.func,onRequestClose:s.default.func,closeTimeoutMS:s.default.number,shouldFocusAfterRender:s.default.bool,shouldCloseOnOverlayClick:s.default.bool,shouldReturnFocusAfterClose:s.default.bool,preventScroll:s.default.bool,role:s.default.string,contentLabel:s.default.string,aria:s.default.object,data:s.default.object,children:s.default.node,shouldCloseOnEsc:s.default.bool,overlayRef:s.default.func,contentRef:s.default.func,id:s.default.string,overlayElement:s.default.func,contentElement:s.default.func,testId:s.default.string},t.default=b,e.exports=t.default},6462:function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.resetState=function(){s&&(s.removeAttribute?s.removeAttribute("aria-hidden"):null!=s.length?s.forEach((function(e){return e.removeAttribute("aria-hidden")})):document.querySelectorAll(s).forEach((function(e){return e.removeAttribute("aria-hidden")})));s=null},t.log=function(){0},t.assertNodeList=l,t.setElement=function(e){var t=e;if("string"==typeof t&&o.canUseDOM){var n=document.querySelectorAll(t);l(n,t),t=n}return s=t||s},t.validateElement=u,t.hide=function(e){var t=!0,n=!1,r=void 0;try{for(var i,a=u(e)[Symbol.iterator]();!(t=(i=a.next()).done);t=!0){i.value.setAttribute("aria-hidden","true")}}catch(o){n=!0,r=o}finally{try{!t&&a.return&&a.return()}finally{if(n)throw r}}},t.show=function(e){var t=!0,n=!1,r=void 0;try{for(var i,a=u(e)[Symbol.iterator]();!(t=(i=a.next()).done);t=!0){i.value.removeAttribute("aria-hidden")}}catch(o){n=!0,r=o}finally{try{!t&&a.return&&a.return()}finally{if(n)throw r}}},t.documentNotReadyOrSSRTesting=function(){s=null};var r,i=n(9771),a=(r=i)&&r.__esModule?r:{default:r},o=n(834);var s=null;function l(e,t){if(!e||!e.length)throw new Error("react-modal: No elements were found for selector "+t+".")}function u(e){var t=e||s;return t?Array.isArray(t)||t instanceof HTMLCollection||t instanceof NodeList?t:[t]:((0,a.default)(!1,["react-modal: App element is not defined.","Please use `Modal.setAppElement(el)` or set `appElement={el}`.","This is needed so screen readers don't see main content","when modal is opened. It is not recommended, but you can opt-out","by setting `ariaHideApp={false}`."].join(" ")),[])}},7727:function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.resetState=function(){for(var e=[o,s],t=0;t0?(document.body.firstChild!==o&&document.body.insertBefore(o,document.body.firstChild),document.body.lastChild!==s&&document.body.appendChild(s)):(o.parentElement&&o.parentElement.removeChild(o),s.parentElement&&s.parentElement.removeChild(s))}))},4838:function(e,t){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.resetState=function(){var e=document.getElementsByTagName("html")[0];for(var t in n)i(e,n[t]);var a=document.body;for(var o in r)i(a,r[o]);n={},r={}},t.log=function(){0};var n={},r={};function i(e,t){e.classList.remove(t)}t.add=function(e,t){return i=e.classList,a="html"==e.nodeName.toLowerCase()?n:r,void t.split(" ").forEach((function(e){!function(e,t){e[t]||(e[t]=0),e[t]+=1}(a,e),i.add(e)}));var i,a},t.remove=function(e,t){return i=e.classList,a="html"==e.nodeName.toLowerCase()?n:r,void t.split(" ").forEach((function(e){!function(e,t){e[t]&&(e[t]-=1)}(a,e),0===a[e]&&i.remove(e)}));var i,a}},7791:function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.resetState=function(){o=[]},t.log=function(){0},t.handleBlur=u,t.handleFocus=c,t.markForFocusLater=function(){o.push(document.activeElement)},t.returnFocus=function(){var e=arguments.length>0&&void 0!==arguments[0]&&arguments[0],t=null;try{return void(0!==o.length&&(t=o.pop()).focus({preventScroll:e}))}catch(n){console.warn(["You tried to return focus to",t,"but it is not in the DOM anymore"].join(" "))}},t.popWithoutFocus=function(){o.length>0&&o.pop()},t.setupScopedFocus=function(e){s=e,window.addEventListener?(window.addEventListener("blur",u,!1),document.addEventListener("focus",c,!0)):(window.attachEvent("onBlur",u),document.attachEvent("onFocus",c))},t.teardownScopedFocus=function(){s=null,window.addEventListener?(window.removeEventListener("blur",u),document.removeEventListener("focus",c)):(window.detachEvent("onBlur",u),document.detachEvent("onFocus",c))};var r,i=n(2411),a=(r=i)&&r.__esModule?r:{default:r};var o=[],s=null,l=!1;function u(){l=!0}function c(){if(l){if(l=!1,!s)return;setTimeout((function(){s.contains(document.activeElement)||((0,a.default)(s)[0]||s).focus()}),0)}}},9628:function(e,t){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.log=function(){console.log("portalOpenInstances ----------"),console.log(r.openInstances.length),r.openInstances.forEach((function(e){return console.log(e)})),console.log("end portalOpenInstances ----------")},t.resetState=function(){r=new n};var n=function e(){var t=this;!function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,e),this.register=function(e){-1===t.openInstances.indexOf(e)&&(t.openInstances.push(e),t.emit("register"))},this.deregister=function(e){var n=t.openInstances.indexOf(e);-1!==n&&(t.openInstances.splice(n,1),t.emit("deregister"))},this.subscribe=function(e){t.subscribers.push(e)},this.emit=function(e){t.subscribers.forEach((function(n){return n(e,t.openInstances.slice())}))},this.openInstances=[],this.subscribers=[]},r=new n;t.default=r},834:function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.canUseDOM=t.SafeNodeList=t.SafeHTMLCollection=void 0;var r,i=n(411);var a=((r=i)&&r.__esModule?r:{default:r}).default,o=a.canUseDOM?window.HTMLElement:{};t.SafeHTMLCollection=a.canUseDOM?window.HTMLCollection:{},t.SafeNodeList=a.canUseDOM?window.NodeList:{},t.canUseDOM=a.canUseDOM;t.default=o},7067:function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default=function(e,t){var n=(0,a.default)(e);if(!n.length)return void t.preventDefault();var r=void 0,i=t.shiftKey,s=n[0],l=n[n.length-1],u=o();if(e===u){if(!i)return;r=l}l!==u||i||(r=s);s===u&&i&&(r=l);if(r)return t.preventDefault(),void r.focus();var c=/(\bChrome\b|\bSafari\b)\//.exec(navigator.userAgent);if(null==c||"Chrome"==c[1]||null!=/\biPod\b|\biPad\b/g.exec(navigator.userAgent))return;var d=n.indexOf(u);d>-1&&(d+=i?-1:1);if(void 0===(r=n[d]))return t.preventDefault(),void(r=i?l:s).focus();t.preventDefault(),r.focus()};var r,i=n(2411),a=(r=i)&&r.__esModule?r:{default:r};function o(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:document;return e.activeElement.shadowRoot?o(e.activeElement.shadowRoot):e.activeElement}e.exports=t.default},2411:function(e,t){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default=function e(t){var n=[].slice.call(t.querySelectorAll("*"),0).reduce((function(t,n){return t.concat(n.shadowRoot?e(n.shadowRoot):[n])}),[]);return n.filter(s)};var n="none",r="contents",i=/input|select|textarea|button|object|iframe/;function a(e){var t=e.offsetWidth<=0&&e.offsetHeight<=0;if(t&&!e.innerHTML)return!0;try{var i=window.getComputedStyle(e),a=i.getPropertyValue("display");return t?a!==r&&function(e,t){return"visible"!==t.getPropertyValue("overflow")||e.scrollWidth<=0&&e.scrollHeight<=0}(e,i):a===n}catch(o){return console.warn("Failed to inspect element style"),!1}}function o(e,t){var n=e.nodeName.toLowerCase();return(i.test(n)&&!e.disabled||"a"===n&&e.href||t)&&function(e){for(var t=e,n=e.getRootNode&&e.getRootNode();t&&t!==document.body;){if(n&&t===n&&(t=n.host.parentNode),a(t))return!1;t=t.parentNode}return!0}(e)}function s(e){var t=e.getAttribute("tabindex");null===t&&(t=void 0);var n=isNaN(t);return(n||t>=0)&&o(e,!n)}e.exports=t.default},312:function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var r,i=n(1720),a=(r=i)&&r.__esModule?r:{default:r};t.default=a.default,e.exports=t.default},2098:function(e,t,n){"use strict";var r,i=n(6540),a=(r=i)&&"object"==typeof r&&"default"in r?r.default:r;function o(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}var s=!("undefined"==typeof window||!window.document||!window.document.createElement);e.exports=function(e,t,n){if("function"!=typeof e)throw new Error("Expected reducePropsToState to be a function.");if("function"!=typeof t)throw new Error("Expected handleStateChangeOnClient to be a function.");if(void 0!==n&&"function"!=typeof n)throw new Error("Expected mapStateOnServer to either be undefined or a function.");return function(r){if("function"!=typeof r)throw new Error("Expected WrappedComponent to be a React component.");var l,u=[];function c(){l=e(u.map((function(e){return e.props}))),d.canUseDOM?t(l):n&&(l=n(l))}var d=function(e){var t,n;function i(){return e.apply(this,arguments)||this}n=e,(t=i).prototype=Object.create(n.prototype),t.prototype.constructor=t,t.__proto__=n,i.peek=function(){return l},i.rewind=function(){if(i.canUseDOM)throw new Error("You may only call rewind() on the server. Call peek() to read the current state.");var e=l;return l=void 0,u=[],e};var o=i.prototype;return o.UNSAFE_componentWillMount=function(){u.push(this),c()},o.componentDidUpdate=function(){c()},o.componentWillUnmount=function(){var e=u.indexOf(this);u.splice(e,1),c()},o.render=function(){return a.createElement(r,this.props)},i}(i.PureComponent);return o(d,"displayName","SideEffect("+function(e){return e.displayName||e.name||"Component"}(r)+")"),o(d,"canUseDOM",s),d}}},9771:function(e){"use strict";var t=function(){};e.exports=t},6942:function(e,t){var n;!function(){"use strict";var r={}.hasOwnProperty;function i(){for(var e="",t=0;t arr.length) len = arr.length;\n\n for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];\n\n return arr2;\n}\n\nfunction _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\n\nfunction _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\n\n/**\n * Placeholder for future translate functionality\n */\nfunction translate(str) {\n var replaceStrings = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;\n\n if (!str) {\n return '';\n }\n\n var translated = str;\n\n if (replaceStrings) {\n Object.keys(replaceStrings).forEach(function (placeholder) {\n translated = translated.replace(placeholder, replaceStrings[placeholder]);\n });\n }\n\n return translated;\n}\nfunction getWindowWidth() {\n return typeof global.window !== 'undefined' ? global.window.innerWidth : 0;\n}\nfunction getWindowHeight() {\n return typeof global.window !== 'undefined' ? global.window.innerHeight : 0;\n}\n\nvar isCrossOriginFrame = function isCrossOriginFrame() {\n try {\n return global.window.location.hostname !== global.window.parent.location.hostname;\n } catch (e) {\n return true;\n }\n}; // Get the highest window context that isn't cross-origin\n// (When in an iframe)\n\n\nfunction getHighestSafeWindowContext() {\n var self = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : global.window.self;\n\n // If we reached the top level, return self\n if (self === global.window.top) {\n return self;\n } // If parent is the same origin, we can move up one context\n // Reference: https://stackoverflow.com/a/21965342/1601953\n\n\n if (!isCrossOriginFrame()) {\n return getHighestSafeWindowContext(self.parent);\n } // If a different origin, we consider the current level\n // as the top reachable one\n\n\n return self;\n}\n\n// Min image zoom level\nvar MIN_ZOOM_LEVEL = 0; // Max image zoom level\n\nvar MAX_ZOOM_LEVEL = 300; // Size ratio between previous and next zoom levels\n\nvar ZOOM_RATIO = 1.007; // How much to increase/decrease the zoom level when the zoom buttons are clicked\n\nvar ZOOM_BUTTON_INCREMENT_SIZE = 100; // Used to judge the amount of horizontal scroll needed to initiate a image move\n\nvar WHEEL_MOVE_X_THRESHOLD = 200; // Used to judge the amount of vertical scroll needed to initiate a zoom action\n\nvar WHEEL_MOVE_Y_THRESHOLD = 1;\nvar KEYS = {\n ESC: 27,\n LEFT_ARROW: 37,\n RIGHT_ARROW: 39\n}; // Actions\n\nvar ACTION_NONE = 0;\nvar ACTION_MOVE = 1;\nvar ACTION_SWIPE = 2;\nvar ACTION_PINCH = 3;\n\nvar SOURCE_ANY = 0;\nvar SOURCE_MOUSE = 1;\nvar SOURCE_TOUCH = 2;\nvar SOURCE_POINTER = 3; // Minimal swipe distance\n\nvar MIN_SWIPE_DISTANCE = 200;\n\nvar ReactImageLightbox = /*#__PURE__*/function (_Component) {\n _inherits(ReactImageLightbox, _Component);\n\n var _super = _createSuper(ReactImageLightbox);\n\n function ReactImageLightbox(props) {\n var _this;\n\n _classCallCheck(this, ReactImageLightbox);\n\n _this = _super.call(this, props);\n _this.state = {\n //-----------------------------\n // Animation\n //-----------------------------\n // Lightbox is closing\n // When Lightbox is mounted, if animation is enabled it will open with the reverse of the closing animation\n isClosing: !props.animationDisabled,\n // Component parts should animate (e.g., when images are moving, or image is being zoomed)\n shouldAnimate: false,\n //-----------------------------\n // Zoom settings\n //-----------------------------\n // Zoom level of image\n zoomLevel: MIN_ZOOM_LEVEL,\n //-----------------------------\n // Image position settings\n //-----------------------------\n // Horizontal offset from center\n offsetX: 0,\n // Vertical offset from center\n offsetY: 0,\n // image load error for srcType\n loadErrorStatus: {}\n }; // Refs\n\n _this.outerEl = /*#__PURE__*/React.createRef();\n _this.zoomInBtn = /*#__PURE__*/React.createRef();\n _this.zoomOutBtn = /*#__PURE__*/React.createRef();\n _this.caption = /*#__PURE__*/React.createRef();\n _this.closeIfClickInner = _this.closeIfClickInner.bind(_assertThisInitialized(_this));\n _this.handleImageDoubleClick = _this.handleImageDoubleClick.bind(_assertThisInitialized(_this));\n _this.handleImageMouseWheel = _this.handleImageMouseWheel.bind(_assertThisInitialized(_this));\n _this.handleKeyInput = _this.handleKeyInput.bind(_assertThisInitialized(_this));\n _this.handleMouseUp = _this.handleMouseUp.bind(_assertThisInitialized(_this));\n _this.handleMouseDown = _this.handleMouseDown.bind(_assertThisInitialized(_this));\n _this.handleMouseMove = _this.handleMouseMove.bind(_assertThisInitialized(_this));\n _this.handleOuterMousewheel = _this.handleOuterMousewheel.bind(_assertThisInitialized(_this));\n _this.handleTouchStart = _this.handleTouchStart.bind(_assertThisInitialized(_this));\n _this.handleTouchMove = _this.handleTouchMove.bind(_assertThisInitialized(_this));\n _this.handleTouchEnd = _this.handleTouchEnd.bind(_assertThisInitialized(_this));\n _this.handlePointerEvent = _this.handlePointerEvent.bind(_assertThisInitialized(_this));\n _this.handleCaptionMousewheel = _this.handleCaptionMousewheel.bind(_assertThisInitialized(_this));\n _this.handleWindowResize = _this.handleWindowResize.bind(_assertThisInitialized(_this));\n _this.handleZoomInButtonClick = _this.handleZoomInButtonClick.bind(_assertThisInitialized(_this));\n _this.handleZoomOutButtonClick = _this.handleZoomOutButtonClick.bind(_assertThisInitialized(_this));\n _this.requestClose = _this.requestClose.bind(_assertThisInitialized(_this));\n _this.requestMoveNext = _this.requestMoveNext.bind(_assertThisInitialized(_this));\n _this.requestMovePrev = _this.requestMovePrev.bind(_assertThisInitialized(_this)); // Timeouts - always clear it before umount\n\n _this.timeouts = []; // Current action\n\n _this.currentAction = ACTION_NONE; // Events source\n\n _this.eventsSource = SOURCE_ANY; // Empty pointers list\n\n _this.pointerList = []; // Prevent inner close\n\n _this.preventInnerClose = false;\n _this.preventInnerCloseTimeout = null; // Used to disable animation when changing props.mainSrc|nextSrc|prevSrc\n\n _this.keyPressed = false; // Used to store load state / dimensions of images\n\n _this.imageCache = {}; // Time the last keydown event was called (used in keyboard action rate limiting)\n\n _this.lastKeyDownTime = 0; // Used for debouncing window resize event\n\n _this.resizeTimeout = null; // Used to determine when actions are triggered by the scroll wheel\n\n _this.wheelActionTimeout = null;\n _this.resetScrollTimeout = null;\n _this.scrollX = 0;\n _this.scrollY = 0; // Used in panning zoomed images\n\n _this.moveStartX = 0;\n _this.moveStartY = 0;\n _this.moveStartOffsetX = 0;\n _this.moveStartOffsetY = 0; // Used to swipe\n\n _this.swipeStartX = 0;\n _this.swipeStartY = 0;\n _this.swipeEndX = 0;\n _this.swipeEndY = 0; // Used to pinch\n\n _this.pinchTouchList = null;\n _this.pinchDistance = 0; // Used to differentiate between images with identical src\n\n _this.keyCounter = 0; // Used to detect a move when all src's remain unchanged (four or more of the same image in a row)\n\n _this.moveRequested = false;\n return _this;\n }\n\n _createClass(ReactImageLightbox, [{\n key: \"componentDidMount\",\n value: function componentDidMount() {\n var _this2 = this;\n\n if (!this.props.animationDisabled) {\n // Make opening animation play\n this.setState({\n isClosing: false\n });\n } // Prevents cross-origin errors when using a cross-origin iframe\n\n\n this.windowContext = getHighestSafeWindowContext();\n this.listeners = {\n resize: this.handleWindowResize,\n mouseup: this.handleMouseUp,\n touchend: this.handleTouchEnd,\n touchcancel: this.handleTouchEnd,\n pointerdown: this.handlePointerEvent,\n pointermove: this.handlePointerEvent,\n pointerup: this.handlePointerEvent,\n pointercancel: this.handlePointerEvent\n };\n Object.keys(this.listeners).forEach(function (type) {\n _this2.windowContext.addEventListener(type, _this2.listeners[type]);\n });\n this.loadAllImages();\n }\n }, {\n key: \"shouldComponentUpdate\",\n value: function shouldComponentUpdate(nextProps) {\n var _this3 = this;\n\n this.getSrcTypes().forEach(function (srcType) {\n if (_this3.props[srcType.name] !== nextProps[srcType.name]) {\n _this3.moveRequested = false;\n }\n }); // Wait for move...\n\n return !this.moveRequested;\n }\n }, {\n key: \"componentDidUpdate\",\n value: function componentDidUpdate(prevProps) {\n var _this4 = this;\n\n var sourcesChanged = false;\n var prevSrcDict = {};\n var nextSrcDict = {};\n this.getSrcTypes().forEach(function (srcType) {\n if (prevProps[srcType.name] !== _this4.props[srcType.name]) {\n sourcesChanged = true;\n prevSrcDict[prevProps[srcType.name]] = true;\n nextSrcDict[_this4.props[srcType.name]] = true;\n }\n });\n\n if (sourcesChanged || this.moveRequested) {\n // Reset the loaded state for images not rendered next\n Object.keys(prevSrcDict).forEach(function (prevSrc) {\n if (!(prevSrc in nextSrcDict) && prevSrc in _this4.imageCache) {\n _this4.imageCache[prevSrc].loaded = false;\n }\n });\n this.moveRequested = false; // Load any new images\n\n this.loadAllImages(this.props);\n }\n }\n }, {\n key: \"componentWillUnmount\",\n value: function componentWillUnmount() {\n var _this5 = this;\n\n this.didUnmount = true;\n Object.keys(this.listeners).forEach(function (type) {\n _this5.windowContext.removeEventListener(type, _this5.listeners[type]);\n });\n this.timeouts.forEach(function (tid) {\n return clearTimeout(tid);\n });\n }\n }, {\n key: \"setTimeout\",\n value: function (_setTimeout) {\n function setTimeout(_x, _x2) {\n return _setTimeout.apply(this, arguments);\n }\n\n setTimeout.toString = function () {\n return _setTimeout.toString();\n };\n\n return setTimeout;\n }(function (func, time) {\n var _this6 = this;\n\n var id = setTimeout(function () {\n _this6.timeouts = _this6.timeouts.filter(function (tid) {\n return tid !== id;\n });\n func();\n }, time);\n this.timeouts.push(id);\n return id;\n })\n }, {\n key: \"setPreventInnerClose\",\n value: function setPreventInnerClose() {\n var _this7 = this;\n\n if (this.preventInnerCloseTimeout) {\n this.clearTimeout(this.preventInnerCloseTimeout);\n }\n\n this.preventInnerClose = true;\n this.preventInnerCloseTimeout = this.setTimeout(function () {\n _this7.preventInnerClose = false;\n _this7.preventInnerCloseTimeout = null;\n }, 100);\n } // Get info for the best suited image to display with the given srcType\n\n }, {\n key: \"getBestImageForType\",\n value: function getBestImageForType(srcType) {\n var imageSrc = this.props[srcType];\n var fitSizes = {};\n\n if (this.isImageLoaded(imageSrc)) {\n // Use full-size image if available\n fitSizes = this.getFitSizes(this.imageCache[imageSrc].width, this.imageCache[imageSrc].height);\n } else if (this.isImageLoaded(this.props[\"\".concat(srcType, \"Thumbnail\")])) {\n // Fall back to using thumbnail if the image has not been loaded\n imageSrc = this.props[\"\".concat(srcType, \"Thumbnail\")];\n fitSizes = this.getFitSizes(this.imageCache[imageSrc].width, this.imageCache[imageSrc].height, true);\n } else {\n return null;\n }\n\n return {\n src: imageSrc,\n height: this.imageCache[imageSrc].height,\n width: this.imageCache[imageSrc].width,\n targetHeight: fitSizes.height,\n targetWidth: fitSizes.width\n };\n } // Get sizing for when an image is larger than the window\n\n }, {\n key: \"getFitSizes\",\n value: function getFitSizes(width, height, stretch) {\n var boxSize = this.getLightboxRect();\n var maxHeight = boxSize.height - this.props.imagePadding * 2;\n var maxWidth = boxSize.width - this.props.imagePadding * 2;\n\n if (!stretch) {\n maxHeight = Math.min(maxHeight, height);\n maxWidth = Math.min(maxWidth, width);\n }\n\n var maxRatio = maxWidth / maxHeight;\n var srcRatio = width / height;\n\n if (maxRatio > srcRatio) {\n // height is the constraining dimension of the photo\n return {\n width: width * maxHeight / height,\n height: maxHeight\n };\n }\n\n return {\n width: maxWidth,\n height: height * maxWidth / width\n };\n }\n }, {\n key: \"getMaxOffsets\",\n value: function getMaxOffsets() {\n var zoomLevel = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.state.zoomLevel;\n var currentImageInfo = this.getBestImageForType('mainSrc');\n\n if (currentImageInfo === null) {\n return {\n maxX: 0,\n minX: 0,\n maxY: 0,\n minY: 0\n };\n }\n\n var boxSize = this.getLightboxRect();\n var zoomMultiplier = this.getZoomMultiplier(zoomLevel);\n var maxX = 0;\n\n if (zoomMultiplier * currentImageInfo.width - boxSize.width < 0) {\n // if there is still blank space in the X dimension, don't limit except to the opposite edge\n maxX = (boxSize.width - zoomMultiplier * currentImageInfo.width) / 2;\n } else {\n maxX = (zoomMultiplier * currentImageInfo.width - boxSize.width) / 2;\n }\n\n var maxY = 0;\n\n if (zoomMultiplier * currentImageInfo.height - boxSize.height < 0) {\n // if there is still blank space in the Y dimension, don't limit except to the opposite edge\n maxY = (boxSize.height - zoomMultiplier * currentImageInfo.height) / 2;\n } else {\n maxY = (zoomMultiplier * currentImageInfo.height - boxSize.height) / 2;\n }\n\n return {\n maxX: maxX,\n maxY: maxY,\n minX: -1 * maxX,\n minY: -1 * maxY\n };\n } // Get image src types\n\n }, {\n key: \"getSrcTypes\",\n value: function getSrcTypes() {\n return [{\n name: 'mainSrc',\n keyEnding: \"i\".concat(this.keyCounter)\n }, {\n name: 'mainSrcThumbnail',\n keyEnding: \"t\".concat(this.keyCounter)\n }, {\n name: 'nextSrc',\n keyEnding: \"i\".concat(this.keyCounter + 1)\n }, {\n name: 'nextSrcThumbnail',\n keyEnding: \"t\".concat(this.keyCounter + 1)\n }, {\n name: 'prevSrc',\n keyEnding: \"i\".concat(this.keyCounter - 1)\n }, {\n name: 'prevSrcThumbnail',\n keyEnding: \"t\".concat(this.keyCounter - 1)\n }];\n }\n /**\n * Get sizing when the image is scaled\n */\n\n }, {\n key: \"getZoomMultiplier\",\n value: function getZoomMultiplier() {\n var zoomLevel = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.state.zoomLevel;\n return Math.pow(ZOOM_RATIO, zoomLevel);\n }\n /**\n * Get the size of the lightbox in pixels\n */\n\n }, {\n key: \"getLightboxRect\",\n value: function getLightboxRect() {\n if (this.outerEl.current) {\n return this.outerEl.current.getBoundingClientRect();\n }\n\n return {\n width: getWindowWidth(),\n height: getWindowHeight(),\n top: 0,\n right: 0,\n bottom: 0,\n left: 0\n };\n }\n }, {\n key: \"clearTimeout\",\n value: function (_clearTimeout) {\n function clearTimeout(_x3) {\n return _clearTimeout.apply(this, arguments);\n }\n\n clearTimeout.toString = function () {\n return _clearTimeout.toString();\n };\n\n return clearTimeout;\n }(function (id) {\n this.timeouts = this.timeouts.filter(function (tid) {\n return tid !== id;\n });\n clearTimeout(id);\n } // Change zoom level\n )\n }, {\n key: \"changeZoom\",\n value: function changeZoom(zoomLevel, clientX, clientY) {\n // Ignore if zoom disabled\n if (!this.props.enableZoom) {\n return;\n } // Constrain zoom level to the set bounds\n\n\n var nextZoomLevel = Math.max(MIN_ZOOM_LEVEL, Math.min(MAX_ZOOM_LEVEL, zoomLevel)); // Ignore requests that don't change the zoom level\n\n if (nextZoomLevel === this.state.zoomLevel) {\n return;\n }\n\n if (nextZoomLevel === MIN_ZOOM_LEVEL) {\n // Snap back to center if zoomed all the way out\n this.setState({\n zoomLevel: nextZoomLevel,\n offsetX: 0,\n offsetY: 0\n });\n return;\n }\n\n var imageBaseSize = this.getBestImageForType('mainSrc');\n\n if (imageBaseSize === null) {\n return;\n }\n\n var currentZoomMultiplier = this.getZoomMultiplier();\n var nextZoomMultiplier = this.getZoomMultiplier(nextZoomLevel); // Default to the center of the image to zoom when no mouse position specified\n\n var boxRect = this.getLightboxRect();\n var pointerX = typeof clientX !== 'undefined' ? clientX - boxRect.left : boxRect.width / 2;\n var pointerY = typeof clientY !== 'undefined' ? clientY - boxRect.top : boxRect.height / 2;\n var currentImageOffsetX = (boxRect.width - imageBaseSize.width * currentZoomMultiplier) / 2;\n var currentImageOffsetY = (boxRect.height - imageBaseSize.height * currentZoomMultiplier) / 2;\n var currentImageRealOffsetX = currentImageOffsetX - this.state.offsetX;\n var currentImageRealOffsetY = currentImageOffsetY - this.state.offsetY;\n var currentPointerXRelativeToImage = (pointerX - currentImageRealOffsetX) / currentZoomMultiplier;\n var currentPointerYRelativeToImage = (pointerY - currentImageRealOffsetY) / currentZoomMultiplier;\n var nextImageRealOffsetX = pointerX - currentPointerXRelativeToImage * nextZoomMultiplier;\n var nextImageRealOffsetY = pointerY - currentPointerYRelativeToImage * nextZoomMultiplier;\n var nextImageOffsetX = (boxRect.width - imageBaseSize.width * nextZoomMultiplier) / 2;\n var nextImageOffsetY = (boxRect.height - imageBaseSize.height * nextZoomMultiplier) / 2;\n var nextOffsetX = nextImageOffsetX - nextImageRealOffsetX;\n var nextOffsetY = nextImageOffsetY - nextImageRealOffsetY; // When zooming out, limit the offset so things don't get left askew\n\n if (this.currentAction !== ACTION_PINCH) {\n var maxOffsets = this.getMaxOffsets();\n\n if (this.state.zoomLevel > nextZoomLevel) {\n nextOffsetX = Math.max(maxOffsets.minX, Math.min(maxOffsets.maxX, nextOffsetX));\n nextOffsetY = Math.max(maxOffsets.minY, Math.min(maxOffsets.maxY, nextOffsetY));\n }\n }\n\n this.setState({\n zoomLevel: nextZoomLevel,\n offsetX: nextOffsetX,\n offsetY: nextOffsetY\n });\n }\n }, {\n key: \"closeIfClickInner\",\n value: function closeIfClickInner(event) {\n if (!this.preventInnerClose && event.target.className.search(/\\bril-inner\\b/) > -1) {\n this.requestClose(event);\n }\n }\n /**\n * Handle user keyboard actions\n */\n\n }, {\n key: \"handleKeyInput\",\n value: function handleKeyInput(event) {\n event.stopPropagation(); // Ignore key input during animations\n\n if (this.isAnimating()) {\n return;\n } // Allow slightly faster navigation through the images when user presses keys repeatedly\n\n\n if (event.type === 'keyup') {\n this.lastKeyDownTime -= this.props.keyRepeatKeyupBonus;\n return;\n }\n\n var keyCode = event.which || event.keyCode; // Ignore key presses that happen too close to each other (when rapid fire key pressing or holding down the key)\n // But allow it if it's a lightbox closing action\n\n var currentTime = new Date();\n\n if (currentTime.getTime() - this.lastKeyDownTime < this.props.keyRepeatLimit && keyCode !== KEYS.ESC) {\n return;\n }\n\n this.lastKeyDownTime = currentTime.getTime();\n\n switch (keyCode) {\n // ESC key closes the lightbox\n case KEYS.ESC:\n event.preventDefault();\n this.requestClose(event);\n break;\n // Left arrow key moves to previous image\n\n case KEYS.LEFT_ARROW:\n if (!this.props.prevSrc) {\n return;\n }\n\n event.preventDefault();\n this.keyPressed = true;\n this.requestMovePrev(event);\n break;\n // Right arrow key moves to next image\n\n case KEYS.RIGHT_ARROW:\n if (!this.props.nextSrc) {\n return;\n }\n\n event.preventDefault();\n this.keyPressed = true;\n this.requestMoveNext(event);\n break;\n }\n }\n /**\n * Handle a mouse wheel event over the lightbox container\n */\n\n }, {\n key: \"handleOuterMousewheel\",\n value: function handleOuterMousewheel(event) {\n var _this8 = this;\n\n // Prevent scrolling of the background\n event.stopPropagation();\n var xThreshold = WHEEL_MOVE_X_THRESHOLD;\n var actionDelay = 0;\n var imageMoveDelay = 500;\n this.clearTimeout(this.resetScrollTimeout);\n this.resetScrollTimeout = this.setTimeout(function () {\n _this8.scrollX = 0;\n _this8.scrollY = 0;\n }, 300); // Prevent rapid-fire zoom behavior\n\n if (this.wheelActionTimeout !== null || this.isAnimating()) {\n return;\n }\n\n if (Math.abs(event.deltaY) < Math.abs(event.deltaX)) {\n // handle horizontal scrolls with image moves\n this.scrollY = 0;\n this.scrollX += event.deltaX;\n var bigLeapX = xThreshold / 2; // If the scroll amount has accumulated sufficiently, or a large leap was taken\n\n if (this.scrollX >= xThreshold || event.deltaX >= bigLeapX) {\n // Scroll right moves to next\n this.requestMoveNext(event);\n actionDelay = imageMoveDelay;\n this.scrollX = 0;\n } else if (this.scrollX <= -1 * xThreshold || event.deltaX <= -1 * bigLeapX) {\n // Scroll left moves to previous\n this.requestMovePrev(event);\n actionDelay = imageMoveDelay;\n this.scrollX = 0;\n }\n } // Allow successive actions after the set delay\n\n\n if (actionDelay !== 0) {\n this.wheelActionTimeout = this.setTimeout(function () {\n _this8.wheelActionTimeout = null;\n }, actionDelay);\n }\n }\n }, {\n key: \"handleImageMouseWheel\",\n value: function handleImageMouseWheel(event) {\n var yThreshold = WHEEL_MOVE_Y_THRESHOLD;\n\n if (Math.abs(event.deltaY) >= Math.abs(event.deltaX)) {\n event.stopPropagation(); // If the vertical scroll amount was large enough, perform a zoom\n\n if (Math.abs(event.deltaY) < yThreshold) {\n return;\n }\n\n this.scrollX = 0;\n this.scrollY += event.deltaY;\n this.changeZoom(this.state.zoomLevel - event.deltaY, event.clientX, event.clientY);\n }\n }\n /**\n * Handle a double click on the current image\n */\n\n }, {\n key: \"handleImageDoubleClick\",\n value: function handleImageDoubleClick(event) {\n if (this.state.zoomLevel > MIN_ZOOM_LEVEL) {\n // A double click when zoomed in zooms all the way out\n this.changeZoom(MIN_ZOOM_LEVEL, event.clientX, event.clientY);\n } else {\n // A double click when zoomed all the way out zooms in\n this.changeZoom(this.state.zoomLevel + ZOOM_BUTTON_INCREMENT_SIZE, event.clientX, event.clientY);\n }\n }\n }, {\n key: \"shouldHandleEvent\",\n value: function shouldHandleEvent(source) {\n if (this.eventsSource === source) {\n return true;\n }\n\n if (this.eventsSource === SOURCE_ANY) {\n this.eventsSource = source;\n return true;\n }\n\n switch (source) {\n case SOURCE_MOUSE:\n return false;\n\n case SOURCE_TOUCH:\n this.eventsSource = SOURCE_TOUCH;\n this.filterPointersBySource();\n return true;\n\n case SOURCE_POINTER:\n if (this.eventsSource === SOURCE_MOUSE) {\n this.eventsSource = SOURCE_POINTER;\n this.filterPointersBySource();\n return true;\n }\n\n return false;\n\n default:\n return false;\n }\n }\n }, {\n key: \"addPointer\",\n value: function addPointer(pointer) {\n this.pointerList.push(pointer);\n }\n }, {\n key: \"removePointer\",\n value: function removePointer(pointer) {\n this.pointerList = this.pointerList.filter(function (_ref) {\n var id = _ref.id;\n return id !== pointer.id;\n });\n }\n }, {\n key: \"filterPointersBySource\",\n value: function filterPointersBySource() {\n var _this9 = this;\n\n this.pointerList = this.pointerList.filter(function (_ref2) {\n var source = _ref2.source;\n return source === _this9.eventsSource;\n });\n }\n }, {\n key: \"handleMouseDown\",\n value: function handleMouseDown(event) {\n if (this.shouldHandleEvent(SOURCE_MOUSE) && ReactImageLightbox.isTargetMatchImage(event.target)) {\n this.addPointer(ReactImageLightbox.parseMouseEvent(event));\n this.multiPointerStart(event);\n }\n }\n }, {\n key: \"handleMouseMove\",\n value: function handleMouseMove(event) {\n if (this.shouldHandleEvent(SOURCE_MOUSE)) {\n this.multiPointerMove(event, [ReactImageLightbox.parseMouseEvent(event)]);\n }\n }\n }, {\n key: \"handleMouseUp\",\n value: function handleMouseUp(event) {\n if (this.shouldHandleEvent(SOURCE_MOUSE)) {\n this.removePointer(ReactImageLightbox.parseMouseEvent(event));\n this.multiPointerEnd(event);\n }\n }\n }, {\n key: \"handlePointerEvent\",\n value: function handlePointerEvent(event) {\n if (this.shouldHandleEvent(SOURCE_POINTER)) {\n switch (event.type) {\n case 'pointerdown':\n if (ReactImageLightbox.isTargetMatchImage(event.target)) {\n this.addPointer(ReactImageLightbox.parsePointerEvent(event));\n this.multiPointerStart(event);\n }\n\n break;\n\n case 'pointermove':\n this.multiPointerMove(event, [ReactImageLightbox.parsePointerEvent(event)]);\n break;\n\n case 'pointerup':\n case 'pointercancel':\n this.removePointer(ReactImageLightbox.parsePointerEvent(event));\n this.multiPointerEnd(event);\n break;\n }\n }\n }\n }, {\n key: \"handleTouchStart\",\n value: function handleTouchStart(event) {\n var _this10 = this;\n\n if (this.shouldHandleEvent(SOURCE_TOUCH) && ReactImageLightbox.isTargetMatchImage(event.target)) {\n [].forEach.call(event.changedTouches, function (eventTouch) {\n return _this10.addPointer(ReactImageLightbox.parseTouchPointer(eventTouch));\n });\n this.multiPointerStart(event);\n }\n }\n }, {\n key: \"handleTouchMove\",\n value: function handleTouchMove(event) {\n if (this.shouldHandleEvent(SOURCE_TOUCH)) {\n this.multiPointerMove(event, [].map.call(event.changedTouches, function (eventTouch) {\n return ReactImageLightbox.parseTouchPointer(eventTouch);\n }));\n }\n }\n }, {\n key: \"handleTouchEnd\",\n value: function handleTouchEnd(event) {\n var _this11 = this;\n\n if (this.shouldHandleEvent(SOURCE_TOUCH)) {\n [].map.call(event.changedTouches, function (touch) {\n return _this11.removePointer(ReactImageLightbox.parseTouchPointer(touch));\n });\n this.multiPointerEnd(event);\n }\n }\n }, {\n key: \"decideMoveOrSwipe\",\n value: function decideMoveOrSwipe(pointer) {\n if (this.state.zoomLevel <= MIN_ZOOM_LEVEL) {\n this.handleSwipeStart(pointer);\n } else {\n this.handleMoveStart(pointer);\n }\n }\n }, {\n key: \"multiPointerStart\",\n value: function multiPointerStart(event) {\n this.handleEnd(null);\n\n switch (this.pointerList.length) {\n case 1:\n {\n event.preventDefault();\n this.decideMoveOrSwipe(this.pointerList[0]);\n break;\n }\n\n case 2:\n {\n event.preventDefault();\n this.handlePinchStart(this.pointerList);\n break;\n }\n }\n }\n }, {\n key: \"multiPointerMove\",\n value: function multiPointerMove(event, pointerList) {\n switch (this.currentAction) {\n case ACTION_MOVE:\n {\n event.preventDefault();\n this.handleMove(pointerList[0]);\n break;\n }\n\n case ACTION_SWIPE:\n {\n event.preventDefault();\n this.handleSwipe(pointerList[0]);\n break;\n }\n\n case ACTION_PINCH:\n {\n event.preventDefault();\n this.handlePinch(pointerList);\n break;\n }\n }\n }\n }, {\n key: \"multiPointerEnd\",\n value: function multiPointerEnd(event) {\n if (this.currentAction !== ACTION_NONE) {\n this.setPreventInnerClose();\n this.handleEnd(event);\n }\n\n switch (this.pointerList.length) {\n case 0:\n {\n this.eventsSource = SOURCE_ANY;\n break;\n }\n\n case 1:\n {\n event.preventDefault();\n this.decideMoveOrSwipe(this.pointerList[0]);\n break;\n }\n\n case 2:\n {\n event.preventDefault();\n this.handlePinchStart(this.pointerList);\n break;\n }\n }\n }\n }, {\n key: \"handleEnd\",\n value: function handleEnd(event) {\n switch (this.currentAction) {\n case ACTION_MOVE:\n this.handleMoveEnd(event);\n break;\n\n case ACTION_SWIPE:\n this.handleSwipeEnd(event);\n break;\n\n case ACTION_PINCH:\n this.handlePinchEnd(event);\n break;\n }\n } // Handle move start over the lightbox container\n // This happens:\n // - On a mouseDown event\n // - On a touchstart event\n\n }, {\n key: \"handleMoveStart\",\n value: function handleMoveStart(_ref3) {\n var clientX = _ref3.x,\n clientY = _ref3.y;\n\n if (!this.props.enableZoom) {\n return;\n }\n\n this.currentAction = ACTION_MOVE;\n this.moveStartX = clientX;\n this.moveStartY = clientY;\n this.moveStartOffsetX = this.state.offsetX;\n this.moveStartOffsetY = this.state.offsetY;\n } // Handle dragging over the lightbox container\n // This happens:\n // - After a mouseDown and before a mouseUp event\n // - After a touchstart and before a touchend event\n\n }, {\n key: \"handleMove\",\n value: function handleMove(_ref4) {\n var clientX = _ref4.x,\n clientY = _ref4.y;\n var newOffsetX = this.moveStartX - clientX + this.moveStartOffsetX;\n var newOffsetY = this.moveStartY - clientY + this.moveStartOffsetY;\n\n if (this.state.offsetX !== newOffsetX || this.state.offsetY !== newOffsetY) {\n this.setState({\n offsetX: newOffsetX,\n offsetY: newOffsetY\n });\n }\n }\n }, {\n key: \"handleMoveEnd\",\n value: function handleMoveEnd() {\n var _this12 = this;\n\n this.currentAction = ACTION_NONE;\n this.moveStartX = 0;\n this.moveStartY = 0;\n this.moveStartOffsetX = 0;\n this.moveStartOffsetY = 0; // Snap image back into frame if outside max offset range\n\n var maxOffsets = this.getMaxOffsets();\n var nextOffsetX = Math.max(maxOffsets.minX, Math.min(maxOffsets.maxX, this.state.offsetX));\n var nextOffsetY = Math.max(maxOffsets.minY, Math.min(maxOffsets.maxY, this.state.offsetY));\n\n if (nextOffsetX !== this.state.offsetX || nextOffsetY !== this.state.offsetY) {\n this.setState({\n offsetX: nextOffsetX,\n offsetY: nextOffsetY,\n shouldAnimate: true\n });\n this.setTimeout(function () {\n _this12.setState({\n shouldAnimate: false\n });\n }, this.props.animationDuration);\n }\n }\n }, {\n key: \"handleSwipeStart\",\n value: function handleSwipeStart(_ref5) {\n var clientX = _ref5.x,\n clientY = _ref5.y;\n this.currentAction = ACTION_SWIPE;\n this.swipeStartX = clientX;\n this.swipeStartY = clientY;\n this.swipeEndX = clientX;\n this.swipeEndY = clientY;\n }\n }, {\n key: \"handleSwipe\",\n value: function handleSwipe(_ref6) {\n var clientX = _ref6.x,\n clientY = _ref6.y;\n this.swipeEndX = clientX;\n this.swipeEndY = clientY;\n }\n }, {\n key: \"handleSwipeEnd\",\n value: function handleSwipeEnd(event) {\n var xDiff = this.swipeEndX - this.swipeStartX;\n var xDiffAbs = Math.abs(xDiff);\n var yDiffAbs = Math.abs(this.swipeEndY - this.swipeStartY);\n this.currentAction = ACTION_NONE;\n this.swipeStartX = 0;\n this.swipeStartY = 0;\n this.swipeEndX = 0;\n this.swipeEndY = 0;\n\n if (!event || this.isAnimating() || xDiffAbs < yDiffAbs * 1.5) {\n return;\n }\n\n if (xDiffAbs < MIN_SWIPE_DISTANCE) {\n var boxRect = this.getLightboxRect();\n\n if (xDiffAbs < boxRect.width / 4) {\n return;\n }\n }\n\n if (xDiff > 0 && this.props.prevSrc) {\n event.preventDefault();\n this.requestMovePrev();\n } else if (xDiff < 0 && this.props.nextSrc) {\n event.preventDefault();\n this.requestMoveNext();\n }\n }\n }, {\n key: \"calculatePinchDistance\",\n value: function calculatePinchDistance() {\n var _ref7 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.pinchTouchList,\n _ref8 = _slicedToArray(_ref7, 2),\n a = _ref8[0],\n b = _ref8[1];\n\n return Math.sqrt(Math.pow(a.x - b.x, 2) + Math.pow(a.y - b.y, 2));\n }\n }, {\n key: \"calculatePinchCenter\",\n value: function calculatePinchCenter() {\n var _ref9 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.pinchTouchList,\n _ref10 = _slicedToArray(_ref9, 2),\n a = _ref10[0],\n b = _ref10[1];\n\n return {\n x: a.x - (a.x - b.x) / 2,\n y: a.y - (a.y - b.y) / 2\n };\n }\n }, {\n key: \"handlePinchStart\",\n value: function handlePinchStart(pointerList) {\n if (!this.props.enableZoom) {\n return;\n }\n\n this.currentAction = ACTION_PINCH;\n this.pinchTouchList = pointerList.map(function (_ref11) {\n var id = _ref11.id,\n x = _ref11.x,\n y = _ref11.y;\n return {\n id: id,\n x: x,\n y: y\n };\n });\n this.pinchDistance = this.calculatePinchDistance();\n }\n }, {\n key: \"handlePinch\",\n value: function handlePinch(pointerList) {\n this.pinchTouchList = this.pinchTouchList.map(function (oldPointer) {\n for (var i = 0; i < pointerList.length; i += 1) {\n if (pointerList[i].id === oldPointer.id) {\n return pointerList[i];\n }\n }\n\n return oldPointer;\n });\n var newDistance = this.calculatePinchDistance();\n var zoomLevel = this.state.zoomLevel + newDistance - this.pinchDistance;\n this.pinchDistance = newDistance;\n\n var _this$calculatePinchC = this.calculatePinchCenter(this.pinchTouchList),\n clientX = _this$calculatePinchC.x,\n clientY = _this$calculatePinchC.y;\n\n this.changeZoom(zoomLevel, clientX, clientY);\n }\n }, {\n key: \"handlePinchEnd\",\n value: function handlePinchEnd() {\n this.currentAction = ACTION_NONE;\n this.pinchTouchList = null;\n this.pinchDistance = 0;\n } // Handle the window resize event\n\n }, {\n key: \"handleWindowResize\",\n value: function handleWindowResize() {\n this.clearTimeout(this.resizeTimeout);\n this.resizeTimeout = this.setTimeout(this.forceUpdate.bind(this), 100);\n }\n }, {\n key: \"handleZoomInButtonClick\",\n value: function handleZoomInButtonClick() {\n var nextZoomLevel = this.state.zoomLevel + ZOOM_BUTTON_INCREMENT_SIZE;\n this.changeZoom(nextZoomLevel);\n\n if (nextZoomLevel === MAX_ZOOM_LEVEL) {\n this.zoomOutBtn.current.focus();\n }\n }\n }, {\n key: \"handleZoomOutButtonClick\",\n value: function handleZoomOutButtonClick() {\n var nextZoomLevel = this.state.zoomLevel - ZOOM_BUTTON_INCREMENT_SIZE;\n this.changeZoom(nextZoomLevel);\n\n if (nextZoomLevel === MIN_ZOOM_LEVEL) {\n this.zoomInBtn.current.focus();\n }\n }\n }, {\n key: \"handleCaptionMousewheel\",\n value: function handleCaptionMousewheel(event) {\n event.stopPropagation();\n\n if (!this.caption.current) {\n return;\n }\n\n var _this$caption$current = this.caption.current.getBoundingClientRect(),\n height = _this$caption$current.height;\n\n var _this$caption$current2 = this.caption.current,\n scrollHeight = _this$caption$current2.scrollHeight,\n scrollTop = _this$caption$current2.scrollTop;\n\n if (event.deltaY > 0 && height + scrollTop >= scrollHeight || event.deltaY < 0 && scrollTop <= 0) {\n event.preventDefault();\n }\n } // Detach key and mouse input events\n\n }, {\n key: \"isAnimating\",\n value: function isAnimating() {\n return this.state.shouldAnimate || this.state.isClosing;\n } // Check if image is loaded\n\n }, {\n key: \"isImageLoaded\",\n value: function isImageLoaded(imageSrc) {\n return imageSrc && imageSrc in this.imageCache && this.imageCache[imageSrc].loaded;\n } // Load image from src and call callback with image width and height on load\n\n }, {\n key: \"loadImage\",\n value: function loadImage(srcType, imageSrc, done) {\n var _this13 = this;\n\n // Return the image info if it is already cached\n if (this.isImageLoaded(imageSrc)) {\n this.setTimeout(function () {\n done();\n }, 1);\n return;\n }\n\n var inMemoryImage = new global.Image();\n\n if (this.props.imageCrossOrigin) {\n inMemoryImage.crossOrigin = this.props.imageCrossOrigin;\n }\n\n inMemoryImage.onerror = function (errorEvent) {\n _this13.props.onImageLoadError(imageSrc, srcType, errorEvent); // failed to load so set the state loadErrorStatus\n\n\n _this13.setState(function (prevState) {\n return {\n loadErrorStatus: _objectSpread2(_objectSpread2({}, prevState.loadErrorStatus), {}, _defineProperty({}, srcType, true))\n };\n });\n\n done(errorEvent);\n };\n\n inMemoryImage.onload = function () {\n _this13.props.onImageLoad(imageSrc, srcType, inMemoryImage);\n\n _this13.imageCache[imageSrc] = {\n loaded: true,\n width: inMemoryImage.width,\n height: inMemoryImage.height\n };\n done();\n };\n\n inMemoryImage.src = imageSrc;\n } // Load all images and their thumbnails\n\n }, {\n key: \"loadAllImages\",\n value: function loadAllImages() {\n var _this14 = this;\n\n var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.props;\n\n var generateLoadDoneCallback = function generateLoadDoneCallback(srcType, imageSrc) {\n return function (err) {\n // Give up showing image on error\n if (err) {\n return;\n } // Don't rerender if the src is not the same as when the load started\n // or if the component has unmounted\n\n\n if (_this14.props[srcType] !== imageSrc || _this14.didUnmount) {\n return;\n } // Force rerender with the new image\n\n\n _this14.forceUpdate();\n };\n }; // Load the images\n\n\n this.getSrcTypes().forEach(function (srcType) {\n var type = srcType.name; // there is no error when we try to load it initially\n\n if (props[type] && _this14.state.loadErrorStatus[type]) {\n _this14.setState(function (prevState) {\n return {\n loadErrorStatus: _objectSpread2(_objectSpread2({}, prevState.loadErrorStatus), {}, _defineProperty({}, type, false))\n };\n });\n } // Load unloaded images\n\n\n if (props[type] && !_this14.isImageLoaded(props[type])) {\n _this14.loadImage(type, props[type], generateLoadDoneCallback(type, props[type]));\n }\n });\n } // Request that the lightbox be closed\n\n }, {\n key: \"requestClose\",\n value: function requestClose(event) {\n var _this15 = this;\n\n // Call the parent close request\n var closeLightbox = function closeLightbox() {\n return _this15.props.onCloseRequest(event);\n };\n\n if (this.props.animationDisabled || event.type === 'keydown' && !this.props.animationOnKeyInput) {\n // No animation\n closeLightbox();\n return;\n } // With animation\n // Start closing animation\n\n\n this.setState({\n isClosing: true\n }); // Perform the actual closing at the end of the animation\n\n this.setTimeout(closeLightbox, this.props.animationDuration);\n }\n }, {\n key: \"requestMove\",\n value: function requestMove(direction, event) {\n var _this16 = this;\n\n // Reset the zoom level on image move\n var nextState = {\n zoomLevel: MIN_ZOOM_LEVEL,\n offsetX: 0,\n offsetY: 0\n }; // Enable animated states\n\n if (!this.props.animationDisabled && (!this.keyPressed || this.props.animationOnKeyInput)) {\n nextState.shouldAnimate = true;\n this.setTimeout(function () {\n return _this16.setState({\n shouldAnimate: false\n });\n }, this.props.animationDuration);\n }\n\n this.keyPressed = false;\n this.moveRequested = true;\n\n if (direction === 'prev') {\n this.keyCounter -= 1;\n this.setState(nextState);\n this.props.onMovePrevRequest(event);\n } else {\n this.keyCounter += 1;\n this.setState(nextState);\n this.props.onMoveNextRequest(event);\n }\n } // Request to transition to the next image\n\n }, {\n key: \"requestMoveNext\",\n value: function requestMoveNext(event) {\n this.requestMove('next', event);\n } // Request to transition to the previous image\n\n }, {\n key: \"requestMovePrev\",\n value: function requestMovePrev(event) {\n this.requestMove('prev', event);\n }\n }, {\n key: \"render\",\n value: function render() {\n var _this17 = this;\n\n var _this$props = this.props,\n animationDisabled = _this$props.animationDisabled,\n animationDuration = _this$props.animationDuration,\n clickOutsideToClose = _this$props.clickOutsideToClose,\n discourageDownloads = _this$props.discourageDownloads,\n enableZoom = _this$props.enableZoom,\n imageTitle = _this$props.imageTitle,\n nextSrc = _this$props.nextSrc,\n prevSrc = _this$props.prevSrc,\n toolbarButtons = _this$props.toolbarButtons,\n reactModalStyle = _this$props.reactModalStyle,\n _onAfterOpen = _this$props.onAfterOpen,\n imageCrossOrigin = _this$props.imageCrossOrigin,\n reactModalProps = _this$props.reactModalProps,\n loader = _this$props.loader;\n var _this$state = this.state,\n zoomLevel = _this$state.zoomLevel,\n offsetX = _this$state.offsetX,\n offsetY = _this$state.offsetY,\n isClosing = _this$state.isClosing,\n loadErrorStatus = _this$state.loadErrorStatus;\n var boxSize = this.getLightboxRect();\n var transitionStyle = {}; // Transition settings for sliding animations\n\n if (!animationDisabled && this.isAnimating()) {\n transitionStyle = _objectSpread2(_objectSpread2({}, transitionStyle), {}, {\n transition: \"transform \".concat(animationDuration, \"ms\")\n });\n } // Key endings to differentiate between images with the same src\n\n\n var keyEndings = {};\n this.getSrcTypes().forEach(function (_ref12) {\n var name = _ref12.name,\n keyEnding = _ref12.keyEnding;\n keyEndings[name] = keyEnding;\n }); // Images to be displayed\n\n var images = [];\n\n var addImage = function addImage(srcType, imageClass, transforms) {\n // Ignore types that have no source defined for their full size image\n if (!_this17.props[srcType]) {\n return;\n }\n\n var bestImageInfo = _this17.getBestImageForType(srcType);\n\n var imageStyle = _objectSpread2(_objectSpread2({}, transitionStyle), ReactImageLightbox.getTransform(_objectSpread2(_objectSpread2({}, transforms), bestImageInfo)));\n\n if (zoomLevel > MIN_ZOOM_LEVEL) {\n imageStyle.cursor = 'move';\n } // support IE 9 and 11\n\n\n var hasTrueValue = function hasTrueValue(object) {\n return Object.keys(object).some(function (key) {\n return object[key];\n });\n }; // when error on one of the loads then push custom error stuff\n\n\n if (bestImageInfo === null && hasTrueValue(loadErrorStatus)) {\n images.push( /*#__PURE__*/React.createElement(\"div\", {\n className: \"\".concat(imageClass, \" ril__image ril-errored\"),\n style: imageStyle,\n key: _this17.props[srcType] + keyEndings[srcType]\n }, /*#__PURE__*/React.createElement(\"div\", {\n className: \"ril__errorContainer\"\n }, _this17.props.imageLoadErrorMessage)));\n return;\n }\n\n if (bestImageInfo === null) {\n var loadingIcon = loader !== undefined ? loader : /*#__PURE__*/React.createElement(\"div\", {\n className: \"ril-loading-circle ril__loadingCircle ril__loadingContainer__icon\"\n }, _toConsumableArray(new Array(12)).map(function (_, index) {\n return /*#__PURE__*/React.createElement(\"div\", {\n // eslint-disable-next-line react/no-array-index-key\n key: index,\n className: \"ril-loading-circle-point ril__loadingCirclePoint\"\n });\n })); // Fall back to loading icon if the thumbnail has not been loaded\n\n images.push( /*#__PURE__*/React.createElement(\"div\", {\n className: \"\".concat(imageClass, \" ril__image ril-not-loaded\"),\n style: imageStyle,\n key: _this17.props[srcType] + keyEndings[srcType]\n }, /*#__PURE__*/React.createElement(\"div\", {\n className: \"ril__loadingContainer\"\n }, loadingIcon)));\n return;\n }\n\n var imageSrc = bestImageInfo.src;\n\n if (discourageDownloads) {\n imageStyle.backgroundImage = \"url('\".concat(imageSrc, \"')\");\n images.push( /*#__PURE__*/React.createElement(\"div\", {\n className: \"\".concat(imageClass, \" ril__image ril__imageDiscourager\"),\n onDoubleClick: _this17.handleImageDoubleClick,\n onWheel: _this17.handleImageMouseWheel,\n style: imageStyle,\n key: imageSrc + keyEndings[srcType]\n }, /*#__PURE__*/React.createElement(\"div\", {\n className: \"ril-download-blocker ril__downloadBlocker\"\n })));\n } else {\n images.push( /*#__PURE__*/React.createElement(\"img\", _extends({}, imageCrossOrigin ? {\n crossOrigin: imageCrossOrigin\n } : {}, {\n className: \"\".concat(imageClass, \" ril__image\"),\n onDoubleClick: _this17.handleImageDoubleClick,\n onWheel: _this17.handleImageMouseWheel,\n onDragStart: function onDragStart(e) {\n return e.preventDefault();\n },\n style: imageStyle,\n src: imageSrc,\n key: imageSrc + keyEndings[srcType],\n alt: typeof imageTitle === 'string' ? imageTitle : translate('Image'),\n draggable: false\n })));\n }\n };\n\n var zoomMultiplier = this.getZoomMultiplier(); // Next Image (displayed on the right)\n\n addImage('nextSrc', 'ril-image-next ril__imageNext', {\n x: boxSize.width\n }); // Main Image\n\n addImage('mainSrc', 'ril-image-current', {\n x: -1 * offsetX,\n y: -1 * offsetY,\n zoom: zoomMultiplier\n }); // Previous Image (displayed on the left)\n\n addImage('prevSrc', 'ril-image-prev ril__imagePrev', {\n x: -1 * boxSize.width\n });\n var modalStyle = {\n overlay: _objectSpread2({\n zIndex: 1000,\n backgroundColor: 'transparent'\n }, reactModalStyle.overlay),\n content: _objectSpread2({\n backgroundColor: 'transparent',\n overflow: 'hidden',\n // Needed, otherwise keyboard shortcuts scroll the page\n border: 'none',\n borderRadius: 0,\n padding: 0,\n top: 0,\n left: 0,\n right: 0,\n bottom: 0\n }, reactModalStyle.content)\n };\n return /*#__PURE__*/React.createElement(Modal, _extends({\n isOpen: true,\n onRequestClose: clickOutsideToClose ? this.requestClose : undefined,\n onAfterOpen: function onAfterOpen() {\n // Focus on the div with key handlers\n if (_this17.outerEl.current) {\n _this17.outerEl.current.focus();\n }\n\n _onAfterOpen();\n },\n style: modalStyle,\n contentLabel: translate('Lightbox'),\n appElement: typeof global.window !== 'undefined' ? global.window.document.body : undefined\n }, reactModalProps), /*#__PURE__*/React.createElement(\"div\", {\n // eslint-disable-line jsx-a11y/no-static-element-interactions\n // Floating modal with closing animations\n className: \"ril-outer ril__outer ril__outerAnimating \".concat(this.props.wrapperClassName, \" \").concat(isClosing ? 'ril-closing ril__outerClosing' : ''),\n style: {\n transition: \"opacity \".concat(animationDuration, \"ms\"),\n animationDuration: \"\".concat(animationDuration, \"ms\"),\n animationDirection: isClosing ? 'normal' : 'reverse'\n },\n ref: this.outerEl,\n onWheel: this.handleOuterMousewheel,\n onMouseMove: this.handleMouseMove,\n onMouseDown: this.handleMouseDown,\n onTouchStart: this.handleTouchStart,\n onTouchMove: this.handleTouchMove,\n tabIndex: \"-1\" // Enables key handlers on div\n ,\n onKeyDown: this.handleKeyInput,\n onKeyUp: this.handleKeyInput\n }, /*#__PURE__*/React.createElement(\"div\", {\n // eslint-disable-line jsx-a11y/no-static-element-interactions, jsx-a11y/click-events-have-key-events\n // Image holder\n className: \"ril-inner ril__inner\",\n onClick: clickOutsideToClose ? this.closeIfClickInner : undefined\n }, images), prevSrc && /*#__PURE__*/React.createElement(\"button\", {\n // Move to previous image button\n type: \"button\",\n className: \"ril-prev-button ril__navButtons ril__navButtonPrev\",\n key: \"prev\",\n \"aria-label\": this.props.prevLabel,\n title: this.props.prevLabel,\n onClick: !this.isAnimating() ? this.requestMovePrev : undefined // Ignore clicks during animation\n\n }), nextSrc && /*#__PURE__*/React.createElement(\"button\", {\n // Move to next image button\n type: \"button\",\n className: \"ril-next-button ril__navButtons ril__navButtonNext\",\n key: \"next\",\n \"aria-label\": this.props.nextLabel,\n title: this.props.nextLabel,\n onClick: !this.isAnimating() ? this.requestMoveNext : undefined // Ignore clicks during animation\n\n }), /*#__PURE__*/React.createElement(\"div\", {\n // Lightbox toolbar\n className: \"ril-toolbar ril__toolbar\"\n }, /*#__PURE__*/React.createElement(\"ul\", {\n className: \"ril-toolbar-left ril__toolbarSide ril__toolbarLeftSide\"\n }, /*#__PURE__*/React.createElement(\"li\", {\n className: \"ril-toolbar__item ril__toolbarItem\"\n }, /*#__PURE__*/React.createElement(\"span\", {\n className: \"ril-toolbar__item__child ril__toolbarItemChild\"\n }, imageTitle))), /*#__PURE__*/React.createElement(\"ul\", {\n className: \"ril-toolbar-right ril__toolbarSide ril__toolbarRightSide\"\n }, toolbarButtons && toolbarButtons.map(function (button, i) {\n return /*#__PURE__*/React.createElement(\"li\", {\n key: \"button_\".concat(i + 1),\n className: \"ril-toolbar__item ril__toolbarItem\"\n }, button);\n }), enableZoom && /*#__PURE__*/React.createElement(\"li\", {\n className: \"ril-toolbar__item ril__toolbarItem\"\n }, /*#__PURE__*/React.createElement(\"button\", {\n // Lightbox zoom in button\n type: \"button\",\n key: \"zoom-in\",\n \"aria-label\": this.props.zoomInLabel,\n title: this.props.zoomInLabel,\n className: ['ril-zoom-in', 'ril__toolbarItemChild', 'ril__builtinButton', 'ril__zoomInButton'].concat(_toConsumableArray(zoomLevel === MAX_ZOOM_LEVEL ? ['ril__builtinButtonDisabled'] : [])).join(' '),\n ref: this.zoomInBtn,\n disabled: this.isAnimating() || zoomLevel === MAX_ZOOM_LEVEL,\n onClick: !this.isAnimating() && zoomLevel !== MAX_ZOOM_LEVEL ? this.handleZoomInButtonClick : undefined\n })), enableZoom && /*#__PURE__*/React.createElement(\"li\", {\n className: \"ril-toolbar__item ril__toolbarItem\"\n }, /*#__PURE__*/React.createElement(\"button\", {\n // Lightbox zoom out button\n type: \"button\",\n key: \"zoom-out\",\n \"aria-label\": this.props.zoomOutLabel,\n title: this.props.zoomOutLabel,\n className: ['ril-zoom-out', 'ril__toolbarItemChild', 'ril__builtinButton', 'ril__zoomOutButton'].concat(_toConsumableArray(zoomLevel === MIN_ZOOM_LEVEL ? ['ril__builtinButtonDisabled'] : [])).join(' '),\n ref: this.zoomOutBtn,\n disabled: this.isAnimating() || zoomLevel === MIN_ZOOM_LEVEL,\n onClick: !this.isAnimating() && zoomLevel !== MIN_ZOOM_LEVEL ? this.handleZoomOutButtonClick : undefined\n })), /*#__PURE__*/React.createElement(\"li\", {\n className: \"ril-toolbar__item ril__toolbarItem\"\n }, /*#__PURE__*/React.createElement(\"button\", {\n // Lightbox close button\n type: \"button\",\n key: \"close\",\n \"aria-label\": this.props.closeLabel,\n title: this.props.closeLabel,\n className: \"ril-close ril-toolbar__item__child ril__toolbarItemChild ril__builtinButton ril__closeButton\",\n onClick: !this.isAnimating() ? this.requestClose : undefined // Ignore clicks during animation\n\n })))), this.props.imageCaption &&\n /*#__PURE__*/\n // eslint-disable-next-line jsx-a11y/no-static-element-interactions\n React.createElement(\"div\", {\n // Image caption\n onWheel: this.handleCaptionMousewheel,\n onMouseDown: function onMouseDown(event) {\n return event.stopPropagation();\n },\n className: \"ril-caption ril__caption\",\n ref: this.caption\n }, /*#__PURE__*/React.createElement(\"div\", {\n className: \"ril-caption-content ril__captionContent\"\n }, this.props.imageCaption))));\n }\n }], [{\n key: \"isTargetMatchImage\",\n value: function isTargetMatchImage(target) {\n return target && /ril-image-current/.test(target.className);\n }\n }, {\n key: \"parseMouseEvent\",\n value: function parseMouseEvent(mouseEvent) {\n return {\n id: 'mouse',\n source: SOURCE_MOUSE,\n x: parseInt(mouseEvent.clientX, 10),\n y: parseInt(mouseEvent.clientY, 10)\n };\n }\n }, {\n key: \"parseTouchPointer\",\n value: function parseTouchPointer(touchPointer) {\n return {\n id: touchPointer.identifier,\n source: SOURCE_TOUCH,\n x: parseInt(touchPointer.clientX, 10),\n y: parseInt(touchPointer.clientY, 10)\n };\n }\n }, {\n key: \"parsePointerEvent\",\n value: function parsePointerEvent(pointerEvent) {\n return {\n id: pointerEvent.pointerId,\n source: SOURCE_POINTER,\n x: parseInt(pointerEvent.clientX, 10),\n y: parseInt(pointerEvent.clientY, 10)\n };\n } // Request to transition to the previous image\n\n }, {\n key: \"getTransform\",\n value: function getTransform(_ref13) {\n var _ref13$x = _ref13.x,\n x = _ref13$x === void 0 ? 0 : _ref13$x,\n _ref13$y = _ref13.y,\n y = _ref13$y === void 0 ? 0 : _ref13$y,\n _ref13$zoom = _ref13.zoom,\n zoom = _ref13$zoom === void 0 ? 1 : _ref13$zoom,\n width = _ref13.width,\n targetWidth = _ref13.targetWidth;\n var nextX = x;\n var windowWidth = getWindowWidth();\n\n if (width > windowWidth) {\n nextX += (windowWidth - width) / 2;\n }\n\n var scaleFactor = zoom * (targetWidth / width);\n return {\n transform: \"translate3d(\".concat(nextX, \"px,\").concat(y, \"px,0) scale3d(\").concat(scaleFactor, \",\").concat(scaleFactor, \",1)\")\n };\n }\n }]);\n\n return ReactImageLightbox;\n}(Component);\n\nReactImageLightbox.propTypes = {\n //-----------------------------\n // Image sources\n //-----------------------------\n // Main display image url\n mainSrc: PropTypes.string.isRequired,\n // eslint-disable-line react/no-unused-prop-types\n // Previous display image url (displayed to the left)\n // If left undefined, movePrev actions will not be performed, and the button not displayed\n prevSrc: PropTypes.string,\n // Next display image url (displayed to the right)\n // If left undefined, moveNext actions will not be performed, and the button not displayed\n nextSrc: PropTypes.string,\n //-----------------------------\n // Image thumbnail sources\n //-----------------------------\n // Thumbnail image url corresponding to props.mainSrc\n mainSrcThumbnail: PropTypes.string,\n // eslint-disable-line react/no-unused-prop-types\n // Thumbnail image url corresponding to props.prevSrc\n prevSrcThumbnail: PropTypes.string,\n // eslint-disable-line react/no-unused-prop-types\n // Thumbnail image url corresponding to props.nextSrc\n nextSrcThumbnail: PropTypes.string,\n // eslint-disable-line react/no-unused-prop-types\n //-----------------------------\n // Event Handlers\n //-----------------------------\n // Close window event\n // Should change the parent state such that the lightbox is not rendered\n onCloseRequest: PropTypes.func.isRequired,\n // Move to previous image event\n // Should change the parent state such that props.prevSrc becomes props.mainSrc,\n // props.mainSrc becomes props.nextSrc, etc.\n onMovePrevRequest: PropTypes.func,\n // Move to next image event\n // Should change the parent state such that props.nextSrc becomes props.mainSrc,\n // props.mainSrc becomes props.prevSrc, etc.\n onMoveNextRequest: PropTypes.func,\n // Called when an image fails to load\n // (imageSrc: string, srcType: string, errorEvent: object): void\n onImageLoadError: PropTypes.func,\n // Called when image successfully loads\n onImageLoad: PropTypes.func,\n // Open window event\n onAfterOpen: PropTypes.func,\n //-----------------------------\n // Download discouragement settings\n //-----------------------------\n // Enable download discouragement (prevents [right-click -> Save Image As...])\n discourageDownloads: PropTypes.bool,\n //-----------------------------\n // Animation settings\n //-----------------------------\n // Disable all animation\n animationDisabled: PropTypes.bool,\n // Disable animation on actions performed with keyboard shortcuts\n animationOnKeyInput: PropTypes.bool,\n // Animation duration (ms)\n animationDuration: PropTypes.number,\n //-----------------------------\n // Keyboard shortcut settings\n //-----------------------------\n // Required interval of time (ms) between key actions\n // (prevents excessively fast navigation of images)\n keyRepeatLimit: PropTypes.number,\n // Amount of time (ms) restored after each keyup\n // (makes rapid key presses slightly faster than holding down the key to navigate images)\n keyRepeatKeyupBonus: PropTypes.number,\n //-----------------------------\n // Image info\n //-----------------------------\n // Image title\n imageTitle: PropTypes.node,\n // Image caption\n imageCaption: PropTypes.node,\n // Optional crossOrigin attribute\n imageCrossOrigin: PropTypes.string,\n //-----------------------------\n // Lightbox style\n //-----------------------------\n // Set z-index style, etc., for the parent react-modal (format: https://github.com/reactjs/react-modal#styles )\n reactModalStyle: PropTypes.shape({}),\n // Padding (px) between the edge of the window and the lightbox\n imagePadding: PropTypes.number,\n wrapperClassName: PropTypes.string,\n //-----------------------------\n // Other\n //-----------------------------\n // Array of custom toolbar buttons\n toolbarButtons: PropTypes.arrayOf(PropTypes.node),\n // When true, clicks outside of the image close the lightbox\n clickOutsideToClose: PropTypes.bool,\n // Set to false to disable zoom functionality and hide zoom buttons\n enableZoom: PropTypes.bool,\n // Override props set on react-modal (https://github.com/reactjs/react-modal)\n reactModalProps: PropTypes.shape({}),\n // Aria-labels\n nextLabel: PropTypes.string,\n prevLabel: PropTypes.string,\n zoomInLabel: PropTypes.string,\n zoomOutLabel: PropTypes.string,\n closeLabel: PropTypes.string,\n imageLoadErrorMessage: PropTypes.node,\n // custom loader\n loader: PropTypes.node\n};\nReactImageLightbox.defaultProps = {\n imageTitle: null,\n imageCaption: null,\n toolbarButtons: null,\n reactModalProps: {},\n animationDisabled: false,\n animationDuration: 300,\n animationOnKeyInput: false,\n clickOutsideToClose: true,\n closeLabel: 'Close lightbox',\n discourageDownloads: false,\n enableZoom: true,\n imagePadding: 10,\n imageCrossOrigin: null,\n keyRepeatKeyupBonus: 40,\n keyRepeatLimit: 180,\n mainSrcThumbnail: null,\n nextLabel: 'Next image',\n nextSrc: null,\n nextSrcThumbnail: null,\n onAfterOpen: function onAfterOpen() {},\n onImageLoadError: function onImageLoadError() {},\n onImageLoad: function onImageLoad() {},\n onMoveNextRequest: function onMoveNextRequest() {},\n onMovePrevRequest: function onMovePrevRequest() {},\n prevLabel: 'Previous image',\n prevSrc: null,\n prevSrcThumbnail: null,\n reactModalStyle: {},\n wrapperClassName: '',\n zoomInLabel: 'Zoom in',\n zoomOutLabel: 'Zoom out',\n imageLoadErrorMessage: 'This image failed to load',\n loader: undefined\n};\n\nexport default ReactImageLightbox;\n","import e from\"classnames\";import t,{useState as n,useEffect as a,useLayoutEffect as i,useCallback as r,useRef as o,createContext as l}from\"react\";import*as c from\"prismjs\";import\"prismjs/components/prism-clike\";import\"prismjs/components/prism-csharp\";import\"prismjs/components/prism-css\";import\"prismjs/components/prism-javascript\";import\"prismjs/components/prism-markup\";import{createPortal as s}from\"react-dom\";import{useCookies as m}from\"react-cookie\";import d from\"react-image-lightbox\";import\"react-image-lightbox/style.css\";function u(){return u=Object.assign?Object.assign.bind():function(e){for(var t=1;t0&&t.createElement(\"span\",{className:\"links\"},s.map(function(e){return t.createElement(f,{\"aria-label\":e.name,as:c,className:\"color-inherit margin-left-md margin-right-md\",external:e.external,key:e.id||e.to,onClick:function(){h&&h(e)},to:e.to},e.name)}))))))}var N=[\"ariaHidden\",\"children\",\"className\",\"inactive\",\"material\",\"name\",\"size\",\"style\",\"theme\"];function x(n){var a,i,r=n.ariaHidden,o=void 0===r||r,l=n.children,c=n.className,s=n.inactive,m=n.material,d=void 0===m||m,v=n.name,p=n.size,f=void 0===p?\"md\":p,g=n.style,w=n.theme,y=h(n,N);return t.createElement(\"i\",u({\"aria-hidden\":o,className:e(\"icon\",(a={},a[\"icon--\"+f]=f&&\"number\"!=typeof f,a),(i={},i[\"icon--\"+w]=w,i),{\"icon--active\":!s},{\"icon--inactive\":s},{\"icon--material\":d},c),style:u({width:\"number\"==typeof f?f+\"px\":void 0,height:\"number\"==typeof f?f+\"px\":void 0},g)},y),v||l)}function k(e){if(null===e)return 0;var t=e.map(function(e){return(e/=255)<=.03928?e/12.92:Math.pow((e+.055)/1.055,2.4)});return.2126*t[0]+.7152*t[1]+.0722*t[2]}function C(e,t){var n=k(e),a=k(t),i=Math.min(n,a);return(Math.max(n,a)+.05)/(i+.05)}function z(e){var t=/^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i.exec(e);return t?[parseInt(t[1],16),parseInt(t[2],16),parseInt(t[3],16)]:null}function _(e){function t(e){var t=e.toString(16);return 1===t.length?\"0\"+t:t}return\"#\"+t(e[0])+t(e[1])+t(e[2])}function L(e,t){return e+\"(\"+S(t)+\")\"}function S(e){return e.displayName||e.name||\"Component\"}function M(e,t,n){e.addEventListener&&e.addEventListener(t,n)}function T(e,t,n){e.removeEventListener&&e.removeEventListener(t,n)}function A(e,t){return function(n){if(!n.defaultPrevented){var a=!1;n.key===e&&(a=!0,t(n)),a&&n.preventDefault()}}}function H(e){return A(\"Enter\",e)}function P(e){return e.replace(/\\b\\w/g,function(e){return e.toUpperCase()})}function I(e,t,n){return Math.min(Math.max(e,t),n)}function V(e,t,n){return e+(t-e)*I(n,0,1)}function B(e,t,n){return I((n-e)/(t-e),0,1)}function j(e,t,n,a){return Math.sqrt(Math.pow(n-e,2)+Math.pow(a-t,2))}function q(e,t,n,a,i,r){var o=2/(a=Math.max(1e-4,a)),l=o*r,c=1/(1+l+.48*l*l+.235*l*l*l),s=e-t,m=t,d=i*a;t=e-(s=Math.min(Math.max(s,-d),d));var u=(n.current+o*s)*r;n.current=(n.current-o*u)*c;var v=t+(s+u)*c;return m-e>0==v>m&&(n.current=((v=m)-m)/r),v}function F(e){var t,n={};for(t in e)[].slice.call(arguments,1).includes(t)||(n[t]=e[t]);return n}function D(e,t){return!!t&&(\"/\"===e?e===t.pathname:t.pathname.includes(e))}function O(e){void 0===e&&(e=\"smooth\"),\"undefined\"!=typeof window&&window.scrollTo({top:0,behavior:e})}function R(){return\"undefined\"!=typeof window&&\"undefined\"!=typeof document?(window.innerWidth||0)-(document.documentElement.clientWidth||0):0}function W(e){return(e.scrollHeight||0)>(e.clientHeight||0)}function Z(e){return(e.scrollWidth||0)>(e.clientWidth||0)}function U(e,t,n){c.highlight(e,t,n)}function Y(e,t){c.highlightAll(e,t)}function G(e,t,n){c.highlightAllUnder(e,t,n)}function J(e,t,n){c.highlightElement(e,t,n)}function K(e,t){var n;return function(){var a=arguments,i=this;clearTimeout(n),n=setTimeout(function(){return e.apply(i,[].slice.call(a))},t)}}function $(e,t){var n,a,i;return void 0===t&&(t=300),function(){var r=this,o=arguments;n?(clearTimeout(a),a=setTimeout(function(){Date.now()-i>=t&&(e.apply(r,o),i=Date.now())},Math.max(t-(Date.now()-i),0))):(e.apply(r,o),i=Date.now(),n=!0)}}var Q=[\"className\",\"hidden\",\"LinkElementType\",\"links\",\"location\",\"onLinkClick\"];function X(n){var a=n.className,i=n.hidden,r=void 0!==i&&i,o=n.LinkElementType,l=void 0===o?\"a\":o,c=n.links,s=n.location,m=void 0===s?\"undefined\"!=typeof window?window.location:null:s,d=n.onLinkClick,v=h(n,Q);return t.createElement(\"nav\",u({className:e(\"navbar\",{\"display-none\":r},a)},v),t.createElement(\"ul\",{className:\"navbar__list\"},c&&c.length>0&&c.map(function(n){var a=D(n.to,m),i=n.icon;return t.createElement(\"li\",{className:\"navbar__item\",key:n.id||n.to},t.createElement(f,{activeClassName:\"\",\"aria-current\":a?\"page\":\"false\",\"aria-label\":n.name,as:n.external?\"a\":l,className:e({active:a}),external:n.external,onClick:function(){d&&d(n)},to:n.to,unstyled:!0},n.icon&&(\"left\"===n.iconAlignment||!n.iconAlignment)&&t.createElement(x,{className:\"margin-right-md\",material:\"string\"==typeof n.icon,size:\"sm\"},\"string\"==typeof n.icon?n.icon:i&&t.createElement(i,null)),n.name,n.icon&&\"right\"===n.iconAlignment&&t.createElement(x,{className:\"margin-left-md\",material:\"string\"==typeof n.icon,size:\"sm\"},\"string\"==typeof n.icon?n.icon:i&&t.createElement(i,null))))})))}var ee=[\"children\",\"className\",\"color\",\"customStyles\",\"icon\",\"iconAlignment\",\"iconSize\",\"onClick\",\"shape\",\"size\",\"style\"];function te(n){var a,i,r,o,l=n.children,c=n.className,s=n.color,m=void 0===s?\"default\":s,d=n.customStyles,v=n.icon,p=n.iconAlignment,f=n.iconSize,g=void 0===f?\"inherit\":f,w=n.onClick,y=n.shape,E=void 0===y?\"rounded-corners\":y,b=n.size,N=void 0===b?\"sm\":b,k=n.style,C=void 0===k?\"solid\":k,z=h(n,ee);return t.createElement(\"button\",u({className:e(\"btn\",(a={},a[\"btn--\"+m]=m,a),(i={},i[\"btn--\"+E]=E,i),(r={},r[\"btn--\"+C]=C,r),(o={},o[\"btn--\"+N]=N&&\"intrinsic\"!==N,o),{\"btn--icon-only\":\"only\"===p},c),onClick:w,style:d},z),\"left\"===p&&t.createElement(\"span\",{\"aria-hidden\":!0,className:\"icon-wrapper margin-right-md\"},\"string\"==typeof v?t.createElement(x,{name:v,size:g}):v),\"only\"===p?t.createElement(\"span\",{\"aria-hidden\":!0,className:\"icon-wrapper\"},\"string\"==typeof v?t.createElement(x,{name:v,size:g}):v):l,\"right\"===p&&t.createElement(\"span\",{\"aria-hidden\":!0,className:\"icon-wrapper margin-left-md\"},\"string\"==typeof v?t.createElement(x,{name:v,size:g}):v))}function ne(e){var i=e.children,r=e.key,o=e.rootElement,l=void 0===o?\"body\":o,c=n(null),m=c[0],d=c[1];return a(function(){\"undefined\"!=typeof document?d(document.querySelector(l)):d(null)},[l]),m?t.createElement(t.Fragment,null,s(i,m,r)):null}var ae=[\"as\",\"backgroundColor\",\"className\",\"foregroundColor\",\"icon\",\"innerPadding\",\"rounded\",\"size\",\"style\"];function ie(n){var a,i=n.as,r=n.backgroundColor,o=n.className,l=n.foregroundColor,c=n.icon,s=n.innerPadding,m=void 0===s?8:s,d=n.rounded,v=void 0!==d&&d,p=n.size,f=void 0===p?24:p,w=n.style,y=h(n,ae),E=c&&\"string\"==typeof c&&c in g?g[c]:c;return t.createElement(null!=i?i:\"i\",u({},y,{className:e(\"icon\",\"social-icon\",{\"social-icon--rounded\":v},(a={},a[c]=\"string\"==typeof c,a),o),style:u({backgroundColor:r,fill:l,width:\"inherit\"!==f?f:void 0,height:\"inherit\"!==f?f:void 0,padding:m},w)}),E&&t.createElement(E,null))}var re={discord:{id:\"discord\",name:\"Discord\",color:\"#7289da\",to:\"https://discord.gg/DdYyWVb\",icon:g.discord,external:!0},email:{id:\"email\",name:\"Email\",to:\"mailto:support@zigurous.com\",icon:g.email,external:!0},facebook:{id:\"facebook\",name:\"Facebook\",color:\"#1877f2\",to:\"https://facebook.com/zigurous\",icon:g.facebook,external:!0},github:{id:\"github\",name:\"GitHub\",to:\"https://github.com/zigurous\",icon:g.github,external:!0},instagram:{id:\"instagram\",name:\"Instagram\",color:\"#e4405f\",to:\"https://instagram.com/zigurous\",icon:g.instagram,external:!0},patreon:{id:\"patreon\",name:\"Patreon\",color:\"#ff424d\",to:\"https://patreon.com/zigurous\",icon:g.patreon,external:!0},paypal:{id:\"paypal\",name:\"PayPal\",color:\"#00457c\",to:\"https://paypal.com/donate?hosted_button_id=BGS8Y9U798JS8\",icon:g.paypal,external:!0},twitch:{id:\"twitch\",name:\"Twitch\",color:\"#9146ff\",to:\"https://twitch.tv/zigurous\",icon:g.twitch,external:!0},twitter:{id:\"twitter\",name:\"Twitter\",color:\"#1da1f2\",to:\"https://twitter.com/zigurous\",icon:g.twitter,external:!0},unity:{id:\"unity\",name:\"Unity\",to:\"https://assetstore.unity.com/publishers/51884\",icon:g.unity,external:!0},youtube:{id:\"youtube\",name:\"YouTube\",color:\"#ff0000\",to:\"https://youtube.com/c/zigurous?sub_confirmation=1\",icon:g.youtube,external:!0}};function oe(n){var a=n.backgroundColor,i=n.foregroundColor,r=n.hidden,o=n.iconInnerPadding,l=void 0===o?12:o,c=n.iconSize,s=void 0===c?24:c,m=n.iconSpacing,d=n.links,u=n.onLinkClick,v=n.rounded,h=void 0!==v&&v,p=n.wrap,f=void 0!==p&&p;return t.createElement(\"div\",{className:e(\"social-nav-links\",{\"display-none\":void 0!==r&&r},n.className)},t.createElement(\"ul\",{className:e(\"social-nav-links__list\",{\"flex-wrap\":f})},d&&d.length>0&&d.map(function(e){var n=\"string\"==typeof e?re[e]:e;return t.createElement(\"li\",{className:\"social-nav-links__item\",key:n.id||n.name,style:{margin:m}},t.createElement(ie,{\"aria-label\":n.name,as:\"a\",backgroundColor:a,foregroundColor:i||n.color,href:n.to,icon:n.icon,innerPadding:l,onClick:function(){u&&u(n)},rel:\"noopener noreferrer\",rounded:h,size:s,target:\"_blank\"}))})))}function le(e,t){var i=\"undefined\"!=typeof window?window.matchMedia(e):null,r=n(i),o=r[0],l=r[1],c=n(Boolean(o&&o.matches)),s=c[0],m=c[1];return a(function(){\"undefined\"!=typeof window&&l(window.matchMedia(e))},[e]),a(function(){var e,n=o;return n&&M(n,\"change\",e=function(){m(n.matches),t&&t(n.matches)}),function(){n&&e&&T(n,\"change\",e)}},[o,t]),s}var ce={sm:576,md:768,lg:992,xl:1200};function se(e){return le(\"number\"==typeof e?\"(min-width: \"+e+\"px)\":\"(min-width: \"+ce[e]+\"px)\")}function me(e){return le(\"number\"==typeof e?\"(max-width: \"+(e-1)+\"px)\":\"(max-width: \"+(ce[e]-1)+\"px)\")}function de(e){function t(){var t,n,a,i;return{width:null!=(t=null==(n=e.current)?void 0:n.offsetWidth)?t:0,height:null!=(a=null==(i=e.current)?void 0:i.offsetHeight)?a:0}}var r=n(t),o=r[0],l=r[1],c=function(){l(t())};return a(function(){if(\"undefined\"!=typeof window)return window.addEventListener(\"resize\",c),function(){return window.removeEventListener(\"resize\",c)}},[]),i(function(){c()},[]),o}function ue(e){var t=n(!0),i=t[0],r=t[1],o=function(){r(!1)};return a(function(){var t=e.current;return t&&i&&(t instanceof HTMLImageElement&&t.complete?o():M(t,\"load\",o)),function(){t&&T(t,\"load\",o)}},[e,i]),i}function ve(e,t){void 0===t&&(t=function(){});var n=!ue(e);return a(function(){n&&t()},[n,t]),n}function he(e,t){var i=n(function(){return pe(e,t)}),r=i[0],o=i[1];return a(function(){\"undefined\"!=typeof window&&localStorage&&localStorage.setItem(e,JSON.stringify(r))},[e,r]),[r,o]}function pe(e,t){if(\"undefined\"==typeof window||!localStorage)return t||null;var n=localStorage.getItem(e);return(n?JSON.parse(n):null)||t||null}function fe(e,t){void 0===e&&(e=!1),void 0===t&&(t=!0),a(function(){if(\"undefined\"!=typeof document)if(e){if(t){var n=R();n>0&&(document.body.style.paddingRight=n+\"px\")}document.body.classList.add(\"overflow-hidden\")}else document.body.classList.remove(\"overflow-hidden\"),t&&(document.body.style.paddingRight=\"\")},[e,t])}function ge(){var e=n(!1),t=e[0],i=e[1];return a(function(){i(!0)},[]),t}function we(e,t,i){void 0===t&&(t=6);var r=n(0),o=r[0],l=r[1],c=o*t,s=c+t,m=Math.ceil(e.length/t);return a(function(){if(i&&\"undefined\"!=typeof sessionStorage){var e=sessionStorage.getItem(i),t=e?parseInt(e,10):NaN;Number.isNaN(t)||l(t),sessionStorage.removeItem(i)}},[i,e]),[{page:o,paginated:m>1,currentPage:o,totalPages:m,itemsPerPage:t,items:e.slice(c,s)},l]}function ye(e,t,i){var o=n(\"\"),l=o[0],c=o[1],s=n(null),m=s[0],d=s[1],u=r(function(n){var a=n.toLowerCase().replace(\" \",\"\").trim();return e.filter(function(e){return t(e,a)})},[e,t]);return a(function(){if(i&&e.length>0&&\"undefined\"!=typeof sessionStorage){var t=sessionStorage.getItem(i);t&&(c(t),d(u(t))),sessionStorage.removeItem(i)}},[i,e,u]),[{query:l,results:m,onChange:function(e){c(e.target.value)},onSearch:function(e){d(e?u(e):null)}},c,d]}function Ee(e,t,i,r){void 0===r&&(r=Infinity);var l=o(),c=o(),s=o(e),m=o(0),d=n(e),u=d[0],v=d[1];return a(function(){var e=function(n){null!=c.current&&(s.current=q(s.current,t.current,m,i/1e3,r,(n-c.current)/1e3),v(s.current)),c.current=n,l.current=requestAnimationFrame(e)};return l.current=requestAnimationFrame(e),function(){void 0!==l.current&&cancelAnimationFrame(l.current)}},[i,r]),u}var be=l({theme:\"light\",setTheme:function(){},toggleTheme:function(){}});function Ne(e){void 0===e&&(e=\"light\");var t=he(\"theme\",e),n=t[0],a=t[1],i=r(function(){a(\"dark\"===n?\"light\":\"dark\")},[n]);return\"undefined\"!=typeof window&&document&&document.documentElement&&document.documentElement.style.setProperty(\"color-scheme\",n),[null!=n?n:e,a,i]}function xe(){var e=n((\"undefined\"==typeof document?null:document.querySelector('link[rel*=\"icon\"]'))||function(){if(\"undefined\"==typeof document)return null;var e=document.createElement(\"link\");return e.setAttribute(\"rel\",\"favicon icon\"),document.head.appendChild(e),e}()),t=e[0],a=le(\"(prefers-color-scheme:light)\"),i=le(\"(prefers-color-scheme:dark)\"),r=null;if(\"undefined\"!=typeof document&&(a?r=document.querySelector('link[rel*=\"icon\"][media=\"(prefers-color-scheme:light)\"]'):i&&(r=document.querySelector('link[rel*=\"icon\"][media=\"(prefers-color-scheme:dark)\"]'))),r&&t){var o=new URL(r.href);t.setAttribute(\"type\",r.type),t.setAttribute(\"href\",o.pathname)}return t}function ke(i){var r=i.animated,o=void 0!==r&&r,l=i.className,c=i.hideSocialLinks,s=void 0===c||c,m=i.LinkElementType,d=void 0===m?\"a\":m,u=i.links,v=i.location,h=void 0===v?\"undefined\"!=typeof window?window.location:null:v,p=i.onLinkClick,g=i.onSocialLinkClick,w=i.rootElement,y=void 0===w?\"body\":w,E=i.socialLinks,b=i.theme,N=n(!1),x=N[0],k=N[1];return fe(x,!0),a(function(){k(!1)},[h]),t.createElement(t.Fragment,null,t.createElement(te,{\"aria-label\":x?\"Close\":\"Open\",className:\"navmenu__button\",customStyles:{zIndex:x?1055:void 0},icon:x?\"close\":\"menu\",iconAlignment:\"only\",iconSize:\"md\",onClick:function(){return k(!x)},size:\"intrinsic\",style:\"unstyled\"}),x&&t.createElement(ne,{rootElement:y},t.createElement(\"div\",{className:e(\"navmenu\",{\"navmenu--open\":x,\"navmenu--closed\":!x},{\"navmenu--animated\":o},l),\"data-theme\":b},t.createElement(\"div\",{className:\"navmenu__overlay\"}),t.createElement(\"div\",{className:\"navmenu__container container\"},t.createElement(\"div\",{className:\"navmenu__wrapper\"},t.createElement(\"ul\",{className:\"navmenu__list\"},u&&u.length>0&&u.map(function(n){var a=D(n.to,h);return t.createElement(\"li\",{className:\"navmenu__item\",key:n.id||n.to},t.createElement(f,{activeClassName:\"\",\"aria-current\":a?\"page\":\"false\",\"aria-label\":n.name,as:n.external?\"a\":d,className:e({active:a}),external:n.external,onClick:function(){p&&p(n)},to:n.to,unstyled:!0},n.name))})),!s&&E&&E.length>0&&t.createElement(oe,{foregroundColor:\"inherit\",iconInnerPadding:10,iconSize:20,links:E,onLinkClick:g}))))))}function Ce(n){var a=n.bordered,i=n.fluid,r=void 0!==i&&i,o=n.hideLogo,l=void 0!==o&&o,c=n.hideNavigation,s=void 0!==c&&c,m=n.hideSocialLinks,d=void 0!==m&&m,v=n.LinkElementType,h=void 0===v?\"a\":v,p=n.links,f=n.location,g=void 0===f?\"undefined\"!=typeof window?window.location:null:f,w=n.LogoElementType,y=void 0===w?\"a\":w,b=n.logoProps,N=n.onLinkClick,x=n.rootElement,k=void 0===x?\"body\":x,C=n.socialLinks,z=n.socialNavLinksProps,_=n.sticky,L=n.theme,S=n.transparent;return t.createElement(\"header\",{className:e(\"app-header\",{\"app-header--bordered\":void 0!==a&&a},{\"app-header--transparent\":void 0!==S&&S},{\"app-header--sticky\":void 0!==_&&_},n.className),\"data-theme\":L},t.createElement(\"div\",{className:e({container:!r,\"container-fluid\":r})},t.createElement(\"div\",{className:\"app-header__content left\"},!l&&t.createElement(E,u({as:y,size:\"sm\"},b)),!s&&t.createElement(X,{LinkElementType:h,links:p,location:g,onLinkClick:N})),t.createElement(\"div\",{className:\"app-header__content right\"},!d&&C&&C.length>0&&t.createElement(oe,u({links:C,iconInnerPadding:10,iconSize:20},z)),!s&&t.createElement(ke,{hideSocialLinks:d,LinkElementType:h,links:p,location:g,onLinkClick:N,rootElement:k,socialLinks:C,theme:L}))))}var ze=[\"alt\",\"as\",\"className\",\"defaultLocale\",\"locale\",\"platform\",\"width\",\"height\",\"style\",\"target\"];function _e(a){var r=a.alt,o=void 0===r?\"Download on the App Store\":r,l=a.as,c=a.className,s=a.defaultLocale,m=void 0===s?\"en-us\":s,d=a.locale,v=void 0===d?\"undefined\"!=typeof navigator&&navigator.language||m:d,p=a.platform,f=a.width,g=void 0===f?200:f,w=a.height,y=void 0===w?g/3.375:w,E=a.style,b=a.target,N=void 0===b?\"_blank\":b,x=h(a,ze),k=null!=l?l:\"a\",C=v=v.toLowerCase();-1===[\"zh-cn\",\"zh-tw\"].indexOf(v)&&(C=v.split(/[_-]/)[0]);var z=n(Le(v,C)),_=z[0],L=z[1];return i(function(){L(Le(v,C))},[v,C]),t.createElement(k,u({},x,{className:e(\"app-store-badge\",c),target:N,style:u({width:g,height:y},E)}),t.createElement(\"img\",{alt:o||\"\",src:_[p],onError:function(){L(Le(m,C))}}))}function Le(e,t){return void 0===e&&(e=\"en-us\"),void 0===t&&(t=e),{ios:\"https://linkmaker.itunes.apple.com/images/badges/\"+e+\"/badge_appstore-lrg.svg\",android:\"https://raw.github.com/yjb94/google-play-badge-svg/master/img/\"+t+\"_get.svg?sanitize=true\"}}var Se=[\"className\",\"direction\",\"LinkElementType\",\"links\",\"theme\"];function Me(n){var a,i=n.className,r=n.direction,o=void 0===r?\"right\":r,l=n.LinkElementType,c=void 0===l?\"a\":l,s=n.links,m=n.theme,d=h(n,Se);return t.createElement(\"div\",u({className:e(\"app-utility-bar\",(a={},a[\"app-utility-bar--\"+o]=o,a),i),\"data-theme\":m},d),t.createElement(\"div\",{className:\"container\"},t.createElement(\"div\",{className:\"row\"},t.createElement(\"div\",{className:\"col font-xs font-weight-500\"},s&&s.length>0&&s.map(function(e){return t.createElement(f,{\"aria-label\":e.name,as:c,className:\"color-inherit margin-left-md margin-right-md\",external:e.external,key:e.id||e.name,to:e.to},e.name)})))))}var Te=[\"children\",\"className\",\"pill\",\"selected\",\"type\"];function Ae(n){var a,i=n.children,r=n.className,o=n.pill,l=void 0!==o&&o,c=n.selected,s=void 0!==c&&c,m=n.type,d=void 0===m?\"solid\":m,v=h(n,Te);return t.createElement(\"div\",u({className:e(\"badge\",(a={},a[\"badge--\"+d]=d,a),{\"badge--pill\":l},{\"badge--selected\":s},r)},v),i)}var He=[\"children\",\"className\",\"layout\"];function Pe(n){var a,i=n.children,r=n.className,o=n.layout,l=void 0===o?\"horizontal\":o,c=h(n,He);return t.createElement(\"div\",u({className:e(\"badge-group\",(a={},a[\"badge-group--\"+l]=l,a),r)},c),i)}var Ie=[\"children\",\"className\",\"layout\"];function Ve(n){var a,i=n.children,r=n.className,o=n.layout,l=void 0===o?\"horizontal\":o,c=h(n,Ie);return t.createElement(\"div\",u({className:e(\"btn-group\",(a={},a[\"btn-group--\"+l]=l,a),r)},c),i)}var Be=[\"children\",\"className\",\"onClick\"];function je(n){var a=n.children,i=n.className,r=n.onClick,o=h(n,Be);return t.createElement(\"div\",u({className:e(i,\"cursor-pointer\"),onClick:r,onKeyDown:H(function(e){r&&r(e)}),role:\"button\",tabIndex:0},o),a)}var qe=[\"children\",\"className\",\"language\"];function Fe(n){var i,r,l=n.children,c=n.className,s=n.language,m=h(n,qe),d=o(null);return a(function(){d.current&&d.current.querySelectorAll(\"pre code\").forEach(function(e){return J(e)})},[l,s,d]),t.createElement(\"pre\",{className:e((i={},i[\"language-\"+s]=s,i),c),ref:d},t.createElement(\"code\",u({className:e((r={},r[\"language-\"+s]=s,r))},m),l))}var De=[\"children\",\"className\",\"gutters\",\"sm\",\"md\",\"lg\",\"xl\"];function Oe(n){var a,i=n.children,r=n.className,o=n.gutters,l=n.sm,c=n.md,s=n.lg,m=n.xl,d=h(n,De);return t.createElement(\"div\",u({className:e({col:!(l||c||s||m)},Re(\"sm\",l),Re(\"md\",c),Re(\"lg\",s),Re(\"xl\",m),(a={},a[\"gutters-\"+o]=o,a),r)},d),i)}function Re(e,t){var n,a;if(\"boolean\"==typeof t)return(n={})[\"col-\"+e]=t,n;if(\"number\"==typeof t||\"string\"==typeof t)return(a={})[\"col-\"+e+\"-\"+t]=!0,a;if(\"object\"==typeof t&&t){var i,r=t.size,o=t.order,l=t.offset;return(i={})[\"col-\"+e]=void 0===r,i[\"col-\"+e+\"-\"+r]=void 0!==r,i[\"order-\"+e+\"-\"+o]=void 0!==o,i[\"offset-\"+e+\"-\"+l]=void 0!==l,i}return null}var We=[\"className\",\"onSubmit\"];function Ze(n){var a=n.className,i=n.onSubmit,r=void 0===i?function(){}:i,o=h(n,We);return t.createElement(\"form\",u({className:e(\"contact-form\",a),onSubmit:r},o),t.createElement(\"input\",{\"aria-label\":\"Name\",id:\"contactName\",name:\"name\",placeholder:\"Name\",required:!0,type:\"text\"}),t.createElement(\"input\",{\"aria-label\":\"Email\",id:\"contactEmail\",name:\"email\",placeholder:\"Email\",required:!0,type:\"email\"}),t.createElement(\"textarea\",{\"aria-label\":\"Message\",id:\"contactMessage\",name:\"message\",placeholder:\"Message\",required:!0}),t.createElement(\"input\",{\"aria-label\":\"Send\",id:\"contactSubmit\",type:\"submit\",value:\"Send\"}))}var Ue=[\"children\",\"className\",\"fluid\"];function Ye(n){var a,i=n.children,r=n.className,o=n.fluid,l=h(n,Ue);return t.createElement(\"div\",u({className:e({container:!o},(a={},a[\"container-\"+o]=o&&\"string\"==typeof o,a),{\"container-fluid\":o&&\"boolean\"==typeof o},r)},l),i)}var Ge=\"cookieconsent_status\",Je=\"accepted\";function Ke(n){var a=n.buttonText,i=void 0===a?\"Agree\":a,r=n.className,o=n.learnMoreLink,l=void 0===o?\"https://www.cookiesandyou.com/\":o,c=n.onConsent,s=void 0===c?function(){}:c,d=n.rootElement,u=void 0===d?\"body\":d,v=n.theme,h=void 0===v?\"high-contrast\":v,p=m([Ge]),g=p[1];return p[0][Ge]===Je?null:t.createElement(ne,{rootElement:u},t.createElement(\"div\",{className:e(\"cookie-consent\",r),\"data-theme\":h},t.createElement(\"div\",{className:\"cookie-consent__container\"},t.createElement(\"span\",{className:\"cookie-consent__text font-sm\"},t.createElement(\"span\",{className:\"margin-right-md\"},\"This website uses cookies to ensure you get the best experience on our website.\"),l&&t.createElement(f,{className:\"color-inherit\",to:l,external:!0,underlined:!0},\"Learn more\")),t.createElement(te,{className:\"cookie-consent__button\",color:\"default\",shape:\"square\",size:\"md\",onClick:function(){g(Ge,Je,{path:\"/\"}),s(!0)}},i))))}function $e(n){var a=n.loading,i=n.size;return t.createElement(\"div\",{\"aria-hidden\":!0,className:e(\"loading-spinner\",{loading:void 0===a||a},void 0===i?\"md\":i,n.className)},t.createElement(\"div\",{className:\"loading-spinner__animation\"},t.createElement(\"div\",null),t.createElement(\"div\",null),t.createElement(\"div\",null),t.createElement(\"div\",null)))}var Qe=Object.freeze({xs:{width:320,height:180},sm:{width:480,height:270},md:{width:640,height:360},lg:{width:960,height:540},xl:{width:1280,height:720}});function Xe(n){var a=n.allowFullScreen,i=void 0===a||a,r=n.className,l=n.frameBorder,c=void 0===l?\"0\":l,s=n.height,m=n.id,d=void 0===m?\"video-player\":m,u=n.scrolling,v=void 0===u?\"no\":u,h=n.size,p=n.src,f=n.title,g=void 0===f?\"Video Player\":f,w=n.width,y=o(null),E=ue(y),b=\"undefined\"!=typeof navigator&&!navigator.onLine,N=w||h&&Qe[h].width,x=s||h&&Qe[h].height;return t.createElement(\"div\",{className:e(\"embedded-video\",{loading:E},h,r),style:{width:et(N),height:et(x)}},t.createElement(\"div\",{className:e(\"embedded-video__wrapper\",\"transition\",\"fade-in\",{visible:!E})},t.createElement(\"iframe\",{allowFullScreen:i,frameBorder:c,height:x||\"100%\",id:d,ref:y,scrolling:v,src:p,title:g,width:N||\"100%\"})),E&&!b&&t.createElement($e,null))}function et(e){if(null!=e)return\"string\"==typeof e&&(e.endsWith(\"%\")||e.endsWith(\"px\"))?e:e+\"px\"}var tt=[\"channel\",\"className\",\"id\",\"muted\",\"secure\",\"title\"];function nt(n){var a=n.channel,i=void 0===a?\"zigurous\":a,r=n.className,o=n.id,l=void 0===o?\"twitch-player\":o,c=n.muted,s=void 0===c||c,m=n.secure,d=void 0===m||m,v=n.title,p=void 0===v?\"Twitch\":v,f=h(n,tt),g=d?\"https\":\"http\",w=[\"zigurous.com\",\"www.zigurous.com\"];return\"development\"===process.env.NODE_ENV&&w.push(\"localhost\"),t.createElement(Xe,u({className:e(\"twitch\",r),id:l,src:g+\"://player.twitch.tv/?channel=\"+i+\"&parent=\"+w.join(\"&parent=\")+\"&muted=\"+s,title:p},f))}var at=[\"autoplay\",\"captions\",\"className\",\"hideBranding\",\"hideControls\",\"hideInfo\",\"hideRelated\",\"id\",\"muted\",\"origin\",\"secure\",\"startTime\",\"title\",\"videoId\"];function it(n){var a=n.autoplay,i=void 0!==a&&a,r=n.captions,o=void 0!==r&&r,l=n.className,c=n.hideBranding,s=void 0!==c&&c,m=n.hideControls,d=void 0!==m&&m,v=n.hideInfo,p=void 0!==v&&v,f=n.hideRelated,g=void 0===f||f,w=n.id,y=void 0===w?\"youtube-player\":w,E=n.muted,b=void 0!==E&&E,N=n.origin,x=n.secure,k=void 0===x||x,C=n.startTime,z=n.title,_=void 0===z?\"YouTube\":z,L=n.videoId,S=h(n,at),M=\"enablejsapi=1\";M+=\"&origin=\"+N,g&&(M+=\"&rel=0\"),d&&(M+=\"&controls=0\"),p&&(M+=\"&showinfo=0\"),s&&(M+=\"&modestbranding=1\"),o&&(M+=\"&cc_load_policy=1\"),i&&(M+=\"&autoplay=1\"),b&&(M+=\"&mute=1\"),C&&(M+=\"&start=\"+C);var T=k?\"https\":\"http\";return t.createElement(Xe,u({className:e(\"youtube\",l),id:y,src:T+\"://www.youtube.com/embed/\"+L+\"?\"+M,title:_},S))}var rt=[\"alt\",\"animated\",\"className\",\"height\",\"imageClassName\",\"imageProps\",\"onLoaded\",\"placeholder\",\"placeholderClassName\",\"placeholderProps\",\"showLoadingSpinner\",\"src\",\"width\"];function ot(n){var a=n.alt,i=n.animated,r=void 0===i||i,l=n.className,c=n.height,s=n.imageClassName,m=n.imageProps,d=void 0===m?{}:m,v=n.onLoaded,p=void 0===v?function(){}:v,f=n.placeholder,g=n.placeholderClassName,w=n.placeholderProps,y=void 0===w?{}:w,E=n.showLoadingSpinner,b=void 0!==E&&E,N=n.src,x=n.width,k=h(n,rt),C=o(null),z=ve(C,p);return t.createElement(\"picture\",u({className:e(\"progressive-image\",{\"progressive-image--loaded\":z},{\"progressive-image--animated\":r},{\"progressive-image--no-placeholder\":!f},l)},k),t.createElement(\"img\",u({},d,{alt:d.alt||a,className:e(\"progressive-image__source\",\"img-fluid\",s,d.className),width:x||d.width,height:c||d.height,ref:C,src:N})),f&&t.createElement(\"img\",u({},y,{alt:y.alt||a,className:e(\"progressive-image__placeholder\",\"img-fluid\",g,y.className),width:x||y.width||d.width,height:c||y.height||d.height,src:f})),b&&!z&&t.createElement($e,null))}function lt(a){var i=a.animated,r=void 0!==i&&i,o=a.animation,l=void 0===o?\"fade-in-up\":o,c=a.className,s=a.columns,m=a.fullWidthFirstItem,u=void 0!==m&&m,v=a.images,h=void 0===v?[]:v,p=a.maxWidth,f=a.minWidth,g=n(!1),w=g[0],y=g[1],E=n(0),b=E[0],N=E[1];return t.createElement(\"div\",{className:e(\"image-gallery\",c)},t.createElement(\"div\",{className:\"image-gallery__thumbnails\",style:{gridTemplateColumns:st(s,f,p)}},h.map(function(n,a){var i,o=\"object\"==typeof n,c=o?n.src:n,s=o?n.key||n.id||n.src:n;return t.createElement(\"button\",{\"aria-label\":\"Image Thumbnail\",className:e(\"image-gallery__thumbnail\",{\"image-gallery__thumbnail--full-width\":0===a&&u},(i={\"animation-short\":r},i[\"animation-delay-\"+(a+1)]=r,i[l]=r,i),o&&n.className),key:s,onClick:function(){N(a),y(!0)}},t.createElement(ot,{imageProps:o?F(n,\"className\"):{},src:c}))})),w&&t.createElement(d,{enableZoom:!1,mainSrc:ct(h[b]),nextSrc:ct(h[(b+1)%h.length]),prevSrc:ct(h[(b+h.length-1)%h.length]),onCloseRequest:function(){y(!1)},onMovePrevRequest:function(){N((b+h.length-1)%h.length)},onMoveNextRequest:function(){N((b+1)%h.length)},wrapperClassName:\"image-gallery__lightbox\"}))}function ct(e){return\"string\"==typeof e?e:e.src}function st(e,t,n){return\"repeat(\"+(e||\"auto-fit\")+\", minmax(\"+(mt(t)||0)+\", \"+(mt(n)||\"1fr\")+\"))\"}function mt(e){return e?e+\"px\":void 0}var dt=[\"className\",\"disabled\",\"icon\",\"iconSize\",\"iconAlignment\",\"onBlur\",\"onFocus\",\"size\"];function ut(a){var i,r,o=a.className,l=a.disabled,c=a.icon,s=a.iconSize,m=void 0===s?\"md\":s,d=a.iconAlignment,v=void 0===d?\"right\":d,p=a.onBlur,f=a.onFocus,g=a.size,w=h(a,dt),y=n(!1),E=y[0],b=y[1];return t.createElement(\"div\",{className:e(\"input-wrapper\",(i={},i[\"input-wrapper--\"+g]=g,i),(r={},r[\"input-wrapper--icon-\"+v]=c&&v,r),{focused:E,disabled:l},o)},t.createElement(\"input\",u({className:\"input-wrapper__input\",disabled:l,onBlur:function(e){b(!1),p&&p(e)},onFocus:function(e){b(!0),f&&f(e)}},w)),c&&t.createElement(x,{className:\"input-wrapper__icon\",name:c,size:m}))}function vt(n){var a,i=n.children,r=n.className,o=n.dialogClassName,l=n.footer,c=n.footerAlignment,s=void 0===c?\"left\":c,m=n.hideHeader,d=void 0!==m&&m,u=n.id,v=n.onRequestClose,h=void 0===v?function(){}:v,p=n.open,f=void 0!==p&&p,g=n.rootElement,w=void 0===g?\"body\":g,y=n.theme,E=n.title;return fe(f,!0),f?t.createElement(ne,{rootElement:w},t.createElement(\"div\",{className:e(\"modal\",{\"modal--open\":f},r),id:u,role:\"dialog\",tabIndex:-1,\"data-theme\":y},t.createElement(\"div\",{className:e(\"modal__dialog\",o),role:\"document\"},t.createElement(\"div\",{className:\"modal__content\"},!d&&t.createElement(\"div\",{className:\"modal__header\"},t.createElement(\"div\",{className:\"modal__title h5\"},E),t.createElement(te,{className:\"modal__close-button\",icon:\"close\",iconAlignment:\"only\",onClick:h,size:\"md\",style:\"unstyled\"})),t.createElement(\"div\",{className:\"modal__body\"},i),l&&t.createElement(\"div\",{className:e(\"modal__footer\",(a={},a[\"modal__footer--\"+s+\"-aligned\"]=s,a))},l))))):null}var ht=[\"backgroundColor\",\"children\",\"className\",\"size\",\"style\",\"theme\",\"transparent\"];function pt(n){var a,i=n.backgroundColor,r=n.children,o=n.className,l=n.size,c=void 0===l?\"md\":l,s=n.style,m=n.theme,d=n.transparent,v=void 0!==d&&d,p=h(n,ht);return t.createElement(\"div\",u({className:e(\"page-banner\",(a={},a[\"page-banner--\"+c]=c,a),{\"page-banner--transparent\":v},o),\"data-theme\":m,style:u({backgroundColor:i},s)},p),r)}function ft(n){for(var a=n.className,i=n.currentPage,r=void 0===i?0:i,o=n.onPageChange,l=void 0===o?function(){}:o,c=n.totalPages,s=[],m=function(n){s.push(t.createElement(te,{className:e({active:r===n}),key:n,onClick:function(){return l(n)},size:\"md\",style:\"outline\"},n+1))},d=0;d=c-1,icon:\"chevron_right\",iconAlignment:\"only\",onClick:function(){return l(r+1)},size:\"md\",style:\"outline\"}))}var gt=[\"children\",\"className\",\"gutters\"];function wt(n){var a,i=n.children,r=n.className,o=n.gutters,l=h(n,gt);return t.createElement(\"div\",u({className:e(\"row\",(a={},a[\"gutters-\"+o]=o,a),r)},l),i)}var yt=[\"className\",\"debounceRate\",\"onChange\",\"onSearch\",\"placeholder\"];function Et(n){var a=n.className,i=n.debounceRate,o=void 0===i?500:i,l=n.onChange,c=n.onSearch,s=n.placeholder,m=h(n,yt),d=r(K(function(e){c&&c(e)},o),[o,c]);return t.createElement(ut,u({\"aria-label\":\"Search\",className:e(\"search-input\",a),icon:\"search\",iconAlignment:\"left\",onChange:function(e){l&&l(e),d(e.target.value)},onKeyDown:H(function(e){e.currentTarget.blur()}),placeholder:s||\"Search\"},m))}function bt(i){var r=i.animated,o=void 0===r||r,l=i.children,c=i.className,s=i.hideOverlay,m=void 0!==s&&s,d=i.location,u=i.rootElement,v=void 0===u?\"body\":u,h=i.theme,p=n(!1),f=p[0],g=p[1];return fe(f,!0),a(function(){g(!1)},[d]),t.createElement(t.Fragment,null,t.createElement(te,{\"aria-label\":f?\"Close\":\"Open\",className:\"sidedrawer__button\",icon:f?\"close\":\"menu\",iconAlignment:\"only\",iconSize:\"md\",onClick:function(){return g(!f)},size:\"intrinsic\",style:\"unstyled\"}),t.createElement(ne,{rootElement:v},t.createElement(\"div\",{className:e(\"sidedrawer\",{\"sidedrawer--open\":f,\"sidedrawer--closed\":!f},{\"sidedrawer--animated\":o},c),\"data-theme\":h},!m&&t.createElement(je,{className:\"sidedrawer__overlay\",onClick:function(){return g(!1)}}),t.createElement(\"div\",{className:\"sidedrawer__container\"},l))))}var Nt=[\"children\",\"className\",\"link\",\"LinkElementType\",\"primaryColor\",\"secondaryColor\",\"url\"];function xt(n){var a=n.children,i=n.className,r=n.link,o=n.LinkElementType,l=void 0===o?\"a\":o,c=n.primaryColor,s=n.secondaryColor,m=n.url,d=h(n,Nt),v=\"string\"==typeof r?re[r]:r,p=c||v.color;return t.createElement(f,{as:l,external:v.external||!0,to:m||v.to,unstyled:!0},t.createElement(te,u({className:e(\"social-button\",v.id,i),customStyles:{\"--btn-color-primary\":p,\"--btn-color-secondary\":s,\"--btn-color-emphasis\":p},icon:t.createElement(ie,{\"aria-hidden\":!0,icon:v.icon,innerPadding:0,size:\"100%\"}),iconAlignment:\"left\",tabIndex:-1},d),a||v.name))}var kt=[\"alignItems\",\"children\",\"direction\",\"justifyContent\",\"reversed\",\"wrap\"];function Ct(n){var a,i=n.alignItems,r=n.children,o=n.direction,l=void 0===o?\"column\":o,c=n.justifyContent,s=n.reversed,m=void 0!==s&&s,d=n.wrap,v=void 0!==d&&d,p=h(n,kt);return t.createElement(\"div\",u({className:e(\"display-flex\",{\"flex-row\":\"row\"===l&&!m,\"flex-row-reverse\":\"row\"===l&&m,\"flex-column\":\"column\"===l&&!m,\"flex-column-reverse\":\"column\"===l&&m,\"flex-wrap\":v},(a={},a[\"justify-content-\"+c]=c,a[\"align-items-\"+i]=i,a))},p),r)}var zt=[\"as\",\"bold\",\"children\",\"className\",\"color\",\"italic\",\"marginBottom\",\"marginTop\",\"size\"];function _t(n){var a,i,r,o,l=n.as,c=n.bold,s=n.children,m=n.className,d=n.color,v=n.italic,p=n.marginBottom,f=n.marginTop,g=n.size,w=h(n,zt);return t.createElement(null!=l?l:\"p\",u({className:e((a={},a[\"font-\"+g]=g,a),(i={},i[\"color-\"+d]=d,i),(r={},r[\"margin-top-\"+f]=f,r),(o={},o[\"margin-bottom-\"+p]=p,o),m)},w),c?t.createElement(\"b\",null,v?t.createElement(\"em\",null,s):s):v?t.createElement(\"em\",null,s):s)}var Lt,St,Mt,Tt=[\"animated\",\"animation\",\"as\",\"children\",\"className\",\"image\",\"index\",\"ref\",\"rounded\",\"shadow\"];function At(i){var r,l=i.animated,c=void 0!==l&&l,s=i.animation,m=void 0===s?\"fade-translate-in\":s,d=i.as,v=i.children,p=i.className,f=i.image,g=i.index,w=void 0===g?-1:g,y=i.rounded,E=void 0===y||y,b=i.shadow,N=void 0===b||b,x=h(i,Tt),k=null!=d?d:\"a\",C=\"object\"==typeof f?f:{src:f},z=o(null),_=n(!1),L=_[0],S=_[1];return a(function(){var e;return c&&L&&(e=setTimeout(function(){z.current&&(z.current.style.animation=\"none\")},600)),function(){e&&clearTimeout(e)}},[c,L,z]),t.createElement(k,u({},x,{className:e(\"thumbnail\",(r={\"animation-short\":c&&L},r[\"animation-delay-\"+(w+1)]=c&&L&&w>=0,r[m]=c&&L,r),{rounded:E,shadow:N},p),ref:z}),f&&t.createElement(ot,u({},C,{onLoaded:function(){S(!0),\"object\"==typeof f&&f.onLoaded&&f.onLoaded()}})),v)}function Ht(n){var a,i,r,o,l,c,s=n.as,m=n.bold,d=n.children,u=n.className,v=n.color,h=n.display,p=n.eyebrow,f=n.italic,g=n.marginBottom,w=n.marginTop,y=n.nowrap,E=n.size,b=n.subtitle,N=n.weight;return t.createElement(null!=s?s:\"div\",{className:e((a={},a[\"h\"+E]=!h&&void 0!==E,a),(i={},i[\"display-\"+E]=h&&void 0!==E,i),(r={},r[\"font-weight-\"+N]=void 0!==N,r),(o={},o[\"color-\"+v]=v,o),(l={},l[\"margin-top-\"+w]=w,l),(c={},c[\"margin-bottom-\"+g]=g,c),{\"text-nowrap\":y},{subtitle:b},{eyebrow:p},u)},m?t.createElement(\"b\",null,f?t.createElement(\"em\",null,d):d):f?t.createElement(\"em\",null,d):d)}!function(e){e[e.sm=576]=\"sm\",e[e.md=768]=\"md\",e[e.lg=992]=\"lg\",e[e.xl=1200]=\"xl\"}(Lt||(Lt={})),function(e){e[e.transparent=0]=\"transparent\",e[e.subtle=.12]=\"subtle\",e[e.disabled=.38]=\"disabled\",e[e.inactive=.62]=\"inactive\",e[e.scrim=.54]=\"scrim\",e[e.active=.87]=\"active\",e[e.opaque=1]=\"opaque\"}(St||(St={})),function(e){e[e.dropdown=1e3]=\"dropdown\",e[e.sticky=1020]=\"sticky\",e[e.fixed=1030]=\"fixed\",e[e.overlay=1040]=\"overlay\",e[e.menu=1050]=\"menu\",e[e.modal=1060]=\"modal\",e[e.popover=1070]=\"popover\",e[e.tooltip=1080]=\"tooltip\",e[e.toast=1090]=\"toast\",e[e.max=1100]=\"max\"}(Mt||(Mt={}));export{b as AppFooter,Ce as AppHeader,_e as AppStoreBadge,Me as AppUtilityBar,Ae as Badge,Pe as BadgeGroup,Lt as Breakpoint,te as Button,Ve as ButtonGroup,je as ClickableDiv,Fe as CodeBlock,Oe as Col,Ze as ContactForm,Ye as Container,Ke as CookieConsent,nt as EmbeddedTwitch,Xe as EmbeddedVideo,it as EmbeddedYouTube,x as Icon,lt as ImageGallery,ut as Input,f as Link,$e as LoadingSpinner,E as Logo,vt as Modal,X as NavBar,ke as NavMenu,St as Opacity,pt as PageBanner,ft as Pagination,ot as ProgressiveImage,ne as ReactPortal,wt as Row,Et as SearchInput,bt as SideDrawer,xt as SocialButton,ie as SocialIcon,oe as SocialNavLinks,Ct as Stack,_t as Text,be as ThemeContext,At as Thumbnail,Ht as Title,Mt as ZIndex,M as bindEvent,I as clamp,C as contrastRatio,K as debounce,j as distance,H as enterKeyHandler,L as getDisplayName,R as getScrollbarWidth,pe as getStorageValue,S as getWrappedDisplayName,Z as hasHorizontalScroll,W as hasVerticalScroll,z as hexToRgb,U as highlight,Y as highlightAll,G as highlightAllUnder,J as highlightElement,B as inverseLerp,D as isPathActive,A as keyHandler,V as lerp,w as logo,k as luminance,F as omit,_ as rgbToHex,O as scrollToTop,q as smoothdamp,g as socialIcons,re as socialLinks,$ as throttle,P as toTitleCase,T as unbindEvent,se as useBreakpoint,me as useBreakpointMax,de as useElementSize,ve as useLoaded,ue as useLoading,he as useLocalStorage,le as useMediaQuery,fe as useModalOverlay,ge as useMounted,we as usePagination,ye as useSearch,Ee as useSmoothDamp,Ne as useTheme,xe as useThemedFavicon};\n//# sourceMappingURL=index.modern.js.map\n","/*!\n Copyright (c) 2015 Jed Watson.\n Based on code that is Copyright 2013-2015, Facebook, Inc.\n All rights reserved.\n*/\n/* global define */\n\n(function () {\n\t'use strict';\n\n\tvar canUseDOM = !!(\n\t\ttypeof window !== 'undefined' &&\n\t\twindow.document &&\n\t\twindow.document.createElement\n\t);\n\n\tvar ExecutionEnvironment = {\n\n\t\tcanUseDOM: canUseDOM,\n\n\t\tcanUseWorkers: typeof Worker !== 'undefined',\n\n\t\tcanUseEventListeners:\n\t\t\tcanUseDOM && !!(window.addEventListener || window.attachEvent),\n\n\t\tcanUseViewport: canUseDOM && !!window.screen\n\n\t};\n\n\tif (typeof define === 'function' && typeof define.amd === 'object' && define.amd) {\n\t\tdefine(function () {\n\t\t\treturn ExecutionEnvironment;\n\t\t});\n\t} else if (typeof module !== 'undefined' && module.exports) {\n\t\tmodule.exports = ExecutionEnvironment;\n\t} else {\n\t\twindow.ExecutionEnvironment = ExecutionEnvironment;\n\t}\n\n}());\n","\"use strict\";\n\nmodule.exports = Object.assign;\n//# sourceMappingURL=object-assign.js.map","import { distance, Icon, inverseLerp, lerp, Link, SocialIcon, useSmoothDamp } from '@zigurous/react-components'; // prettier-ignore\nimport { Link as GatsbyLink } from 'gatsby';\nimport React, { useEffect, useRef } from 'react';\nimport type { LinkType } from '../types';\n\nconst settings = {\n minSize: 44,\n maxSize: 64,\n minFontSize: 20,\n maxFontSize: 30,\n distance: 150,\n smoothTime: 50,\n};\n\nexport interface DockItemProps {\n asButton?: boolean;\n external?: boolean;\n link: LinkType;\n mouseState: { x: number; y: number; entered: boolean };\n onClick?: () => void;\n}\n\nexport default function DockItem({\n asButton = false,\n external = false,\n link,\n mouseState,\n onClick,\n}: DockItemProps) {\n const ref = useRef(null);\n const targetSizeRef = useRef(settings.minSize);\n const size = useSmoothDamp(\n settings.minSize,\n targetSizeRef,\n settings.smoothTime,\n );\n const iconSize = size * 0.45;\n\n useEffect(() => {\n if (!ref.current) return;\n if (mouseState.entered) {\n targetSizeRef.current = getSize(ref.current, mouseState.x, mouseState.y);\n } else {\n targetSizeRef.current = settings.minSize;\n }\n }, [ref, mouseState]);\n\n return (\n \n {asButton ? (\n \n ) : (\n \n {link.icon && }\n {link.socialIcon && (\n \n )}\n \n )}\n
{link.name}
\n \n );\n}\n\nfunction getSize(el: HTMLDivElement, mouseX: number, mouseY: number) {\n const rect = el.getBoundingClientRect();\n const d = distance(\n mouseX,\n mouseY,\n rect.left + rect.width / 2,\n rect.top + rect.height / 2,\n );\n return lerp(\n settings.minSize,\n settings.maxSize,\n inverseLerp(settings.distance, 0, d),\n );\n}\n","import '../styles/dock.css';\nimport { Theme, useMediaQuery } from '@zigurous/react-components'; // prettier-ignore\nimport React, { useEffect, useRef, useState } from 'react';\nimport DockItem from './DockItem';\nimport { dockLinks, socialLinks } from '../links';\nimport type { LinkType } from '../types';\n\nexport interface DockProps {\n theme: Theme;\n toggleTheme: () => void;\n secondaryLinks?: LinkType[];\n}\n\nexport default function Dock({\n theme,\n toggleTheme,\n secondaryLinks,\n}: DockProps) {\n const ref = useRef(null);\n const canHover = useMediaQuery('(hover: hover)');\n const [mouseState, setMouseState] = useState({ x: 0, y: 0, entered: false });\n\n useEffect(() => {\n if (!ref.current) return;\n\n const mouseleave = (e: MouseEvent) => {\n setMouseState({ x: e.clientX, y: e.clientY, entered: false });\n };\n const mousemove = (e: MouseEvent) => {\n setMouseState({ x: e.clientX, y: e.clientY, entered: true });\n };\n\n if (canHover) {\n ref.current.addEventListener('mousemove', mousemove);\n ref.current.addEventListener('mouseleave', mouseleave);\n }\n\n return () => {\n if (ref.current) {\n ref.current.removeEventListener('mousemove', mousemove);\n ref.current.removeEventListener('mouseleave', mouseleave);\n }\n };\n }, [ref, canHover]);\n\n return (\n
\n
\n
\n {dockLinks.map(link => (\n \n ))}\n
\n
\n {socialLinks.map(link => (\n \n ))}\n
\n
\n {\n if (!document) return;\n const e = new Event('previous_slide');\n document.dispatchEvent(e);\n }}\n />\n {\n if (!document) return;\n const e = new Event('next_slide');\n document.dispatchEvent(e);\n }}\n />\n
\n
\n \n
\n
\n {secondaryLinks && (\n
\n {secondaryLinks.map(link => (\n \n ))}\n
\n )}\n
\n );\n}\n","import '../styles/shadow-button.css';\nimport { Button, ButtonProps } from '@zigurous/react-components';\nimport classNames from 'classnames';\nimport React from 'react';\n\nexport type ShadowButtonProps = {\n children?: React.ReactNode;\n className?: string;\n} & ButtonProps;\n\nexport default function ShadowButton({\n children,\n className,\n ...rest\n}: ShadowButtonProps) {\n return (\n \n {children}\n \n );\n}\n","import '../styles/slide.css';\nimport { Link, ProgressiveImage } from '@zigurous/react-components';\nimport classNames from 'classnames';\nimport { Link as GatsbyLink } from 'gatsby';\nimport React from 'react';\nimport ShadowButton from './ShadowButton';\nimport type { SlideData } from '../types';\n\nexport interface SlideProps {\n slide: SlideData;\n}\n\nexport default function Slide({ slide }: SlideProps) {\n const offline = typeof navigator !== 'undefined' && !navigator.onLine;\n const projectPath = `/${slide.category}/${slide.id}`;\n return (\n
\n
\n \n \n \n
\n
\n
\n

{slide.date}

\n

{slide.title}

\n

\n {slide.description_short || slide.description}\n

\n \n More Details\n \n
\n
\n
\n );\n}\n","import '../styles/gallery.css';\nimport { useMediaQuery } from '@zigurous/react-components';\nimport classNames from 'classnames';\nimport { navigate } from 'gatsby';\nimport React, { useCallback, useEffect } from 'react';\nimport Slide from './Slide';\nimport type { SlideData } from '../types';\nimport { getSessionIndex, setSessionIndex } from '../utils/session';\n\nexport interface GalleryProps {\n category: string;\n location: Location;\n slides: SlideData[];\n}\n\nexport default function Gallery({\n category,\n location,\n slides = [],\n}: GalleryProps) {\n const vertical = useMediaQuery('(max-width: 1365px)');\n\n const urlParams = new URLSearchParams(location?.search);\n const slideIndex =\n (urlParams.has('index')\n ? Number.parseInt(urlParams.get('index')!) || 0\n : getSessionIndex(category)) % slides.length;\n\n const currentSlide =\n slideIndex >= 0 && slideIndex < slides.length ? slides[slideIndex] : null;\n\n const setSlideIndex = useCallback(\n (index: number) => {\n if (index >= slides.length) index = 0;\n if (index < 0) index = slides.length - 1;\n setSessionIndex(category, index);\n navigate(`/${category}?index=${index}`, { replace: true });\n },\n [category, slides, slideIndex],\n );\n\n useEffect(() => {\n if (!document) return;\n const prev = () => setSlideIndex(slideIndex - 1);\n const next = () => setSlideIndex(slideIndex + 1);\n document.addEventListener('previous_slide', prev);\n document.addEventListener('next_slide', next);\n return () => {\n document.removeEventListener('previous_slide', prev);\n document.removeEventListener('next_slide', next);\n };\n }, [slideIndex]);\n\n return (\n \n setSlideIndex(slideIndex - 1)}\n >\n \n \n \n \n
\n {currentSlide && }\n
\n setSlideIndex(slideIndex + 1)}\n >\n \n \n \n \n \n );\n}\n","export function getSessionIndex(category: string): number {\n if (category && typeof sessionStorage !== 'undefined') {\n const index = sessionStorage.getItem(`${category}-slide`);\n return index ? Number.parseInt(index) : 0;\n } else {\n return 0;\n }\n}\n\nexport function setSessionIndex(category: string, slideIndex: number): void {\n if (category && typeof sessionStorage !== 'undefined') {\n sessionStorage.setItem(`${category}-slide`, String(slideIndex));\n }\n}\n","import '../styles/grid-3d.css';\nimport React from 'react';\n\nexport interface Grid3DProps {\n width?: number;\n height?: number;\n}\n\nexport default function Grid3D({ width = 30, height = 30 }: Grid3DProps) {\n const cells = [];\n for (let i = 0; i < width * height; i++) {\n cells.push(
);\n }\n return (\n \n {cells.map(cell => cell)}\n
\n );\n}\n","import '../styles/logo.css';\nimport { Link } from '@zigurous/react-components';\nimport classNames from 'classnames';\nimport { Link as GatsbyLink } from 'gatsby';\nimport React from 'react';\n\nexport interface LogoProps {\n rounded?: boolean;\n size?: number;\n}\n\nexport default function Logo({ rounded = false, size = 48 }: LogoProps) {\n return (\n \n \n
\n \n \n \n \n \n
\n );\n}\n","import '../styles/menu-gallery.css';\nimport { Button, Link, Thumbnail, useModalOverlay } from '@zigurous/react-components'; // prettier-ignore\nimport classNames from 'classnames';\nimport { Link as GatsbyLink, graphql, StaticQuery } from 'gatsby';\nimport React from 'react';\nimport { headerLinks } from '../links';\nimport type { ProjectJson } from '../types';\n\nexport interface MenuData {\n games: ProjectJson;\n websites: ProjectJson;\n art: ProjectJson;\n tech: ProjectJson;\n presentations: ProjectJson;\n}\n\nexport interface MenuGalleryProps {\n open: boolean;\n onRequestClose: () => void;\n}\n\nexport default function MenuGallery({\n open = false,\n onRequestClose = () => {},\n}: MenuGalleryProps) {\n useModalOverlay(open, true);\n return (\n \n \n
    \n {open && (\n \n headerLinks.map(link => {\n const gallery: ProjectJson = data[\n link.id as keyof typeof data\n ] || { nodes: [] };\n return (\n
  • \n \n {link.name}\n \n \n
    \n {gallery.nodes.map((item, index) => (\n \n ))}\n
    \n
  • \n );\n })\n }\n />\n )}\n
\n \n \n );\n}\n\nconst query = graphql`\n query Menu {\n games: allGamesJson {\n nodes {\n id: jsonId\n category\n title\n image {\n sharp: childImageSharp {\n original {\n src\n width\n height\n }\n }\n }\n imageAltText\n imageBorder\n }\n }\n websites: allWebsitesJson {\n nodes {\n id: jsonId\n category\n title\n image {\n sharp: childImageSharp {\n original {\n src\n width\n height\n }\n }\n }\n imageAltText\n imageBorder\n }\n }\n art: allArtJson {\n nodes {\n id: jsonId\n category\n title\n image {\n sharp: childImageSharp {\n original {\n src\n width\n height\n }\n }\n }\n imageAltText\n imageBorder\n }\n }\n tech: allTechJson {\n nodes {\n id: jsonId\n category\n title\n image {\n sharp: childImageSharp {\n original {\n src\n width\n height\n }\n }\n }\n imageAltText\n imageBorder\n }\n }\n presentations: allPresentationsJson {\n nodes {\n id: jsonId\n category\n title\n image {\n sharp: childImageSharp {\n original {\n src\n width\n height\n }\n }\n }\n imageAltText\n imageBorder\n }\n }\n }\n`;\n","import '../styles/header.css';\nimport { Button, NavBar } from '@zigurous/react-components';\nimport { Link as GatsbyLink, navigate } from 'gatsby';\nimport React, { useState } from 'react';\nimport Logo from './Logo';\nimport MenuGallery from './MenuGallery';\nimport { headerLinks } from '../links';\n\nexport interface HeaderProps {\n location?: Location | null;\n pageTitle?: string;\n}\n\nexport default function Header({\n location = typeof window !== 'undefined' ? window.location : null,\n pageTitle,\n}: HeaderProps) {\n const [isMenuOpen, setIsMenuOpen] = useState(false);\n return (\n <>\n
\n
\n \n \n {pageTitle && (\n {\n const link = headerLinks.find(link => link.name === pageTitle);\n if (link) {\n navigate(link.to);\n } else {\n setIsMenuOpen(true);\n }\n }}\n style=\"unstyled\"\n >\n {pageTitle}\n \n )}\n setIsMenuOpen(!isMenuOpen)}\n >\n {isMenuOpen ? (\n \n \n \n ) : (\n \n \n \n )}\n \n
\n
\n setIsMenuOpen(false)}\n />\n \n );\n}\n","import PropTypes from 'prop-types';\nimport withSideEffect from 'react-side-effect';\nimport isEqual from 'react-fast-compare';\nimport React from 'react';\nimport objectAssign from 'object-assign';\n\nvar ATTRIBUTE_NAMES = {\n BODY: \"bodyAttributes\",\n HTML: \"htmlAttributes\",\n TITLE: \"titleAttributes\"\n};\n\nvar TAG_NAMES = {\n BASE: \"base\",\n BODY: \"body\",\n HEAD: \"head\",\n HTML: \"html\",\n LINK: \"link\",\n META: \"meta\",\n NOSCRIPT: \"noscript\",\n SCRIPT: \"script\",\n STYLE: \"style\",\n TITLE: \"title\"\n};\n\nvar VALID_TAG_NAMES = Object.keys(TAG_NAMES).map(function (name) {\n return TAG_NAMES[name];\n});\n\nvar TAG_PROPERTIES = {\n CHARSET: \"charset\",\n CSS_TEXT: \"cssText\",\n HREF: \"href\",\n HTTPEQUIV: \"http-equiv\",\n INNER_HTML: \"innerHTML\",\n ITEM_PROP: \"itemprop\",\n NAME: \"name\",\n PROPERTY: \"property\",\n REL: \"rel\",\n SRC: \"src\",\n TARGET: \"target\"\n};\n\nvar REACT_TAG_MAP = {\n accesskey: \"accessKey\",\n charset: \"charSet\",\n class: \"className\",\n contenteditable: \"contentEditable\",\n contextmenu: \"contextMenu\",\n \"http-equiv\": \"httpEquiv\",\n itemprop: \"itemProp\",\n tabindex: \"tabIndex\"\n};\n\nvar HELMET_PROPS = {\n DEFAULT_TITLE: \"defaultTitle\",\n DEFER: \"defer\",\n ENCODE_SPECIAL_CHARACTERS: \"encodeSpecialCharacters\",\n ON_CHANGE_CLIENT_STATE: \"onChangeClientState\",\n TITLE_TEMPLATE: \"titleTemplate\"\n};\n\nvar HTML_TAG_MAP = Object.keys(REACT_TAG_MAP).reduce(function (obj, key) {\n obj[REACT_TAG_MAP[key]] = key;\n return obj;\n}, {});\n\nvar SELF_CLOSING_TAGS = [TAG_NAMES.NOSCRIPT, TAG_NAMES.SCRIPT, TAG_NAMES.STYLE];\n\nvar HELMET_ATTRIBUTE = \"data-react-helmet\";\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) {\n return typeof obj;\n} : function (obj) {\n return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n};\n\nvar classCallCheck = function (instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n};\n\nvar createClass = function () {\n function defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n }\n\n return function (Constructor, protoProps, staticProps) {\n if (protoProps) defineProperties(Constructor.prototype, protoProps);\n if (staticProps) defineProperties(Constructor, staticProps);\n return Constructor;\n };\n}();\n\nvar _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n};\n\nvar inherits = function (subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass);\n }\n\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n enumerable: false,\n writable: true,\n configurable: true\n }\n });\n if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass;\n};\n\nvar objectWithoutProperties = function (obj, keys) {\n var target = {};\n\n for (var i in obj) {\n if (keys.indexOf(i) >= 0) continue;\n if (!Object.prototype.hasOwnProperty.call(obj, i)) continue;\n target[i] = obj[i];\n }\n\n return target;\n};\n\nvar possibleConstructorReturn = function (self, call) {\n if (!self) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self;\n};\n\nvar encodeSpecialCharacters = function encodeSpecialCharacters(str) {\n var encode = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n\n if (encode === false) {\n return String(str);\n }\n\n return String(str).replace(/&/g, \"&\").replace(//g, \">\").replace(/\"/g, \""\").replace(/'/g, \"'\");\n};\n\nvar getTitleFromPropsList = function getTitleFromPropsList(propsList) {\n var innermostTitle = getInnermostProperty(propsList, TAG_NAMES.TITLE);\n var innermostTemplate = getInnermostProperty(propsList, HELMET_PROPS.TITLE_TEMPLATE);\n\n if (innermostTemplate && innermostTitle) {\n // use function arg to avoid need to escape $ characters\n return innermostTemplate.replace(/%s/g, function () {\n return Array.isArray(innermostTitle) ? innermostTitle.join(\"\") : innermostTitle;\n });\n }\n\n var innermostDefaultTitle = getInnermostProperty(propsList, HELMET_PROPS.DEFAULT_TITLE);\n\n return innermostTitle || innermostDefaultTitle || undefined;\n};\n\nvar getOnChangeClientState = function getOnChangeClientState(propsList) {\n return getInnermostProperty(propsList, HELMET_PROPS.ON_CHANGE_CLIENT_STATE) || function () {};\n};\n\nvar getAttributesFromPropsList = function getAttributesFromPropsList(tagType, propsList) {\n return propsList.filter(function (props) {\n return typeof props[tagType] !== \"undefined\";\n }).map(function (props) {\n return props[tagType];\n }).reduce(function (tagAttrs, current) {\n return _extends({}, tagAttrs, current);\n }, {});\n};\n\nvar getBaseTagFromPropsList = function getBaseTagFromPropsList(primaryAttributes, propsList) {\n return propsList.filter(function (props) {\n return typeof props[TAG_NAMES.BASE] !== \"undefined\";\n }).map(function (props) {\n return props[TAG_NAMES.BASE];\n }).reverse().reduce(function (innermostBaseTag, tag) {\n if (!innermostBaseTag.length) {\n var keys = Object.keys(tag);\n\n for (var i = 0; i < keys.length; i++) {\n var attributeKey = keys[i];\n var lowerCaseAttributeKey = attributeKey.toLowerCase();\n\n if (primaryAttributes.indexOf(lowerCaseAttributeKey) !== -1 && tag[lowerCaseAttributeKey]) {\n return innermostBaseTag.concat(tag);\n }\n }\n }\n\n return innermostBaseTag;\n }, []);\n};\n\nvar getTagsFromPropsList = function getTagsFromPropsList(tagName, primaryAttributes, propsList) {\n // Calculate list of tags, giving priority innermost component (end of the propslist)\n var approvedSeenTags = {};\n\n return propsList.filter(function (props) {\n if (Array.isArray(props[tagName])) {\n return true;\n }\n if (typeof props[tagName] !== \"undefined\") {\n warn(\"Helmet: \" + tagName + \" should be of type \\\"Array\\\". Instead found type \\\"\" + _typeof(props[tagName]) + \"\\\"\");\n }\n return false;\n }).map(function (props) {\n return props[tagName];\n }).reverse().reduce(function (approvedTags, instanceTags) {\n var instanceSeenTags = {};\n\n instanceTags.filter(function (tag) {\n var primaryAttributeKey = void 0;\n var keys = Object.keys(tag);\n for (var i = 0; i < keys.length; i++) {\n var attributeKey = keys[i];\n var lowerCaseAttributeKey = attributeKey.toLowerCase();\n\n // Special rule with link tags, since rel and href are both primary tags, rel takes priority\n if (primaryAttributes.indexOf(lowerCaseAttributeKey) !== -1 && !(primaryAttributeKey === TAG_PROPERTIES.REL && tag[primaryAttributeKey].toLowerCase() === \"canonical\") && !(lowerCaseAttributeKey === TAG_PROPERTIES.REL && tag[lowerCaseAttributeKey].toLowerCase() === \"stylesheet\")) {\n primaryAttributeKey = lowerCaseAttributeKey;\n }\n // Special case for innerHTML which doesn't work lowercased\n if (primaryAttributes.indexOf(attributeKey) !== -1 && (attributeKey === TAG_PROPERTIES.INNER_HTML || attributeKey === TAG_PROPERTIES.CSS_TEXT || attributeKey === TAG_PROPERTIES.ITEM_PROP)) {\n primaryAttributeKey = attributeKey;\n }\n }\n\n if (!primaryAttributeKey || !tag[primaryAttributeKey]) {\n return false;\n }\n\n var value = tag[primaryAttributeKey].toLowerCase();\n\n if (!approvedSeenTags[primaryAttributeKey]) {\n approvedSeenTags[primaryAttributeKey] = {};\n }\n\n if (!instanceSeenTags[primaryAttributeKey]) {\n instanceSeenTags[primaryAttributeKey] = {};\n }\n\n if (!approvedSeenTags[primaryAttributeKey][value]) {\n instanceSeenTags[primaryAttributeKey][value] = true;\n return true;\n }\n\n return false;\n }).reverse().forEach(function (tag) {\n return approvedTags.push(tag);\n });\n\n // Update seen tags with tags from this instance\n var keys = Object.keys(instanceSeenTags);\n for (var i = 0; i < keys.length; i++) {\n var attributeKey = keys[i];\n var tagUnion = objectAssign({}, approvedSeenTags[attributeKey], instanceSeenTags[attributeKey]);\n\n approvedSeenTags[attributeKey] = tagUnion;\n }\n\n return approvedTags;\n }, []).reverse();\n};\n\nvar getInnermostProperty = function getInnermostProperty(propsList, property) {\n for (var i = propsList.length - 1; i >= 0; i--) {\n var props = propsList[i];\n\n if (props.hasOwnProperty(property)) {\n return props[property];\n }\n }\n\n return null;\n};\n\nvar reducePropsToState = function reducePropsToState(propsList) {\n return {\n baseTag: getBaseTagFromPropsList([TAG_PROPERTIES.HREF, TAG_PROPERTIES.TARGET], propsList),\n bodyAttributes: getAttributesFromPropsList(ATTRIBUTE_NAMES.BODY, propsList),\n defer: getInnermostProperty(propsList, HELMET_PROPS.DEFER),\n encode: getInnermostProperty(propsList, HELMET_PROPS.ENCODE_SPECIAL_CHARACTERS),\n htmlAttributes: getAttributesFromPropsList(ATTRIBUTE_NAMES.HTML, propsList),\n linkTags: getTagsFromPropsList(TAG_NAMES.LINK, [TAG_PROPERTIES.REL, TAG_PROPERTIES.HREF], propsList),\n metaTags: getTagsFromPropsList(TAG_NAMES.META, [TAG_PROPERTIES.NAME, TAG_PROPERTIES.CHARSET, TAG_PROPERTIES.HTTPEQUIV, TAG_PROPERTIES.PROPERTY, TAG_PROPERTIES.ITEM_PROP], propsList),\n noscriptTags: getTagsFromPropsList(TAG_NAMES.NOSCRIPT, [TAG_PROPERTIES.INNER_HTML], propsList),\n onChangeClientState: getOnChangeClientState(propsList),\n scriptTags: getTagsFromPropsList(TAG_NAMES.SCRIPT, [TAG_PROPERTIES.SRC, TAG_PROPERTIES.INNER_HTML], propsList),\n styleTags: getTagsFromPropsList(TAG_NAMES.STYLE, [TAG_PROPERTIES.CSS_TEXT], propsList),\n title: getTitleFromPropsList(propsList),\n titleAttributes: getAttributesFromPropsList(ATTRIBUTE_NAMES.TITLE, propsList)\n };\n};\n\nvar rafPolyfill = function () {\n var clock = Date.now();\n\n return function (callback) {\n var currentTime = Date.now();\n\n if (currentTime - clock > 16) {\n clock = currentTime;\n callback(currentTime);\n } else {\n setTimeout(function () {\n rafPolyfill(callback);\n }, 0);\n }\n };\n}();\n\nvar cafPolyfill = function cafPolyfill(id) {\n return clearTimeout(id);\n};\n\nvar requestAnimationFrame = typeof window !== \"undefined\" ? window.requestAnimationFrame && window.requestAnimationFrame.bind(window) || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || rafPolyfill : global.requestAnimationFrame || rafPolyfill;\n\nvar cancelAnimationFrame = typeof window !== \"undefined\" ? window.cancelAnimationFrame || window.webkitCancelAnimationFrame || window.mozCancelAnimationFrame || cafPolyfill : global.cancelAnimationFrame || cafPolyfill;\n\nvar warn = function warn(msg) {\n return console && typeof console.warn === \"function\" && console.warn(msg);\n};\n\nvar _helmetCallback = null;\n\nvar handleClientStateChange = function handleClientStateChange(newState) {\n if (_helmetCallback) {\n cancelAnimationFrame(_helmetCallback);\n }\n\n if (newState.defer) {\n _helmetCallback = requestAnimationFrame(function () {\n commitTagChanges(newState, function () {\n _helmetCallback = null;\n });\n });\n } else {\n commitTagChanges(newState);\n _helmetCallback = null;\n }\n};\n\nvar commitTagChanges = function commitTagChanges(newState, cb) {\n var baseTag = newState.baseTag,\n bodyAttributes = newState.bodyAttributes,\n htmlAttributes = newState.htmlAttributes,\n linkTags = newState.linkTags,\n metaTags = newState.metaTags,\n noscriptTags = newState.noscriptTags,\n onChangeClientState = newState.onChangeClientState,\n scriptTags = newState.scriptTags,\n styleTags = newState.styleTags,\n title = newState.title,\n titleAttributes = newState.titleAttributes;\n\n updateAttributes(TAG_NAMES.BODY, bodyAttributes);\n updateAttributes(TAG_NAMES.HTML, htmlAttributes);\n\n updateTitle(title, titleAttributes);\n\n var tagUpdates = {\n baseTag: updateTags(TAG_NAMES.BASE, baseTag),\n linkTags: updateTags(TAG_NAMES.LINK, linkTags),\n metaTags: updateTags(TAG_NAMES.META, metaTags),\n noscriptTags: updateTags(TAG_NAMES.NOSCRIPT, noscriptTags),\n scriptTags: updateTags(TAG_NAMES.SCRIPT, scriptTags),\n styleTags: updateTags(TAG_NAMES.STYLE, styleTags)\n };\n\n var addedTags = {};\n var removedTags = {};\n\n Object.keys(tagUpdates).forEach(function (tagType) {\n var _tagUpdates$tagType = tagUpdates[tagType],\n newTags = _tagUpdates$tagType.newTags,\n oldTags = _tagUpdates$tagType.oldTags;\n\n\n if (newTags.length) {\n addedTags[tagType] = newTags;\n }\n if (oldTags.length) {\n removedTags[tagType] = tagUpdates[tagType].oldTags;\n }\n });\n\n cb && cb();\n\n onChangeClientState(newState, addedTags, removedTags);\n};\n\nvar flattenArray = function flattenArray(possibleArray) {\n return Array.isArray(possibleArray) ? possibleArray.join(\"\") : possibleArray;\n};\n\nvar updateTitle = function updateTitle(title, attributes) {\n if (typeof title !== \"undefined\" && document.title !== title) {\n document.title = flattenArray(title);\n }\n\n updateAttributes(TAG_NAMES.TITLE, attributes);\n};\n\nvar updateAttributes = function updateAttributes(tagName, attributes) {\n var elementTag = document.getElementsByTagName(tagName)[0];\n\n if (!elementTag) {\n return;\n }\n\n var helmetAttributeString = elementTag.getAttribute(HELMET_ATTRIBUTE);\n var helmetAttributes = helmetAttributeString ? helmetAttributeString.split(\",\") : [];\n var attributesToRemove = [].concat(helmetAttributes);\n var attributeKeys = Object.keys(attributes);\n\n for (var i = 0; i < attributeKeys.length; i++) {\n var attribute = attributeKeys[i];\n var value = attributes[attribute] || \"\";\n\n if (elementTag.getAttribute(attribute) !== value) {\n elementTag.setAttribute(attribute, value);\n }\n\n if (helmetAttributes.indexOf(attribute) === -1) {\n helmetAttributes.push(attribute);\n }\n\n var indexToSave = attributesToRemove.indexOf(attribute);\n if (indexToSave !== -1) {\n attributesToRemove.splice(indexToSave, 1);\n }\n }\n\n for (var _i = attributesToRemove.length - 1; _i >= 0; _i--) {\n elementTag.removeAttribute(attributesToRemove[_i]);\n }\n\n if (helmetAttributes.length === attributesToRemove.length) {\n elementTag.removeAttribute(HELMET_ATTRIBUTE);\n } else if (elementTag.getAttribute(HELMET_ATTRIBUTE) !== attributeKeys.join(\",\")) {\n elementTag.setAttribute(HELMET_ATTRIBUTE, attributeKeys.join(\",\"));\n }\n};\n\nvar updateTags = function updateTags(type, tags) {\n var headElement = document.head || document.querySelector(TAG_NAMES.HEAD);\n var tagNodes = headElement.querySelectorAll(type + \"[\" + HELMET_ATTRIBUTE + \"]\");\n var oldTags = Array.prototype.slice.call(tagNodes);\n var newTags = [];\n var indexToDelete = void 0;\n\n if (tags && tags.length) {\n tags.forEach(function (tag) {\n var newElement = document.createElement(type);\n\n for (var attribute in tag) {\n if (tag.hasOwnProperty(attribute)) {\n if (attribute === TAG_PROPERTIES.INNER_HTML) {\n newElement.innerHTML = tag.innerHTML;\n } else if (attribute === TAG_PROPERTIES.CSS_TEXT) {\n if (newElement.styleSheet) {\n newElement.styleSheet.cssText = tag.cssText;\n } else {\n newElement.appendChild(document.createTextNode(tag.cssText));\n }\n } else {\n var value = typeof tag[attribute] === \"undefined\" ? \"\" : tag[attribute];\n newElement.setAttribute(attribute, value);\n }\n }\n }\n\n newElement.setAttribute(HELMET_ATTRIBUTE, \"true\");\n\n // Remove a duplicate tag from domTagstoRemove, so it isn't cleared.\n if (oldTags.some(function (existingTag, index) {\n indexToDelete = index;\n return newElement.isEqualNode(existingTag);\n })) {\n oldTags.splice(indexToDelete, 1);\n } else {\n newTags.push(newElement);\n }\n });\n }\n\n oldTags.forEach(function (tag) {\n return tag.parentNode.removeChild(tag);\n });\n newTags.forEach(function (tag) {\n return headElement.appendChild(tag);\n });\n\n return {\n oldTags: oldTags,\n newTags: newTags\n };\n};\n\nvar generateElementAttributesAsString = function generateElementAttributesAsString(attributes) {\n return Object.keys(attributes).reduce(function (str, key) {\n var attr = typeof attributes[key] !== \"undefined\" ? key + \"=\\\"\" + attributes[key] + \"\\\"\" : \"\" + key;\n return str ? str + \" \" + attr : attr;\n }, \"\");\n};\n\nvar generateTitleAsString = function generateTitleAsString(type, title, attributes, encode) {\n var attributeString = generateElementAttributesAsString(attributes);\n var flattenedTitle = flattenArray(title);\n return attributeString ? \"<\" + type + \" \" + HELMET_ATTRIBUTE + \"=\\\"true\\\" \" + attributeString + \">\" + encodeSpecialCharacters(flattenedTitle, encode) + \"\" : \"<\" + type + \" \" + HELMET_ATTRIBUTE + \"=\\\"true\\\">\" + encodeSpecialCharacters(flattenedTitle, encode) + \"\";\n};\n\nvar generateTagsAsString = function generateTagsAsString(type, tags, encode) {\n return tags.reduce(function (str, tag) {\n var attributeHtml = Object.keys(tag).filter(function (attribute) {\n return !(attribute === TAG_PROPERTIES.INNER_HTML || attribute === TAG_PROPERTIES.CSS_TEXT);\n }).reduce(function (string, attribute) {\n var attr = typeof tag[attribute] === \"undefined\" ? attribute : attribute + \"=\\\"\" + encodeSpecialCharacters(tag[attribute], encode) + \"\\\"\";\n return string ? string + \" \" + attr : attr;\n }, \"\");\n\n var tagContent = tag.innerHTML || tag.cssText || \"\";\n\n var isSelfClosing = SELF_CLOSING_TAGS.indexOf(type) === -1;\n\n return str + \"<\" + type + \" \" + HELMET_ATTRIBUTE + \"=\\\"true\\\" \" + attributeHtml + (isSelfClosing ? \"/>\" : \">\" + tagContent + \"\");\n }, \"\");\n};\n\nvar convertElementAttributestoReactProps = function convertElementAttributestoReactProps(attributes) {\n var initProps = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n return Object.keys(attributes).reduce(function (obj, key) {\n obj[REACT_TAG_MAP[key] || key] = attributes[key];\n return obj;\n }, initProps);\n};\n\nvar convertReactPropstoHtmlAttributes = function convertReactPropstoHtmlAttributes(props) {\n var initAttributes = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n return Object.keys(props).reduce(function (obj, key) {\n obj[HTML_TAG_MAP[key] || key] = props[key];\n return obj;\n }, initAttributes);\n};\n\nvar generateTitleAsReactComponent = function generateTitleAsReactComponent(type, title, attributes) {\n var _initProps;\n\n // assigning into an array to define toString function on it\n var initProps = (_initProps = {\n key: title\n }, _initProps[HELMET_ATTRIBUTE] = true, _initProps);\n var props = convertElementAttributestoReactProps(attributes, initProps);\n\n return [React.createElement(TAG_NAMES.TITLE, props, title)];\n};\n\nvar generateTagsAsReactComponent = function generateTagsAsReactComponent(type, tags) {\n return tags.map(function (tag, i) {\n var _mappedTag;\n\n var mappedTag = (_mappedTag = {\n key: i\n }, _mappedTag[HELMET_ATTRIBUTE] = true, _mappedTag);\n\n Object.keys(tag).forEach(function (attribute) {\n var mappedAttribute = REACT_TAG_MAP[attribute] || attribute;\n\n if (mappedAttribute === TAG_PROPERTIES.INNER_HTML || mappedAttribute === TAG_PROPERTIES.CSS_TEXT) {\n var content = tag.innerHTML || tag.cssText;\n mappedTag.dangerouslySetInnerHTML = { __html: content };\n } else {\n mappedTag[mappedAttribute] = tag[attribute];\n }\n });\n\n return React.createElement(type, mappedTag);\n });\n};\n\nvar getMethodsForTag = function getMethodsForTag(type, tags, encode) {\n switch (type) {\n case TAG_NAMES.TITLE:\n return {\n toComponent: function toComponent() {\n return generateTitleAsReactComponent(type, tags.title, tags.titleAttributes, encode);\n },\n toString: function toString() {\n return generateTitleAsString(type, tags.title, tags.titleAttributes, encode);\n }\n };\n case ATTRIBUTE_NAMES.BODY:\n case ATTRIBUTE_NAMES.HTML:\n return {\n toComponent: function toComponent() {\n return convertElementAttributestoReactProps(tags);\n },\n toString: function toString() {\n return generateElementAttributesAsString(tags);\n }\n };\n default:\n return {\n toComponent: function toComponent() {\n return generateTagsAsReactComponent(type, tags);\n },\n toString: function toString() {\n return generateTagsAsString(type, tags, encode);\n }\n };\n }\n};\n\nvar mapStateOnServer = function mapStateOnServer(_ref) {\n var baseTag = _ref.baseTag,\n bodyAttributes = _ref.bodyAttributes,\n encode = _ref.encode,\n htmlAttributes = _ref.htmlAttributes,\n linkTags = _ref.linkTags,\n metaTags = _ref.metaTags,\n noscriptTags = _ref.noscriptTags,\n scriptTags = _ref.scriptTags,\n styleTags = _ref.styleTags,\n _ref$title = _ref.title,\n title = _ref$title === undefined ? \"\" : _ref$title,\n titleAttributes = _ref.titleAttributes;\n return {\n base: getMethodsForTag(TAG_NAMES.BASE, baseTag, encode),\n bodyAttributes: getMethodsForTag(ATTRIBUTE_NAMES.BODY, bodyAttributes, encode),\n htmlAttributes: getMethodsForTag(ATTRIBUTE_NAMES.HTML, htmlAttributes, encode),\n link: getMethodsForTag(TAG_NAMES.LINK, linkTags, encode),\n meta: getMethodsForTag(TAG_NAMES.META, metaTags, encode),\n noscript: getMethodsForTag(TAG_NAMES.NOSCRIPT, noscriptTags, encode),\n script: getMethodsForTag(TAG_NAMES.SCRIPT, scriptTags, encode),\n style: getMethodsForTag(TAG_NAMES.STYLE, styleTags, encode),\n title: getMethodsForTag(TAG_NAMES.TITLE, { title: title, titleAttributes: titleAttributes }, encode)\n };\n};\n\nvar Helmet = function Helmet(Component) {\n var _class, _temp;\n\n return _temp = _class = function (_React$Component) {\n inherits(HelmetWrapper, _React$Component);\n\n function HelmetWrapper() {\n classCallCheck(this, HelmetWrapper);\n return possibleConstructorReturn(this, _React$Component.apply(this, arguments));\n }\n\n HelmetWrapper.prototype.shouldComponentUpdate = function shouldComponentUpdate(nextProps) {\n return !isEqual(this.props, nextProps);\n };\n\n HelmetWrapper.prototype.mapNestedChildrenToProps = function mapNestedChildrenToProps(child, nestedChildren) {\n if (!nestedChildren) {\n return null;\n }\n\n switch (child.type) {\n case TAG_NAMES.SCRIPT:\n case TAG_NAMES.NOSCRIPT:\n return {\n innerHTML: nestedChildren\n };\n\n case TAG_NAMES.STYLE:\n return {\n cssText: nestedChildren\n };\n }\n\n throw new Error(\"<\" + child.type + \" /> elements are self-closing and can not contain children. Refer to our API for more information.\");\n };\n\n HelmetWrapper.prototype.flattenArrayTypeChildren = function flattenArrayTypeChildren(_ref) {\n var _babelHelpers$extends;\n\n var child = _ref.child,\n arrayTypeChildren = _ref.arrayTypeChildren,\n newChildProps = _ref.newChildProps,\n nestedChildren = _ref.nestedChildren;\n\n return _extends({}, arrayTypeChildren, (_babelHelpers$extends = {}, _babelHelpers$extends[child.type] = [].concat(arrayTypeChildren[child.type] || [], [_extends({}, newChildProps, this.mapNestedChildrenToProps(child, nestedChildren))]), _babelHelpers$extends));\n };\n\n HelmetWrapper.prototype.mapObjectTypeChildren = function mapObjectTypeChildren(_ref2) {\n var _babelHelpers$extends2, _babelHelpers$extends3;\n\n var child = _ref2.child,\n newProps = _ref2.newProps,\n newChildProps = _ref2.newChildProps,\n nestedChildren = _ref2.nestedChildren;\n\n switch (child.type) {\n case TAG_NAMES.TITLE:\n return _extends({}, newProps, (_babelHelpers$extends2 = {}, _babelHelpers$extends2[child.type] = nestedChildren, _babelHelpers$extends2.titleAttributes = _extends({}, newChildProps), _babelHelpers$extends2));\n\n case TAG_NAMES.BODY:\n return _extends({}, newProps, {\n bodyAttributes: _extends({}, newChildProps)\n });\n\n case TAG_NAMES.HTML:\n return _extends({}, newProps, {\n htmlAttributes: _extends({}, newChildProps)\n });\n }\n\n return _extends({}, newProps, (_babelHelpers$extends3 = {}, _babelHelpers$extends3[child.type] = _extends({}, newChildProps), _babelHelpers$extends3));\n };\n\n HelmetWrapper.prototype.mapArrayTypeChildrenToProps = function mapArrayTypeChildrenToProps(arrayTypeChildren, newProps) {\n var newFlattenedProps = _extends({}, newProps);\n\n Object.keys(arrayTypeChildren).forEach(function (arrayChildName) {\n var _babelHelpers$extends4;\n\n newFlattenedProps = _extends({}, newFlattenedProps, (_babelHelpers$extends4 = {}, _babelHelpers$extends4[arrayChildName] = arrayTypeChildren[arrayChildName], _babelHelpers$extends4));\n });\n\n return newFlattenedProps;\n };\n\n HelmetWrapper.prototype.warnOnInvalidChildren = function warnOnInvalidChildren(child, nestedChildren) {\n if (process.env.NODE_ENV !== \"production\") {\n if (!VALID_TAG_NAMES.some(function (name) {\n return child.type === name;\n })) {\n if (typeof child.type === \"function\") {\n return warn(\"You may be attempting to nest components within each other, which is not allowed. Refer to our API for more information.\");\n }\n\n return warn(\"Only elements types \" + VALID_TAG_NAMES.join(\", \") + \" are allowed. Helmet does not support rendering <\" + child.type + \"> elements. Refer to our API for more information.\");\n }\n\n if (nestedChildren && typeof nestedChildren !== \"string\" && (!Array.isArray(nestedChildren) || nestedChildren.some(function (nestedChild) {\n return typeof nestedChild !== \"string\";\n }))) {\n throw new Error(\"Helmet expects a string as a child of <\" + child.type + \">. Did you forget to wrap your children in braces? ( <\" + child.type + \">{``} ) Refer to our API for more information.\");\n }\n }\n\n return true;\n };\n\n HelmetWrapper.prototype.mapChildrenToProps = function mapChildrenToProps(children, newProps) {\n var _this2 = this;\n\n var arrayTypeChildren = {};\n\n React.Children.forEach(children, function (child) {\n if (!child || !child.props) {\n return;\n }\n\n var _child$props = child.props,\n nestedChildren = _child$props.children,\n childProps = objectWithoutProperties(_child$props, [\"children\"]);\n\n var newChildProps = convertReactPropstoHtmlAttributes(childProps);\n\n _this2.warnOnInvalidChildren(child, nestedChildren);\n\n switch (child.type) {\n case TAG_NAMES.LINK:\n case TAG_NAMES.META:\n case TAG_NAMES.NOSCRIPT:\n case TAG_NAMES.SCRIPT:\n case TAG_NAMES.STYLE:\n arrayTypeChildren = _this2.flattenArrayTypeChildren({\n child: child,\n arrayTypeChildren: arrayTypeChildren,\n newChildProps: newChildProps,\n nestedChildren: nestedChildren\n });\n break;\n\n default:\n newProps = _this2.mapObjectTypeChildren({\n child: child,\n newProps: newProps,\n newChildProps: newChildProps,\n nestedChildren: nestedChildren\n });\n break;\n }\n });\n\n newProps = this.mapArrayTypeChildrenToProps(arrayTypeChildren, newProps);\n return newProps;\n };\n\n HelmetWrapper.prototype.render = function render() {\n var _props = this.props,\n children = _props.children,\n props = objectWithoutProperties(_props, [\"children\"]);\n\n var newProps = _extends({}, props);\n\n if (children) {\n newProps = this.mapChildrenToProps(children, newProps);\n }\n\n return React.createElement(Component, newProps);\n };\n\n createClass(HelmetWrapper, null, [{\n key: \"canUseDOM\",\n\n\n // Component.peek comes from react-side-effect:\n // For testing, you may use a static peek() method available on the returned component.\n // It lets you get the current state without resetting the mounted instance stack.\n // Don’t use it for anything other than testing.\n\n /**\n * @param {Object} base: {\"target\": \"_blank\", \"href\": \"http://mysite.com/\"}\n * @param {Object} bodyAttributes: {\"className\": \"root\"}\n * @param {String} defaultTitle: \"Default Title\"\n * @param {Boolean} defer: true\n * @param {Boolean} encodeSpecialCharacters: true\n * @param {Object} htmlAttributes: {\"lang\": \"en\", \"amp\": undefined}\n * @param {Array} link: [{\"rel\": \"canonical\", \"href\": \"http://mysite.com/example\"}]\n * @param {Array} meta: [{\"name\": \"description\", \"content\": \"Test description\"}]\n * @param {Array} noscript: [{\"innerHTML\": \" console.log(newState)\"\n * @param {Array} script: [{\"type\": \"text/javascript\", \"src\": \"http://mysite.com/js/test.js\"}]\n * @param {Array} style: [{\"type\": \"text/css\", \"cssText\": \"div { display: block; color: blue; }\"}]\n * @param {String} title: \"Title\"\n * @param {Object} titleAttributes: {\"itemprop\": \"name\"}\n * @param {String} titleTemplate: \"MySite.com - %s\"\n */\n set: function set$$1(canUseDOM) {\n Component.canUseDOM = canUseDOM;\n }\n }]);\n return HelmetWrapper;\n }(React.Component), _class.propTypes = {\n base: PropTypes.object,\n bodyAttributes: PropTypes.object,\n children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node]),\n defaultTitle: PropTypes.string,\n defer: PropTypes.bool,\n encodeSpecialCharacters: PropTypes.bool,\n htmlAttributes: PropTypes.object,\n link: PropTypes.arrayOf(PropTypes.object),\n meta: PropTypes.arrayOf(PropTypes.object),\n noscript: PropTypes.arrayOf(PropTypes.object),\n onChangeClientState: PropTypes.func,\n script: PropTypes.arrayOf(PropTypes.object),\n style: PropTypes.arrayOf(PropTypes.object),\n title: PropTypes.string,\n titleAttributes: PropTypes.object,\n titleTemplate: PropTypes.string\n }, _class.defaultProps = {\n defer: true,\n encodeSpecialCharacters: true\n }, _class.peek = Component.peek, _class.rewind = function () {\n var mappedState = Component.rewind();\n if (!mappedState) {\n // provide fallback if mappedState is undefined\n mappedState = mapStateOnServer({\n baseTag: [],\n bodyAttributes: {},\n encodeSpecialCharacters: true,\n htmlAttributes: {},\n linkTags: [],\n metaTags: [],\n noscriptTags: [],\n scriptTags: [],\n styleTags: [],\n title: \"\",\n titleAttributes: {}\n });\n }\n\n return mappedState;\n }, _temp;\n};\n\nvar NullComponent = function NullComponent() {\n return null;\n};\n\nvar HelmetSideEffects = withSideEffect(reducePropsToState, handleClientStateChange, mapStateOnServer)(NullComponent);\n\nvar HelmetExport = Helmet(HelmetSideEffects);\nHelmetExport.renderStatic = HelmetExport.rewind;\n\nexport default HelmetExport;\nexport { HelmetExport as Helmet };\n","import { graphql, useStaticQuery } from 'gatsby';\nimport { Helmet } from 'react-helmet';\nimport React from 'react';\n\nexport interface MetadataProps {\n description?: string;\n image?: string;\n title?: string;\n url?: string;\n}\n\nexport default function Metadata(props: MetadataProps) {\n const queryData = useStaticQuery(query);\n const { metadata: siteMetadata } = queryData.site;\n const metadata = { ...siteMetadata, ...props };\n return (\n \n {metadata.title}\n \n {metadata.image && }\n\n {metadata.url && }\n \n \n \n {metadata.image && }\n\n \n \n \n \n {metadata.image && }\n \n );\n}\n\nconst query = graphql`\n query Metadata {\n site {\n metadata: siteMetadata {\n title\n description\n }\n }\n }\n`;\n","import { useTheme } from '@zigurous/react-components';\nimport classNames from 'classnames';\nimport React from 'react';\nimport Dock from './Dock';\nimport Header from './Header';\nimport Metadata, { MetadataProps } from './Metadata';\nimport type { LinkType } from '../types/link';\n\nexport interface PageProps {\n children?: React.ReactNode;\n className?: string;\n dockLinks?: LinkType[];\n hideDock?: boolean;\n hideHeader?: boolean;\n id?: string;\n location?: Location | null;\n metadata?: MetadataProps;\n title?: string;\n}\n\nexport default function Page({\n children,\n className,\n dockLinks,\n hideDock = false,\n hideHeader = false,\n id,\n location = typeof window !== 'undefined' ? window.location : null,\n metadata,\n title,\n}: PageProps) {\n const [theme, _, toggleTheme] = useTheme('light');\n return (\n
\n \n {!hideHeader &&
}\n
\n {children}\n
\n {!hideDock && (\n \n )}\n
\n );\n}\n","import '../styles/project.css';\nimport { Badge, EmbeddedYouTube, ImageGallery, Link, ProgressiveImage } from '@zigurous/react-components'; // prettier-ignore\nimport React from 'react';\nimport type { ProjectData } from '../types';\n\nexport interface ProjectProps {\n project: ProjectData;\n}\n\nexport default function Project({ project }: ProjectProps) {\n return (\n
\n
\n

{project.title}

\n
\n {project.date}\n |\n {project.role}\n
\n {project.tech && (\n
\n {project.tech.map(tech => (\n \n {tech}\n \n ))}\n
\n )}\n
\n {project.description && (\n

{project.description}

\n )}\n {project.description_long &&\n project.description_long.map(description => (\n

\n {description}\n

\n ))}\n
\n
\n {project.sections &&\n project.sections.map((section, index) => (\n
\n {section.title && (\n

\n {section.link ? (\n \n {section.title}\n \n ) : (\n {section.title}\n )}\n

\n )}\n {section.mainImage &&\n (section.mainImageLink ? (\n \n \n \n ) : (\n \n ))}\n {section.mainVideo && (\n \n )}\n {section.paragraphs &&\n section.paragraphs.map((paragraph, paragraphIndex) => (\n \n {paragraph}\n

\n ))}\n {section.gallery && (\n ({\n width: image.sharp.original.width,\n height: image.sharp.original.height,\n src: image.sharp.original.src,\n }))}\n minWidth={132}\n />\n )}\n {section.videos &&\n section.videos.map(video => (\n \n ))}\n
\n ))}\n
\n );\n}\n","import '../styles/vignette.css';\nimport React from 'react';\n\nexport default function Vignette() {\n return
;\n}\n","import { LinkType } from './types/link';\n\nexport const baseUri = 'https://adamgraham.github.io';\nexport const email = 'mailto:adam@zigurous.com';\nexport const resume = 'https://docs.google.com/document/d/1qLHBV7Ry11O-pd0XC3HvALBIKJ8YDBmSafP0Z5c4dww/edit?usp=drive_link'; // prettier-ignore\nexport const github = 'https://github.com/adamgraham';\nexport const linkedIn = 'https://www.linkedin.com/in/adamzigurous';\nexport const instagram = 'http://instagram.com/adam.zigurous';\nexport const twitter = 'https://twitter.com/zigurous';\n\nexport const headerLinks: LinkType[] = [\n {\n id: 'games',\n to: '/games',\n name: 'Games',\n },\n {\n id: 'websites',\n to: '/websites',\n name: 'Websites',\n },\n {\n id: 'art',\n to: '/art',\n name: 'Interactive Art',\n },\n {\n id: 'tech',\n to: '/tech',\n name: 'Tech Showcases',\n },\n {\n id: 'presentations',\n to: '/presentations',\n name: 'Presentations',\n },\n];\n\nexport const dockLinks: LinkType[] = [\n {\n id: 'home',\n to: '/',\n name: 'Home',\n icon: 'home',\n },\n {\n id: 'gallery',\n to: '/gallery',\n name: 'Gallery',\n icon: 'collections',\n },\n {\n id: 'projects',\n to: '/projects',\n name: 'Projects',\n icon: 'menu',\n },\n];\n\nexport const socialLinks: LinkType[] = [\n {\n id: 'github',\n to: github,\n name: 'GitHub',\n socialIcon: 'github',\n },\n {\n id: 'linkedIn',\n to: linkedIn,\n name: 'LinkedIn',\n socialIcon: 'linkedIn',\n },\n {\n id: 'resume',\n to: resume,\n name: 'Resume',\n icon: 'description',\n },\n {\n id: 'email',\n to: email,\n name: 'Email',\n icon: 'mail',\n },\n];\n","Prism.languages.clike = {\n\t'comment': [\n\t\t{\n\t\t\tpattern: /(^|[^\\\\])\\/\\*[\\s\\S]*?(?:\\*\\/|$)/,\n\t\t\tlookbehind: true,\n\t\t\tgreedy: true\n\t\t},\n\t\t{\n\t\t\tpattern: /(^|[^\\\\:])\\/\\/.*/,\n\t\t\tlookbehind: true,\n\t\t\tgreedy: true\n\t\t}\n\t],\n\t'string': {\n\t\tpattern: /([\"'])(?:\\\\(?:\\r\\n|[\\s\\S])|(?!\\1)[^\\\\\\r\\n])*\\1/,\n\t\tgreedy: true\n\t},\n\t'class-name': {\n\t\tpattern: /(\\b(?:class|extends|implements|instanceof|interface|new|trait)\\s+|\\bcatch\\s+\\()[\\w.\\\\]+/i,\n\t\tlookbehind: true,\n\t\tinside: {\n\t\t\t'punctuation': /[.\\\\]/\n\t\t}\n\t},\n\t'keyword': /\\b(?:break|catch|continue|do|else|finally|for|function|if|in|instanceof|new|null|return|throw|try|while)\\b/,\n\t'boolean': /\\b(?:false|true)\\b/,\n\t'function': /\\b\\w+(?=\\()/,\n\t'number': /\\b0x[\\da-f]+\\b|(?:\\b\\d+(?:\\.\\d*)?|\\B\\.\\d+)(?:e[+-]?\\d+)?/i,\n\t'operator': /[<>]=?|[!=]=?=?|--?|\\+\\+?|&&?|\\|\\|?|[?*/~^%]/,\n\t'punctuation': /[{}[\\];(),.:]/\n};\n","(function (Prism) {\n\n\t/**\n\t * Replaces all placeholders \"<>\" of given pattern with the n-th replacement (zero based).\n\t *\n\t * Note: This is a simple text based replacement. Be careful when using backreferences!\n\t *\n\t * @param {string} pattern the given pattern.\n\t * @param {string[]} replacements a list of replacement which can be inserted into the given pattern.\n\t * @returns {string} the pattern with all placeholders replaced with their corresponding replacements.\n\t * @example replace(/a<<0>>a/.source, [/b+/.source]) === /a(?:b+)a/.source\n\t */\n\tfunction replace(pattern, replacements) {\n\t\treturn pattern.replace(/<<(\\d+)>>/g, function (m, index) {\n\t\t\treturn '(?:' + replacements[+index] + ')';\n\t\t});\n\t}\n\t/**\n\t * @param {string} pattern\n\t * @param {string[]} replacements\n\t * @param {string} [flags]\n\t * @returns {RegExp}\n\t */\n\tfunction re(pattern, replacements, flags) {\n\t\treturn RegExp(replace(pattern, replacements), flags || '');\n\t}\n\n\t/**\n\t * Creates a nested pattern where all occurrences of the string `<>` are replaced with the pattern itself.\n\t *\n\t * @param {string} pattern\n\t * @param {number} depthLog2\n\t * @returns {string}\n\t */\n\tfunction nested(pattern, depthLog2) {\n\t\tfor (var i = 0; i < depthLog2; i++) {\n\t\t\tpattern = pattern.replace(/<>/g, function () { return '(?:' + pattern + ')'; });\n\t\t}\n\t\treturn pattern.replace(/<>/g, '[^\\\\s\\\\S]');\n\t}\n\n\t// https://docs.microsoft.com/en-us/dotnet/csharp/language-reference/keywords/\n\tvar keywordKinds = {\n\t\t// keywords which represent a return or variable type\n\t\ttype: 'bool byte char decimal double dynamic float int long object sbyte short string uint ulong ushort var void',\n\t\t// keywords which are used to declare a type\n\t\ttypeDeclaration: 'class enum interface record struct',\n\t\t// contextual keywords\n\t\t// (\"var\" and \"dynamic\" are missing because they are used like types)\n\t\tcontextual: 'add alias and ascending async await by descending from(?=\\\\s*(?:\\\\w|$)) get global group into init(?=\\\\s*;) join let nameof not notnull on or orderby partial remove select set unmanaged value when where with(?=\\\\s*{)',\n\t\t// all other keywords\n\t\tother: 'abstract as base break case catch checked const continue default delegate do else event explicit extern finally fixed for foreach goto if implicit in internal is lock namespace new null operator out override params private protected public readonly ref return sealed sizeof stackalloc static switch this throw try typeof unchecked unsafe using virtual volatile while yield'\n\t};\n\n\t// keywords\n\tfunction keywordsToPattern(words) {\n\t\treturn '\\\\b(?:' + words.trim().replace(/ /g, '|') + ')\\\\b';\n\t}\n\tvar typeDeclarationKeywords = keywordsToPattern(keywordKinds.typeDeclaration);\n\tvar keywords = RegExp(keywordsToPattern(keywordKinds.type + ' ' + keywordKinds.typeDeclaration + ' ' + keywordKinds.contextual + ' ' + keywordKinds.other));\n\tvar nonTypeKeywords = keywordsToPattern(keywordKinds.typeDeclaration + ' ' + keywordKinds.contextual + ' ' + keywordKinds.other);\n\tvar nonContextualKeywords = keywordsToPattern(keywordKinds.type + ' ' + keywordKinds.typeDeclaration + ' ' + keywordKinds.other);\n\n\t// types\n\tvar generic = nested(/<(?:[^<>;=+\\-*/%&|^]|<>)*>/.source, 2); // the idea behind the other forbidden characters is to prevent false positives. Same for tupleElement.\n\tvar nestedRound = nested(/\\((?:[^()]|<>)*\\)/.source, 2);\n\tvar name = /@?\\b[A-Za-z_]\\w*\\b/.source;\n\tvar genericName = replace(/<<0>>(?:\\s*<<1>>)?/.source, [name, generic]);\n\tvar identifier = replace(/(?!<<0>>)<<1>>(?:\\s*\\.\\s*<<1>>)*/.source, [nonTypeKeywords, genericName]);\n\tvar array = /\\[\\s*(?:,\\s*)*\\]/.source;\n\tvar typeExpressionWithoutTuple = replace(/<<0>>(?:\\s*(?:\\?\\s*)?<<1>>)*(?:\\s*\\?)?/.source, [identifier, array]);\n\tvar tupleElement = replace(/[^,()<>[\\];=+\\-*/%&|^]|<<0>>|<<1>>|<<2>>/.source, [generic, nestedRound, array]);\n\tvar tuple = replace(/\\(<<0>>+(?:,<<0>>+)+\\)/.source, [tupleElement]);\n\tvar typeExpression = replace(/(?:<<0>>|<<1>>)(?:\\s*(?:\\?\\s*)?<<2>>)*(?:\\s*\\?)?/.source, [tuple, identifier, array]);\n\n\tvar typeInside = {\n\t\t'keyword': keywords,\n\t\t'punctuation': /[<>()?,.:[\\]]/\n\t};\n\n\t// strings & characters\n\t// https://docs.microsoft.com/en-us/dotnet/csharp/language-reference/language-specification/lexical-structure#character-literals\n\t// https://docs.microsoft.com/en-us/dotnet/csharp/language-reference/language-specification/lexical-structure#string-literals\n\tvar character = /'(?:[^\\r\\n'\\\\]|\\\\.|\\\\[Uux][\\da-fA-F]{1,8})'/.source; // simplified pattern\n\tvar regularString = /\"(?:\\\\.|[^\\\\\"\\r\\n])*\"/.source;\n\tvar verbatimString = /@\"(?:\"\"|\\\\[\\s\\S]|[^\\\\\"])*\"(?!\")/.source;\n\n\n\tPrism.languages.csharp = Prism.languages.extend('clike', {\n\t\t'string': [\n\t\t\t{\n\t\t\t\tpattern: re(/(^|[^$\\\\])<<0>>/.source, [verbatimString]),\n\t\t\t\tlookbehind: true,\n\t\t\t\tgreedy: true\n\t\t\t},\n\t\t\t{\n\t\t\t\tpattern: re(/(^|[^@$\\\\])<<0>>/.source, [regularString]),\n\t\t\t\tlookbehind: true,\n\t\t\t\tgreedy: true\n\t\t\t}\n\t\t],\n\t\t'class-name': [\n\t\t\t{\n\t\t\t\t// Using static\n\t\t\t\t// using static System.Math;\n\t\t\t\tpattern: re(/(\\busing\\s+static\\s+)<<0>>(?=\\s*;)/.source, [identifier]),\n\t\t\t\tlookbehind: true,\n\t\t\t\tinside: typeInside\n\t\t\t},\n\t\t\t{\n\t\t\t\t// Using alias (type)\n\t\t\t\t// using Project = PC.MyCompany.Project;\n\t\t\t\tpattern: re(/(\\busing\\s+<<0>>\\s*=\\s*)<<1>>(?=\\s*;)/.source, [name, typeExpression]),\n\t\t\t\tlookbehind: true,\n\t\t\t\tinside: typeInside\n\t\t\t},\n\t\t\t{\n\t\t\t\t// Using alias (alias)\n\t\t\t\t// using Project = PC.MyCompany.Project;\n\t\t\t\tpattern: re(/(\\busing\\s+)<<0>>(?=\\s*=)/.source, [name]),\n\t\t\t\tlookbehind: true\n\t\t\t},\n\t\t\t{\n\t\t\t\t// Type declarations\n\t\t\t\t// class Foo\n\t\t\t\t// interface Foo\n\t\t\t\tpattern: re(/(\\b<<0>>\\s+)<<1>>/.source, [typeDeclarationKeywords, genericName]),\n\t\t\t\tlookbehind: true,\n\t\t\t\tinside: typeInside\n\t\t\t},\n\t\t\t{\n\t\t\t\t// Single catch exception declaration\n\t\t\t\t// catch(Foo)\n\t\t\t\t// (things like catch(Foo e) is covered by variable declaration)\n\t\t\t\tpattern: re(/(\\bcatch\\s*\\(\\s*)<<0>>/.source, [identifier]),\n\t\t\t\tlookbehind: true,\n\t\t\t\tinside: typeInside\n\t\t\t},\n\t\t\t{\n\t\t\t\t// Name of the type parameter of generic constraints\n\t\t\t\t// where Foo : class\n\t\t\t\tpattern: re(/(\\bwhere\\s+)<<0>>/.source, [name]),\n\t\t\t\tlookbehind: true\n\t\t\t},\n\t\t\t{\n\t\t\t\t// Casts and checks via as and is.\n\t\t\t\t// as Foo, is Bar\n\t\t\t\t// (things like if(a is Foo b) is covered by variable declaration)\n\t\t\t\tpattern: re(/(\\b(?:is(?:\\s+not)?|as)\\s+)<<0>>/.source, [typeExpressionWithoutTuple]),\n\t\t\t\tlookbehind: true,\n\t\t\t\tinside: typeInside\n\t\t\t},\n\t\t\t{\n\t\t\t\t// Variable, field and parameter declaration\n\t\t\t\t// (Foo bar, Bar baz, Foo[,,] bay, Foo> bax)\n\t\t\t\tpattern: re(/\\b<<0>>(?=\\s+(?!<<1>>|with\\s*\\{)<<2>>(?:\\s*[=,;:{)\\]]|\\s+(?:in|when)\\b))/.source, [typeExpression, nonContextualKeywords, name]),\n\t\t\t\tinside: typeInside\n\t\t\t}\n\t\t],\n\t\t'keyword': keywords,\n\t\t// https://docs.microsoft.com/en-us/dotnet/csharp/language-reference/language-specification/lexical-structure#literals\n\t\t'number': /(?:\\b0(?:x[\\da-f_]*[\\da-f]|b[01_]*[01])|(?:\\B\\.\\d+(?:_+\\d+)*|\\b\\d+(?:_+\\d+)*(?:\\.\\d+(?:_+\\d+)*)?)(?:e[-+]?\\d+(?:_+\\d+)*)?)(?:[dflmu]|lu|ul)?\\b/i,\n\t\t'operator': />>=?|<<=?|[-=]>|([-+&|])\\1|~|\\?\\?=?|[-+*/%&|^!=<>]=?/,\n\t\t'punctuation': /\\?\\.?|::|[{}[\\];(),.:]/\n\t});\n\n\tPrism.languages.insertBefore('csharp', 'number', {\n\t\t'range': {\n\t\t\tpattern: /\\.\\./,\n\t\t\talias: 'operator'\n\t\t}\n\t});\n\n\tPrism.languages.insertBefore('csharp', 'punctuation', {\n\t\t'named-parameter': {\n\t\t\tpattern: re(/([(,]\\s*)<<0>>(?=\\s*:)/.source, [name]),\n\t\t\tlookbehind: true,\n\t\t\talias: 'punctuation'\n\t\t}\n\t});\n\n\tPrism.languages.insertBefore('csharp', 'class-name', {\n\t\t'namespace': {\n\t\t\t// namespace Foo.Bar {}\n\t\t\t// using Foo.Bar;\n\t\t\tpattern: re(/(\\b(?:namespace|using)\\s+)<<0>>(?:\\s*\\.\\s*<<0>>)*(?=\\s*[;{])/.source, [name]),\n\t\t\tlookbehind: true,\n\t\t\tinside: {\n\t\t\t\t'punctuation': /\\./\n\t\t\t}\n\t\t},\n\t\t'type-expression': {\n\t\t\t// default(Foo), typeof(Foo), sizeof(int)\n\t\t\tpattern: re(/(\\b(?:default|sizeof|typeof)\\s*\\(\\s*(?!\\s))(?:[^()\\s]|\\s(?!\\s)|<<0>>)*(?=\\s*\\))/.source, [nestedRound]),\n\t\t\tlookbehind: true,\n\t\t\talias: 'class-name',\n\t\t\tinside: typeInside\n\t\t},\n\t\t'return-type': {\n\t\t\t// Foo ForBar(); Foo IFoo.Bar() => 0\n\t\t\t// int this[int index] => 0; T IReadOnlyList.this[int index] => this[index];\n\t\t\t// int Foo => 0; int Foo { get; set } = 0;\n\t\t\tpattern: re(/<<0>>(?=\\s+(?:<<1>>\\s*(?:=>|[({]|\\.\\s*this\\s*\\[)|this\\s*\\[))/.source, [typeExpression, identifier]),\n\t\t\tinside: typeInside,\n\t\t\talias: 'class-name'\n\t\t},\n\t\t'constructor-invocation': {\n\t\t\t// new List> { }\n\t\t\tpattern: re(/(\\bnew\\s+)<<0>>(?=\\s*[[({])/.source, [typeExpression]),\n\t\t\tlookbehind: true,\n\t\t\tinside: typeInside,\n\t\t\talias: 'class-name'\n\t\t},\n\t\t/*'explicit-implementation': {\n\t\t\t// int IFoo.Bar => 0; void IFoo>.Foo();\n\t\t\tpattern: replace(/\\b<<0>>(?=\\.<<1>>)/, className, methodOrPropertyDeclaration),\n\t\t\tinside: classNameInside,\n\t\t\talias: 'class-name'\n\t\t},*/\n\t\t'generic-method': {\n\t\t\t// foo()\n\t\t\tpattern: re(/<<0>>\\s*<<1>>(?=\\s*\\()/.source, [name, generic]),\n\t\t\tinside: {\n\t\t\t\t'function': re(/^<<0>>/.source, [name]),\n\t\t\t\t'generic': {\n\t\t\t\t\tpattern: RegExp(generic),\n\t\t\t\t\talias: 'class-name',\n\t\t\t\t\tinside: typeInside\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\t\t'type-list': {\n\t\t\t// The list of types inherited or of generic constraints\n\t\t\t// class Foo : Bar, IList\n\t\t\t// where F : Bar, IList\n\t\t\tpattern: re(\n\t\t\t\t/\\b((?:<<0>>\\s+<<1>>|record\\s+<<1>>\\s*<<5>>|where\\s+<<2>>)\\s*:\\s*)(?:<<3>>|<<4>>|<<1>>\\s*<<5>>|<<6>>)(?:\\s*,\\s*(?:<<3>>|<<4>>|<<6>>))*(?=\\s*(?:where|[{;]|=>|$))/.source,\n\t\t\t\t[typeDeclarationKeywords, genericName, name, typeExpression, keywords.source, nestedRound, /\\bnew\\s*\\(\\s*\\)/.source]\n\t\t\t),\n\t\t\tlookbehind: true,\n\t\t\tinside: {\n\t\t\t\t'record-arguments': {\n\t\t\t\t\tpattern: re(/(^(?!new\\s*\\()<<0>>\\s*)<<1>>/.source, [genericName, nestedRound]),\n\t\t\t\t\tlookbehind: true,\n\t\t\t\t\tgreedy: true,\n\t\t\t\t\tinside: Prism.languages.csharp\n\t\t\t\t},\n\t\t\t\t'keyword': keywords,\n\t\t\t\t'class-name': {\n\t\t\t\t\tpattern: RegExp(typeExpression),\n\t\t\t\t\tgreedy: true,\n\t\t\t\t\tinside: typeInside\n\t\t\t\t},\n\t\t\t\t'punctuation': /[,()]/\n\t\t\t}\n\t\t},\n\t\t'preprocessor': {\n\t\t\tpattern: /(^[\\t ]*)#.*/m,\n\t\t\tlookbehind: true,\n\t\t\talias: 'property',\n\t\t\tinside: {\n\t\t\t\t// highlight preprocessor directives as keywords\n\t\t\t\t'directive': {\n\t\t\t\t\tpattern: /(#)\\b(?:define|elif|else|endif|endregion|error|if|line|nullable|pragma|region|undef|warning)\\b/,\n\t\t\t\t\tlookbehind: true,\n\t\t\t\t\talias: 'keyword'\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t});\n\n\t// attributes\n\tvar regularStringOrCharacter = regularString + '|' + character;\n\tvar regularStringCharacterOrComment = replace(/\\/(?![*/])|\\/\\/[^\\r\\n]*[\\r\\n]|\\/\\*(?:[^*]|\\*(?!\\/))*\\*\\/|<<0>>/.source, [regularStringOrCharacter]);\n\tvar roundExpression = nested(replace(/[^\"'/()]|<<0>>|\\(<>*\\)/.source, [regularStringCharacterOrComment]), 2);\n\n\t// https://docs.microsoft.com/en-us/dotnet/csharp/programming-guide/concepts/attributes/#attribute-targets\n\tvar attrTarget = /\\b(?:assembly|event|field|method|module|param|property|return|type)\\b/.source;\n\tvar attr = replace(/<<0>>(?:\\s*\\(<<1>>*\\))?/.source, [identifier, roundExpression]);\n\n\tPrism.languages.insertBefore('csharp', 'class-name', {\n\t\t'attribute': {\n\t\t\t// Attributes\n\t\t\t// [Foo], [Foo(1), Bar(2, Prop = \"foo\")], [return: Foo(1), Bar(2)], [assembly: Foo(Bar)]\n\t\t\tpattern: re(/((?:^|[^\\s\\w>)?])\\s*\\[\\s*)(?:<<0>>\\s*:\\s*)?<<1>>(?:\\s*,\\s*<<1>>)*(?=\\s*\\])/.source, [attrTarget, attr]),\n\t\t\tlookbehind: true,\n\t\t\tgreedy: true,\n\t\t\tinside: {\n\t\t\t\t'target': {\n\t\t\t\t\tpattern: re(/^<<0>>(?=\\s*:)/.source, [attrTarget]),\n\t\t\t\t\talias: 'keyword'\n\t\t\t\t},\n\t\t\t\t'attribute-arguments': {\n\t\t\t\t\tpattern: re(/\\(<<0>>*\\)/.source, [roundExpression]),\n\t\t\t\t\tinside: Prism.languages.csharp\n\t\t\t\t},\n\t\t\t\t'class-name': {\n\t\t\t\t\tpattern: RegExp(identifier),\n\t\t\t\t\tinside: {\n\t\t\t\t\t\t'punctuation': /\\./\n\t\t\t\t\t}\n\t\t\t\t},\n\t\t\t\t'punctuation': /[:,]/\n\t\t\t}\n\t\t}\n\t});\n\n\n\t// string interpolation\n\tvar formatString = /:[^}\\r\\n]+/.source;\n\t// multi line\n\tvar mInterpolationRound = nested(replace(/[^\"'/()]|<<0>>|\\(<>*\\)/.source, [regularStringCharacterOrComment]), 2);\n\tvar mInterpolation = replace(/\\{(?!\\{)(?:(?![}:])<<0>>)*<<1>>?\\}/.source, [mInterpolationRound, formatString]);\n\t// single line\n\tvar sInterpolationRound = nested(replace(/[^\"'/()]|\\/(?!\\*)|\\/\\*(?:[^*]|\\*(?!\\/))*\\*\\/|<<0>>|\\(<>*\\)/.source, [regularStringOrCharacter]), 2);\n\tvar sInterpolation = replace(/\\{(?!\\{)(?:(?![}:])<<0>>)*<<1>>?\\}/.source, [sInterpolationRound, formatString]);\n\n\tfunction createInterpolationInside(interpolation, interpolationRound) {\n\t\treturn {\n\t\t\t'interpolation': {\n\t\t\t\tpattern: re(/((?:^|[^{])(?:\\{\\{)*)<<0>>/.source, [interpolation]),\n\t\t\t\tlookbehind: true,\n\t\t\t\tinside: {\n\t\t\t\t\t'format-string': {\n\t\t\t\t\t\tpattern: re(/(^\\{(?:(?![}:])<<0>>)*)<<1>>(?=\\}$)/.source, [interpolationRound, formatString]),\n\t\t\t\t\t\tlookbehind: true,\n\t\t\t\t\t\tinside: {\n\t\t\t\t\t\t\t'punctuation': /^:/\n\t\t\t\t\t\t}\n\t\t\t\t\t},\n\t\t\t\t\t'punctuation': /^\\{|\\}$/,\n\t\t\t\t\t'expression': {\n\t\t\t\t\t\tpattern: /[\\s\\S]+/,\n\t\t\t\t\t\talias: 'language-csharp',\n\t\t\t\t\t\tinside: Prism.languages.csharp\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t},\n\t\t\t'string': /[\\s\\S]+/\n\t\t};\n\t}\n\n\tPrism.languages.insertBefore('csharp', 'string', {\n\t\t'interpolation-string': [\n\t\t\t{\n\t\t\t\tpattern: re(/(^|[^\\\\])(?:\\$@|@\\$)\"(?:\"\"|\\\\[\\s\\S]|\\{\\{|<<0>>|[^\\\\{\"])*\"/.source, [mInterpolation]),\n\t\t\t\tlookbehind: true,\n\t\t\t\tgreedy: true,\n\t\t\t\tinside: createInterpolationInside(mInterpolation, mInterpolationRound),\n\t\t\t},\n\t\t\t{\n\t\t\t\tpattern: re(/(^|[^@\\\\])\\$\"(?:\\\\.|\\{\\{|<<0>>|[^\\\\\"{])*\"/.source, [sInterpolation]),\n\t\t\t\tlookbehind: true,\n\t\t\t\tgreedy: true,\n\t\t\t\tinside: createInterpolationInside(sInterpolation, sInterpolationRound),\n\t\t\t}\n\t\t],\n\t\t'char': {\n\t\t\tpattern: RegExp(character),\n\t\t\tgreedy: true\n\t\t}\n\t});\n\n\tPrism.languages.dotnet = Prism.languages.cs = Prism.languages.csharp;\n\n}(Prism));\n","(function (Prism) {\n\n\tvar string = /(?:\"(?:\\\\(?:\\r\\n|[\\s\\S])|[^\"\\\\\\r\\n])*\"|'(?:\\\\(?:\\r\\n|[\\s\\S])|[^'\\\\\\r\\n])*')/;\n\n\tPrism.languages.css = {\n\t\t'comment': /\\/\\*[\\s\\S]*?\\*\\//,\n\t\t'atrule': {\n\t\t\tpattern: RegExp('@[\\\\w-](?:' + /[^;{\\s\"']|\\s+(?!\\s)/.source + '|' + string.source + ')*?' + /(?:;|(?=\\s*\\{))/.source),\n\t\t\tinside: {\n\t\t\t\t'rule': /^@[\\w-]+/,\n\t\t\t\t'selector-function-argument': {\n\t\t\t\t\tpattern: /(\\bselector\\s*\\(\\s*(?![\\s)]))(?:[^()\\s]|\\s+(?![\\s)])|\\((?:[^()]|\\([^()]*\\))*\\))+(?=\\s*\\))/,\n\t\t\t\t\tlookbehind: true,\n\t\t\t\t\talias: 'selector'\n\t\t\t\t},\n\t\t\t\t'keyword': {\n\t\t\t\t\tpattern: /(^|[^\\w-])(?:and|not|only|or)(?![\\w-])/,\n\t\t\t\t\tlookbehind: true\n\t\t\t\t}\n\t\t\t\t// See rest below\n\t\t\t}\n\t\t},\n\t\t'url': {\n\t\t\t// https://drafts.csswg.org/css-values-3/#urls\n\t\t\tpattern: RegExp('\\\\burl\\\\((?:' + string.source + '|' + /(?:[^\\\\\\r\\n()\"']|\\\\[\\s\\S])*/.source + ')\\\\)', 'i'),\n\t\t\tgreedy: true,\n\t\t\tinside: {\n\t\t\t\t'function': /^url/i,\n\t\t\t\t'punctuation': /^\\(|\\)$/,\n\t\t\t\t'string': {\n\t\t\t\t\tpattern: RegExp('^' + string.source + '$'),\n\t\t\t\t\talias: 'url'\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\t\t'selector': {\n\t\t\tpattern: RegExp('(^|[{}\\\\s])[^{}\\\\s](?:[^{};\"\\'\\\\s]|\\\\s+(?![\\\\s{])|' + string.source + ')*(?=\\\\s*\\\\{)'),\n\t\t\tlookbehind: true\n\t\t},\n\t\t'string': {\n\t\t\tpattern: string,\n\t\t\tgreedy: true\n\t\t},\n\t\t'property': {\n\t\t\tpattern: /(^|[^-\\w\\xA0-\\uFFFF])(?!\\s)[-_a-z\\xA0-\\uFFFF](?:(?!\\s)[-\\w\\xA0-\\uFFFF])*(?=\\s*:)/i,\n\t\t\tlookbehind: true\n\t\t},\n\t\t'important': /!important\\b/i,\n\t\t'function': {\n\t\t\tpattern: /(^|[^-a-z0-9])[-a-z0-9]+(?=\\()/i,\n\t\t\tlookbehind: true\n\t\t},\n\t\t'punctuation': /[(){};:,]/\n\t};\n\n\tPrism.languages.css['atrule'].inside.rest = Prism.languages.css;\n\n\tvar markup = Prism.languages.markup;\n\tif (markup) {\n\t\tmarkup.tag.addInlined('style', 'css');\n\t\tmarkup.tag.addAttribute('style', 'css');\n\t}\n\n}(Prism));\n","Prism.languages.javascript = Prism.languages.extend('clike', {\n\t'class-name': [\n\t\tPrism.languages.clike['class-name'],\n\t\t{\n\t\t\tpattern: /(^|[^$\\w\\xA0-\\uFFFF])(?!\\s)[_$A-Z\\xA0-\\uFFFF](?:(?!\\s)[$\\w\\xA0-\\uFFFF])*(?=\\.(?:constructor|prototype))/,\n\t\t\tlookbehind: true\n\t\t}\n\t],\n\t'keyword': [\n\t\t{\n\t\t\tpattern: /((?:^|\\})\\s*)catch\\b/,\n\t\t\tlookbehind: true\n\t\t},\n\t\t{\n\t\t\tpattern: /(^|[^.]|\\.\\.\\.\\s*)\\b(?:as|assert(?=\\s*\\{)|async(?=\\s*(?:function\\b|\\(|[$\\w\\xA0-\\uFFFF]|$))|await|break|case|class|const|continue|debugger|default|delete|do|else|enum|export|extends|finally(?=\\s*(?:\\{|$))|for|from(?=\\s*(?:['\"]|$))|function|(?:get|set)(?=\\s*(?:[#\\[$\\w\\xA0-\\uFFFF]|$))|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|static|super|switch|this|throw|try|typeof|undefined|var|void|while|with|yield)\\b/,\n\t\t\tlookbehind: true\n\t\t},\n\t],\n\t// Allow for all non-ASCII characters (See http://stackoverflow.com/a/2008444)\n\t'function': /#?(?!\\s)[_$a-zA-Z\\xA0-\\uFFFF](?:(?!\\s)[$\\w\\xA0-\\uFFFF])*(?=\\s*(?:\\.\\s*(?:apply|bind|call)\\s*)?\\()/,\n\t'number': {\n\t\tpattern: RegExp(\n\t\t\t/(^|[^\\w$])/.source +\n\t\t\t'(?:' +\n\t\t\t(\n\t\t\t\t// constant\n\t\t\t\t/NaN|Infinity/.source +\n\t\t\t\t'|' +\n\t\t\t\t// binary integer\n\t\t\t\t/0[bB][01]+(?:_[01]+)*n?/.source +\n\t\t\t\t'|' +\n\t\t\t\t// octal integer\n\t\t\t\t/0[oO][0-7]+(?:_[0-7]+)*n?/.source +\n\t\t\t\t'|' +\n\t\t\t\t// hexadecimal integer\n\t\t\t\t/0[xX][\\dA-Fa-f]+(?:_[\\dA-Fa-f]+)*n?/.source +\n\t\t\t\t'|' +\n\t\t\t\t// decimal bigint\n\t\t\t\t/\\d+(?:_\\d+)*n/.source +\n\t\t\t\t'|' +\n\t\t\t\t// decimal number (integer or float) but no bigint\n\t\t\t\t/(?:\\d+(?:_\\d+)*(?:\\.(?:\\d+(?:_\\d+)*)?)?|\\.\\d+(?:_\\d+)*)(?:[Ee][+-]?\\d+(?:_\\d+)*)?/.source\n\t\t\t) +\n\t\t\t')' +\n\t\t\t/(?![\\w$])/.source\n\t\t),\n\t\tlookbehind: true\n\t},\n\t'operator': /--|\\+\\+|\\*\\*=?|=>|&&=?|\\|\\|=?|[!=]==|<<=?|>>>?=?|[-+*/%&|^!=<>]=?|\\.{3}|\\?\\?=?|\\?\\.?|[~:]/\n});\n\nPrism.languages.javascript['class-name'][0].pattern = /(\\b(?:class|extends|implements|instanceof|interface|new)\\s+)[\\w.\\\\]+/;\n\nPrism.languages.insertBefore('javascript', 'keyword', {\n\t'regex': {\n\t\tpattern: RegExp(\n\t\t\t// lookbehind\n\t\t\t// eslint-disable-next-line regexp/no-dupe-characters-character-class\n\t\t\t/((?:^|[^$\\w\\xA0-\\uFFFF.\"'\\])\\s]|\\b(?:return|yield))\\s*)/.source +\n\t\t\t// Regex pattern:\n\t\t\t// There are 2 regex patterns here. The RegExp set notation proposal added support for nested character\n\t\t\t// classes if the `v` flag is present. Unfortunately, nested CCs are both context-free and incompatible\n\t\t\t// with the only syntax, so we have to define 2 different regex patterns.\n\t\t\t/\\//.source +\n\t\t\t'(?:' +\n\t\t\t/(?:\\[(?:[^\\]\\\\\\r\\n]|\\\\.)*\\]|\\\\.|[^/\\\\\\[\\r\\n])+\\/[dgimyus]{0,7}/.source +\n\t\t\t'|' +\n\t\t\t// `v` flag syntax. This supports 3 levels of nested character classes.\n\t\t\t/(?:\\[(?:[^[\\]\\\\\\r\\n]|\\\\.|\\[(?:[^[\\]\\\\\\r\\n]|\\\\.|\\[(?:[^[\\]\\\\\\r\\n]|\\\\.)*\\])*\\])*\\]|\\\\.|[^/\\\\\\[\\r\\n])+\\/[dgimyus]{0,7}v[dgimyus]{0,7}/.source +\n\t\t\t')' +\n\t\t\t// lookahead\n\t\t\t/(?=(?:\\s|\\/\\*(?:[^*]|\\*(?!\\/))*\\*\\/)*(?:$|[\\r\\n,.;:})\\]]|\\/\\/))/.source\n\t\t),\n\t\tlookbehind: true,\n\t\tgreedy: true,\n\t\tinside: {\n\t\t\t'regex-source': {\n\t\t\t\tpattern: /^(\\/)[\\s\\S]+(?=\\/[a-z]*$)/,\n\t\t\t\tlookbehind: true,\n\t\t\t\talias: 'language-regex',\n\t\t\t\tinside: Prism.languages.regex\n\t\t\t},\n\t\t\t'regex-delimiter': /^\\/|\\/$/,\n\t\t\t'regex-flags': /^[a-z]+$/,\n\t\t}\n\t},\n\t// This must be declared before keyword because we use \"function\" inside the look-forward\n\t'function-variable': {\n\t\tpattern: /#?(?!\\s)[_$a-zA-Z\\xA0-\\uFFFF](?:(?!\\s)[$\\w\\xA0-\\uFFFF])*(?=\\s*[=:]\\s*(?:async\\s*)?(?:\\bfunction\\b|(?:\\((?:[^()]|\\([^()]*\\))*\\)|(?!\\s)[_$a-zA-Z\\xA0-\\uFFFF](?:(?!\\s)[$\\w\\xA0-\\uFFFF])*)\\s*=>))/,\n\t\talias: 'function'\n\t},\n\t'parameter': [\n\t\t{\n\t\t\tpattern: /(function(?:\\s+(?!\\s)[_$a-zA-Z\\xA0-\\uFFFF](?:(?!\\s)[$\\w\\xA0-\\uFFFF])*)?\\s*\\(\\s*)(?!\\s)(?:[^()\\s]|\\s+(?![\\s)])|\\([^()]*\\))+(?=\\s*\\))/,\n\t\t\tlookbehind: true,\n\t\t\tinside: Prism.languages.javascript\n\t\t},\n\t\t{\n\t\t\tpattern: /(^|[^$\\w\\xA0-\\uFFFF])(?!\\s)[_$a-z\\xA0-\\uFFFF](?:(?!\\s)[$\\w\\xA0-\\uFFFF])*(?=\\s*=>)/i,\n\t\t\tlookbehind: true,\n\t\t\tinside: Prism.languages.javascript\n\t\t},\n\t\t{\n\t\t\tpattern: /(\\(\\s*)(?!\\s)(?:[^()\\s]|\\s+(?![\\s)])|\\([^()]*\\))+(?=\\s*\\)\\s*=>)/,\n\t\t\tlookbehind: true,\n\t\t\tinside: Prism.languages.javascript\n\t\t},\n\t\t{\n\t\t\tpattern: /((?:\\b|\\s|^)(?!(?:as|async|await|break|case|catch|class|const|continue|debugger|default|delete|do|else|enum|export|extends|finally|for|from|function|get|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|set|static|super|switch|this|throw|try|typeof|undefined|var|void|while|with|yield)(?![$\\w\\xA0-\\uFFFF]))(?:(?!\\s)[_$a-zA-Z\\xA0-\\uFFFF](?:(?!\\s)[$\\w\\xA0-\\uFFFF])*\\s*)\\(\\s*|\\]\\s*\\(\\s*)(?!\\s)(?:[^()\\s]|\\s+(?![\\s)])|\\([^()]*\\))+(?=\\s*\\)\\s*\\{)/,\n\t\t\tlookbehind: true,\n\t\t\tinside: Prism.languages.javascript\n\t\t}\n\t],\n\t'constant': /\\b[A-Z](?:[A-Z_]|\\dx?)*\\b/\n});\n\nPrism.languages.insertBefore('javascript', 'string', {\n\t'hashbang': {\n\t\tpattern: /^#!.*/,\n\t\tgreedy: true,\n\t\talias: 'comment'\n\t},\n\t'template-string': {\n\t\tpattern: /`(?:\\\\[\\s\\S]|\\$\\{(?:[^{}]|\\{(?:[^{}]|\\{[^}]*\\})*\\})+\\}|(?!\\$\\{)[^\\\\`])*`/,\n\t\tgreedy: true,\n\t\tinside: {\n\t\t\t'template-punctuation': {\n\t\t\t\tpattern: /^`|`$/,\n\t\t\t\talias: 'string'\n\t\t\t},\n\t\t\t'interpolation': {\n\t\t\t\tpattern: /((?:^|[^\\\\])(?:\\\\{2})*)\\$\\{(?:[^{}]|\\{(?:[^{}]|\\{[^}]*\\})*\\})+\\}/,\n\t\t\t\tlookbehind: true,\n\t\t\t\tinside: {\n\t\t\t\t\t'interpolation-punctuation': {\n\t\t\t\t\t\tpattern: /^\\$\\{|\\}$/,\n\t\t\t\t\t\talias: 'punctuation'\n\t\t\t\t\t},\n\t\t\t\t\trest: Prism.languages.javascript\n\t\t\t\t}\n\t\t\t},\n\t\t\t'string': /[\\s\\S]+/\n\t\t}\n\t},\n\t'string-property': {\n\t\tpattern: /((?:^|[,{])[ \\t]*)([\"'])(?:\\\\(?:\\r\\n|[\\s\\S])|(?!\\2)[^\\\\\\r\\n])*\\2(?=\\s*:)/m,\n\t\tlookbehind: true,\n\t\tgreedy: true,\n\t\talias: 'property'\n\t}\n});\n\nPrism.languages.insertBefore('javascript', 'operator', {\n\t'literal-property': {\n\t\tpattern: /((?:^|[,{])[ \\t]*)(?!\\s)[_$a-zA-Z\\xA0-\\uFFFF](?:(?!\\s)[$\\w\\xA0-\\uFFFF])*(?=\\s*:)/m,\n\t\tlookbehind: true,\n\t\talias: 'property'\n\t},\n});\n\nif (Prism.languages.markup) {\n\tPrism.languages.markup.tag.addInlined('script', 'javascript');\n\n\t// add attribute support for all DOM events.\n\t// https://developer.mozilla.org/en-US/docs/Web/Events#Standard_events\n\tPrism.languages.markup.tag.addAttribute(\n\t\t/on(?:abort|blur|change|click|composition(?:end|start|update)|dblclick|error|focus(?:in|out)?|key(?:down|up)|load|mouse(?:down|enter|leave|move|out|over|up)|reset|resize|scroll|select|slotchange|submit|unload|wheel)/.source,\n\t\t'javascript'\n\t);\n}\n\nPrism.languages.js = Prism.languages.javascript;\n","Prism.languages.markup = {\n\t'comment': {\n\t\tpattern: //,\n\t\tgreedy: true\n\t},\n\t'prolog': {\n\t\tpattern: /<\\?[\\s\\S]+?\\?>/,\n\t\tgreedy: true\n\t},\n\t'doctype': {\n\t\t// https://www.w3.org/TR/xml/#NT-doctypedecl\n\t\tpattern: /\"'[\\]]|\"[^\"]*\"|'[^']*')+(?:\\[(?:[^<\"'\\]]|\"[^\"]*\"|'[^']*'|<(?!!--)|)*\\]\\s*)?>/i,\n\t\tgreedy: true,\n\t\tinside: {\n\t\t\t'internal-subset': {\n\t\t\t\tpattern: /(^[^\\[]*\\[)[\\s\\S]+(?=\\]>$)/,\n\t\t\t\tlookbehind: true,\n\t\t\t\tgreedy: true,\n\t\t\t\tinside: null // see below\n\t\t\t},\n\t\t\t'string': {\n\t\t\t\tpattern: /\"[^\"]*\"|'[^']*'/,\n\t\t\t\tgreedy: true\n\t\t\t},\n\t\t\t'punctuation': /^$|[[\\]]/,\n\t\t\t'doctype-tag': /^DOCTYPE/i,\n\t\t\t'name': /[^\\s<>'\"]+/\n\t\t}\n\t},\n\t'cdata': {\n\t\tpattern: //i,\n\t\tgreedy: true\n\t},\n\t'tag': {\n\t\tpattern: /<\\/?(?!\\d)[^\\s>\\/=$<%]+(?:\\s(?:\\s*[^\\s>\\/=]+(?:\\s*=\\s*(?:\"[^\"]*\"|'[^']*'|[^\\s'\">=]+(?=[\\s>]))|(?=[\\s/>])))+)?\\s*\\/?>/,\n\t\tgreedy: true,\n\t\tinside: {\n\t\t\t'tag': {\n\t\t\t\tpattern: /^<\\/?[^\\s>\\/]+/,\n\t\t\t\tinside: {\n\t\t\t\t\t'punctuation': /^<\\/?/,\n\t\t\t\t\t'namespace': /^[^\\s>\\/:]+:/\n\t\t\t\t}\n\t\t\t},\n\t\t\t'special-attr': [],\n\t\t\t'attr-value': {\n\t\t\t\tpattern: /=\\s*(?:\"[^\"]*\"|'[^']*'|[^\\s'\">=]+)/,\n\t\t\t\tinside: {\n\t\t\t\t\t'punctuation': [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tpattern: /^=/,\n\t\t\t\t\t\t\talias: 'attr-equals'\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tpattern: /^(\\s*)[\"']|[\"']$/,\n\t\t\t\t\t\t\tlookbehind: true\n\t\t\t\t\t\t}\n\t\t\t\t\t]\n\t\t\t\t}\n\t\t\t},\n\t\t\t'punctuation': /\\/?>/,\n\t\t\t'attr-name': {\n\t\t\t\tpattern: /[^\\s>\\/]+/,\n\t\t\t\tinside: {\n\t\t\t\t\t'namespace': /^[^\\s>\\/:]+:/\n\t\t\t\t}\n\t\t\t}\n\n\t\t}\n\t},\n\t'entity': [\n\t\t{\n\t\t\tpattern: /&[\\da-z]{1,8};/i,\n\t\t\talias: 'named-entity'\n\t\t},\n\t\t/&#x?[\\da-f]{1,8};/i\n\t]\n};\n\nPrism.languages.markup['tag'].inside['attr-value'].inside['entity'] =\n\tPrism.languages.markup['entity'];\nPrism.languages.markup['doctype'].inside['internal-subset'].inside = Prism.languages.markup;\n\n// Plugin to make entity title show the real entity, idea by Roman Komarov\nPrism.hooks.add('wrap', function (env) {\n\n\tif (env.type === 'entity') {\n\t\tenv.attributes['title'] = env.content.replace(/&/, '&');\n\t}\n});\n\nObject.defineProperty(Prism.languages.markup.tag, 'addInlined', {\n\t/**\n\t * Adds an inlined language to markup.\n\t *\n\t * An example of an inlined language is CSS with `
\ No newline at end of file diff --git a/games/alphas/index.html b/games/alphas/index.html index 5fd6f08..cc286c4 100644 --- a/games/alphas/index.html +++ b/games/alphas/index.html @@ -1 +1 @@ -Adam Graham • Alphas
\ No newline at end of file +Adam Graham • Alphas

Alphas

June 2013|Team Lead, Lead Programmer & Designer
XNA
C#

Alphas is a top-down twin-stick shooter developed as a university project. The game consists of five interlinked deadly arenas, several unique weapons, and a multitude of engaging enemies lead by the alpha boss. Can you survive the swarm?

Media

GitHub
LinkedIn
Email
Dark Mode
Download
\ No newline at end of file diff --git a/games/ancient-odyssey/index.html b/games/ancient-odyssey/index.html index a378ec6..66cd972 100644 --- a/games/ancient-odyssey/index.html +++ b/games/ancient-odyssey/index.html @@ -1 +1 @@ -Adam Graham • Ancient Odyssey

Ancient Odyssey

November 2013|Lead Programmer, Producer, Designer
Adobe Flash
ActionScript 3.0

Ancient Odyssey is an "escape" puzzle game for mobile devices. Each level is individually designed to make you think harder and harder. Can you survive the journey to the underworld by plundering all 30 levels?

Media

Ancient Odyssey Screenshot
GitHub
LinkedIn
Email
Dark Mode
Play Game
\ No newline at end of file +Adam Graham • Ancient Odyssey

Ancient Odyssey

November 2013|Lead Programmer, Producer, Designer
Adobe Flash
ActionScript 3.0

Ancient Odyssey is an "escape" puzzle game for mobile devices. Each level is individually designed to make you think harder and harder. Can you survive the journey to the underworld by plundering all 30 levels?

Media

Ancient Odyssey Screenshot
GitHub
LinkedIn
Email
Dark Mode
Play Game
\ No newline at end of file diff --git a/games/boss-rush/index.html b/games/boss-rush/index.html index 37eec25..b2c2d97 100644 --- a/games/boss-rush/index.html +++ b/games/boss-rush/index.html @@ -1 +1 @@ -Adam Graham • Boss Rush

Boss Rush

November 2014|Gameplay & Systems Programmer
Unity
C#

Boss Rush is a top-down twin-stick shooter consisting of nothing but boss fights. Developed as a university project, the objective was to create a vertical slice of a complete game, thus it consists of one action-packed boss fight – the Spider Tank.

Media

GitHub
LinkedIn
Email
Dark Mode
Download
Source Code
\ No newline at end of file +Adam Graham • Boss Rush

Boss Rush

November 2014|Gameplay & Systems Programmer
Unity
C#

Boss Rush is a top-down twin-stick shooter consisting of nothing but boss fights. Developed as a university project, the objective was to create a vertical slice of a complete game, thus it consists of one action-packed boss fight – the Spider Tank.

Media

GitHub
LinkedIn
Email
Dark Mode
Download
Source Code
\ No newline at end of file diff --git a/games/elegy/index.html b/games/elegy/index.html index ec889e1..b93bb42 100644 --- a/games/elegy/index.html +++ b/games/elegy/index.html @@ -1 +1 @@ -Adam Graham • Elegy

Elegy

March 2015|Lead Programmer, Designer
Adobe Flash
ActionScript 3.0

Elegy is a deep game covering the five stages of grief as a parent deals with the loss of their child. The parent attends the funeral of their child and tries to rewind time to stop their child's death. The player engages in different scenes to figure out how they can stop the events from happening, but they must ultimately accept the death of their child.

Media

GitHub
LinkedIn
Email
Dark Mode
Download
Source Code
\ No newline at end of file +Adam Graham • Elegy

Elegy

March 2015|Lead Programmer, Designer
Adobe Flash
ActionScript 3.0

Elegy is a deep game covering the five stages of grief as a parent deals with the loss of their child. The parent attends the funeral of their child and tries to rewind time to stop their child's death. The player engages in different scenes to figure out how they can stop the events from happening, but they must ultimately accept the death of their child.

Media

GitHub
LinkedIn
Email
Dark Mode
Download
Source Code
\ No newline at end of file diff --git a/games/escape-the-basement/index.html b/games/escape-the-basement/index.html index fa51084..2dabd74 100644 --- a/games/escape-the-basement/index.html +++ b/games/escape-the-basement/index.html @@ -1 +1 @@ -Adam Graham • Escape the Basement

Escape the Basement

August 2012|Lead Programmer, Producer, Designer
Adobe Flash
ActionScript 3.0

Escape the Basement is a point-and-click adventure game. You of all people were chosen to die. A cruel man named Kane has locked you in his basement with no thought of letting you free. Can you outwit his evil plan and escape?

Media

Escape the Basement Screenshot
GitHub
LinkedIn
Email
Dark Mode
Play Game
\ No newline at end of file +Adam Graham • Escape the Basement

Escape the Basement

August 2012|Lead Programmer, Producer, Designer
Adobe Flash
ActionScript 3.0

Escape the Basement is a point-and-click adventure game. You of all people were chosen to die. A cruel man named Kane has locked you in his basement with no thought of letting you free. Can you outwit his evil plan and escape?

Media

Escape the Basement Screenshot
GitHub
LinkedIn
Email
Dark Mode
Play Game
\ No newline at end of file diff --git a/games/escape-the-estate/index.html b/games/escape-the-estate/index.html index 99f92e9..81c5210 100644 --- a/games/escape-the-estate/index.html +++ b/games/escape-the-estate/index.html @@ -1 +1 @@ -Adam Graham • Escape the Estate

Escape the Estate

August 2013|Lead Programmer, Producer, Designer, Artist
Adobe Flash
ActionScript 3.0

Escape the Estate is a point-and-click adventure game. Your life is on the line! Kane is at it again, and this time he is angry! Do you have what it takes to prevent his cruel intentions? Put your puzzle-solving skills to the test in the sequel to Escape the Basement!

Media

Escape the Estate Screenshot
GitHub
LinkedIn
Email
Dark Mode
Play Game
\ No newline at end of file +Adam Graham • Escape the Estate

Escape the Estate

August 2013|Lead Programmer, Producer, Designer, Artist
Adobe Flash
ActionScript 3.0

Escape the Estate is a point-and-click adventure game. Your life is on the line! Kane is at it again, and this time he is angry! Do you have what it takes to prevent his cruel intentions? Put your puzzle-solving skills to the test in the sequel to Escape the Basement!

Media

Escape the Estate Screenshot
GitHub
LinkedIn
Email
Dark Mode
Play Game
\ No newline at end of file diff --git a/games/ferro/index.html b/games/ferro/index.html index f1f8950..cd74f4e 100644 --- a/games/ferro/index.html +++ b/games/ferro/index.html @@ -1 +1 @@ -Adam Graham • Ferro

Ferro

April 2015|I/O Programmer
Unity
C#
Oculus Rift
Midi Keyboard

Inspired by ferrofluids, Ferro is a virtual reality experience created by Michael Louden and Adam Graham. As a scientist who has discovered a potential gateway into another universe, your job is to channel it to the right frequency. Players use a midi keyboard as the primary input device to initiate the machines and tune the portal.

Media

GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file +Adam Graham • Ferro

Ferro

April 2015|I/O Programmer
Unity
C#
Oculus Rift
Midi Keyboard

Inspired by ferrofluids, Ferro is a virtual reality experience created by Michael Louden and Adam Graham. As a scientist who has discovered a potential gateway into another universe, your job is to channel it to the right frequency. Players use a midi keyboard as the primary input device to initiate the machines and tune the portal.

Media

GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file diff --git a/games/hackathon-for-wildlife/index.html b/games/hackathon-for-wildlife/index.html index 6a7b295..b014a26 100644 --- a/games/hackathon-for-wildlife/index.html +++ b/games/hackathon-for-wildlife/index.html @@ -1 +1 @@ -Adam Graham • Hackathon for Wildlife

Hackathon for Wildlife

November 2015|Lead Programmer & Designer
Unity
C#

Developed in 24 hours during the Hackathon for Wildlife, the game is an empathetic and educational experience that teaches players about the dangers of poaching. By putting the player in the role of the elephant, it creates a deeper connection between the human and the animal.

"On November 14th and 15th over 60 people came together to explore and develop innovative ways to engage worldwide audiences with wild animals. The hackathon teams created amazing concepts through a combination of technologies that include GPS hardware, data, games, and social media to create a stronger, more vested connection between people and animals."

Media

GitHub
LinkedIn
Email
Dark Mode
Source Code
\ No newline at end of file +Adam Graham • Hackathon for Wildlife

Hackathon for Wildlife

November 2015|Lead Programmer & Designer
Unity
C#

Developed in 24 hours during the Hackathon for Wildlife, the game is an empathetic and educational experience that teaches players about the dangers of poaching. By putting the player in the role of the elephant, it creates a deeper connection between the human and the animal.

"On November 14th and 15th over 60 people came together to explore and develop innovative ways to engage worldwide audiences with wild animals. The hackathon teams created amazing concepts through a combination of technologies that include GPS hardware, data, games, and social media to create a stronger, more vested connection between people and animals."

Media

GitHub
LinkedIn
Email
Dark Mode
Source Code
\ No newline at end of file diff --git a/games/index.html b/games/index.html index df91186..f4b0b5e 100644 --- a/games/index.html +++ b/games/index.html @@ -1 +1 @@ -Adam Graham • Games
GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file +Adam Graham • Games
GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file diff --git a/games/lunar-escape/index.html b/games/lunar-escape/index.html index f157026..7dde2d6 100644 --- a/games/lunar-escape/index.html +++ b/games/lunar-escape/index.html @@ -1 +1 @@ -Adam Graham • Lunar Escape

Lunar Escape

September 2013|Lead Programmer, Producer, Designer, Artist
Adobe Flash
ActionScript 3.0

Lunar Escape is an "escape" puzzle game for mobile devices. Each level is individually designed to make you think harder and harder. Do you have the logical skills needed to transcend all 30 levels?

Media

Lunar Escape Screenshot
GitHub
LinkedIn
Email
Dark Mode
Play Game
\ No newline at end of file +Adam Graham • Lunar Escape

Lunar Escape

September 2013|Lead Programmer, Producer, Designer, Artist
Adobe Flash
ActionScript 3.0

Lunar Escape is an "escape" puzzle game for mobile devices. Each level is individually designed to make you think harder and harder. Do you have the logical skills needed to transcend all 30 levels?

Media

Lunar Escape Screenshot
GitHub
LinkedIn
Email
Dark Mode
Play Game
\ No newline at end of file diff --git a/games/squish-em/index.html b/games/squish-em/index.html index 8cc86d7..5cc59ec 100644 --- a/games/squish-em/index.html +++ b/games/squish-em/index.html @@ -1 +1 @@ -Adam Graham • Squish-em!

Squish-em!

April 2015|Lead Programmer, Producer, Designer
Adobe Flash
ActionScript 3.0
iOS

Squish-em! is a simple whack-a-mole re-creation designed for mobile devices. Squish your way to the top of the leaderboards, earn achievements along the way, and brag to your friends when you beat their best score! Do you have what it takes to become the best squisher around?

Media

Squish-em! Screenshot
GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file +Adam Graham • Squish-em!

Squish-em!

April 2015|Lead Programmer, Producer, Designer
Adobe Flash
ActionScript 3.0
iOS

Squish-em! is a simple whack-a-mole re-creation designed for mobile devices. Squish your way to the top of the leaderboards, earn achievements along the way, and brag to your friends when you beat their best score! Do you have what it takes to become the best squisher around?

Media

Squish-em! Screenshot
GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file diff --git a/games/the-rise/index.html b/games/the-rise/index.html index 9a976f8..9d94c96 100644 --- a/games/the-rise/index.html +++ b/games/the-rise/index.html @@ -1 +1 @@ -Adam Graham • The Rise

The Rise

July 2013|Lead Programmer, Producer, Designer
Adobe Flash
ActionScript 3.0

The Rise is an "escape" puzzle game for mobile devices. Each level is individually designed to make you think harder and harder. Put your logical skills to the test, rise to the top, and conquer all 30 levels.

Media

The Rise Screenshot
GitHub
LinkedIn
Email
Dark Mode
Play Game
\ No newline at end of file +Adam Graham • The Rise

The Rise

July 2013|Lead Programmer, Producer, Designer
Adobe Flash
ActionScript 3.0

The Rise is an "escape" puzzle game for mobile devices. Each level is individually designed to make you think harder and harder. Put your logical skills to the test, rise to the top, and conquer all 30 levels.

Media

The Rise Screenshot
GitHub
LinkedIn
Email
Dark Mode
Play Game
\ No newline at end of file diff --git a/games/the-wandering-dark/index.html b/games/the-wandering-dark/index.html index 51c24e5..50f7d94 100644 --- a/games/the-wandering-dark/index.html +++ b/games/the-wandering-dark/index.html @@ -1 +1 @@ -Adam Graham • The Wandering Dark

The Wandering Dark

June 2015|Lead Programmer, Co-Designer
Unity
C#

The Wandering Dark is an indie adventure game that takes you through a girl's dreams and nightmares. Explore her unique dream worlds, conquer her fears, and fight for survival as she matures and grows. Adam developed the game alongside Michael Louden for his senior capstone project before graduating from DePaul University.

Beta

Alpha

GitHub
LinkedIn
Email
Dark Mode
Download
\ No newline at end of file +Adam Graham • The Wandering Dark

The Wandering Dark

June 2015|Lead Programmer, Co-Designer
Unity
C#

The Wandering Dark is an indie adventure game that takes you through a girl's dreams and nightmares. Explore her unique dream worlds, conquer her fears, and fight for survival as she matures and grows. Adam developed the game alongside Michael Louden for his senior capstone project before graduating from DePaul University.

Beta

Alpha

GitHub
LinkedIn
Email
Dark Mode
Download
\ No newline at end of file diff --git a/index.html b/index.html index 7064473..dccd31f 100644 --- a/index.html +++ b/index.html @@ -1 +1 @@ -Adam Graham • Portfolio
Hello! 👋 My name is

Adam Graham

I'm a software engineer and game developer inspired by the blending of art, design, and engineering to create best in class user experiences. I love working on design centric projects across web and mobile having been a tech lead and UX engineer for many Fortune 500 clients over the past 10 years.

\ No newline at end of file +Adam Graham • Portfolio

Hello! 👋 My name is

Adam Graham

I'm a software engineer and game developer inspired by the blending of art, design, and engineering to create best in class user experiences.

\ No newline at end of file diff --git a/page-data/404.html/page-data.json b/page-data/404.html/page-data.json index 0e8fd4b..625486c 100644 --- a/page-data/404.html/page-data.json +++ b/page-data/404.html/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-404-js","path":"/404.html","result":{"pageContext":{}},"staticQueryHashes":[]} \ No newline at end of file +{"componentChunkName":"component---src-pages-404-tsx","path":"/404.html","result":{"pageContext":{}},"staticQueryHashes":[]} \ No newline at end of file diff --git a/page-data/404/page-data.json b/page-data/404/page-data.json index d54bff9..15646e5 100644 --- a/page-data/404/page-data.json +++ b/page-data/404/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-404-js","path":"/404","result":{"pageContext":{}},"staticQueryHashes":[]} \ No newline at end of file +{"componentChunkName":"component---src-pages-404-tsx","path":"/404","result":{"pageContext":{}},"staticQueryHashes":[]} \ No newline at end of file diff --git a/page-data/app-data.json b/page-data/app-data.json index a971954..4835173 100644 --- a/page-data/app-data.json +++ b/page-data/app-data.json @@ -1 +1 @@ -{"webpackCompilationHash":"e454a1ea7b91e6792a2d"} +{"webpackCompilationHash":"f7ac58186c70591b1439"} diff --git a/page-data/art/blackhole/page-data.json b/page-data/art/blackhole/page-data.json index e5eb0b6..1b63976 100644 --- a/page-data/art/blackhole/page-data.json +++ b/page-data/art/blackhole/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-art-art-json-json-id-js","path":"/art/blackhole","result":{"data":{"project":{"id":"blackhole","category":"art","title":"Blackhole","description":"Blackhole is a free-form, avant-garde game that enables players to control particles in unique ways. Individuals explore their own creative design within the art piece, loosely making their own objectives and discovering new ways of controlling this \"creative chaos\" - a new type of game genre.","description_short":"Blackhole is a free-form, avant-garde game that enables players to control particles in unique ways. Individuals explore their own creative design within the art piece, loosely making their own objectives and discovering new ways of controlling this \"creative chaos\".","description_long":null,"date":"January 2015","role":"Solo Project","tech":["Adobe Flash","ActionScript 3.0"],"image":{"sharp":{"original":{"src":"/static/blackhole-painting-ce57b1b3c9fb499010b3f451c327a4c0.jpg","width":1680,"height":840}}},"buttons":[{"name":"Download","url":"https://drive.google.com/file/d/14FD_603deu6C40w49c3u3vpvZOD9sDkA/view?usp=drive_link","icon":"download"},{"name":"Source Code","url":"https://github.com/adamgraham/blackhole","icon":"code"}],"sections":[{"title":"Media","link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/blackhole-screenshot-01-a0fe344f4895b16bac15b9f8c793b8d1.jpg","width":1678,"height":943}}},{"sharp":{"original":{"src":"/static/blackhole-screenshot-02-69803fe23d21e6e18df1e7cacd5a1d57.jpg","width":1678,"height":943}}},{"sharp":{"original":{"src":"/static/blackhole-screenshot-03-2a453fe8c3dfa77320419a0d5bdbb8f6.jpg","width":1678,"height":943}}}],"videos":["-rvjwFqjres"]}]}},"pageContext":{"id":"7ed24c47-d0c2-53b7-a9c9-bc7031ed053c","jsonId":"blackhole","__params":{"jsonId":"blackhole"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-art-art-json-json-id-tsx","path":"/art/blackhole","result":{"data":{"project":{"id":"blackhole","category":"art","title":"Blackhole","description":"Blackhole is a free-form, avant-garde game that enables players to control particles in unique ways. Individuals explore their own creative design within the art piece, loosely making their own objectives and discovering new ways of controlling this \"creative chaos\" - a new type of game genre.","description_short":"Blackhole is a free-form, avant-garde game that enables players to control particles in unique ways. Individuals explore their own creative design within the art piece, loosely making their own objectives and discovering new ways of controlling this \"creative chaos\".","description_long":null,"date":"January 2015","role":"Solo Project","tech":["Adobe Flash","ActionScript 3.0"],"image":{"sharp":{"original":{"src":"/static/blackhole-painting-ce57b1b3c9fb499010b3f451c327a4c0.jpg","width":1680,"height":840}}},"buttons":[{"to":"https://drive.google.com/file/d/14FD_603deu6C40w49c3u3vpvZOD9sDkA/view?usp=drive_link","name":"Download","icon":"download"},{"to":"https://github.com/adamgraham/blackhole","name":"Source Code","icon":"code"}],"sections":[{"title":"Media","link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/blackhole-screenshot-01-a0fe344f4895b16bac15b9f8c793b8d1.jpg","width":1678,"height":943}}},{"sharp":{"original":{"src":"/static/blackhole-screenshot-02-69803fe23d21e6e18df1e7cacd5a1d57.jpg","width":1678,"height":943}}},{"sharp":{"original":{"src":"/static/blackhole-screenshot-03-2a453fe8c3dfa77320419a0d5bdbb8f6.jpg","width":1678,"height":943}}}],"videos":["-rvjwFqjres"]}]}},"pageContext":{"id":"7ed24c47-d0c2-53b7-a9c9-bc7031ed053c","jsonId":"blackhole","__params":{"jsonId":"blackhole"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/art/canvas/page-data.json b/page-data/art/canvas/page-data.json index 6301dfd..b5fc5ba 100644 --- a/page-data/art/canvas/page-data.json +++ b/page-data/art/canvas/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-art-art-json-json-id-js","path":"/art/canvas","result":{"data":{"project":{"id":"canvas","category":"art","title":"Canvas","description":"Canvas is a never-ending, interactive painting. Alter the direction of the brushes to influence the painting or sit back and watch. Every thirty seconds the canvas is cleared and a new set of design principles are created. Learn to let go and design with the flow.","description_short":"Canvas is a never-ending, interactive painting. Alter the direction of the brushes to influence the painting. Every thirty seconds the canvas is cleared and a new set of design principles are created. Learn to let go and design with the flow.","description_long":null,"date":"March 2015","role":"Solo Project","tech":["Adobe Flash","ActionScript 3.0"],"image":{"sharp":{"original":{"src":"/static/canvas-painting-2201431580ef00d90383aed291502f8a.png","width":1380,"height":820}}},"buttons":[{"name":"Download","url":"https://drive.google.com/file/d/1WG-eI8QvhrFCTdRJlGesNV7vs7nddq6L/view?usp=drive_link","icon":"download"},{"name":"Source Code","url":"https://github.com/adamgraham/canvas","icon":"code"}],"sections":[{"title":"Media","link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/canvas-screenshot-01-34e5ac17af0852defea488436e0a9f8e.jpg","width":1280,"height":720}}},{"sharp":{"original":{"src":"/static/canvas-screenshot-02-f541224d3507dd491f4959796fa5414b.jpg","width":1280,"height":720}}}],"videos":["xXHhnwwRHIw"]}]}},"pageContext":{"id":"e83bb4e7-1ab0-59ee-9d0b-4ddf11c7a6af","jsonId":"canvas","__params":{"jsonId":"canvas"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-art-art-json-json-id-tsx","path":"/art/canvas","result":{"data":{"project":{"id":"canvas","category":"art","title":"Canvas","description":"Canvas is a never-ending, interactive painting. Alter the direction of the brushes to influence the painting or sit back and watch. Every thirty seconds the canvas is cleared and a new set of design principles are created. Learn to let go and design with the flow.","description_short":"Canvas is a never-ending, interactive painting. Alter the direction of the brushes to influence the painting. Every thirty seconds the canvas is cleared and a new set of design principles are created. Learn to let go and design with the flow.","description_long":null,"date":"March 2015","role":"Solo Project","tech":["Adobe Flash","ActionScript 3.0"],"image":{"sharp":{"original":{"src":"/static/canvas-painting-2201431580ef00d90383aed291502f8a.png","width":1380,"height":820}}},"buttons":[{"to":"https://drive.google.com/file/d/1WG-eI8QvhrFCTdRJlGesNV7vs7nddq6L/view?usp=drive_link","name":"Download","icon":"download"},{"to":"https://github.com/adamgraham/canvas","name":"Source Code","icon":"code"}],"sections":[{"title":"Media","link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/canvas-screenshot-01-34e5ac17af0852defea488436e0a9f8e.jpg","width":1280,"height":720}}},{"sharp":{"original":{"src":"/static/canvas-screenshot-02-f541224d3507dd491f4959796fa5414b.jpg","width":1280,"height":720}}}],"videos":["xXHhnwwRHIw"]}]}},"pageContext":{"id":"e83bb4e7-1ab0-59ee-9d0b-4ddf11c7a6af","jsonId":"canvas","__params":{"jsonId":"canvas"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/art/hexahedroniks/page-data.json b/page-data/art/hexahedroniks/page-data.json index 4afb9de..9c4f721 100644 --- a/page-data/art/hexahedroniks/page-data.json +++ b/page-data/art/hexahedroniks/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-art-art-json-json-id-js","path":"/art/hexahedroniks","result":{"data":{"project":{"id":"hexahedroniks","category":"art","title":"Hexahedroniks","description":"Hexahedroniks is a virtual reality, puzzle-like toy inspired by Rubik cubes. Paint the cube various colors by looking around and shooting colored orbs at the many faces. Avoid turning the cube all black while enjoying the calming experience of this art piece.","description_short":null,"description_long":null,"date":"June 2015","role":"Solo Project","tech":["Unity","C#","Oculus Rift"],"image":{"sharp":{"original":{"src":"/static/hexahedroniks-painting-4d13493a90b51eb7b9d0c4dd5e156d37.jpg","width":1680,"height":840}}},"buttons":[{"name":"Download","url":"https://drive.google.com/drive/folders/1uJo0g6eBtnyHLSCCmUatIQl80VX0UY_9?usp=drive_link","icon":"download"},{"name":"Source Code","url":"https://github.com/adamgraham/hexahedroniks","icon":"code"}],"sections":[{"title":"Media","link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/hexahedroniks-screenshot-01-b52554000fbe5122af437e64b1ff0bb0.jpg","width":1680,"height":940}}},{"sharp":{"original":{"src":"/static/hexahedroniks-screenshot-02-076153186eee975d24af1b12a5737c1b.jpg","width":1680,"height":940}}},{"sharp":{"original":{"src":"/static/hexahedroniks-screenshot-03-93f6445bbab33ddd426aba11dabb6af8.jpg","width":1680,"height":940}}}],"videos":["_QMCs2V_IA4"]}]}},"pageContext":{"id":"3ccb4c9c-84d1-5700-9dc1-991fd01039d0","jsonId":"hexahedroniks","__params":{"jsonId":"hexahedroniks"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-art-art-json-json-id-tsx","path":"/art/hexahedroniks","result":{"data":{"project":{"id":"hexahedroniks","category":"art","title":"Hexahedroniks","description":"Hexahedroniks is a virtual reality, puzzle-like toy inspired by Rubik cubes. Paint the cube various colors by looking around and shooting colored orbs at the many faces. Avoid turning the cube all black while enjoying the calming experience of this art piece.","description_short":null,"description_long":null,"date":"June 2015","role":"Solo Project","tech":["Unity","C#","Oculus Rift"],"image":{"sharp":{"original":{"src":"/static/hexahedroniks-painting-4d13493a90b51eb7b9d0c4dd5e156d37.jpg","width":1680,"height":840}}},"buttons":[{"to":"https://drive.google.com/drive/folders/1uJo0g6eBtnyHLSCCmUatIQl80VX0UY_9?usp=drive_link","name":"Download","icon":"download"},{"to":"https://github.com/adamgraham/hexahedroniks","name":"Source Code","icon":"code"}],"sections":[{"title":"Media","link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/hexahedroniks-screenshot-01-b52554000fbe5122af437e64b1ff0bb0.jpg","width":1680,"height":940}}},{"sharp":{"original":{"src":"/static/hexahedroniks-screenshot-02-076153186eee975d24af1b12a5737c1b.jpg","width":1680,"height":940}}},{"sharp":{"original":{"src":"/static/hexahedroniks-screenshot-03-93f6445bbab33ddd426aba11dabb6af8.jpg","width":1680,"height":940}}}],"videos":["_QMCs2V_IA4"]}]}},"pageContext":{"id":"3ccb4c9c-84d1-5700-9dc1-991fd01039d0","jsonId":"hexahedroniks","__params":{"jsonId":"hexahedroniks"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/art/mixed/page-data.json b/page-data/art/mixed/page-data.json index 021fb01..056259d 100644 --- a/page-data/art/mixed/page-data.json +++ b/page-data/art/mixed/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-art-art-json-json-id-js","path":"/art/mixed","result":{"data":{"project":{"id":"mixed","category":"art","title":"Mixed","description":"Mixed is an interactive, avant-garde experiment touching on the topics of diversity, racism, and interracial relationships. Navigate around in an abstract space, mixing with different colors to create AI-controlled players. Explore the effects of cultural diversity and see how diversity is (im)balanced in the world. What impact can you leave on the world?","description_short":"Mixed is an interactive, avant-garde experiment touching on the topics of diversity, racism, and interracial relationships. Navigate around mixing with different colors to create AI-controlled players. Explore the effects of cultural diversity and see how diversity is (im)balanced in the world.","description_long":null,"date":"February 2015","role":"Solo Project","tech":["Adobe Flash","ActionScript 3.0"],"image":{"sharp":{"original":{"src":"/static/mixed-painting-fcd381fb2cbd3d7e584a45dc0fae918f.jpg","width":1280,"height":640}}},"buttons":[{"name":"Download","url":"https://drive.google.com/file/d/1Sr5wxTQrm2jqemSOTLa0xlzYCEKysixm/view?usp=drive_link","icon":"download"},{"name":"Source Code","url":"https://github.com/adamgraham/mixed","icon":"code"}],"sections":[{"title":"Media","link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/mixed-screenshot-01-fb61758808b7cd1c8359972d59c09416.jpg","width":1280,"height":720}}},{"sharp":{"original":{"src":"/static/mixed-screenshot-02-330d5c5c34e925dedc8a4740c35cbe32.jpg","width":1280,"height":720}}}],"videos":["aMqgmqNu9Qw"]}]}},"pageContext":{"id":"64710f2b-474c-51c2-a05e-50db5216a8db","jsonId":"mixed","__params":{"jsonId":"mixed"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-art-art-json-json-id-tsx","path":"/art/mixed","result":{"data":{"project":{"id":"mixed","category":"art","title":"Mixed","description":"Mixed is an interactive, avant-garde experiment touching on the topics of diversity, racism, and interracial relationships. Navigate around in an abstract space, mixing with different colors to create AI-controlled players. Explore the effects of cultural diversity and see how diversity is (im)balanced in the world. What impact can you leave on the world?","description_short":"Mixed is an interactive, avant-garde experiment touching on the topics of diversity, racism, and interracial relationships. Navigate around mixing with different colors to create AI-controlled players. Explore the effects of cultural diversity and see how diversity is (im)balanced in the world.","description_long":null,"date":"February 2015","role":"Solo Project","tech":["Adobe Flash","ActionScript 3.0"],"image":{"sharp":{"original":{"src":"/static/mixed-painting-fcd381fb2cbd3d7e584a45dc0fae918f.jpg","width":1280,"height":640}}},"buttons":[{"to":"https://drive.google.com/file/d/1Sr5wxTQrm2jqemSOTLa0xlzYCEKysixm/view?usp=drive_link","name":"Download","icon":"download"},{"to":"https://github.com/adamgraham/mixed","name":"Source Code","icon":"code"}],"sections":[{"title":"Media","link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/mixed-screenshot-01-fb61758808b7cd1c8359972d59c09416.jpg","width":1280,"height":720}}},{"sharp":{"original":{"src":"/static/mixed-screenshot-02-330d5c5c34e925dedc8a4740c35cbe32.jpg","width":1280,"height":720}}}],"videos":["aMqgmqNu9Qw"]}]}},"pageContext":{"id":"64710f2b-474c-51c2-a05e-50db5216a8db","jsonId":"mixed","__params":{"jsonId":"mixed"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/art/page-data.json b/page-data/art/page-data.json index 8d37b89..9513a72 100644 --- a/page-data/art/page-data.json +++ b/page-data/art/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-art-js","path":"/art","result":{"data":{"json":{"slides":[{"id":"canvas","category":"art","date":"March 2015","title":"Canvas","description":"Canvas is a never-ending, interactive painting. Alter the direction of the brushes to influence the painting or sit back and watch. Every thirty seconds the canvas is cleared and a new set of design principles are created. Learn to let go and design with the flow.","description_short":"Canvas is a never-ending, interactive painting. Alter the direction of the brushes to influence the painting. Every thirty seconds the canvas is cleared and a new set of design principles are created. Learn to let go and design with the flow.","image":{"sharp":{"original":{"src":"/static/canvas-painting-2201431580ef00d90383aed291502f8a.png","width":1380,"height":820}}},"imageAltText":"Canvas Painting","imageBorder":"none"},{"id":"blackhole","category":"art","date":"January 2015","title":"Blackhole","description":"Blackhole is a free-form, avant-garde game that enables players to control particles in unique ways. Individuals explore their own creative design within the art piece, loosely making their own objectives and discovering new ways of controlling this \"creative chaos\" - a new type of game genre.","description_short":"Blackhole is a free-form, avant-garde game that enables players to control particles in unique ways. Individuals explore their own creative design within the art piece, loosely making their own objectives and discovering new ways of controlling this \"creative chaos\".","image":{"sharp":{"original":{"src":"/static/blackhole-painting-ce57b1b3c9fb499010b3f451c327a4c0.jpg","width":1680,"height":840}}},"imageAltText":"Blackhole Painting","imageBorder":null},{"id":"mixed","category":"art","date":"February 2015","title":"Mixed","description":"Mixed is an interactive, avant-garde experiment touching on the topics of diversity, racism, and interracial relationships. Navigate around in an abstract space, mixing with different colors to create AI-controlled players. Explore the effects of cultural diversity and see how diversity is (im)balanced in the world. What impact can you leave on the world?","description_short":"Mixed is an interactive, avant-garde experiment touching on the topics of diversity, racism, and interracial relationships. Navigate around mixing with different colors to create AI-controlled players. Explore the effects of cultural diversity and see how diversity is (im)balanced in the world.","image":{"sharp":{"original":{"src":"/static/mixed-painting-fcd381fb2cbd3d7e584a45dc0fae918f.jpg","width":1280,"height":640}}},"imageAltText":"Mixed Painting","imageBorder":null},{"id":"hexahedroniks","category":"art","date":"June 2015","title":"Hexahedroniks","description":"Hexahedroniks is a virtual reality, puzzle-like toy inspired by Rubik cubes. Paint the cube various colors by looking around and shooting colored orbs at the many faces. Avoid turning the cube all black while enjoying the calming experience of this art piece.","description_short":null,"image":{"sharp":{"original":{"src":"/static/hexahedroniks-painting-4d13493a90b51eb7b9d0c4dd5e156d37.jpg","width":1680,"height":840}}},"imageAltText":"Hexahedroniks Painting","imageBorder":null}]}},"pageContext":{}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-art-tsx","path":"/art","result":{"data":{"json":{"slides":[{"id":"canvas","category":"art","date":"March 2015","title":"Canvas","description":"Canvas is a never-ending, interactive painting. Alter the direction of the brushes to influence the painting or sit back and watch. Every thirty seconds the canvas is cleared and a new set of design principles are created. Learn to let go and design with the flow.","description_short":"Canvas is a never-ending, interactive painting. Alter the direction of the brushes to influence the painting. Every thirty seconds the canvas is cleared and a new set of design principles are created. Learn to let go and design with the flow.","image":{"sharp":{"original":{"src":"/static/canvas-painting-2201431580ef00d90383aed291502f8a.png","width":1380,"height":820}}},"imageAltText":"Canvas Painting","imageBorder":false},{"id":"blackhole","category":"art","date":"January 2015","title":"Blackhole","description":"Blackhole is a free-form, avant-garde game that enables players to control particles in unique ways. Individuals explore their own creative design within the art piece, loosely making their own objectives and discovering new ways of controlling this \"creative chaos\" - a new type of game genre.","description_short":"Blackhole is a free-form, avant-garde game that enables players to control particles in unique ways. Individuals explore their own creative design within the art piece, loosely making their own objectives and discovering new ways of controlling this \"creative chaos\".","image":{"sharp":{"original":{"src":"/static/blackhole-painting-ce57b1b3c9fb499010b3f451c327a4c0.jpg","width":1680,"height":840}}},"imageAltText":"Blackhole Painting","imageBorder":null},{"id":"mixed","category":"art","date":"February 2015","title":"Mixed","description":"Mixed is an interactive, avant-garde experiment touching on the topics of diversity, racism, and interracial relationships. Navigate around in an abstract space, mixing with different colors to create AI-controlled players. Explore the effects of cultural diversity and see how diversity is (im)balanced in the world. What impact can you leave on the world?","description_short":"Mixed is an interactive, avant-garde experiment touching on the topics of diversity, racism, and interracial relationships. Navigate around mixing with different colors to create AI-controlled players. Explore the effects of cultural diversity and see how diversity is (im)balanced in the world.","image":{"sharp":{"original":{"src":"/static/mixed-painting-fcd381fb2cbd3d7e584a45dc0fae918f.jpg","width":1280,"height":640}}},"imageAltText":"Mixed Painting","imageBorder":null},{"id":"hexahedroniks","category":"art","date":"June 2015","title":"Hexahedroniks","description":"Hexahedroniks is a virtual reality, puzzle-like toy inspired by Rubik cubes. Paint the cube various colors by looking around and shooting colored orbs at the many faces. Avoid turning the cube all black while enjoying the calming experience of this art piece.","description_short":null,"image":{"sharp":{"original":{"src":"/static/hexahedroniks-painting-4d13493a90b51eb7b9d0c4dd5e156d37.jpg","width":1680,"height":840}}},"imageAltText":"Hexahedroniks Painting","imageBorder":null}]}},"pageContext":{}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/gallery/page-data.json b/page-data/gallery/page-data.json new file mode 100644 index 0000000..efb34b7 --- /dev/null +++ b/page-data/gallery/page-data.json @@ -0,0 +1 @@ +{"componentChunkName":"component---src-pages-gallery-tsx","path":"/gallery","result":{"pageContext":{}},"staticQueryHashes":[]} \ No newline at end of file diff --git a/page-data/games/alphas/page-data.json b/page-data/games/alphas/page-data.json index 671614e..2dbbd3c 100644 --- a/page-data/games/alphas/page-data.json +++ b/page-data/games/alphas/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-games-games-json-json-id-js","path":"/games/alphas","result":{"data":{"project":{"id":"alphas","category":"games","title":"Alphas","description":"Alphas is a top-down twin-stick shooter developed as a university project. The game consists of five interlinked deadly arenas, several unique weapons, and a multitude of engaging enemies lead by the alpha boss. Can you survive the swarm?","description_short":null,"description_long":null,"date":"June 2013","role":"Team Lead, Lead Programmer & Designer","tech":["XNA","C#"],"image":{"sharp":{"original":{"src":"/static/alphas-painting-b30cd5e096e0c931e7c944358b2d3ae4.jpg","width":800,"height":380}}},"buttons":[{"name":"Download","url":"https://drive.google.com/file/d/1wfnwkmW56U3aYZ4cnrMFPZOIpwjYz-52/view?usp=drive_link","icon":"download"}],"sections":[{"title":"Media","link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/alphas-screenshot-01-9567054331fb8823e51a6d3ed045b302.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/alphas-screenshot-02-32ec60d684ca427e1d6cacc56b5ee411.jpg","width":800,"height":480}}}],"videos":["waZor8haeuY"]}]}},"pageContext":{"id":"05511c2e-00e7-578b-bbc5-6d8e5b5f117b","jsonId":"alphas","__params":{"jsonId":"alphas"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-games-games-json-json-id-tsx","path":"/games/alphas","result":{"data":{"project":{"id":"alphas","category":"games","title":"Alphas","description":"Alphas is a top-down twin-stick shooter developed as a university project. The game consists of five interlinked deadly arenas, several unique weapons, and a multitude of engaging enemies lead by the alpha boss. Can you survive the swarm?","description_short":null,"description_long":null,"date":"June 2013","role":"Team Lead, Lead Programmer & Designer","tech":["XNA","C#"],"image":{"sharp":{"original":{"src":"/static/alphas-painting-b30cd5e096e0c931e7c944358b2d3ae4.jpg","width":800,"height":380}}},"buttons":[{"to":"https://drive.google.com/file/d/1wfnwkmW56U3aYZ4cnrMFPZOIpwjYz-52/view?usp=drive_link","name":"Download","icon":"download"}],"sections":[{"title":"Media","link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/alphas-screenshot-01-9567054331fb8823e51a6d3ed045b302.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/alphas-screenshot-02-32ec60d684ca427e1d6cacc56b5ee411.jpg","width":800,"height":480}}}],"videos":["waZor8haeuY"]}]}},"pageContext":{"id":"05511c2e-00e7-578b-bbc5-6d8e5b5f117b","jsonId":"alphas","__params":{"jsonId":"alphas"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/games/ancient-odyssey/page-data.json b/page-data/games/ancient-odyssey/page-data.json index f7acece..cbd9e0f 100644 --- a/page-data/games/ancient-odyssey/page-data.json +++ b/page-data/games/ancient-odyssey/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-games-games-json-json-id-js","path":"/games/ancient-odyssey","result":{"data":{"project":{"id":"ancient-odyssey","category":"games","title":"Ancient Odyssey","description":"Ancient Odyssey is an \"escape\" puzzle game for mobile devices. Each level is individually designed to make you think harder and harder. Can you survive the journey to the underworld by plundering all 30 levels?","description_short":null,"description_long":null,"date":"November 2013","role":"Lead Programmer, Producer, Designer","tech":["Adobe Flash","ActionScript 3.0"],"image":{"sharp":{"original":{"src":"/static/ancient-odyssey-painting-59a5b2f87ad3d126a5d9d1a0b40294a7.jpg","width":800,"height":400}}},"buttons":[{"name":"Play Game","url":"https://www.newgrounds.com/portal/view/628001","icon":"play_circle"}],"sections":[{"title":"Media","link":null,"mainImage":{"sharp":{"original":{"src":"/static/ancient-odyssey-banner-444156a51bb7a4295c46454b4bb5b342.jpg","width":800,"height":250}}},"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/ancient-odyssey-screenshot-01-1aef375b549306e024a9c4652c1975a4.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/ancient-odyssey-screenshot-02-307d575849f65ad0217ce9e427cfe8f2.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/ancient-odyssey-screenshot-03-0c1b1ad14a8cee2acc6c8dd5e3b20289.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/ancient-odyssey-screenshot-04-d0ffa8eac4d117961b70aa7fce57f7df.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/ancient-odyssey-screenshot-05-87303976570f0d0191c87d2a246953fc.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/ancient-odyssey-screenshot-06-073b50af620f85025fe7f3c56dca3dfc.jpg","width":800,"height":480}}}],"videos":null}]}},"pageContext":{"id":"73568a66-4084-518f-a288-1528d1561bcb","jsonId":"ancient-odyssey","__params":{"jsonId":"ancient-odyssey"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-games-games-json-json-id-tsx","path":"/games/ancient-odyssey","result":{"data":{"project":{"id":"ancient-odyssey","category":"games","title":"Ancient Odyssey","description":"Ancient Odyssey is an \"escape\" puzzle game for mobile devices. Each level is individually designed to make you think harder and harder. Can you survive the journey to the underworld by plundering all 30 levels?","description_short":null,"description_long":null,"date":"November 2013","role":"Lead Programmer, Producer, Designer","tech":["Adobe Flash","ActionScript 3.0"],"image":{"sharp":{"original":{"src":"/static/ancient-odyssey-painting-59a5b2f87ad3d126a5d9d1a0b40294a7.jpg","width":800,"height":400}}},"buttons":[{"to":"https://www.newgrounds.com/portal/view/628001","name":"Play Game","icon":"play_circle"}],"sections":[{"title":"Media","link":null,"mainImage":{"sharp":{"original":{"src":"/static/ancient-odyssey-banner-444156a51bb7a4295c46454b4bb5b342.jpg","width":800,"height":250}}},"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/ancient-odyssey-screenshot-01-1aef375b549306e024a9c4652c1975a4.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/ancient-odyssey-screenshot-02-307d575849f65ad0217ce9e427cfe8f2.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/ancient-odyssey-screenshot-03-0c1b1ad14a8cee2acc6c8dd5e3b20289.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/ancient-odyssey-screenshot-04-d0ffa8eac4d117961b70aa7fce57f7df.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/ancient-odyssey-screenshot-05-87303976570f0d0191c87d2a246953fc.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/ancient-odyssey-screenshot-06-073b50af620f85025fe7f3c56dca3dfc.jpg","width":800,"height":480}}}],"videos":null}]}},"pageContext":{"id":"73568a66-4084-518f-a288-1528d1561bcb","jsonId":"ancient-odyssey","__params":{"jsonId":"ancient-odyssey"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/games/boss-rush/page-data.json b/page-data/games/boss-rush/page-data.json index be81cde..217f9eb 100644 --- a/page-data/games/boss-rush/page-data.json +++ b/page-data/games/boss-rush/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-games-games-json-json-id-js","path":"/games/boss-rush","result":{"data":{"project":{"id":"boss-rush","category":"games","title":"Boss Rush","description":"Boss Rush is a top-down twin-stick shooter consisting of nothing but boss fights. Developed as a university project, the objective was to create a vertical slice of a complete game, thus it consists of one action-packed boss fight – the Spider Tank.","description_short":null,"description_long":null,"date":"November 2014","role":"Gameplay & Systems Programmer","tech":["Unity","C#"],"image":{"sharp":{"original":{"src":"/static/boss-rush-painting-b2339ec284e2424c331883a20e30fbf1.jpg","width":1920,"height":960}}},"buttons":[{"name":"Download","url":"https://github.com/ModSquadWorkshop/BossRush/releases","icon":"download"},{"name":"Source Code","url":"https://github.com/adamgraham/boss-rush","icon":"code"}],"sections":[{"title":"Media","link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/boss-rush-screenshot-01-f8f30c84bb960c9b367b0daf8be1233a.jpg","width":1920,"height":1015}}},{"sharp":{"original":{"src":"/static/boss-rush-screenshot-02-46ac589d35c4643ca7de3e307d1dedf2.jpg","width":1920,"height":1015}}}],"videos":["mbLD45xPQME"]}]}},"pageContext":{"id":"1b0f3b29-ef5c-5ade-8a2f-73dc92c7f4f3","jsonId":"boss-rush","__params":{"jsonId":"boss-rush"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-games-games-json-json-id-tsx","path":"/games/boss-rush","result":{"data":{"project":{"id":"boss-rush","category":"games","title":"Boss Rush","description":"Boss Rush is a top-down twin-stick shooter consisting of nothing but boss fights. Developed as a university project, the objective was to create a vertical slice of a complete game, thus it consists of one action-packed boss fight – the Spider Tank.","description_short":null,"description_long":null,"date":"November 2014","role":"Gameplay & Systems Programmer","tech":["Unity","C#"],"image":{"sharp":{"original":{"src":"/static/boss-rush-painting-b2339ec284e2424c331883a20e30fbf1.jpg","width":1920,"height":960}}},"buttons":[{"to":"https://github.com/ModSquadWorkshop/BossRush/releases","name":"Download","icon":"download"},{"to":"https://github.com/adamgraham/boss-rush","name":"Source Code","icon":"code"}],"sections":[{"title":"Media","link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/boss-rush-screenshot-01-f8f30c84bb960c9b367b0daf8be1233a.jpg","width":1920,"height":1015}}},{"sharp":{"original":{"src":"/static/boss-rush-screenshot-02-46ac589d35c4643ca7de3e307d1dedf2.jpg","width":1920,"height":1015}}}],"videos":["mbLD45xPQME"]}]}},"pageContext":{"id":"1b0f3b29-ef5c-5ade-8a2f-73dc92c7f4f3","jsonId":"boss-rush","__params":{"jsonId":"boss-rush"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/games/elegy/page-data.json b/page-data/games/elegy/page-data.json index 048eb62..2ca1868 100644 --- a/page-data/games/elegy/page-data.json +++ b/page-data/games/elegy/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-games-games-json-json-id-js","path":"/games/elegy","result":{"data":{"project":{"id":"elegy","category":"games","title":"Elegy","description":"Elegy is a deep game covering the five stages of grief as a parent deals with the loss of their child. The parent attends the funeral of their child and tries to rewind time to stop their child's death. The player engages in different scenes to figure out how they can stop the events from happening, but they must ultimately accept the death of their child.","description_short":"Elegy is a deep game covering the five stages of grief as a parent deals with the loss of their child. While attending the funeral, they try to rewind time to stop the tragedy but they must ultimatley accept the death of their child.","description_long":null,"date":"March 2015","role":"Lead Programmer, Designer","tech":["Adobe Flash","ActionScript 3.0"],"image":{"sharp":{"original":{"src":"/static/elegy-painting-c740be5d8c41cb8756acfab75b735d61.jpg","width":1280,"height":620}}},"buttons":[{"name":"Download","url":"https://drive.google.com/file/d/1VOryTrKiH_2HlJKeO_CmzNbVjCrU7wRr/view?usp=drive_link","icon":"download"},{"name":"Source Code","url":"https://github.com/adamgraham/elegy","icon":"code"}],"sections":[{"title":"Media","link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/elegy-screenshot-01-392fee680ae0de4020febde6a14f4e86.jpg","width":1280,"height":720}}},{"sharp":{"original":{"src":"/static/elegy-screenshot-02-b3162443f12147b0d9f2f0fc556343d6.jpg","width":1280,"height":720}}}],"videos":["KQxgLDEK05g"]}]}},"pageContext":{"id":"5a39bfb1-8f32-53da-b304-e9176953b77f","jsonId":"elegy","__params":{"jsonId":"elegy"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-games-games-json-json-id-tsx","path":"/games/elegy","result":{"data":{"project":{"id":"elegy","category":"games","title":"Elegy","description":"Elegy is a deep game covering the five stages of grief as a parent deals with the loss of their child. The parent attends the funeral of their child and tries to rewind time to stop their child's death. The player engages in different scenes to figure out how they can stop the events from happening, but they must ultimately accept the death of their child.","description_short":"Elegy is a deep game covering the five stages of grief as a parent deals with the loss of their child. While attending the funeral, they try to rewind time to stop the tragedy but they must ultimatley accept the death of their child.","description_long":null,"date":"March 2015","role":"Lead Programmer, Designer","tech":["Adobe Flash","ActionScript 3.0"],"image":{"sharp":{"original":{"src":"/static/elegy-painting-c740be5d8c41cb8756acfab75b735d61.jpg","width":1280,"height":620}}},"buttons":[{"to":"https://drive.google.com/file/d/1VOryTrKiH_2HlJKeO_CmzNbVjCrU7wRr/view?usp=drive_link","name":"Download","icon":"download"},{"to":"https://github.com/adamgraham/elegy","name":"Source Code","icon":"code"}],"sections":[{"title":"Media","link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/elegy-screenshot-01-392fee680ae0de4020febde6a14f4e86.jpg","width":1280,"height":720}}},{"sharp":{"original":{"src":"/static/elegy-screenshot-02-b3162443f12147b0d9f2f0fc556343d6.jpg","width":1280,"height":720}}}],"videos":["KQxgLDEK05g"]}]}},"pageContext":{"id":"5a39bfb1-8f32-53da-b304-e9176953b77f","jsonId":"elegy","__params":{"jsonId":"elegy"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/games/escape-the-basement/page-data.json b/page-data/games/escape-the-basement/page-data.json index 3945839..164d137 100644 --- a/page-data/games/escape-the-basement/page-data.json +++ b/page-data/games/escape-the-basement/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-games-games-json-json-id-js","path":"/games/escape-the-basement","result":{"data":{"project":{"id":"escape-the-basement","category":"games","title":"Escape the Basement","description":"Escape the Basement is a point-and-click adventure game. You of all people were chosen to die. A cruel man named Kane has locked you in his basement with no thought of letting you free. Can you outwit his evil plan and escape?","description_short":null,"description_long":null,"date":"August 2012","role":"Lead Programmer, Producer, Designer","tech":["Adobe Flash","ActionScript 3.0"],"image":{"sharp":{"original":{"src":"/static/escape-the-basement-painting-e8eaa3ea9847059180b86d174b4bea2b.jpg","width":800,"height":535}}},"buttons":[{"name":"Play Game","url":"https://www.newgrounds.com/portal/view/601869","icon":"play_circle"}],"sections":[{"title":"Media","link":null,"mainImage":{"sharp":{"original":{"src":"/static/escape-the-basement-banner-2bb806c48d312046e23ab653a0d670aa.jpg","width":800,"height":250}}},"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/escape-the-basement-screenshot-01-8dc4905470de12cd953274ff2707999c.jpg","width":800,"height":535}}},{"sharp":{"original":{"src":"/static/escape-the-basement-screenshot-02-5fe7bf0103ba3b96fdc7aaa826454c98.jpg","width":800,"height":535}}},{"sharp":{"original":{"src":"/static/escape-the-basement-screenshot-03-22de70af7d2a59a68e19451360dffd60.jpg","width":800,"height":535}}},{"sharp":{"original":{"src":"/static/escape-the-basement-screenshot-04-2ff2269e0f1ce0b4bfbc7fa0803b4a19.jpg","width":800,"height":535}}},{"sharp":{"original":{"src":"/static/escape-the-basement-screenshot-05-ec593e1261731c21fcb4d7262a07265f.jpg","width":800,"height":535}}},{"sharp":{"original":{"src":"/static/escape-the-basement-screenshot-06-ddffab3b7de6b4300ee25fa9f05bd0ee.jpg","width":800,"height":535}}}],"videos":null}]}},"pageContext":{"id":"4c83c759-12a2-50aa-815e-e0ece9a0b1db","jsonId":"escape-the-basement","__params":{"jsonId":"escape-the-basement"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-games-games-json-json-id-tsx","path":"/games/escape-the-basement","result":{"data":{"project":{"id":"escape-the-basement","category":"games","title":"Escape the Basement","description":"Escape the Basement is a point-and-click adventure game. You of all people were chosen to die. A cruel man named Kane has locked you in his basement with no thought of letting you free. Can you outwit his evil plan and escape?","description_short":null,"description_long":null,"date":"August 2012","role":"Lead Programmer, Producer, Designer","tech":["Adobe Flash","ActionScript 3.0"],"image":{"sharp":{"original":{"src":"/static/escape-the-basement-painting-e8eaa3ea9847059180b86d174b4bea2b.jpg","width":800,"height":535}}},"buttons":[{"to":"https://www.newgrounds.com/portal/view/601869","name":"Play Game","icon":"play_circle"}],"sections":[{"title":"Media","link":null,"mainImage":{"sharp":{"original":{"src":"/static/escape-the-basement-banner-2bb806c48d312046e23ab653a0d670aa.jpg","width":800,"height":250}}},"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/escape-the-basement-screenshot-01-8dc4905470de12cd953274ff2707999c.jpg","width":800,"height":535}}},{"sharp":{"original":{"src":"/static/escape-the-basement-screenshot-02-5fe7bf0103ba3b96fdc7aaa826454c98.jpg","width":800,"height":535}}},{"sharp":{"original":{"src":"/static/escape-the-basement-screenshot-03-22de70af7d2a59a68e19451360dffd60.jpg","width":800,"height":535}}},{"sharp":{"original":{"src":"/static/escape-the-basement-screenshot-04-2ff2269e0f1ce0b4bfbc7fa0803b4a19.jpg","width":800,"height":535}}},{"sharp":{"original":{"src":"/static/escape-the-basement-screenshot-05-ec593e1261731c21fcb4d7262a07265f.jpg","width":800,"height":535}}},{"sharp":{"original":{"src":"/static/escape-the-basement-screenshot-06-ddffab3b7de6b4300ee25fa9f05bd0ee.jpg","width":800,"height":535}}}],"videos":null}]}},"pageContext":{"id":"4c83c759-12a2-50aa-815e-e0ece9a0b1db","jsonId":"escape-the-basement","__params":{"jsonId":"escape-the-basement"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/games/escape-the-estate/page-data.json b/page-data/games/escape-the-estate/page-data.json index 73cf868..4dcab71 100644 --- a/page-data/games/escape-the-estate/page-data.json +++ b/page-data/games/escape-the-estate/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-games-games-json-json-id-js","path":"/games/escape-the-estate","result":{"data":{"project":{"id":"escape-the-estate","category":"games","title":"Escape the Estate","description":"Escape the Estate is a point-and-click adventure game. Your life is on the line! Kane is at it again, and this time he is angry! Do you have what it takes to prevent his cruel intentions? Put your puzzle-solving skills to the test in the sequel to Escape the Basement!","description_short":null,"description_long":null,"date":"August 2013","role":"Lead Programmer, Producer, Designer, Artist","tech":["Adobe Flash","ActionScript 3.0"],"image":{"sharp":{"original":{"src":"/static/escape-the-estate-painting-94c6124b5af649da24c14859698dc218.jpg","width":640,"height":480}}},"buttons":[{"name":"Play Game","url":"https://www.newgrounds.com/portal/view/622915","icon":"play_circle"}],"sections":[{"title":"Media","link":null,"mainImage":{"sharp":{"original":{"src":"/static/escape-the-estate-banner-f7f1723db0d63e263d4cc162a7fc4fef.jpg","width":800,"height":250}}},"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/escape-the-estate-screenshot-01-e6552a9a00e1653e009631a6c3ec6c82.jpg","width":640,"height":480}}},{"sharp":{"original":{"src":"/static/escape-the-estate-screenshot-02-5c6d58b7d46e33d6aa9d1cc17f491919.jpg","width":640,"height":480}}},{"sharp":{"original":{"src":"/static/escape-the-estate-screenshot-03-2436064ef9eada0c45d92788d0e68398.jpg","width":640,"height":480}}},{"sharp":{"original":{"src":"/static/escape-the-estate-screenshot-04-b41c3f79c88b57692d5e5b2a3a4dd905.jpg","width":640,"height":480}}},{"sharp":{"original":{"src":"/static/escape-the-estate-screenshot-05-50608cc8437c42f1edbbddb38171ae51.jpg","width":640,"height":480}}},{"sharp":{"original":{"src":"/static/escape-the-estate-screenshot-06-fda62aea58ea4d359c79b49cae099c96.jpg","width":640,"height":480}}},{"sharp":{"original":{"src":"/static/escape-the-estate-screenshot-07-b8e48ef1a00a72d7b657897601438f52.jpg","width":640,"height":480}}}],"videos":null}]}},"pageContext":{"id":"70b1a1fd-19df-52e0-b7d2-0f132df427b7","jsonId":"escape-the-estate","__params":{"jsonId":"escape-the-estate"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-games-games-json-json-id-tsx","path":"/games/escape-the-estate","result":{"data":{"project":{"id":"escape-the-estate","category":"games","title":"Escape the Estate","description":"Escape the Estate is a point-and-click adventure game. Your life is on the line! Kane is at it again, and this time he is angry! Do you have what it takes to prevent his cruel intentions? Put your puzzle-solving skills to the test in the sequel to Escape the Basement!","description_short":null,"description_long":null,"date":"August 2013","role":"Lead Programmer, Producer, Designer, Artist","tech":["Adobe Flash","ActionScript 3.0"],"image":{"sharp":{"original":{"src":"/static/escape-the-estate-painting-94c6124b5af649da24c14859698dc218.jpg","width":640,"height":480}}},"buttons":[{"to":"https://www.newgrounds.com/portal/view/622915","name":"Play Game","icon":"play_circle"}],"sections":[{"title":"Media","link":null,"mainImage":{"sharp":{"original":{"src":"/static/escape-the-estate-banner-f7f1723db0d63e263d4cc162a7fc4fef.jpg","width":800,"height":250}}},"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/escape-the-estate-screenshot-01-e6552a9a00e1653e009631a6c3ec6c82.jpg","width":640,"height":480}}},{"sharp":{"original":{"src":"/static/escape-the-estate-screenshot-02-5c6d58b7d46e33d6aa9d1cc17f491919.jpg","width":640,"height":480}}},{"sharp":{"original":{"src":"/static/escape-the-estate-screenshot-03-2436064ef9eada0c45d92788d0e68398.jpg","width":640,"height":480}}},{"sharp":{"original":{"src":"/static/escape-the-estate-screenshot-04-b41c3f79c88b57692d5e5b2a3a4dd905.jpg","width":640,"height":480}}},{"sharp":{"original":{"src":"/static/escape-the-estate-screenshot-05-50608cc8437c42f1edbbddb38171ae51.jpg","width":640,"height":480}}},{"sharp":{"original":{"src":"/static/escape-the-estate-screenshot-06-fda62aea58ea4d359c79b49cae099c96.jpg","width":640,"height":480}}},{"sharp":{"original":{"src":"/static/escape-the-estate-screenshot-07-b8e48ef1a00a72d7b657897601438f52.jpg","width":640,"height":480}}}],"videos":null}]}},"pageContext":{"id":"70b1a1fd-19df-52e0-b7d2-0f132df427b7","jsonId":"escape-the-estate","__params":{"jsonId":"escape-the-estate"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/games/ferro/page-data.json b/page-data/games/ferro/page-data.json index 12d108e..402f18f 100644 --- a/page-data/games/ferro/page-data.json +++ b/page-data/games/ferro/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-games-games-json-json-id-js","path":"/games/ferro","result":{"data":{"project":{"id":"ferro","category":"games","title":"Ferro","description":"Inspired by ferrofluids, Ferro is a virtual reality experience created by Michael Louden and Adam Graham. As a scientist who has discovered a potential gateway into another universe, your job is to channel it to the right frequency. Players use a midi keyboard as the primary input device to initiate the machines and tune the portal.","description_short":"Ferro is a virtual reality experience inspired by ferrofluids. As a scientist who has discovered a potential gateway into another universe, your job is to channel it to the right frequency using a midi keyboard as the primary input device.","description_long":null,"date":"April 2015","role":"I/O Programmer","tech":["Unity","C#","Oculus Rift","Midi Keyboard"],"image":{"sharp":{"original":{"src":"/static/ferro-painting-1fa5cc35a12c4c391a1b6decc8a66a9f.jpg","width":1920,"height":900}}},"buttons":null,"sections":[{"title":"Media","link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/ferro-screenshot-01-cdfbf4aca5b2eade50b61f9cbe6ac362.jpg","width":1920,"height":910}}},{"sharp":{"original":{"src":"/static/ferro-screenshot-02-deb5fe24eb6f7346c3e824380eb4302f.jpg","width":1920,"height":910}}}],"videos":["nybrBOkmNkM"]}]}},"pageContext":{"id":"0b8f053d-a4f9-5280-b575-7ebc41966b8b","jsonId":"ferro","__params":{"jsonId":"ferro"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-games-games-json-json-id-tsx","path":"/games/ferro","result":{"data":{"project":{"id":"ferro","category":"games","title":"Ferro","description":"Inspired by ferrofluids, Ferro is a virtual reality experience created by Michael Louden and Adam Graham. As a scientist who has discovered a potential gateway into another universe, your job is to channel it to the right frequency. Players use a midi keyboard as the primary input device to initiate the machines and tune the portal.","description_short":"Ferro is a virtual reality experience inspired by ferrofluids. As a scientist who has discovered a potential gateway into another universe, your job is to channel it to the right frequency using a midi keyboard as the primary input device.","description_long":null,"date":"April 2015","role":"I/O Programmer","tech":["Unity","C#","Oculus Rift","Midi Keyboard"],"image":{"sharp":{"original":{"src":"/static/ferro-painting-1fa5cc35a12c4c391a1b6decc8a66a9f.jpg","width":1920,"height":900}}},"buttons":null,"sections":[{"title":"Media","link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/ferro-screenshot-01-cdfbf4aca5b2eade50b61f9cbe6ac362.jpg","width":1920,"height":910}}},{"sharp":{"original":{"src":"/static/ferro-screenshot-02-deb5fe24eb6f7346c3e824380eb4302f.jpg","width":1920,"height":910}}}],"videos":["nybrBOkmNkM"]}]}},"pageContext":{"id":"0b8f053d-a4f9-5280-b575-7ebc41966b8b","jsonId":"ferro","__params":{"jsonId":"ferro"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/games/hackathon-for-wildlife/page-data.json b/page-data/games/hackathon-for-wildlife/page-data.json index d10354f..b889ac5 100644 --- a/page-data/games/hackathon-for-wildlife/page-data.json +++ b/page-data/games/hackathon-for-wildlife/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-games-games-json-json-id-js","path":"/games/hackathon-for-wildlife","result":{"data":{"project":{"id":"hackathon-for-wildlife","category":"games","title":"Hackathon for Wildlife","description":null,"description_short":"An empathetic and educational experience that teaches players about the dangers of poaching. By putting the player in the role of the elephant, it creates a deeper connection between the human and the animal.","description_long":["Developed in 24 hours during the Hackathon for Wildlife, the game is an empathetic and educational experience that teaches players about the dangers of poaching. By putting the player in the role of the elephant, it creates a deeper connection between the human and the animal.","\"On November 14th and 15th over 60 people came together to explore and develop innovative ways to engage worldwide audiences with wild animals. The hackathon teams created amazing concepts through a combination of technologies that include GPS hardware, data, games, and social media to create a stronger, more vested connection between people and animals.\""],"date":"November 2015","role":"Lead Programmer & Designer","tech":["Unity","C#"],"image":{"sharp":{"original":{"src":"/static/hackathon-for-wildlife-painting-ccf9c600d554f105d20ff2975c9b71b2.jpg","width":2560,"height":1260}}},"buttons":[{"name":"Source Code","url":"https://github.com/adamgraham/hackathon-for-wildlife","icon":"code"}],"sections":[{"title":"Media","link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/hackathon-for-wildlife-screenshot-01-c390a2d9084e35fbcdcb87f6362bd306.jpg","width":2560,"height":1269}}},{"sharp":{"original":{"src":"/static/hackathon-for-wildlife-screenshot-02-69810c6d8d60122d0a77ef8a1712baf1.jpg","width":2560,"height":1269}}}],"videos":["VXWw1CmOkEw"]}]}},"pageContext":{"id":"0629c944-9b6f-5827-9136-dc6c31d0e0e2","jsonId":"hackathon-for-wildlife","__params":{"jsonId":"hackathon-for-wildlife"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-games-games-json-json-id-tsx","path":"/games/hackathon-for-wildlife","result":{"data":{"project":{"id":"hackathon-for-wildlife","category":"games","title":"Hackathon for Wildlife","description":null,"description_short":"An empathetic and educational experience that teaches players about the dangers of poaching. By putting the player in the role of the elephant, it creates a deeper connection between the human and the animal.","description_long":["Developed in 24 hours during the Hackathon for Wildlife, the game is an empathetic and educational experience that teaches players about the dangers of poaching. By putting the player in the role of the elephant, it creates a deeper connection between the human and the animal.","\"On November 14th and 15th over 60 people came together to explore and develop innovative ways to engage worldwide audiences with wild animals. The hackathon teams created amazing concepts through a combination of technologies that include GPS hardware, data, games, and social media to create a stronger, more vested connection between people and animals.\""],"date":"November 2015","role":"Lead Programmer & Designer","tech":["Unity","C#"],"image":{"sharp":{"original":{"src":"/static/hackathon-for-wildlife-painting-ccf9c600d554f105d20ff2975c9b71b2.jpg","width":2560,"height":1260}}},"buttons":[{"to":"https://github.com/adamgraham/hackathon-for-wildlife","name":"Source Code","icon":"code"}],"sections":[{"title":"Media","link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/hackathon-for-wildlife-screenshot-01-c390a2d9084e35fbcdcb87f6362bd306.jpg","width":2560,"height":1269}}},{"sharp":{"original":{"src":"/static/hackathon-for-wildlife-screenshot-02-69810c6d8d60122d0a77ef8a1712baf1.jpg","width":2560,"height":1269}}}],"videos":["VXWw1CmOkEw"]}]}},"pageContext":{"id":"0629c944-9b6f-5827-9136-dc6c31d0e0e2","jsonId":"hackathon-for-wildlife","__params":{"jsonId":"hackathon-for-wildlife"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/games/lunar-escape/page-data.json b/page-data/games/lunar-escape/page-data.json index 0c69a14..b11d03f 100644 --- a/page-data/games/lunar-escape/page-data.json +++ b/page-data/games/lunar-escape/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-games-games-json-json-id-js","path":"/games/lunar-escape","result":{"data":{"project":{"id":"lunar-escape","category":"games","title":"Lunar Escape","description":"Lunar Escape is an \"escape\" puzzle game for mobile devices. Each level is individually designed to make you think harder and harder. Do you have the logical skills needed to transcend all 30 levels?","description_short":null,"description_long":null,"date":"September 2013","role":"Lead Programmer, Producer, Designer, Artist","tech":["Adobe Flash","ActionScript 3.0"],"image":{"sharp":{"original":{"src":"/static/lunar-escape-painting-d260a732497ade1dce42ac320185b113.jpg","width":800,"height":400}}},"buttons":[{"name":"Play Game","url":"https://www.newgrounds.com/portal/view/625640","icon":"play_circle"}],"sections":[{"title":"Media","link":null,"mainImage":{"sharp":{"original":{"src":"/static/lunar-escape-banner-665db3a21d2af34d6bb7201fe91475a3.jpg","width":800,"height":250}}},"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/lunar-escape-screenshot-01-b1896f9d793a9b95534d629485564eb7.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/lunar-escape-screenshot-02-5eca689a344cf5f86989dddbc9f20527.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/lunar-escape-screenshot-03-f1c59b788accc4de1adee94f3786f47d.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/lunar-escape-screenshot-04-c731cf97686ac28e729aaf30141066bd.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/lunar-escape-screenshot-05-7903c3bc7b7bc70545e01ee5928b002f.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/lunar-escape-screenshot-06-d63d07341167e344c5eaea756009b00d.jpg","width":800,"height":480}}}],"videos":null}]}},"pageContext":{"id":"2a2b4431-cf57-5e3f-bcd3-01bb045a1171","jsonId":"lunar-escape","__params":{"jsonId":"lunar-escape"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-games-games-json-json-id-tsx","path":"/games/lunar-escape","result":{"data":{"project":{"id":"lunar-escape","category":"games","title":"Lunar Escape","description":"Lunar Escape is an \"escape\" puzzle game for mobile devices. Each level is individually designed to make you think harder and harder. Do you have the logical skills needed to transcend all 30 levels?","description_short":null,"description_long":null,"date":"September 2013","role":"Lead Programmer, Producer, Designer, Artist","tech":["Adobe Flash","ActionScript 3.0"],"image":{"sharp":{"original":{"src":"/static/lunar-escape-painting-d260a732497ade1dce42ac320185b113.jpg","width":800,"height":400}}},"buttons":[{"to":"https://www.newgrounds.com/portal/view/625640","name":"Play Game","icon":"play_circle"}],"sections":[{"title":"Media","link":null,"mainImage":{"sharp":{"original":{"src":"/static/lunar-escape-banner-665db3a21d2af34d6bb7201fe91475a3.jpg","width":800,"height":250}}},"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/lunar-escape-screenshot-01-b1896f9d793a9b95534d629485564eb7.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/lunar-escape-screenshot-02-5eca689a344cf5f86989dddbc9f20527.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/lunar-escape-screenshot-03-f1c59b788accc4de1adee94f3786f47d.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/lunar-escape-screenshot-04-c731cf97686ac28e729aaf30141066bd.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/lunar-escape-screenshot-05-7903c3bc7b7bc70545e01ee5928b002f.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/lunar-escape-screenshot-06-d63d07341167e344c5eaea756009b00d.jpg","width":800,"height":480}}}],"videos":null}]}},"pageContext":{"id":"2a2b4431-cf57-5e3f-bcd3-01bb045a1171","jsonId":"lunar-escape","__params":{"jsonId":"lunar-escape"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/games/page-data.json b/page-data/games/page-data.json index b6dd123..9821dd8 100644 --- a/page-data/games/page-data.json +++ b/page-data/games/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-games-js","path":"/games","result":{"data":{"json":{"slides":[{"id":"the-wandering-dark","category":"games","date":"June 2015","title":"The Wandering Dark","description":"The Wandering Dark is an indie adventure game that takes you through a girl's dreams and nightmares. Explore her unique dream worlds, conquer her fears, and fight for survival as she matures and grows. Adam developed the game alongside Michael Louden for his senior capstone project before graduating from DePaul University.","description_short":"The Wandering Dark is an indie adventure game that takes you through a girl's dreams and nightmares. Explore her unique dream worlds, conquer her fears, and fight for survival as she matures and grows.","image":{"sharp":{"original":{"src":"/static/the-wandering-dark-painting-42c7a01901465e811b451d8e0efc39ed.jpg","width":1920,"height":756}}},"imageAltText":"The Wandering Dark Painting","imageBorder":null},{"id":"boss-rush","category":"games","date":"November 2014","title":"Boss Rush","description":"Boss Rush is a top-down twin-stick shooter consisting of nothing but boss fights. Developed as a university project, the objective was to create a vertical slice of a complete game, thus it consists of one action-packed boss fight – the Spider Tank.","description_short":null,"image":{"sharp":{"original":{"src":"/static/boss-rush-painting-b2339ec284e2424c331883a20e30fbf1.jpg","width":1920,"height":960}}},"imageAltText":"Boss Rush Painting","imageBorder":null},{"id":"alphas","category":"games","date":"June 2013","title":"Alphas","description":"Alphas is a top-down twin-stick shooter developed as a university project. The game consists of five interlinked deadly arenas, several unique weapons, and a multitude of engaging enemies lead by the alpha boss. Can you survive the swarm?","description_short":null,"image":{"sharp":{"original":{"src":"/static/alphas-painting-b30cd5e096e0c931e7c944358b2d3ae4.jpg","width":800,"height":380}}},"imageAltText":"Alphas Painting","imageBorder":null},{"id":"hackathon-for-wildlife","category":"games","date":"November 2015","title":"Hackathon for Wildlife","description":null,"description_short":"An empathetic and educational experience that teaches players about the dangers of poaching. By putting the player in the role of the elephant, it creates a deeper connection between the human and the animal.","image":{"sharp":{"original":{"src":"/static/hackathon-for-wildlife-painting-ccf9c600d554f105d20ff2975c9b71b2.jpg","width":2560,"height":1260}}},"imageAltText":"Hackathon for Wildlife Painting","imageBorder":null},{"id":"ferro","category":"games","date":"April 2015","title":"Ferro","description":"Inspired by ferrofluids, Ferro is a virtual reality experience created by Michael Louden and Adam Graham. As a scientist who has discovered a potential gateway into another universe, your job is to channel it to the right frequency. Players use a midi keyboard as the primary input device to initiate the machines and tune the portal.","description_short":"Ferro is a virtual reality experience inspired by ferrofluids. As a scientist who has discovered a potential gateway into another universe, your job is to channel it to the right frequency using a midi keyboard as the primary input device.","image":{"sharp":{"original":{"src":"/static/ferro-painting-1fa5cc35a12c4c391a1b6decc8a66a9f.jpg","width":1920,"height":900}}},"imageAltText":"Ferro Painting","imageBorder":null},{"id":"elegy","category":"games","date":"March 2015","title":"Elegy","description":"Elegy is a deep game covering the five stages of grief as a parent deals with the loss of their child. The parent attends the funeral of their child and tries to rewind time to stop their child's death. The player engages in different scenes to figure out how they can stop the events from happening, but they must ultimately accept the death of their child.","description_short":"Elegy is a deep game covering the five stages of grief as a parent deals with the loss of their child. While attending the funeral, they try to rewind time to stop the tragedy but they must ultimatley accept the death of their child.","image":{"sharp":{"original":{"src":"/static/elegy-painting-c740be5d8c41cb8756acfab75b735d61.jpg","width":1280,"height":620}}},"imageAltText":"Elegy Painting","imageBorder":null},{"id":"squish-em","category":"games","date":"April 2015","title":"Squish-em!","description":"Squish-em! is a simple whack-a-mole re-creation designed for mobile devices. Squish your way to the top of the leaderboards, earn achievements along the way, and brag to your friends when you beat their best score! Do you have what it takes to become the best squisher around?","description_short":"Squish-em! is a simple whack-a-mole re-creation designed for mobile devices. Squish your way to the top of the leaderboards, earn achievements along the way, and brag to your friends when you beat their best score!","image":{"sharp":{"original":{"src":"/static/squishem-game-painting-03ac014a69e3ca9d2c9c43807ac5032b.jpg","width":1024,"height":500}}},"imageAltText":"Squish-em! Painting","imageBorder":null},{"id":"ancient-odyssey","category":"games","date":"November 2013","title":"Ancient Odyssey","description":"Ancient Odyssey is an \"escape\" puzzle game for mobile devices. Each level is individually designed to make you think harder and harder. Can you survive the journey to the underworld by plundering all 30 levels?","description_short":null,"image":{"sharp":{"original":{"src":"/static/ancient-odyssey-painting-59a5b2f87ad3d126a5d9d1a0b40294a7.jpg","width":800,"height":400}}},"imageAltText":"Ancient Odyssey Painting","imageBorder":null},{"id":"lunar-escape","category":"games","date":"September 2013","title":"Lunar Escape","description":"Lunar Escape is an \"escape\" puzzle game for mobile devices. Each level is individually designed to make you think harder and harder. Do you have the logical skills needed to transcend all 30 levels?","description_short":null,"image":{"sharp":{"original":{"src":"/static/lunar-escape-painting-d260a732497ade1dce42ac320185b113.jpg","width":800,"height":400}}},"imageAltText":"Lunar Escape Painting","imageBorder":null},{"id":"the-rise","category":"games","date":"July 2013","title":"The Rise","description":"The Rise is an \"escape\" puzzle game for mobile devices. Each level is individually designed to make you think harder and harder. Put your logical skills to the test, rise to the top, and conquer all 30 levels.","description_short":null,"image":{"sharp":{"original":{"src":"/static/the-rise-painting-76bf4fd5f507d788e18d265d70ffed2d.jpg","width":800,"height":480}}},"imageAltText":"The Rise Painting","imageBorder":null},{"id":"escape-the-estate","category":"games","date":"August 2013","title":"Escape the Estate","description":"Escape the Estate is a point-and-click adventure game. Your life is on the line! Kane is at it again, and this time he is angry! Do you have what it takes to prevent his cruel intentions? Put your puzzle-solving skills to the test in the sequel to Escape the Basement!","description_short":null,"image":{"sharp":{"original":{"src":"/static/escape-the-estate-painting-94c6124b5af649da24c14859698dc218.jpg","width":640,"height":480}}},"imageAltText":"Escape the Estate Painting","imageBorder":null},{"id":"escape-the-basement","category":"games","date":"August 2012","title":"Escape the Basement","description":"Escape the Basement is a point-and-click adventure game. You of all people were chosen to die. A cruel man named Kane has locked you in his basement with no thought of letting you free. Can you outwit his evil plan and escape?","description_short":null,"image":{"sharp":{"original":{"src":"/static/escape-the-basement-painting-e8eaa3ea9847059180b86d174b4bea2b.jpg","width":800,"height":535}}},"imageAltText":"Escape the Basement Painting","imageBorder":null}]}},"pageContext":{}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-games-tsx","path":"/games","result":{"data":{"json":{"slides":[{"id":"the-wandering-dark","category":"games","date":"June 2015","title":"The Wandering Dark","description":"The Wandering Dark is an indie adventure game that takes you through a girl's dreams and nightmares. Explore her unique dream worlds, conquer her fears, and fight for survival as she matures and grows. Adam developed the game alongside Michael Louden for his senior capstone project before graduating from DePaul University.","description_short":"The Wandering Dark is an indie adventure game that takes you through a girl's dreams and nightmares. Explore her unique dream worlds, conquer her fears, and fight for survival as she matures and grows.","image":{"sharp":{"original":{"src":"/static/the-wandering-dark-painting-42c7a01901465e811b451d8e0efc39ed.jpg","width":1920,"height":756}}},"imageAltText":"The Wandering Dark Painting","imageBorder":null},{"id":"boss-rush","category":"games","date":"November 2014","title":"Boss Rush","description":"Boss Rush is a top-down twin-stick shooter consisting of nothing but boss fights. Developed as a university project, the objective was to create a vertical slice of a complete game, thus it consists of one action-packed boss fight – the Spider Tank.","description_short":null,"image":{"sharp":{"original":{"src":"/static/boss-rush-painting-b2339ec284e2424c331883a20e30fbf1.jpg","width":1920,"height":960}}},"imageAltText":"Boss Rush Painting","imageBorder":null},{"id":"alphas","category":"games","date":"June 2013","title":"Alphas","description":"Alphas is a top-down twin-stick shooter developed as a university project. The game consists of five interlinked deadly arenas, several unique weapons, and a multitude of engaging enemies lead by the alpha boss. Can you survive the swarm?","description_short":null,"image":{"sharp":{"original":{"src":"/static/alphas-painting-b30cd5e096e0c931e7c944358b2d3ae4.jpg","width":800,"height":380}}},"imageAltText":"Alphas Painting","imageBorder":null},{"id":"hackathon-for-wildlife","category":"games","date":"November 2015","title":"Hackathon for Wildlife","description":null,"description_short":"An empathetic and educational experience that teaches players about the dangers of poaching. By putting the player in the role of the elephant, it creates a deeper connection between the human and the animal.","image":{"sharp":{"original":{"src":"/static/hackathon-for-wildlife-painting-ccf9c600d554f105d20ff2975c9b71b2.jpg","width":2560,"height":1260}}},"imageAltText":"Hackathon for Wildlife Painting","imageBorder":null},{"id":"ferro","category":"games","date":"April 2015","title":"Ferro","description":"Inspired by ferrofluids, Ferro is a virtual reality experience created by Michael Louden and Adam Graham. As a scientist who has discovered a potential gateway into another universe, your job is to channel it to the right frequency. Players use a midi keyboard as the primary input device to initiate the machines and tune the portal.","description_short":"Ferro is a virtual reality experience inspired by ferrofluids. As a scientist who has discovered a potential gateway into another universe, your job is to channel it to the right frequency using a midi keyboard as the primary input device.","image":{"sharp":{"original":{"src":"/static/ferro-painting-1fa5cc35a12c4c391a1b6decc8a66a9f.jpg","width":1920,"height":900}}},"imageAltText":"Ferro Painting","imageBorder":null},{"id":"elegy","category":"games","date":"March 2015","title":"Elegy","description":"Elegy is a deep game covering the five stages of grief as a parent deals with the loss of their child. The parent attends the funeral of their child and tries to rewind time to stop their child's death. The player engages in different scenes to figure out how they can stop the events from happening, but they must ultimately accept the death of their child.","description_short":"Elegy is a deep game covering the five stages of grief as a parent deals with the loss of their child. While attending the funeral, they try to rewind time to stop the tragedy but they must ultimatley accept the death of their child.","image":{"sharp":{"original":{"src":"/static/elegy-painting-c740be5d8c41cb8756acfab75b735d61.jpg","width":1280,"height":620}}},"imageAltText":"Elegy Painting","imageBorder":null},{"id":"squish-em","category":"games","date":"April 2015","title":"Squish-em!","description":"Squish-em! is a simple whack-a-mole re-creation designed for mobile devices. Squish your way to the top of the leaderboards, earn achievements along the way, and brag to your friends when you beat their best score! Do you have what it takes to become the best squisher around?","description_short":"Squish-em! is a simple whack-a-mole re-creation designed for mobile devices. Squish your way to the top of the leaderboards, earn achievements along the way, and brag to your friends when you beat their best score!","image":{"sharp":{"original":{"src":"/static/squishem-game-painting-03ac014a69e3ca9d2c9c43807ac5032b.jpg","width":1024,"height":500}}},"imageAltText":"Squish-em! Painting","imageBorder":null},{"id":"ancient-odyssey","category":"games","date":"November 2013","title":"Ancient Odyssey","description":"Ancient Odyssey is an \"escape\" puzzle game for mobile devices. Each level is individually designed to make you think harder and harder. Can you survive the journey to the underworld by plundering all 30 levels?","description_short":null,"image":{"sharp":{"original":{"src":"/static/ancient-odyssey-painting-59a5b2f87ad3d126a5d9d1a0b40294a7.jpg","width":800,"height":400}}},"imageAltText":"Ancient Odyssey Painting","imageBorder":null},{"id":"lunar-escape","category":"games","date":"September 2013","title":"Lunar Escape","description":"Lunar Escape is an \"escape\" puzzle game for mobile devices. Each level is individually designed to make you think harder and harder. Do you have the logical skills needed to transcend all 30 levels?","description_short":null,"image":{"sharp":{"original":{"src":"/static/lunar-escape-painting-d260a732497ade1dce42ac320185b113.jpg","width":800,"height":400}}},"imageAltText":"Lunar Escape Painting","imageBorder":null},{"id":"the-rise","category":"games","date":"July 2013","title":"The Rise","description":"The Rise is an \"escape\" puzzle game for mobile devices. Each level is individually designed to make you think harder and harder. Put your logical skills to the test, rise to the top, and conquer all 30 levels.","description_short":null,"image":{"sharp":{"original":{"src":"/static/the-rise-painting-76bf4fd5f507d788e18d265d70ffed2d.jpg","width":800,"height":480}}},"imageAltText":"The Rise Painting","imageBorder":null},{"id":"escape-the-estate","category":"games","date":"August 2013","title":"Escape the Estate","description":"Escape the Estate is a point-and-click adventure game. Your life is on the line! Kane is at it again, and this time he is angry! Do you have what it takes to prevent his cruel intentions? Put your puzzle-solving skills to the test in the sequel to Escape the Basement!","description_short":null,"image":{"sharp":{"original":{"src":"/static/escape-the-estate-painting-94c6124b5af649da24c14859698dc218.jpg","width":640,"height":480}}},"imageAltText":"Escape the Estate Painting","imageBorder":null},{"id":"escape-the-basement","category":"games","date":"August 2012","title":"Escape the Basement","description":"Escape the Basement is a point-and-click adventure game. You of all people were chosen to die. A cruel man named Kane has locked you in his basement with no thought of letting you free. Can you outwit his evil plan and escape?","description_short":null,"image":{"sharp":{"original":{"src":"/static/escape-the-basement-painting-e8eaa3ea9847059180b86d174b4bea2b.jpg","width":800,"height":535}}},"imageAltText":"Escape the Basement Painting","imageBorder":null}]}},"pageContext":{}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/games/squish-em/page-data.json b/page-data/games/squish-em/page-data.json index 427b3df..10bbc62 100644 --- a/page-data/games/squish-em/page-data.json +++ b/page-data/games/squish-em/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-games-games-json-json-id-js","path":"/games/squish-em","result":{"data":{"project":{"id":"squish-em","category":"games","title":"Squish-em!","description":"Squish-em! is a simple whack-a-mole re-creation designed for mobile devices. Squish your way to the top of the leaderboards, earn achievements along the way, and brag to your friends when you beat their best score! Do you have what it takes to become the best squisher around?","description_short":"Squish-em! is a simple whack-a-mole re-creation designed for mobile devices. Squish your way to the top of the leaderboards, earn achievements along the way, and brag to your friends when you beat their best score!","description_long":null,"date":"April 2015","role":"Lead Programmer, Producer, Designer","tech":["Adobe Flash","ActionScript 3.0","iOS"],"image":{"sharp":{"original":{"src":"/static/squishem-game-painting-03ac014a69e3ca9d2c9c43807ac5032b.jpg","width":1024,"height":500}}},"buttons":null,"sections":[{"title":"Media","link":null,"mainImage":{"sharp":{"original":{"src":"/static/squishem-banner-c32e3f067d185eb30fe5534424766916.jpg","width":800,"height":400}}},"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/squishem-screenshot-01-bfa97aad9c0e2359a78d445bcfa1af92.jpg","width":640,"height":960}}},{"sharp":{"original":{"src":"/static/squishem-screenshot-02-f53988f56c2bef9699fe5574d5c55bf4.jpg","width":640,"height":960}}},{"sharp":{"original":{"src":"/static/squishem-screenshot-03-b77371c7245046f2fa8f02dc032f2a7c.jpg","width":640,"height":960}}},{"sharp":{"original":{"src":"/static/squishem-screenshot-04-ef9ae2409017ec042848ed26912c4209.jpg","width":640,"height":960}}}],"videos":null}]}},"pageContext":{"id":"f29201ec-882d-5d75-b008-fb94bb9a62ba","jsonId":"squish-em","__params":{"jsonId":"squish-em"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-games-games-json-json-id-tsx","path":"/games/squish-em","result":{"data":{"project":{"id":"squish-em","category":"games","title":"Squish-em!","description":"Squish-em! is a simple whack-a-mole re-creation designed for mobile devices. Squish your way to the top of the leaderboards, earn achievements along the way, and brag to your friends when you beat their best score! Do you have what it takes to become the best squisher around?","description_short":"Squish-em! is a simple whack-a-mole re-creation designed for mobile devices. Squish your way to the top of the leaderboards, earn achievements along the way, and brag to your friends when you beat their best score!","description_long":null,"date":"April 2015","role":"Lead Programmer, Producer, Designer","tech":["Adobe Flash","ActionScript 3.0","iOS"],"image":{"sharp":{"original":{"src":"/static/squishem-game-painting-03ac014a69e3ca9d2c9c43807ac5032b.jpg","width":1024,"height":500}}},"buttons":null,"sections":[{"title":"Media","link":null,"mainImage":{"sharp":{"original":{"src":"/static/squishem-banner-c32e3f067d185eb30fe5534424766916.jpg","width":800,"height":400}}},"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/squishem-screenshot-01-bfa97aad9c0e2359a78d445bcfa1af92.jpg","width":640,"height":960}}},{"sharp":{"original":{"src":"/static/squishem-screenshot-02-f53988f56c2bef9699fe5574d5c55bf4.jpg","width":640,"height":960}}},{"sharp":{"original":{"src":"/static/squishem-screenshot-03-b77371c7245046f2fa8f02dc032f2a7c.jpg","width":640,"height":960}}},{"sharp":{"original":{"src":"/static/squishem-screenshot-04-ef9ae2409017ec042848ed26912c4209.jpg","width":640,"height":960}}}],"videos":null}]}},"pageContext":{"id":"f29201ec-882d-5d75-b008-fb94bb9a62ba","jsonId":"squish-em","__params":{"jsonId":"squish-em"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/games/the-rise/page-data.json b/page-data/games/the-rise/page-data.json index d24beab..25d1562 100644 --- a/page-data/games/the-rise/page-data.json +++ b/page-data/games/the-rise/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-games-games-json-json-id-js","path":"/games/the-rise","result":{"data":{"project":{"id":"the-rise","category":"games","title":"The Rise","description":"The Rise is an \"escape\" puzzle game for mobile devices. Each level is individually designed to make you think harder and harder. Put your logical skills to the test, rise to the top, and conquer all 30 levels.","description_short":null,"description_long":null,"date":"July 2013","role":"Lead Programmer, Producer, Designer","tech":["Adobe Flash","ActionScript 3.0"],"image":{"sharp":{"original":{"src":"/static/the-rise-painting-76bf4fd5f507d788e18d265d70ffed2d.jpg","width":800,"height":480}}},"buttons":[{"name":"Play Game","url":"https://www.newgrounds.com/portal/view/622585","icon":"play_circle"}],"sections":[{"title":"Media","link":null,"mainImage":{"sharp":{"original":{"src":"/static/the-rise-banner-7f54bfdf096595d842ca738e2965cb66.jpg","width":800,"height":250}}},"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/the-rise-screenshot-01-c3d2a3eaf631d344b2943bb49f64efae.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/the-rise-screenshot-02-8d59957cbeb4215ea1132565dd16ec5b.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/the-rise-screenshot-03-560364750c051f188ae3efe50e908e0e.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/the-rise-screenshot-04-19e8f315a6d6246619e157366fc90c3c.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/the-rise-screenshot-05-d1296d7106ca93d88195d6a50cab17de.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/the-rise-screenshot-06-adc81c250a236afe20ac49161f05b95b.jpg","width":800,"height":480}}}],"videos":null}]}},"pageContext":{"id":"828f9324-1033-5e6b-ac8e-84ca197b25f4","jsonId":"the-rise","__params":{"jsonId":"the-rise"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-games-games-json-json-id-tsx","path":"/games/the-rise","result":{"data":{"project":{"id":"the-rise","category":"games","title":"The Rise","description":"The Rise is an \"escape\" puzzle game for mobile devices. Each level is individually designed to make you think harder and harder. Put your logical skills to the test, rise to the top, and conquer all 30 levels.","description_short":null,"description_long":null,"date":"July 2013","role":"Lead Programmer, Producer, Designer","tech":["Adobe Flash","ActionScript 3.0"],"image":{"sharp":{"original":{"src":"/static/the-rise-painting-76bf4fd5f507d788e18d265d70ffed2d.jpg","width":800,"height":480}}},"buttons":[{"to":"https://www.newgrounds.com/portal/view/622585","name":"Play Game","icon":"play_circle"}],"sections":[{"title":"Media","link":null,"mainImage":{"sharp":{"original":{"src":"/static/the-rise-banner-7f54bfdf096595d842ca738e2965cb66.jpg","width":800,"height":250}}},"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/the-rise-screenshot-01-c3d2a3eaf631d344b2943bb49f64efae.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/the-rise-screenshot-02-8d59957cbeb4215ea1132565dd16ec5b.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/the-rise-screenshot-03-560364750c051f188ae3efe50e908e0e.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/the-rise-screenshot-04-19e8f315a6d6246619e157366fc90c3c.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/the-rise-screenshot-05-d1296d7106ca93d88195d6a50cab17de.jpg","width":800,"height":480}}},{"sharp":{"original":{"src":"/static/the-rise-screenshot-06-adc81c250a236afe20ac49161f05b95b.jpg","width":800,"height":480}}}],"videos":null}]}},"pageContext":{"id":"828f9324-1033-5e6b-ac8e-84ca197b25f4","jsonId":"the-rise","__params":{"jsonId":"the-rise"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/games/the-wandering-dark/page-data.json b/page-data/games/the-wandering-dark/page-data.json index cc2e859..5f42c91 100644 --- a/page-data/games/the-wandering-dark/page-data.json +++ b/page-data/games/the-wandering-dark/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-games-games-json-json-id-js","path":"/games/the-wandering-dark","result":{"data":{"project":{"id":"the-wandering-dark","category":"games","title":"The Wandering Dark","description":"The Wandering Dark is an indie adventure game that takes you through a girl's dreams and nightmares. Explore her unique dream worlds, conquer her fears, and fight for survival as she matures and grows. Adam developed the game alongside Michael Louden for his senior capstone project before graduating from DePaul University.","description_short":"The Wandering Dark is an indie adventure game that takes you through a girl's dreams and nightmares. Explore her unique dream worlds, conquer her fears, and fight for survival as she matures and grows.","description_long":null,"date":"June 2015","role":"Lead Programmer, Co-Designer","tech":["Unity","C#"],"image":{"sharp":{"original":{"src":"/static/the-wandering-dark-painting-42c7a01901465e811b451d8e0efc39ed.jpg","width":1920,"height":756}}},"buttons":[{"name":"Download","url":"https://drive.google.com/file/d/1A28Dm-oLWkOgr3L49f46jjcyovBnfp-G/view?usp=drive_link","icon":"download"}],"sections":[{"title":"Beta","link":"https://drive.google.com/file/d/1A28Dm-oLWkOgr3L49f46jjcyovBnfp-G/view?usp=drive_link","mainImage":null,"mainImageLink":null,"mainVideo":"JtCg7oB67wY","paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/the-wandering-dark-screenshot-01-cda6faa5eb3ad16f91c673d13f54bb73.jpg","width":1920,"height":1080}}},{"sharp":{"original":{"src":"/static/the-wandering-dark-screenshot-02-0535f07989d3fa5a3a2e9e4ac075e9d3.jpg","width":1920,"height":1080}}},{"sharp":{"original":{"src":"/static/the-wandering-dark-screenshot-03-85d1ff61dd5ab86ac200daf604eed801.jpg","width":1920,"height":1080}}},{"sharp":{"original":{"src":"/static/the-wandering-dark-screenshot-04-8c68772f712c9ee42cbbcfb4633d3c51.jpg","width":1920,"height":1080}}},{"sharp":{"original":{"src":"/static/the-wandering-dark-screenshot-05-91c445eb0a767c97082a675f982cbab2.jpg","width":1920,"height":1080}}},{"sharp":{"original":{"src":"/static/the-wandering-dark-screenshot-06-bfcb671aedf74ab6fba28ebc2b8d05f9.jpg","width":1920,"height":1080}}},{"sharp":{"original":{"src":"/static/the-wandering-dark-screenshot-07-8d6235b7d59a0fc693ff95d21975c2f6.jpg","width":1920,"height":1080}}}],"videos":null},{"title":"Alpha","link":"https://drive.google.com/file/d/1smEETzdTMVHylPhxZzS2nHsCTbrBYddo/view?usp=drive_link","mainImage":null,"mainImageLink":null,"mainVideo":"EF8ywk3Qq48","paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/project-dream-screenshot-01-297dc66a58566a80d203fc0e423791ba.jpg","width":1280,"height":720}}},{"sharp":{"original":{"src":"/static/project-dream-screenshot-02-646b48d84690ed7e246800da331efad0.jpg","width":1920,"height":1080}}},{"sharp":{"original":{"src":"/static/project-dream-screenshot-03-7b6c0648be1410271cf12fe8929190ed.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/project-dream-screenshot-04-4479361a64e7e810c5888f68378f7cb2.jpg","width":1920,"height":1080}}}],"videos":null}]}},"pageContext":{"id":"5526aec1-5797-5e3e-bd84-94753bbcb711","jsonId":"the-wandering-dark","__params":{"jsonId":"the-wandering-dark"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-games-games-json-json-id-tsx","path":"/games/the-wandering-dark","result":{"data":{"project":{"id":"the-wandering-dark","category":"games","title":"The Wandering Dark","description":"The Wandering Dark is an indie adventure game that takes you through a girl's dreams and nightmares. Explore her unique dream worlds, conquer her fears, and fight for survival as she matures and grows. Adam developed the game alongside Michael Louden for his senior capstone project before graduating from DePaul University.","description_short":"The Wandering Dark is an indie adventure game that takes you through a girl's dreams and nightmares. Explore her unique dream worlds, conquer her fears, and fight for survival as she matures and grows.","description_long":null,"date":"June 2015","role":"Lead Programmer, Co-Designer","tech":["Unity","C#"],"image":{"sharp":{"original":{"src":"/static/the-wandering-dark-painting-42c7a01901465e811b451d8e0efc39ed.jpg","width":1920,"height":756}}},"buttons":[{"to":"https://drive.google.com/file/d/1A28Dm-oLWkOgr3L49f46jjcyovBnfp-G/view?usp=drive_link","name":"Download","icon":"download"}],"sections":[{"title":"Beta","link":"https://drive.google.com/file/d/1A28Dm-oLWkOgr3L49f46jjcyovBnfp-G/view?usp=drive_link","mainImage":null,"mainImageLink":null,"mainVideo":"JtCg7oB67wY","paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/the-wandering-dark-screenshot-01-cda6faa5eb3ad16f91c673d13f54bb73.jpg","width":1920,"height":1080}}},{"sharp":{"original":{"src":"/static/the-wandering-dark-screenshot-02-0535f07989d3fa5a3a2e9e4ac075e9d3.jpg","width":1920,"height":1080}}},{"sharp":{"original":{"src":"/static/the-wandering-dark-screenshot-03-85d1ff61dd5ab86ac200daf604eed801.jpg","width":1920,"height":1080}}},{"sharp":{"original":{"src":"/static/the-wandering-dark-screenshot-04-8c68772f712c9ee42cbbcfb4633d3c51.jpg","width":1920,"height":1080}}},{"sharp":{"original":{"src":"/static/the-wandering-dark-screenshot-05-91c445eb0a767c97082a675f982cbab2.jpg","width":1920,"height":1080}}},{"sharp":{"original":{"src":"/static/the-wandering-dark-screenshot-06-bfcb671aedf74ab6fba28ebc2b8d05f9.jpg","width":1920,"height":1080}}},{"sharp":{"original":{"src":"/static/the-wandering-dark-screenshot-07-8d6235b7d59a0fc693ff95d21975c2f6.jpg","width":1920,"height":1080}}}],"videos":null},{"title":"Alpha","link":"https://drive.google.com/file/d/1smEETzdTMVHylPhxZzS2nHsCTbrBYddo/view?usp=drive_link","mainImage":null,"mainImageLink":null,"mainVideo":"EF8ywk3Qq48","paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/project-dream-screenshot-01-297dc66a58566a80d203fc0e423791ba.jpg","width":1280,"height":720}}},{"sharp":{"original":{"src":"/static/project-dream-screenshot-02-646b48d84690ed7e246800da331efad0.jpg","width":1920,"height":1080}}},{"sharp":{"original":{"src":"/static/project-dream-screenshot-03-7b6c0648be1410271cf12fe8929190ed.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/project-dream-screenshot-04-4479361a64e7e810c5888f68378f7cb2.jpg","width":1920,"height":1080}}}],"videos":null}]}},"pageContext":{"id":"5526aec1-5797-5e3e-bd84-94753bbcb711","jsonId":"the-wandering-dark","__params":{"jsonId":"the-wandering-dark"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/index/page-data.json b/page-data/index/page-data.json index a992556..cac58fe 100644 --- a/page-data/index/page-data.json +++ b/page-data/index/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-index-js","path":"/","result":{"pageContext":{}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-index-tsx","path":"/","result":{"pageContext":{}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/presentations/3d-application-development-overview/page-data.json b/page-data/presentations/3d-application-development-overview/page-data.json index d27f33f..0dc53b4 100644 --- a/page-data/presentations/3d-application-development-overview/page-data.json +++ b/page-data/presentations/3d-application-development-overview/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-presentations-presentations-json-json-id-js","path":"/presentations/3d-application-development-overview","result":{"data":{"project":{"id":"3d-application-development-overview","category":"presentations","title":"3D Application Development","description":null,"description_short":"A presentation to teach introductory concepts for 3D application development covering topics across art, design, and tech. The presentation serves as a starting point from which creators can continue to grow their knowledge.","description_long":["A presentation to teach introductory concepts for 3D application development covering topics across art, design, and tech. The presentation serves as a starting point from which creators can continue to grow their knowledge by providing high-level, easy-to-understand definitions that give a taste of the information they might need to know when developing a 3D application.","The deck is grounded in the Unity engine to provide real, applicable examples of the concepts. Adam presented this deck to around 30 software professionals who were interested in learning more."],"date":"April 2016","role":"Designer, Presenter","tech":["Unity","C#","Blender"],"image":{"sharp":{"original":{"src":"/static/3d-application-development-overview-painting-dcc07e558c8fdc5a1f99644f10112c51.jpg","width":1920,"height":800}}},"buttons":[{"name":"View Deck","url":"https://drive.google.com/file/d/1r2DCuz7PckbaD0CH4NWlKIK1X5-po9MI/view?usp=drive_link","icon":"picture_as_pdf"}],"sections":[{"title":null,"link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/3d-application-development-overview-screenshot-01-440fdefe1a8a0a05a970752bcf7d9e9c.jpg","width":3000,"height":1688}}},{"sharp":{"original":{"src":"/static/3d-application-development-overview-screenshot-02-c84f61d6252ccf14f422b5c4a0925e93.jpg","width":3000,"height":1688}}},{"sharp":{"original":{"src":"/static/3d-application-development-overview-screenshot-03-3c1c72826114e017b07bbb8e80beab12.jpg","width":3000,"height":1688}}},{"sharp":{"original":{"src":"/static/3d-application-development-overview-screenshot-04-419514de233cff0e8171ca92dc75ce35.jpg","width":3000,"height":1688}}},{"sharp":{"original":{"src":"/static/3d-application-development-overview-screenshot-05-c870b1d0c237539772afffcb08e6cd66.jpg","width":3000,"height":1688}}},{"sharp":{"original":{"src":"/static/3d-application-development-overview-screenshot-06-79a6ed9d7101075707052a3b0f254f59.jpg","width":3000,"height":1688}}},{"sharp":{"original":{"src":"/static/3d-application-development-overview-screenshot-07-e979a9aa2eabfd832489a47e9c50c4e3.jpg","width":3000,"height":1688}}},{"sharp":{"original":{"src":"/static/3d-application-development-overview-screenshot-08-84ea672b816abb62584519d706c39552.jpg","width":3000,"height":1688}}}],"videos":null}]}},"pageContext":{"id":"3e14a3df-c992-5bcc-99a2-d457ed3eae2f","jsonId":"3d-application-development-overview","__params":{"jsonId":"3d-application-development-overview"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-presentations-presentations-json-json-id-tsx","path":"/presentations/3d-application-development-overview","result":{"data":{"project":{"id":"3d-application-development-overview","category":"presentations","title":"3D Application Development","description":null,"description_short":"A presentation to teach introductory concepts for 3D application development covering topics across art, design, and tech. The presentation serves as a starting point from which creators can continue to grow their knowledge.","description_long":["A presentation to teach introductory concepts for 3D application development covering topics across art, design, and tech. The presentation serves as a starting point from which creators can continue to grow their knowledge by providing high-level, easy-to-understand definitions that give a taste of the information they might need to know when developing a 3D application.","The deck is grounded in the Unity engine to provide real, applicable examples of the concepts. Adam presented this deck to around 30 software professionals who were interested in learning more."],"date":"April 2016","role":"Designer, Presenter","tech":["Unity","C#","Blender"],"image":{"sharp":{"original":{"src":"/static/3d-application-development-overview-painting-dcc07e558c8fdc5a1f99644f10112c51.jpg","width":1920,"height":800}}},"buttons":[{"to":"https://drive.google.com/file/d/1r2DCuz7PckbaD0CH4NWlKIK1X5-po9MI/view?usp=drive_link","name":"View Deck","icon":"picture_as_pdf"}],"sections":[{"title":null,"link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/3d-application-development-overview-screenshot-01-440fdefe1a8a0a05a970752bcf7d9e9c.jpg","width":3000,"height":1688}}},{"sharp":{"original":{"src":"/static/3d-application-development-overview-screenshot-02-c84f61d6252ccf14f422b5c4a0925e93.jpg","width":3000,"height":1688}}},{"sharp":{"original":{"src":"/static/3d-application-development-overview-screenshot-03-3c1c72826114e017b07bbb8e80beab12.jpg","width":3000,"height":1688}}},{"sharp":{"original":{"src":"/static/3d-application-development-overview-screenshot-04-419514de233cff0e8171ca92dc75ce35.jpg","width":3000,"height":1688}}},{"sharp":{"original":{"src":"/static/3d-application-development-overview-screenshot-05-c870b1d0c237539772afffcb08e6cd66.jpg","width":3000,"height":1688}}},{"sharp":{"original":{"src":"/static/3d-application-development-overview-screenshot-06-79a6ed9d7101075707052a3b0f254f59.jpg","width":3000,"height":1688}}},{"sharp":{"original":{"src":"/static/3d-application-development-overview-screenshot-07-e979a9aa2eabfd832489a47e9c50c4e3.jpg","width":3000,"height":1688}}},{"sharp":{"original":{"src":"/static/3d-application-development-overview-screenshot-08-84ea672b816abb62584519d706c39552.jpg","width":3000,"height":1688}}}],"videos":null}]}},"pageContext":{"id":"3e14a3df-c992-5bcc-99a2-d457ed3eae2f","jsonId":"3d-application-development-overview","__params":{"jsonId":"3d-application-development-overview"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/presentations/an-animation-story/page-data.json b/page-data/presentations/an-animation-story/page-data.json index d2624d7..2c358c2 100644 --- a/page-data/presentations/an-animation-story/page-data.json +++ b/page-data/presentations/an-animation-story/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-presentations-presentations-json-json-id-js","path":"/presentations/an-animation-story","result":{"data":{"project":{"id":"an-animation-story","category":"presentations","title":"An Animation Story","description":"A love story between a girl named Design and a boy named Animation. Adam created, narrated, and presented this story to a group of 20 developers at Solstice in order to talk about the importance of having a \"design-gineering\" mindset and the value of the relationship between designers and engineers.","description_short":"A love story between a girl named Design and a boy named Animation. Adam created, narrated, and presented this story to a group of developers in order to talk about the importance of having a \"design-gineering\" mindset and the value of the relationship between designers and engineers.","description_long":null,"date":"August 2017","role":"Designer, Animator, Narrator","tech":["Unity","C#"],"image":{"sharp":{"original":{"src":"/static/an-animation-story-painting-bbee52f6d37d18f18550a7b9eac6a68f.jpg","width":1920,"height":800}}},"buttons":null,"sections":[{"title":null,"link":null,"mainImage":null,"mainImageLink":null,"mainVideo":"uHQvPFud3-I","paragraphs":null,"gallery":null,"videos":null},{"title":"Postface","link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":["So, what the heck was that all about? And what ever happened to Engineering? Well, this story highlights the Design-Engineering mindset, or rather the lack of. Too often do I see us breaking designers' hearts. It seems implementing a design exactly as it was created often presents a problem. But instead of solving the problem, we find ways to avoid it. \"Oh this increases technical complexity, let's simplify\". \"Oh this skyrockets our scope, let's do this later\" (aka never). Specifically, implementing animations is a common trigger to these excuses.","Why is it so important to not break out designers hearts? In my opinion, a great design tells a story. It evokes emotions and brings character to the product. Animation is a tool in a designer's toolbelt that brings life to a design. It is a story in of itself - the change of values over time from one point to another. You see, when we find reasons to not fulfill a designer's creation, to not implement their animations, or any other design element for that matter, we are taking the life out of the design. We are stripping it of character and emotion.","What ever happened to Engineering? Perhaps he makes an epic return in Chapter 2. Perhaps not. It is our job as engineers to create Chapter 2...to not break our designers hearts. And, so, honestly I don't see the value in sitting here and showing you how to implement animations. Because, I believe that without a \"design-gineering\" mindset, we will continue to find excuses not to meet design face to face. I don't think you all need to be as passionate about design or animation as I am, but I think we all have to at least appreciate what it is a designer does, and the impact their designs have on a product.","I encourage everyone to work very closely with your designers. Understand what it is they do everyday, what problems they think about, and what tools they use to solve those problems. The best way to understand a designer is to become one. This, in my opinion, is what the \"design-gineering\" mindset is all about."],"gallery":null,"videos":null}]}},"pageContext":{"id":"a0764781-8cea-5961-af1d-ac1d9e57413d","jsonId":"an-animation-story","__params":{"jsonId":"an-animation-story"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-presentations-presentations-json-json-id-tsx","path":"/presentations/an-animation-story","result":{"data":{"project":{"id":"an-animation-story","category":"presentations","title":"An Animation Story","description":"A love story between a girl named Design and a boy named Animation. Adam created, narrated, and presented this story to a group of 20 developers at Solstice in order to talk about the importance of having a \"design-gineering\" mindset and the value of the relationship between designers and engineers.","description_short":"A love story between a girl named Design and a boy named Animation. Adam created, narrated, and presented this story to a group of developers in order to talk about the importance of having a \"design-gineering\" mindset and the value of the relationship between designers and engineers.","description_long":null,"date":"August 2017","role":"Designer, Animator, Narrator","tech":["Unity","C#"],"image":{"sharp":{"original":{"src":"/static/an-animation-story-painting-bbee52f6d37d18f18550a7b9eac6a68f.jpg","width":1920,"height":800}}},"buttons":null,"sections":[{"title":null,"link":null,"mainImage":null,"mainImageLink":null,"mainVideo":"uHQvPFud3-I","paragraphs":null,"gallery":null,"videos":null},{"title":"Postface","link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":["So, what the heck was that all about? And what ever happened to Engineering? Well, this story highlights the Design-Engineering mindset, or rather the lack of. Too often do I see us breaking designers' hearts. It seems implementing a design exactly as it was created often presents a problem. But instead of solving the problem, we find ways to avoid it. \"Oh this increases technical complexity, let's simplify\". \"Oh this skyrockets our scope, let's do this later\" (aka never). Specifically, implementing animations is a common trigger to these excuses.","Why is it so important to not break out designers hearts? In my opinion, a great design tells a story. It evokes emotions and brings character to the product. Animation is a tool in a designer's toolbelt that brings life to a design. It is a story in of itself - the change of values over time from one point to another. You see, when we find reasons to not fulfill a designer's creation, to not implement their animations, or any other design element for that matter, we are taking the life out of the design. We are stripping it of character and emotion.","What ever happened to Engineering? Perhaps he makes an epic return in Chapter 2. Perhaps not. It is our job as engineers to create Chapter 2...to not break our designers hearts. And, so, honestly I don't see the value in sitting here and showing you how to implement animations. Because, I believe that without a \"design-gineering\" mindset, we will continue to find excuses not to meet design face to face. I don't think you all need to be as passionate about design or animation as I am, but I think we all have to at least appreciate what it is a designer does, and the impact their designs have on a product.","I encourage everyone to work very closely with your designers. Understand what it is they do everyday, what problems they think about, and what tools they use to solve those problems. The best way to understand a designer is to become one. This, in my opinion, is what the \"design-gineering\" mindset is all about."],"gallery":null,"videos":null}]}},"pageContext":{"id":"a0764781-8cea-5961-af1d-ac1d9e57413d","jsonId":"an-animation-story","__params":{"jsonId":"an-animation-story"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/presentations/entering-the-new-reality/page-data.json b/page-data/presentations/entering-the-new-reality/page-data.json index 18d69bf..6753ec8 100644 --- a/page-data/presentations/entering-the-new-reality/page-data.json +++ b/page-data/presentations/entering-the-new-reality/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-presentations-presentations-json-json-id-js","path":"/presentations/entering-the-new-reality","result":{"data":{"project":{"id":"entering-the-new-reality","category":"presentations","title":"Entering the New Reality","description":null,"description_short":"A presentation exploring the technologies of VR, AR, and MR. What are the differences between these technologies? What industries will it disrupt and who will be building these applications? What problems will they solve? These are the questions to be answered.","description_long":["A presentation exploring the technologies of VR, AR, and MR. What are the differences between these technologies? What industries will it disrupt and who will be building these applications? What problems will they solve? These are the questions to be answered.","Adam presented this deck alongside 3 other Solstice engineers during a monthly Solstice Mobile meetup. There were about 100 people that attended the event and listened to the presentation."],"date":"May 2016","role":"VR Engineer, Co-Presenter","tech":["Unity","Oculus Rift","HTC Vive","Microsoft HoloLens"],"image":{"sharp":{"original":{"src":"/static/entering-the-new-reality-painting-2c3fe156a632e1340aa78016491dcab4.jpg","width":1920,"height":800}}},"buttons":[{"name":"View Deck","url":"https://drive.google.com/file/d/1nw_EMTZB47svcDjgCPaSAAPE84gNYqfK/view?usp=drive_link","icon":"picture_as_pdf"}],"sections":[{"title":null,"link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/entering-the-new-reality-screenshot-01-363f0112becc4be4e1e3ab34ad10abf0.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/entering-the-new-reality-screenshot-02-e5541a574312728d196eca3962f84ec2.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/entering-the-new-reality-screenshot-03-e5ee516ddbfda9dbd70db2375f5c7a75.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/entering-the-new-reality-screenshot-04-87d3c8f7a966117be455436b363be481.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/entering-the-new-reality-screenshot-05-1624dde454fc983055ab6bd6f285294c.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/entering-the-new-reality-screenshot-06-72ad4c62677f9661ab9a28e0968007e2.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/entering-the-new-reality-screenshot-07-74a6eb5d22861678d62065607a150f35.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/entering-the-new-reality-screenshot-08-1078968f1a66d925e35e3535eb533c18.jpg","width":2560,"height":1440}}}],"videos":null},{"title":"Preface","link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":["If you were at or watched Facebook's F8 conference and witnessed their 10 year roadmap, you may have noticed how the company plans to continue to invest in not only Virtual Reality with its Oculus, but also into augmented reality as well. They even stated that future headsets would be the size of a normal pair of glasses and would be able to not only handle AR, but VR as well all in one platform. Considering the social-networking leader's Q1 revenue jumped 52% year over year to $5.38 billion, topping the consensus estimate of $5.26 billion. It would be safe to assume that they have a good idea of where the market is heading.","It is nothing new that these technologies are becoming more and more prominent and focused on by several big name players such as Samsung, HTC, Google, and Microsoft. Rumors have been flying around about a possible Google Headset in the works with the release of Android N's second developer preview where there are references to virtual reality capabilities. Furthermore, \"VR\" is an entire content track at Google I/O this year, with seven sessions dedicated to virtual or augmented reality, based on the schedule posted by Google.","So ok we established that this is important and worth paying attention to. However, where are we exactly with these reality technologies? Is it at a mature state at this point where the barrier entry for producing a successful application have been reduced that any developer can produce a VR or AR application? What's the difference between VR and AR? What does it take to build one of these new \"reality\" applications? What problems will they solve? What industries will it disrupt and who will be building these applications? Will it only be important to the gaming industry? Are we scratching the surface with these platforms? What can we predict these platforms will become in the near future?"],"gallery":null,"videos":null}]}},"pageContext":{"id":"f9e959a6-065e-5da8-a7a3-cff09b6ce9c3","jsonId":"entering-the-new-reality","__params":{"jsonId":"entering-the-new-reality"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-presentations-presentations-json-json-id-tsx","path":"/presentations/entering-the-new-reality","result":{"data":{"project":{"id":"entering-the-new-reality","category":"presentations","title":"Entering the New Reality","description":null,"description_short":"A presentation exploring the technologies of VR, AR, and MR. What are the differences between these technologies? What industries will it disrupt and who will be building these applications? What problems will they solve? These are the questions to be answered.","description_long":["A presentation exploring the technologies of VR, AR, and MR. What are the differences between these technologies? What industries will it disrupt and who will be building these applications? What problems will they solve? These are the questions to be answered.","Adam presented this deck alongside 3 other Solstice engineers during a monthly Solstice Mobile meetup. There were about 100 people that attended the event and listened to the presentation."],"date":"May 2016","role":"VR Engineer, Co-Presenter","tech":["Unity","Oculus Rift","HTC Vive","Microsoft HoloLens"],"image":{"sharp":{"original":{"src":"/static/entering-the-new-reality-painting-2c3fe156a632e1340aa78016491dcab4.jpg","width":1920,"height":800}}},"buttons":[{"to":"https://drive.google.com/file/d/1nw_EMTZB47svcDjgCPaSAAPE84gNYqfK/view?usp=drive_link","name":"View Deck","icon":"picture_as_pdf"}],"sections":[{"title":null,"link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/entering-the-new-reality-screenshot-01-363f0112becc4be4e1e3ab34ad10abf0.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/entering-the-new-reality-screenshot-02-e5541a574312728d196eca3962f84ec2.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/entering-the-new-reality-screenshot-03-e5ee516ddbfda9dbd70db2375f5c7a75.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/entering-the-new-reality-screenshot-04-87d3c8f7a966117be455436b363be481.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/entering-the-new-reality-screenshot-05-1624dde454fc983055ab6bd6f285294c.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/entering-the-new-reality-screenshot-06-72ad4c62677f9661ab9a28e0968007e2.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/entering-the-new-reality-screenshot-07-74a6eb5d22861678d62065607a150f35.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/entering-the-new-reality-screenshot-08-1078968f1a66d925e35e3535eb533c18.jpg","width":2560,"height":1440}}}],"videos":null},{"title":"Preface","link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":["If you were at or watched Facebook's F8 conference and witnessed their 10 year roadmap, you may have noticed how the company plans to continue to invest in not only Virtual Reality with its Oculus, but also into augmented reality as well. They even stated that future headsets would be the size of a normal pair of glasses and would be able to not only handle AR, but VR as well all in one platform. Considering the social-networking leader's Q1 revenue jumped 52% year over year to $5.38 billion, topping the consensus estimate of $5.26 billion. It would be safe to assume that they have a good idea of where the market is heading.","It is nothing new that these technologies are becoming more and more prominent and focused on by several big name players such as Samsung, HTC, Google, and Microsoft. Rumors have been flying around about a possible Google Headset in the works with the release of Android N's second developer preview where there are references to virtual reality capabilities. Furthermore, \"VR\" is an entire content track at Google I/O this year, with seven sessions dedicated to virtual or augmented reality, based on the schedule posted by Google.","So ok we established that this is important and worth paying attention to. However, where are we exactly with these reality technologies? Is it at a mature state at this point where the barrier entry for producing a successful application have been reduced that any developer can produce a VR or AR application? What's the difference between VR and AR? What does it take to build one of these new \"reality\" applications? What problems will they solve? What industries will it disrupt and who will be building these applications? Will it only be important to the gaming industry? Are we scratching the surface with these platforms? What can we predict these platforms will become in the near future?"],"gallery":null,"videos":null}]}},"pageContext":{"id":"f9e959a6-065e-5da8-a7a3-cff09b6ce9c3","jsonId":"entering-the-new-reality","__params":{"jsonId":"entering-the-new-reality"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/presentations/page-data.json b/page-data/presentations/page-data.json index 6c0e4d1..f8f2bd4 100644 --- a/page-data/presentations/page-data.json +++ b/page-data/presentations/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-presentations-js","path":"/presentations","result":{"data":{"json":{"slides":[{"id":"the-life-of-a-ux-engineer","category":"presentations","date":"August 2020","title":"The Life of a UX Engineer","description":"What is a UX Engineer? This specialty role sits on a cross-functional design team and helps facilitate collaboration between designers and engineers. This presentation explores the relationship between designers and engineers and how a UX Engineer uses a particular skillset to solve UX problems. Adam presented this deck to around 20 professionals at one of Kin + Carta's monthly design meetups.","description_short":"What is a UX Engineer? This specialty role sits on a cross-functional design team and helps facilitate collaboration between designers and engineers. This presentation explores the relationship between designers and engineers and how a UX Engineer uses a particular skillset to solve UX problems.","image":{"sharp":{"original":{"src":"/static/the-life-of-a-ux-engineer-painting-ca68e947b1c6cccc1dab1a636456e8eb.jpg","width":1920,"height":800}}},"imageAltText":"The Life of a UX Engineer Painting","imageBorder":null},{"id":"an-animation-story","category":"presentations","date":"August 2017","title":"An Animation Story","description":"A love story between a girl named Design and a boy named Animation. Adam created, narrated, and presented this story to a group of 20 developers at Solstice in order to talk about the importance of having a \"design-gineering\" mindset and the value of the relationship between designers and engineers.","description_short":"A love story between a girl named Design and a boy named Animation. Adam created, narrated, and presented this story to a group of developers in order to talk about the importance of having a \"design-gineering\" mindset and the value of the relationship between designers and engineers.","image":{"sharp":{"original":{"src":"/static/an-animation-story-painting-bbee52f6d37d18f18550a7b9eac6a68f.jpg","width":1920,"height":800}}},"imageAltText":"An Animation Story Painting","imageBorder":null},{"id":"entering-the-new-reality","category":"presentations","date":"May 2016","title":"Entering the New Reality","description":null,"description_short":"A presentation exploring the technologies of VR, AR, and MR. What are the differences between these technologies? What industries will it disrupt and who will be building these applications? What problems will they solve? These are the questions to be answered.","image":{"sharp":{"original":{"src":"/static/entering-the-new-reality-painting-2c3fe156a632e1340aa78016491dcab4.jpg","width":1920,"height":800}}},"imageAltText":"Entering the New Reality Painting","imageBorder":null},{"id":"3d-application-development-overview","category":"presentations","date":"April 2016","title":"3D Application Development","description":null,"description_short":"A presentation to teach introductory concepts for 3D application development covering topics across art, design, and tech. The presentation serves as a starting point from which creators can continue to grow their knowledge.","image":{"sharp":{"original":{"src":"/static/3d-application-development-overview-painting-dcc07e558c8fdc5a1f99644f10112c51.jpg","width":1920,"height":800}}},"imageAltText":"3D Application Development Painting","imageBorder":null}]}},"pageContext":{}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-presentations-tsx","path":"/presentations","result":{"data":{"json":{"slides":[{"id":"the-life-of-a-ux-engineer","category":"presentations","date":"August 2020","title":"The Life of a UX Engineer","description":"What is a UX Engineer? This specialty role sits on a cross-functional design team and helps facilitate collaboration between designers and engineers. This presentation explores the relationship between designers and engineers and how a UX Engineer uses a particular skillset to solve UX problems. Adam presented this deck to around 20 professionals at one of Kin + Carta's monthly design meetups.","description_short":"What is a UX Engineer? This specialty role sits on a cross-functional design team and helps facilitate collaboration between designers and engineers. This presentation explores the relationship between designers and engineers and how a UX Engineer uses a particular skillset to solve UX problems.","image":{"sharp":{"original":{"src":"/static/the-life-of-a-ux-engineer-painting-ca68e947b1c6cccc1dab1a636456e8eb.jpg","width":1920,"height":800}}},"imageAltText":"The Life of a UX Engineer Painting","imageBorder":null},{"id":"an-animation-story","category":"presentations","date":"August 2017","title":"An Animation Story","description":"A love story between a girl named Design and a boy named Animation. Adam created, narrated, and presented this story to a group of 20 developers at Solstice in order to talk about the importance of having a \"design-gineering\" mindset and the value of the relationship between designers and engineers.","description_short":"A love story between a girl named Design and a boy named Animation. Adam created, narrated, and presented this story to a group of developers in order to talk about the importance of having a \"design-gineering\" mindset and the value of the relationship between designers and engineers.","image":{"sharp":{"original":{"src":"/static/an-animation-story-painting-bbee52f6d37d18f18550a7b9eac6a68f.jpg","width":1920,"height":800}}},"imageAltText":"An Animation Story Painting","imageBorder":null},{"id":"entering-the-new-reality","category":"presentations","date":"May 2016","title":"Entering the New Reality","description":null,"description_short":"A presentation exploring the technologies of VR, AR, and MR. What are the differences between these technologies? What industries will it disrupt and who will be building these applications? What problems will they solve? These are the questions to be answered.","image":{"sharp":{"original":{"src":"/static/entering-the-new-reality-painting-2c3fe156a632e1340aa78016491dcab4.jpg","width":1920,"height":800}}},"imageAltText":"Entering the New Reality Painting","imageBorder":null},{"id":"3d-application-development-overview","category":"presentations","date":"April 2016","title":"3D Application Development","description":null,"description_short":"A presentation to teach introductory concepts for 3D application development covering topics across art, design, and tech. The presentation serves as a starting point from which creators can continue to grow their knowledge.","image":{"sharp":{"original":{"src":"/static/3d-application-development-overview-painting-dcc07e558c8fdc5a1f99644f10112c51.jpg","width":1920,"height":800}}},"imageAltText":"3D Application Development Painting","imageBorder":null}]}},"pageContext":{}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/presentations/the-life-of-a-ux-engineer/page-data.json b/page-data/presentations/the-life-of-a-ux-engineer/page-data.json index 1c1283c..0587265 100644 --- a/page-data/presentations/the-life-of-a-ux-engineer/page-data.json +++ b/page-data/presentations/the-life-of-a-ux-engineer/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-presentations-presentations-json-json-id-js","path":"/presentations/the-life-of-a-ux-engineer","result":{"data":{"project":{"id":"the-life-of-a-ux-engineer","category":"presentations","title":"The Life of a UX Engineer","description":"What is a UX Engineer? This specialty role sits on a cross-functional design team and helps facilitate collaboration between designers and engineers. This presentation explores the relationship between designers and engineers and how a UX Engineer uses a particular skillset to solve UX problems. Adam presented this deck to around 20 professionals at one of Kin + Carta's monthly design meetups.","description_short":"What is a UX Engineer? This specialty role sits on a cross-functional design team and helps facilitate collaboration between designers and engineers. This presentation explores the relationship between designers and engineers and how a UX Engineer uses a particular skillset to solve UX problems.","description_long":null,"date":"August 2020","role":"Designer, Presenter","tech":["React","JavaScript","HTML/CSS","Adobe Illustrator","Figma"],"image":{"sharp":{"original":{"src":"/static/the-life-of-a-ux-engineer-painting-ca68e947b1c6cccc1dab1a636456e8eb.jpg","width":1920,"height":800}}},"buttons":[{"name":"View Deck","url":"https://drive.google.com/file/d/1mHUDzD7EzfrRR03Z_1WNsduszsIUj4ny/view?usp=drive_link","icon":"picture_as_pdf"}],"sections":[{"title":null,"link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/the-life-of-a-ux-engineer-screenshot-01-d2bbb4fdb3cda06a7eea8f5f4fbbf09b.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/the-life-of-a-ux-engineer-screenshot-02-6f485eecb9c4b6cf23163784e9a7212e.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/the-life-of-a-ux-engineer-screenshot-03-5620a5da3b176ee848bc1bfaeb5495bd.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/the-life-of-a-ux-engineer-screenshot-04-42bdf7127b8c913a15d92b2d8b47ddbb.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/the-life-of-a-ux-engineer-screenshot-05-de9600cefc7514e19d6f77339a1eebaa.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/the-life-of-a-ux-engineer-screenshot-06-306abc040551181e33dd2573130640aa.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/the-life-of-a-ux-engineer-screenshot-07-65a8b1be7142bbaf0d5c1227943438b6.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/the-life-of-a-ux-engineer-screenshot-08-3f5446f0d90e0be101f874c7f3c8f7e9.jpg","width":2560,"height":1440}}}],"videos":null}]}},"pageContext":{"id":"9261a9d4-eabb-56dc-8d3b-f2430dfa54d3","jsonId":"the-life-of-a-ux-engineer","__params":{"jsonId":"the-life-of-a-ux-engineer"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-presentations-presentations-json-json-id-tsx","path":"/presentations/the-life-of-a-ux-engineer","result":{"data":{"project":{"id":"the-life-of-a-ux-engineer","category":"presentations","title":"The Life of a UX Engineer","description":"What is a UX Engineer? This specialty role sits on a cross-functional design team and helps facilitate collaboration between designers and engineers. This presentation explores the relationship between designers and engineers and how a UX Engineer uses a particular skillset to solve UX problems. Adam presented this deck to around 20 professionals at one of Kin + Carta's monthly design meetups.","description_short":"What is a UX Engineer? This specialty role sits on a cross-functional design team and helps facilitate collaboration between designers and engineers. This presentation explores the relationship between designers and engineers and how a UX Engineer uses a particular skillset to solve UX problems.","description_long":null,"date":"August 2020","role":"Designer, Presenter","tech":["React","JavaScript","HTML/CSS","Adobe Illustrator","Figma"],"image":{"sharp":{"original":{"src":"/static/the-life-of-a-ux-engineer-painting-ca68e947b1c6cccc1dab1a636456e8eb.jpg","width":1920,"height":800}}},"buttons":[{"to":"https://drive.google.com/file/d/1mHUDzD7EzfrRR03Z_1WNsduszsIUj4ny/view?usp=drive_link","name":"View Deck","icon":"picture_as_pdf"}],"sections":[{"title":null,"link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/the-life-of-a-ux-engineer-screenshot-01-d2bbb4fdb3cda06a7eea8f5f4fbbf09b.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/the-life-of-a-ux-engineer-screenshot-02-6f485eecb9c4b6cf23163784e9a7212e.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/the-life-of-a-ux-engineer-screenshot-03-5620a5da3b176ee848bc1bfaeb5495bd.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/the-life-of-a-ux-engineer-screenshot-04-42bdf7127b8c913a15d92b2d8b47ddbb.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/the-life-of-a-ux-engineer-screenshot-05-de9600cefc7514e19d6f77339a1eebaa.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/the-life-of-a-ux-engineer-screenshot-06-306abc040551181e33dd2573130640aa.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/the-life-of-a-ux-engineer-screenshot-07-65a8b1be7142bbaf0d5c1227943438b6.jpg","width":2560,"height":1440}}},{"sharp":{"original":{"src":"/static/the-life-of-a-ux-engineer-screenshot-08-3f5446f0d90e0be101f874c7f3c8f7e9.jpg","width":2560,"height":1440}}}],"videos":null}]}},"pageContext":{"id":"9261a9d4-eabb-56dc-8d3b-f2430dfa54d3","jsonId":"the-life-of-a-ux-engineer","__params":{"jsonId":"the-life-of-a-ux-engineer"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/projects/page-data.json b/page-data/projects/page-data.json index 370b37d..41cce2e 100644 --- a/page-data/projects/page-data.json +++ b/page-data/projects/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-projects-js","path":"/projects","result":{"data":{"json":{"categories":[{"title":"Client Work","projects":[{"title":"3D Farming World","description":"Fully simulated 3D world to visualize farming data","date":"2024","link":null,"externalLink":"https://www.linkedin.com/in/adamzigurous","tags":["Unity","React","3D"]},{"title":"Wealth Management App","description":"Native iPad app + React web app to manage wealth portfolios","date":"2021","link":null,"externalLink":"https://www.linkedin.com/in/adamzigurous","tags":["React","iOS"]},{"title":"Bale Mobile App","description":"Native iOS app to help farmers improve efficiency when baling hay","date":"2019","link":null,"externalLink":"https://www.linkedin.com/in/adamzigurous","tags":["iOS"]},{"title":"Predictive Yield","description":"React web app to visualize predictive yield and moisture data","date":"2019","link":null,"externalLink":"https://www.linkedin.com/in/adamzigurous","tags":["React"]},{"title":"Banking / Credit Card App","description":"Native iOS app with over 1 million daily active users","date":"2018","link":null,"externalLink":"https://www.linkedin.com/in/adamzigurous","tags":["iOS","React Native"]},{"title":"Cinematic VR App","description":"Mobile VR app that puts the user in the front-seat of a self-driving car","date":"2017","link":null,"externalLink":"https://www.linkedin.com/in/adamzigurous","tags":["Unity","iOS","VR/AR"]}]},{"title":"Tech Showcases","projects":[{"title":"Blockchain Gardens","description":"Real-time 3D visualization of a private Ethereum blockchain instance","date":"2018","link":"/tech/blockchain-gardens","externalLink":null,"tags":["Unity","Blockchain","3D"]},{"title":"RockstAR","description":"Interactive AR experience of a live rock concert using Microsoft HoloLens","date":"2016","link":"/tech/rockstar","externalLink":null,"tags":["Unity","VR/AR","3D"]},{"title":"Vender VR","description":"VR experience synced with an IoT vending machine to dispense real products","date":"2015","link":"/tech/vender-vr","externalLink":null,"tags":["Unity","VR/AR","3D"]}]},{"title":"Libraries & Frameworks","projects":[{"title":"Palette","description":"Swift command line tool to parse and generate color palettes","date":"2019","link":null,"externalLink":"https://github.com/adamgraham/palette","tags":["iOS"]},{"title":"Colorly","description":"iOS framework with hundreds of functions to manipulate colors","date":"2019","link":null,"externalLink":"https://github.com/adamgraham/colorly-ios","tags":["iOS"]},{"title":"Polykai","description":"Dark color scheme for code editors inspired by the Monokai theme","date":"2019","link":null,"externalLink":"https://github.com/adamgraham/polykai","tags":[]},{"title":"STween","description":"iOS animation framework for creating complex tweening animations","date":"2016","link":null,"externalLink":"https://github.com/adamgraham/STween","tags":["iOS"]},{"title":"Chronos","description":"iOS utility framework to create different types of timers","date":"2016","link":null,"externalLink":"https://github.com/adamgraham/chronos","tags":["iOS"]}]},{"title":"Presentations","projects":[{"title":"The Life of a UX Engineer","description":"Bridging the gap between design and engineering","date":"2020","link":"/presentations/the-life-of-a-ux-engineer","externalLink":null,"tags":["React"]},{"title":"An Animation Story","description":"A 3D animated story about designers and engineers","date":"2017","link":"/presentations/an-animation-story","externalLink":null,"tags":["Unity","3D"]},{"title":"Entering the New Reality","description":"Presentation and meet-up exploring VR, AR, and MR","date":"2016","link":"/presentations/entering-the-new-reality","externalLink":null,"tags":["VR/AR","3D"]},{"title":"3D Application Development","description":"Introductory concepts for 3D application development","date":"2016","link":"/presentations/3d-application-development-overview","externalLink":null,"tags":["Unity","3D"]}]},{"title":"Games","projects":[{"title":"Hackathon for Wildlife","description":"Empathetic game that teaches about the dangers of poaching","date":"2015","link":"/games/hackathon-for-wildlife","externalLink":null,"tags":["Unity","3D"]},{"title":"The Wandering Dark","description":"Indie adventure game that explores a girl's dreams and nightmares","date":"2015","link":"/games/the-wandering-dark","externalLink":null,"tags":["Unity","3D"]},{"title":"Squish-em!","description":"Whack-a-mole arcade game published on the App Store","date":"2015","link":"/games/squish-em","externalLink":null,"tags":["Flash","iOS","2D"]},{"title":"Ferro","description":"Virtual reality experience inspired by ferrofluids","date":"2015","link":"/games/ferro","externalLink":null,"tags":["Unity","3D"]},{"title":"Elegy","description":"Deep game covering stages of grief as a parent deals with the loss of their child","date":"2015","link":"/games/elegy","externalLink":null,"tags":["Flash","2D"]},{"title":"Boss Rush","description":"Top-down twin-stick shooter consisting of nothing but boss fights","date":"2014","link":"/games/boss-rush","externalLink":null,"tags":["Unity","3D"]},{"title":"Alphas","description":"Top-down twin-stick shooter consisting of five interlinked deadly arenas","date":"2013","link":"/games/alphas","externalLink":null,"tags":["XNA","3D"]},{"title":"Ancient Odyssey","description":"Puzzle escape room game for iOS and Android","date":"2013","link":"/games/ancient-odyssey","externalLink":null,"tags":["Flash","iOS","2D"]},{"title":"Lunar Escape","description":"Puzzle escape room game for iOS and Android","date":"2013","link":"/games/lunar-escape","externalLink":null,"tags":["Flash","iOS","2D"]},{"title":"The Rise","description":"Puzzle escape room game for iOS and Android","date":"2013","link":"/games/the-rise","externalLink":null,"tags":["Flash","iOS","2D"]},{"title":"Escape the Estate","description":"Point-and-click adventure game for the web","date":"2013","link":"/games/escape-the-estate","externalLink":null,"tags":["Flash","2D"]},{"title":"Escape the Basement","description":"Point-and-click adventure game for the web","date":"2012","link":"/games/escape-the-basement","externalLink":null,"tags":["Flash","2D"]}]},{"title":"Websites","projects":[{"title":"Zigurous","description":"Game studio website showcasing assets, tutorials, and games","date":"2021","link":"/websites/zigurous","externalLink":"https://zigurous.com/","tags":["React","Unity"]},{"title":"Colorly","description":"Versatile collection of color tools for designers and developers","date":"2020","link":"/websites/colorly","externalLink":"https://adamgraham.github.io/colorly","tags":["React"]},{"title":"Polykai","description":"Dark color scheme for code editors inspired by the Monokai theme","date":"2019","link":"/websites/polykai","externalLink":"https://adamgraham.github.io/polykai-website/","tags":["React"]},{"title":"Be Super","description":"Social justice movement calling for everyone to be the hero within","date":"2016","link":"/websites/be-super","externalLink":"https://adamgraham.github.io/preview/besuper","tags":["Muse"]},{"title":"Margaret Baughman","description":"Theatre director, choreographer, and empathetic human","date":"2016","link":"/websites/margaret-baughman","externalLink":"https://adamgraham.github.io/preview/margaretbaughman","tags":["Muse"]},{"title":"Ashantis Jones","description":"Event planner creating memorable events through detailed design","date":"2016","link":"/websites/ashantis-jones","externalLink":"https://adamgraham.github.io/preview/ashantisjones","tags":["Muse"]},{"title":"Allium","description":"Home-based floral design studio - fresh faced floral design","date":"2015","link":"/websites/allium","externalLink":"https://adamgraham.github.io/preview/allium","tags":["Muse"]},{"title":"Squish-em!","description":"One-page artistic cover designed to promote the mobile game","date":"2015","link":"/websites/squish-em","externalLink":"https://adamgraham.github.io/preview/squishem","tags":["Muse"]},{"title":"Let It Beard","description":"Animated short film that follows the misadventures of an enigmatic cult","date":"2014","link":"/websites/let-it-beard","externalLink":"https://adamgraham.github.io/preview/letitbeard","tags":["Muse","Flash"]},{"title":"DemonTHON","description":"Year-long fundraising org culminating in a 24-hour Dance Marathon","date":"2014","link":"/websites/demonthon","externalLink":"https://adamgraham.github.io/preview/demonthon","tags":["Muse"]},{"title":"Taylor Cochran Music","description":"Singer/songwriter from Nashville pursuing his songwriting career","date":"2013","link":"/websites/taylor-cochran-music","externalLink":"https://adamgraham.github.io/preview/taylorcochranmusic","tags":["Muse"]}]},{"title":"Interactive Art","projects":[{"title":"Hexahedroniks","description":"Virtual reality puzzle-like toy inspired by Rubik cubes","date":"2015","link":"/art/hexahedroniks","externalLink":null,"tags":["Unity","VR/AR","3D"]},{"title":"Canvas","description":"Never-ending interactive painting | Learn to let go and design with the flow","date":"2015","link":"/art/canvas","externalLink":null,"tags":["Flash","2D"]},{"title":"Mixed","description":"Interactive avant-garde experiment about diversity and interracial relationships","date":"2015","link":"/art/mixed","externalLink":null,"tags":["Flash","2D"]},{"title":"Blackhole","description":"Free-form avant-garde game to control particles in unique ways","date":"2015","link":"/art/blackhole","externalLink":null,"tags":["Flash","2D"]}]}]}},"pageContext":{}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-projects-tsx","path":"/projects","result":{"data":{"json":{"categories":[{"title":"Client Work","projects":[{"title":"3D Farming World","description":"Fully simulated 3D world to visualize farming data","date":"2024","link":null,"externalLink":"https://www.linkedin.com/in/adamzigurous","tags":["Unity","React","3D"]},{"title":"Wealth Management App","description":"Native iPad app + React web app to manage wealth portfolios","date":"2021","link":null,"externalLink":"https://www.linkedin.com/in/adamzigurous","tags":["React","iOS"]},{"title":"Bale Mobile App","description":"Native iOS app to help farmers improve efficiency when baling hay","date":"2019","link":null,"externalLink":"https://www.linkedin.com/in/adamzigurous","tags":["iOS"]},{"title":"Predictive Yield","description":"React web app to visualize predictive yield and moisture data","date":"2019","link":null,"externalLink":"https://www.linkedin.com/in/adamzigurous","tags":["React"]},{"title":"Banking / Credit Card App","description":"Native iOS app with over 1 million daily active users","date":"2018","link":null,"externalLink":"https://www.linkedin.com/in/adamzigurous","tags":["iOS","React Native"]},{"title":"Cinematic VR App","description":"Mobile VR app that puts the user in the front-seat of a self-driving car","date":"2017","link":null,"externalLink":"https://www.linkedin.com/in/adamzigurous","tags":["Unity","iOS","VR/AR"]}]},{"title":"Tech Showcases","projects":[{"title":"Blockchain Gardens","description":"Real-time 3D visualization of a private Ethereum blockchain instance","date":"2018","link":"/tech/blockchain-gardens","externalLink":null,"tags":["Unity","Blockchain","3D"]},{"title":"RockstAR","description":"Interactive AR experience of a live rock concert using Microsoft HoloLens","date":"2016","link":"/tech/rockstar","externalLink":null,"tags":["Unity","VR/AR","3D"]},{"title":"Vender VR","description":"VR experience synced with an IoT vending machine to dispense real products","date":"2015","link":"/tech/vender-vr","externalLink":null,"tags":["Unity","VR/AR","3D"]}]},{"title":"Libraries & Frameworks","projects":[{"title":"Palette","description":"Swift command line tool to parse and generate color palettes","date":"2019","link":null,"externalLink":"https://github.com/adamgraham/palette","tags":["iOS"]},{"title":"Colorly","description":"iOS framework with hundreds of functions to manipulate colors","date":"2019","link":null,"externalLink":"https://github.com/adamgraham/colorly-ios","tags":["iOS"]},{"title":"Polykai","description":"Dark color scheme for code editors inspired by the Monokai theme","date":"2019","link":null,"externalLink":"https://github.com/adamgraham/polykai","tags":[]},{"title":"STween","description":"iOS animation framework for creating complex tweening animations","date":"2016","link":null,"externalLink":"https://github.com/adamgraham/STween","tags":["iOS"]},{"title":"Chronos","description":"iOS utility framework to create different types of timers","date":"2016","link":null,"externalLink":"https://github.com/adamgraham/chronos","tags":["iOS"]}]},{"title":"Presentations","projects":[{"title":"The Life of a UX Engineer","description":"Bridging the gap between design and engineering","date":"2020","link":"/presentations/the-life-of-a-ux-engineer","externalLink":null,"tags":["React"]},{"title":"An Animation Story","description":"A 3D animated story about designers and engineers","date":"2017","link":"/presentations/an-animation-story","externalLink":null,"tags":["Unity","3D"]},{"title":"Entering the New Reality","description":"Presentation and meet-up exploring VR, AR, and MR","date":"2016","link":"/presentations/entering-the-new-reality","externalLink":null,"tags":["VR/AR","3D"]},{"title":"3D Application Development","description":"Introductory concepts for 3D application development","date":"2016","link":"/presentations/3d-application-development-overview","externalLink":null,"tags":["Unity","3D"]}]},{"title":"Games","projects":[{"title":"Hackathon for Wildlife","description":"Empathetic game that teaches about the dangers of poaching","date":"2015","link":"/games/hackathon-for-wildlife","externalLink":null,"tags":["Unity","3D"]},{"title":"The Wandering Dark","description":"Indie adventure game that explores a girl's dreams and nightmares","date":"2015","link":"/games/the-wandering-dark","externalLink":null,"tags":["Unity","3D"]},{"title":"Squish-em!","description":"Whack-a-mole arcade game published on the App Store","date":"2015","link":"/games/squish-em","externalLink":null,"tags":["Flash","iOS","2D"]},{"title":"Ferro","description":"Virtual reality experience inspired by ferrofluids","date":"2015","link":"/games/ferro","externalLink":null,"tags":["Unity","3D"]},{"title":"Elegy","description":"Deep game covering stages of grief as a parent deals with the loss of their child","date":"2015","link":"/games/elegy","externalLink":null,"tags":["Flash","2D"]},{"title":"Boss Rush","description":"Top-down twin-stick shooter consisting of nothing but boss fights","date":"2014","link":"/games/boss-rush","externalLink":null,"tags":["Unity","3D"]},{"title":"Alphas","description":"Top-down twin-stick shooter consisting of five interlinked deadly arenas","date":"2013","link":"/games/alphas","externalLink":null,"tags":["XNA","3D"]},{"title":"Ancient Odyssey","description":"Puzzle escape room game for iOS and Android","date":"2013","link":"/games/ancient-odyssey","externalLink":null,"tags":["Flash","iOS","2D"]},{"title":"Lunar Escape","description":"Puzzle escape room game for iOS and Android","date":"2013","link":"/games/lunar-escape","externalLink":null,"tags":["Flash","iOS","2D"]},{"title":"The Rise","description":"Puzzle escape room game for iOS and Android","date":"2013","link":"/games/the-rise","externalLink":null,"tags":["Flash","iOS","2D"]},{"title":"Escape the Estate","description":"Point-and-click adventure game for the web","date":"2013","link":"/games/escape-the-estate","externalLink":null,"tags":["Flash","2D"]},{"title":"Escape the Basement","description":"Point-and-click adventure game for the web","date":"2012","link":"/games/escape-the-basement","externalLink":null,"tags":["Flash","2D"]}]},{"title":"Websites","projects":[{"title":"Zigurous","description":"Game studio website showcasing assets, tutorials, and games","date":"2021","link":"/websites/zigurous","externalLink":"https://zigurous.com/","tags":["React","Unity"]},{"title":"Colorly","description":"Versatile collection of color tools for designers and developers","date":"2020","link":"/websites/colorly","externalLink":"https://adamgraham.github.io/colorly","tags":["React"]},{"title":"Polykai","description":"Dark color scheme for code editors inspired by the Monokai theme","date":"2019","link":"/websites/polykai","externalLink":"https://adamgraham.github.io/polykai-website/","tags":["React"]},{"title":"Be Super","description":"Social justice movement calling for everyone to be the hero within","date":"2016","link":"/websites/be-super","externalLink":"https://adamgraham.github.io/preview/besuper","tags":["Muse"]},{"title":"Margaret Baughman","description":"Theatre director, choreographer, and empathetic human","date":"2016","link":"/websites/margaret-baughman","externalLink":"https://adamgraham.github.io/preview/margaretbaughman","tags":["Muse"]},{"title":"Ashantis Jones","description":"Event planner creating memorable events through detailed design","date":"2016","link":"/websites/ashantis-jones","externalLink":"https://adamgraham.github.io/preview/ashantisjones","tags":["Muse"]},{"title":"Allium","description":"Home-based floral design studio - fresh faced floral design","date":"2015","link":"/websites/allium","externalLink":"https://adamgraham.github.io/preview/allium","tags":["Muse"]},{"title":"Squish-em!","description":"One-page artistic cover designed to promote the mobile game","date":"2015","link":"/websites/squish-em","externalLink":"https://adamgraham.github.io/preview/squishem","tags":["Muse"]},{"title":"Let It Beard","description":"Animated short film that follows the misadventures of an enigmatic cult","date":"2014","link":"/websites/let-it-beard","externalLink":"https://adamgraham.github.io/preview/letitbeard","tags":["Muse","Flash"]},{"title":"DemonTHON","description":"Year-long fundraising org culminating in a 24-hour Dance Marathon","date":"2014","link":"/websites/demonthon","externalLink":"https://adamgraham.github.io/preview/demonthon","tags":["Muse"]},{"title":"Taylor Cochran Music","description":"Singer/songwriter from Nashville pursuing his songwriting career","date":"2013","link":"/websites/taylor-cochran-music","externalLink":"https://adamgraham.github.io/preview/taylorcochranmusic","tags":["Muse"]}]},{"title":"Interactive Art","projects":[{"title":"Hexahedroniks","description":"Virtual reality puzzle-like toy inspired by Rubik cubes","date":"2015","link":"/art/hexahedroniks","externalLink":null,"tags":["Unity","VR/AR","3D"]},{"title":"Canvas","description":"Never-ending interactive painting | Learn to let go and design with the flow","date":"2015","link":"/art/canvas","externalLink":null,"tags":["Flash","2D"]},{"title":"Mixed","description":"Interactive avant-garde experiment about diversity and interracial relationships","date":"2015","link":"/art/mixed","externalLink":null,"tags":["Flash","2D"]},{"title":"Blackhole","description":"Free-form avant-garde game to control particles in unique ways","date":"2015","link":"/art/blackhole","externalLink":null,"tags":["Flash","2D"]}]}]}},"pageContext":{}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/software/page-data.json b/page-data/software/page-data.json index 5e99ab1..b8320d3 100644 --- a/page-data/software/page-data.json +++ b/page-data/software/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-software-js","path":"/software","result":{"pageContext":{}},"staticQueryHashes":[]} \ No newline at end of file +{"componentChunkName":"component---src-pages-software-tsx","path":"/software","result":{"pageContext":{}},"staticQueryHashes":[]} \ No newline at end of file diff --git a/page-data/sq/d/3141325806.json b/page-data/sq/d/3141325806.json deleted file mode 100644 index c33fbf8..0000000 --- a/page-data/sq/d/3141325806.json +++ /dev/null @@ -1 +0,0 @@ -{"data":{"games":{"nodes":[{"id":"the-wandering-dark","category":"games","title":"The Wandering Dark","image":{"sharp":{"original":{"src":"/static/the-wandering-dark-painting-42c7a01901465e811b451d8e0efc39ed.jpg","width":1920,"height":756}}},"imageAltText":"The Wandering Dark Painting","imageBorder":null},{"id":"boss-rush","category":"games","title":"Boss Rush","image":{"sharp":{"original":{"src":"/static/boss-rush-painting-b2339ec284e2424c331883a20e30fbf1.jpg","width":1920,"height":960}}},"imageAltText":"Boss Rush Painting","imageBorder":null},{"id":"alphas","category":"games","title":"Alphas","image":{"sharp":{"original":{"src":"/static/alphas-painting-b30cd5e096e0c931e7c944358b2d3ae4.jpg","width":800,"height":380}}},"imageAltText":"Alphas Painting","imageBorder":null},{"id":"hackathon-for-wildlife","category":"games","title":"Hackathon for Wildlife","image":{"sharp":{"original":{"src":"/static/hackathon-for-wildlife-painting-ccf9c600d554f105d20ff2975c9b71b2.jpg","width":2560,"height":1260}}},"imageAltText":"Hackathon for Wildlife Painting","imageBorder":null},{"id":"ferro","category":"games","title":"Ferro","image":{"sharp":{"original":{"src":"/static/ferro-painting-1fa5cc35a12c4c391a1b6decc8a66a9f.jpg","width":1920,"height":900}}},"imageAltText":"Ferro Painting","imageBorder":null},{"id":"elegy","category":"games","title":"Elegy","image":{"sharp":{"original":{"src":"/static/elegy-painting-c740be5d8c41cb8756acfab75b735d61.jpg","width":1280,"height":620}}},"imageAltText":"Elegy Painting","imageBorder":null},{"id":"squish-em","category":"games","title":"Squish-em!","image":{"sharp":{"original":{"src":"/static/squishem-game-painting-03ac014a69e3ca9d2c9c43807ac5032b.jpg","width":1024,"height":500}}},"imageAltText":"Squish-em! Painting","imageBorder":null},{"id":"ancient-odyssey","category":"games","title":"Ancient Odyssey","image":{"sharp":{"original":{"src":"/static/ancient-odyssey-painting-59a5b2f87ad3d126a5d9d1a0b40294a7.jpg","width":800,"height":400}}},"imageAltText":"Ancient Odyssey Painting","imageBorder":null},{"id":"lunar-escape","category":"games","title":"Lunar Escape","image":{"sharp":{"original":{"src":"/static/lunar-escape-painting-d260a732497ade1dce42ac320185b113.jpg","width":800,"height":400}}},"imageAltText":"Lunar Escape Painting","imageBorder":null},{"id":"the-rise","category":"games","title":"The Rise","image":{"sharp":{"original":{"src":"/static/the-rise-painting-76bf4fd5f507d788e18d265d70ffed2d.jpg","width":800,"height":480}}},"imageAltText":"The Rise Painting","imageBorder":null},{"id":"escape-the-estate","category":"games","title":"Escape the Estate","image":{"sharp":{"original":{"src":"/static/escape-the-estate-painting-94c6124b5af649da24c14859698dc218.jpg","width":640,"height":480}}},"imageAltText":"Escape the Estate Painting","imageBorder":null},{"id":"escape-the-basement","category":"games","title":"Escape the Basement","image":{"sharp":{"original":{"src":"/static/escape-the-basement-painting-e8eaa3ea9847059180b86d174b4bea2b.jpg","width":800,"height":535}}},"imageAltText":"Escape the Basement Painting","imageBorder":null}]},"art":{"nodes":[{"id":"canvas","category":"art","title":"Canvas","image":{"sharp":{"original":{"src":"/static/canvas-painting-2201431580ef00d90383aed291502f8a.png","width":1380,"height":820}}},"imageAltText":"Canvas Painting","imageBorder":"none"},{"id":"blackhole","category":"art","title":"Blackhole","image":{"sharp":{"original":{"src":"/static/blackhole-painting-ce57b1b3c9fb499010b3f451c327a4c0.jpg","width":1680,"height":840}}},"imageAltText":"Blackhole Painting","imageBorder":null},{"id":"mixed","category":"art","title":"Mixed","image":{"sharp":{"original":{"src":"/static/mixed-painting-fcd381fb2cbd3d7e584a45dc0fae918f.jpg","width":1280,"height":640}}},"imageAltText":"Mixed Painting","imageBorder":null},{"id":"hexahedroniks","category":"art","title":"Hexahedroniks","image":{"sharp":{"original":{"src":"/static/hexahedroniks-painting-4d13493a90b51eb7b9d0c4dd5e156d37.jpg","width":1680,"height":840}}},"imageAltText":"Hexahedroniks Painting","imageBorder":null}]},"websites":{"nodes":[{"id":"zigurous","category":"websites","title":"Zigurous","image":{"sharp":{"original":{"src":"/static/zigurous-painting-a61220284b22e1a8d288977a83e87ff1.jpg","width":1920,"height":800}}},"imageAltText":"Zigurous Painting","imageBorder":null},{"id":"colorly","category":"websites","title":"Colorly","image":{"sharp":{"original":{"src":"/static/colorly-painting-c337bc9f4a03e108182b21f3555dd304.jpg","width":1920,"height":800}}},"imageAltText":"Colorly Painting","imageBorder":null},{"id":"polykai","category":"websites","title":"Polykai","image":{"sharp":{"original":{"src":"/static/polykai-painting-bdc58a58a1c2aed5e90b381d661b2839.jpg","width":1920,"height":800}}},"imageAltText":"Polykai Painting","imageBorder":null},{"id":"allium","category":"websites","title":"Allium","image":{"sharp":{"original":{"src":"/static/allium-painting-20490acb31bcafb163dfdfd8ab014688.jpg","width":1920,"height":800}}},"imageAltText":"Allium Painting","imageBorder":null},{"id":"demonthon","category":"websites","title":"DemonTHON","image":{"sharp":{"original":{"src":"/static/demonthon-painting-8ff5a00ecb31b9d93202e6c41464b932.jpg","width":1920,"height":800}}},"imageAltText":"DemonTHON Painting","imageBorder":null},{"id":"be-super","category":"websites","title":"Be Super","image":{"sharp":{"original":{"src":"/static/be-super-painting-01320e270561aaedd70580e9e1624c66.jpg","width":1920,"height":800}}},"imageAltText":"Be Super Painting","imageBorder":null},{"id":"ashantis-jones","category":"websites","title":"Ashantis Jones","image":{"sharp":{"original":{"src":"/static/ashantis-jones-painting-3ee0f7c4d4fc33ecef231639d5d96b71.jpg","width":1920,"height":800}}},"imageAltText":"Ashantis Jones Painting","imageBorder":null},{"id":"margaret-baughman","category":"websites","title":"Margaret Baughman","image":{"sharp":{"original":{"src":"/static/margaret-baughman-painting-5f1ea4c73cfc624545863d14b4a7f7b9.jpg","width":1920,"height":800}}},"imageAltText":"Margaret Baughman Painting","imageBorder":null},{"id":"taylor-cochran-music","category":"websites","title":"Taylor Cochran Music","image":{"sharp":{"original":{"src":"/static/taylor-cochran-music-painting-086051bf1e9725d9a46b7aa52a43e868.jpg","width":1920,"height":800}}},"imageAltText":"Taylor Cochran Music Painting","imageBorder":null},{"id":"squish-em","category":"websites","title":"Squish-em!","image":{"sharp":{"original":{"src":"/static/squishem-website-painting-5d9f949228abbe50f01993e6fb4e5414.jpg","width":1920,"height":800}}},"imageAltText":"Squish-em! Painting","imageBorder":null},{"id":"let-it-beard","category":"websites","title":"Let It Beard","image":{"sharp":{"original":{"src":"/static/let-it-beard-painting-4004bc86c65e8e913c130befc7011778.jpg","width":1920,"height":800}}},"imageAltText":"Let It Beard Painting","imageBorder":null}]},"tech":{"nodes":[{"id":"blockchain-gardens","category":"tech","title":"Blockchain Gardens","image":{"sharp":{"original":{"src":"/static/blockchain-gardens-painting-e2f0809e8cb80d4a2d8412ba2aad85fe.jpg","width":1920,"height":800}}},"imageAltText":"Blockchain Gardens Painting","imageBorder":null},{"id":"rockstar","category":"tech","title":"RockstAR","image":{"sharp":{"original":{"src":"/static/rockstar-painting-2a5c7827553b84947b3d383cff8edfd0.jpg","width":1920,"height":800}}},"imageAltText":"RockstAR Painting","imageBorder":null},{"id":"vender-vr","category":"tech","title":"Vender VR","image":{"sharp":{"original":{"src":"/static/vender-vr-painting-a742ca62f33d3eaf903d24170e10bd34.jpg","width":1920,"height":800}}},"imageAltText":"Vender VR Painting","imageBorder":null}]},"presentations":{"nodes":[{"id":"the-life-of-a-ux-engineer","category":"presentations","title":"The Life of a UX Engineer","image":{"sharp":{"original":{"src":"/static/the-life-of-a-ux-engineer-painting-ca68e947b1c6cccc1dab1a636456e8eb.jpg","width":1920,"height":800}}},"imageAltText":"The Life of a UX Engineer Painting","imageBorder":null},{"id":"an-animation-story","category":"presentations","title":"An Animation Story","image":{"sharp":{"original":{"src":"/static/an-animation-story-painting-bbee52f6d37d18f18550a7b9eac6a68f.jpg","width":1920,"height":800}}},"imageAltText":"An Animation Story Painting","imageBorder":null},{"id":"entering-the-new-reality","category":"presentations","title":"Entering the New Reality","image":{"sharp":{"original":{"src":"/static/entering-the-new-reality-painting-2c3fe156a632e1340aa78016491dcab4.jpg","width":1920,"height":800}}},"imageAltText":"Entering the New Reality Painting","imageBorder":null},{"id":"3d-application-development-overview","category":"presentations","title":"3D Application Development","image":{"sharp":{"original":{"src":"/static/3d-application-development-overview-painting-dcc07e558c8fdc5a1f99644f10112c51.jpg","width":1920,"height":800}}},"imageAltText":"3D Application Development Painting","imageBorder":null}]}}} \ No newline at end of file diff --git a/page-data/sq/d/3709745113.json b/page-data/sq/d/3709745113.json new file mode 100644 index 0000000..a4e545d --- /dev/null +++ b/page-data/sq/d/3709745113.json @@ -0,0 +1 @@ +{"data":{"games":{"nodes":[{"id":"the-wandering-dark","category":"games","title":"The Wandering Dark","image":{"sharp":{"original":{"src":"/static/the-wandering-dark-painting-42c7a01901465e811b451d8e0efc39ed.jpg","width":1920,"height":756}}},"imageAltText":"The Wandering Dark Painting","imageBorder":null},{"id":"boss-rush","category":"games","title":"Boss Rush","image":{"sharp":{"original":{"src":"/static/boss-rush-painting-b2339ec284e2424c331883a20e30fbf1.jpg","width":1920,"height":960}}},"imageAltText":"Boss Rush Painting","imageBorder":null},{"id":"alphas","category":"games","title":"Alphas","image":{"sharp":{"original":{"src":"/static/alphas-painting-b30cd5e096e0c931e7c944358b2d3ae4.jpg","width":800,"height":380}}},"imageAltText":"Alphas Painting","imageBorder":null},{"id":"hackathon-for-wildlife","category":"games","title":"Hackathon for Wildlife","image":{"sharp":{"original":{"src":"/static/hackathon-for-wildlife-painting-ccf9c600d554f105d20ff2975c9b71b2.jpg","width":2560,"height":1260}}},"imageAltText":"Hackathon for Wildlife Painting","imageBorder":null},{"id":"ferro","category":"games","title":"Ferro","image":{"sharp":{"original":{"src":"/static/ferro-painting-1fa5cc35a12c4c391a1b6decc8a66a9f.jpg","width":1920,"height":900}}},"imageAltText":"Ferro Painting","imageBorder":null},{"id":"elegy","category":"games","title":"Elegy","image":{"sharp":{"original":{"src":"/static/elegy-painting-c740be5d8c41cb8756acfab75b735d61.jpg","width":1280,"height":620}}},"imageAltText":"Elegy Painting","imageBorder":null},{"id":"squish-em","category":"games","title":"Squish-em!","image":{"sharp":{"original":{"src":"/static/squishem-game-painting-03ac014a69e3ca9d2c9c43807ac5032b.jpg","width":1024,"height":500}}},"imageAltText":"Squish-em! Painting","imageBorder":null},{"id":"ancient-odyssey","category":"games","title":"Ancient Odyssey","image":{"sharp":{"original":{"src":"/static/ancient-odyssey-painting-59a5b2f87ad3d126a5d9d1a0b40294a7.jpg","width":800,"height":400}}},"imageAltText":"Ancient Odyssey Painting","imageBorder":null},{"id":"lunar-escape","category":"games","title":"Lunar Escape","image":{"sharp":{"original":{"src":"/static/lunar-escape-painting-d260a732497ade1dce42ac320185b113.jpg","width":800,"height":400}}},"imageAltText":"Lunar Escape Painting","imageBorder":null},{"id":"the-rise","category":"games","title":"The Rise","image":{"sharp":{"original":{"src":"/static/the-rise-painting-76bf4fd5f507d788e18d265d70ffed2d.jpg","width":800,"height":480}}},"imageAltText":"The Rise Painting","imageBorder":null},{"id":"escape-the-estate","category":"games","title":"Escape the Estate","image":{"sharp":{"original":{"src":"/static/escape-the-estate-painting-94c6124b5af649da24c14859698dc218.jpg","width":640,"height":480}}},"imageAltText":"Escape the Estate Painting","imageBorder":null},{"id":"escape-the-basement","category":"games","title":"Escape the Basement","image":{"sharp":{"original":{"src":"/static/escape-the-basement-painting-e8eaa3ea9847059180b86d174b4bea2b.jpg","width":800,"height":535}}},"imageAltText":"Escape the Basement Painting","imageBorder":null}]},"websites":{"nodes":[{"id":"zigurous","category":"websites","title":"Zigurous","image":{"sharp":{"original":{"src":"/static/zigurous-painting-a61220284b22e1a8d288977a83e87ff1.jpg","width":1920,"height":800}}},"imageAltText":"Zigurous Painting","imageBorder":null},{"id":"colorly","category":"websites","title":"Colorly","image":{"sharp":{"original":{"src":"/static/colorly-painting-c337bc9f4a03e108182b21f3555dd304.jpg","width":1920,"height":800}}},"imageAltText":"Colorly Painting","imageBorder":null},{"id":"polykai","category":"websites","title":"Polykai","image":{"sharp":{"original":{"src":"/static/polykai-painting-bdc58a58a1c2aed5e90b381d661b2839.jpg","width":1920,"height":800}}},"imageAltText":"Polykai Painting","imageBorder":null},{"id":"allium","category":"websites","title":"Allium","image":{"sharp":{"original":{"src":"/static/allium-painting-20490acb31bcafb163dfdfd8ab014688.jpg","width":1920,"height":800}}},"imageAltText":"Allium Painting","imageBorder":null},{"id":"demonthon","category":"websites","title":"DemonTHON","image":{"sharp":{"original":{"src":"/static/demonthon-painting-8ff5a00ecb31b9d93202e6c41464b932.jpg","width":1920,"height":800}}},"imageAltText":"DemonTHON Painting","imageBorder":null},{"id":"be-super","category":"websites","title":"Be Super","image":{"sharp":{"original":{"src":"/static/be-super-painting-01320e270561aaedd70580e9e1624c66.jpg","width":1920,"height":800}}},"imageAltText":"Be Super Painting","imageBorder":null},{"id":"ashantis-jones","category":"websites","title":"Ashantis Jones","image":{"sharp":{"original":{"src":"/static/ashantis-jones-painting-3ee0f7c4d4fc33ecef231639d5d96b71.jpg","width":1920,"height":800}}},"imageAltText":"Ashantis Jones Painting","imageBorder":null},{"id":"margaret-baughman","category":"websites","title":"Margaret Baughman","image":{"sharp":{"original":{"src":"/static/margaret-baughman-painting-5f1ea4c73cfc624545863d14b4a7f7b9.jpg","width":1920,"height":800}}},"imageAltText":"Margaret Baughman Painting","imageBorder":null},{"id":"taylor-cochran-music","category":"websites","title":"Taylor Cochran Music","image":{"sharp":{"original":{"src":"/static/taylor-cochran-music-painting-086051bf1e9725d9a46b7aa52a43e868.jpg","width":1920,"height":800}}},"imageAltText":"Taylor Cochran Music Painting","imageBorder":null},{"id":"squish-em","category":"websites","title":"Squish-em!","image":{"sharp":{"original":{"src":"/static/squishem-website-painting-5d9f949228abbe50f01993e6fb4e5414.jpg","width":1920,"height":800}}},"imageAltText":"Squish-em! Painting","imageBorder":null},{"id":"let-it-beard","category":"websites","title":"Let It Beard","image":{"sharp":{"original":{"src":"/static/let-it-beard-painting-4004bc86c65e8e913c130befc7011778.jpg","width":1920,"height":800}}},"imageAltText":"Let It Beard Painting","imageBorder":null}]},"art":{"nodes":[{"id":"canvas","category":"art","title":"Canvas","image":{"sharp":{"original":{"src":"/static/canvas-painting-2201431580ef00d90383aed291502f8a.png","width":1380,"height":820}}},"imageAltText":"Canvas Painting","imageBorder":false},{"id":"blackhole","category":"art","title":"Blackhole","image":{"sharp":{"original":{"src":"/static/blackhole-painting-ce57b1b3c9fb499010b3f451c327a4c0.jpg","width":1680,"height":840}}},"imageAltText":"Blackhole Painting","imageBorder":null},{"id":"mixed","category":"art","title":"Mixed","image":{"sharp":{"original":{"src":"/static/mixed-painting-fcd381fb2cbd3d7e584a45dc0fae918f.jpg","width":1280,"height":640}}},"imageAltText":"Mixed Painting","imageBorder":null},{"id":"hexahedroniks","category":"art","title":"Hexahedroniks","image":{"sharp":{"original":{"src":"/static/hexahedroniks-painting-4d13493a90b51eb7b9d0c4dd5e156d37.jpg","width":1680,"height":840}}},"imageAltText":"Hexahedroniks Painting","imageBorder":null}]},"tech":{"nodes":[{"id":"blockchain-gardens","category":"tech","title":"Blockchain Gardens","image":{"sharp":{"original":{"src":"/static/blockchain-gardens-painting-e2f0809e8cb80d4a2d8412ba2aad85fe.jpg","width":1920,"height":800}}},"imageAltText":"Blockchain Gardens Painting","imageBorder":null},{"id":"rockstar","category":"tech","title":"RockstAR","image":{"sharp":{"original":{"src":"/static/rockstar-painting-2a5c7827553b84947b3d383cff8edfd0.jpg","width":1920,"height":800}}},"imageAltText":"RockstAR Painting","imageBorder":null},{"id":"vender-vr","category":"tech","title":"Vender VR","image":{"sharp":{"original":{"src":"/static/vender-vr-painting-a742ca62f33d3eaf903d24170e10bd34.jpg","width":1920,"height":800}}},"imageAltText":"Vender VR Painting","imageBorder":null}]},"presentations":{"nodes":[{"id":"the-life-of-a-ux-engineer","category":"presentations","title":"The Life of a UX Engineer","image":{"sharp":{"original":{"src":"/static/the-life-of-a-ux-engineer-painting-ca68e947b1c6cccc1dab1a636456e8eb.jpg","width":1920,"height":800}}},"imageAltText":"The Life of a UX Engineer Painting","imageBorder":null},{"id":"an-animation-story","category":"presentations","title":"An Animation Story","image":{"sharp":{"original":{"src":"/static/an-animation-story-painting-bbee52f6d37d18f18550a7b9eac6a68f.jpg","width":1920,"height":800}}},"imageAltText":"An Animation Story Painting","imageBorder":null},{"id":"entering-the-new-reality","category":"presentations","title":"Entering the New Reality","image":{"sharp":{"original":{"src":"/static/entering-the-new-reality-painting-2c3fe156a632e1340aa78016491dcab4.jpg","width":1920,"height":800}}},"imageAltText":"Entering the New Reality Painting","imageBorder":null},{"id":"3d-application-development-overview","category":"presentations","title":"3D Application Development","image":{"sharp":{"original":{"src":"/static/3d-application-development-overview-painting-dcc07e558c8fdc5a1f99644f10112c51.jpg","width":1920,"height":800}}},"imageAltText":"3D Application Development Painting","imageBorder":null}]}}} \ No newline at end of file diff --git a/page-data/tech/blockchain-gardens/page-data.json b/page-data/tech/blockchain-gardens/page-data.json index 22467f1..79c67b2 100644 --- a/page-data/tech/blockchain-gardens/page-data.json +++ b/page-data/tech/blockchain-gardens/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-tech-tech-json-json-id-js","path":"/tech/blockchain-gardens","result":{"data":{"project":{"id":"blockchain-gardens","category":"tech","title":"Blockchain Gardens","description":null,"description_short":"Blockchain Gardens is a real-time 3D visualization of a private Ethereum blockchain instance. It was one of the main displays at Solstice's annual digital innovation summit.","description_long":["The blockchain is as complicated, misunderstood and powerfully compelling as any emerging technology that currently exists. It's no longer sufficient to merely explain the technical nuances and intricacies, the time has come for you to experience them. Built on the Ethereum backbone, Solstice FWD attendees participated in one of the first human blockchain experiments in history. Interactions and exchanges were recorded on the FWD ledger and the \"future of trust in a trustless world\" was on full display.","Blockchain Gardens is a real-time 3D visualization of a private Ethereum blockchain instance displayed at Solstice's annual digital innovation summit. Attendees at the event were tracked throughout the space by an RFID in their badge. As they visited each event booth, these moments and experiences were recorded on the blockchain. We wanted to explore what it would be like to put humans at the center of this emerging technology."],"date":"June 2018","role":"Front-end Developer, 3D Designer","tech":["Unity","C#","Ethereum","Firebase","RFID","AWS","PCF"],"image":{"sharp":{"original":{"src":"/static/blockchain-gardens-painting-e2f0809e8cb80d4a2d8412ba2aad85fe.jpg","width":1920,"height":800}}},"buttons":null,"sections":[{"title":"Media","link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/blockchain-gardens-screenshot-01-d2b34c1e599d92f835d387cff8625f7f.jpg","width":1920,"height":1080}}},{"sharp":{"original":{"src":"/static/blockchain-gardens-screenshot-02-d35d47574c200a3c4dc5a385c76b9f99.jpg","width":1920,"height":1080}}},{"sharp":{"original":{"src":"/static/blockchain-gardens-screenshot-03-108997a4a686141b56aabd37a76bffb6.jpg","width":1920,"height":1080}}},{"sharp":{"original":{"src":"/static/blockchain-gardens-screenshot-04-351093e70fe51af665532952e77184bb.jpg","width":1920,"height":1080}}}],"videos":["R-OoF7NQWOI","s7MI_uzRdMI","Ng0IEkbdkHc"]}]}},"pageContext":{"id":"8958175a-7c5b-5dad-99ae-6a8e6dc3ebe4","jsonId":"blockchain-gardens","__params":{"jsonId":"blockchain-gardens"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-tech-tech-json-json-id-tsx","path":"/tech/blockchain-gardens","result":{"data":{"project":{"id":"blockchain-gardens","category":"tech","title":"Blockchain Gardens","description":null,"description_short":"Blockchain Gardens is a real-time 3D visualization of a private Ethereum blockchain instance. It was one of the main displays at Solstice's annual digital innovation summit.","description_long":["The blockchain is as complicated, misunderstood and powerfully compelling as any emerging technology that currently exists. It's no longer sufficient to merely explain the technical nuances and intricacies, the time has come for you to experience them. Built on the Ethereum backbone, Solstice FWD attendees participated in one of the first human blockchain experiments in history. Interactions and exchanges were recorded on the FWD ledger and the \"future of trust in a trustless world\" was on full display.","Blockchain Gardens is a real-time 3D visualization of a private Ethereum blockchain instance displayed at Solstice's annual digital innovation summit. Attendees at the event were tracked throughout the space by an RFID in their badge. As they visited each event booth, these moments and experiences were recorded on the blockchain. We wanted to explore what it would be like to put humans at the center of this emerging technology."],"date":"June 2018","role":"Front-end Developer, 3D Designer","tech":["Unity","C#","Ethereum","Firebase","RFID","AWS","PCF"],"image":{"sharp":{"original":{"src":"/static/blockchain-gardens-painting-e2f0809e8cb80d4a2d8412ba2aad85fe.jpg","width":1920,"height":800}}},"buttons":null,"sections":[{"title":"Media","link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/blockchain-gardens-screenshot-01-d2b34c1e599d92f835d387cff8625f7f.jpg","width":1920,"height":1080}}},{"sharp":{"original":{"src":"/static/blockchain-gardens-screenshot-02-d35d47574c200a3c4dc5a385c76b9f99.jpg","width":1920,"height":1080}}},{"sharp":{"original":{"src":"/static/blockchain-gardens-screenshot-03-108997a4a686141b56aabd37a76bffb6.jpg","width":1920,"height":1080}}},{"sharp":{"original":{"src":"/static/blockchain-gardens-screenshot-04-351093e70fe51af665532952e77184bb.jpg","width":1920,"height":1080}}}],"videos":["R-OoF7NQWOI","s7MI_uzRdMI","Ng0IEkbdkHc"]}]}},"pageContext":{"id":"8958175a-7c5b-5dad-99ae-6a8e6dc3ebe4","jsonId":"blockchain-gardens","__params":{"jsonId":"blockchain-gardens"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/tech/page-data.json b/page-data/tech/page-data.json index 6f1d4a2..0619a6b 100644 --- a/page-data/tech/page-data.json +++ b/page-data/tech/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-tech-js","path":"/tech","result":{"data":{"json":{"slides":[{"id":"blockchain-gardens","category":"tech","date":"June 2018","title":"Blockchain Gardens","description":null,"description_short":"Blockchain Gardens is a real-time 3D visualization of a private Ethereum blockchain instance. It was one of the main displays at Solstice's annual digital innovation summit.","image":{"sharp":{"original":{"src":"/static/blockchain-gardens-painting-e2f0809e8cb80d4a2d8412ba2aad85fe.jpg","width":1920,"height":800}}},"imageAltText":"Blockchain Gardens Painting","imageBorder":null},{"id":"rockstar","category":"tech","date":"September 2016","title":"RockstAR","description":null,"description_short":"RockstAR is an interactive AR experience demoed at Solstice FWD. By coupling the power of Microsoft's HoloLens, Philips Hue Lightbulbs, and a series of stage technologies, users are given the ability to customize a live rock band experience.","image":{"sharp":{"original":{"src":"/static/rockstar-painting-2a5c7827553b84947b3d383cff8edfd0.jpg","width":1920,"height":800}}},"imageAltText":"RockstAR Painting","imageBorder":null},{"id":"vender-vr","category":"tech","date":"September 2015","title":"Vender VR","description":null,"description_short":"Vender is an IoT connected vending machine that started as an R&D project at Solstice. Less than a month before Solstice's digital innovation summit, Adam expanded Vender to the virtual world, creating the first ever VR vending machine experience.","image":{"sharp":{"original":{"src":"/static/vender-vr-painting-a742ca62f33d3eaf903d24170e10bd34.jpg","width":1920,"height":800}}},"imageAltText":"Vender VR Painting","imageBorder":null}]}},"pageContext":{}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-tech-tsx","path":"/tech","result":{"data":{"json":{"slides":[{"id":"blockchain-gardens","category":"tech","date":"June 2018","title":"Blockchain Gardens","description":null,"description_short":"Blockchain Gardens is a real-time 3D visualization of a private Ethereum blockchain instance. It was one of the main displays at Solstice's annual digital innovation summit.","image":{"sharp":{"original":{"src":"/static/blockchain-gardens-painting-e2f0809e8cb80d4a2d8412ba2aad85fe.jpg","width":1920,"height":800}}},"imageAltText":"Blockchain Gardens Painting","imageBorder":null},{"id":"rockstar","category":"tech","date":"September 2016","title":"RockstAR","description":null,"description_short":"RockstAR is an interactive AR experience demoed at Solstice FWD. By coupling the power of Microsoft's HoloLens, Philips Hue Lightbulbs, and a series of stage technologies, users are given the ability to customize a live rock band experience.","image":{"sharp":{"original":{"src":"/static/rockstar-painting-2a5c7827553b84947b3d383cff8edfd0.jpg","width":1920,"height":800}}},"imageAltText":"RockstAR Painting","imageBorder":null},{"id":"vender-vr","category":"tech","date":"September 2015","title":"Vender VR","description":null,"description_short":"Vender is an IoT connected vending machine that started as an R&D project at Solstice. Less than a month before Solstice's digital innovation summit, Adam expanded Vender to the virtual world, creating the first ever VR vending machine experience.","image":{"sharp":{"original":{"src":"/static/vender-vr-painting-a742ca62f33d3eaf903d24170e10bd34.jpg","width":1920,"height":800}}},"imageAltText":"Vender VR Painting","imageBorder":null}]}},"pageContext":{}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/tech/rockstar/page-data.json b/page-data/tech/rockstar/page-data.json index 45342d1..ec71490 100644 --- a/page-data/tech/rockstar/page-data.json +++ b/page-data/tech/rockstar/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-tech-tech-json-json-id-js","path":"/tech/rockstar","result":{"data":{"project":{"id":"rockstar","category":"tech","title":"RockstAR","description":null,"description_short":"RockstAR is an interactive AR experience demoed at Solstice FWD. By coupling the power of Microsoft's HoloLens, Philips Hue Lightbulbs, and a series of stage technologies, users are given the ability to customize a live rock band experience.","description_long":["Augmented reality is making it possible to merge virtual objects into the physical world around us. To explore the possibilities, Adam and fellow Solstice engineers built RockstAR, an interactive AR experience demoed at Solstice FWD. By coupling the power of Microsoft's HoloLens, Philips Hue Lightbulbs, and a series of stage technologies, users are given the ability to customize a live rock band experience.","You can choose your song and color theme preferences using digital menus. Once you're ready to go, the band plays your song as you set the stage for your audience and let the lights groove to the beat. You might look a little odd pointing to things no one else can see, but the joke's on them - you're the star of the show!"],"date":"September 2016","role":"Front-end Developer, Experience Designer","tech":["Unity","C#","HoloLens","Raspberry Pi + Node.js","Phillips Hue Lights","IoT Devices","iPad"],"image":{"sharp":{"original":{"src":"/static/rockstar-painting-2a5c7827553b84947b3d383cff8edfd0.jpg","width":1920,"height":800}}},"buttons":null,"sections":[{"title":"Media","link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/rockstar-screenshot-01-cc3b6c2cad3622dd2af90a05247f05cc.jpg","width":851,"height":1200}}},{"sharp":{"original":{"src":"/static/rockstar-screenshot-02-ccd37aad2c92a17d39af8d80a28e1b94.jpg","width":1000,"height":667}}},{"sharp":{"original":{"src":"/static/rockstar-screenshot-03-16052140a5774e90be85bf0db61587f9.jpg","width":1000,"height":667}}}],"videos":["9VotoUsUsew","fUKUr3F2VVM","zQn6-UV4tGQ"]}]}},"pageContext":{"id":"b3cb1fb7-8edf-50c1-a1f2-8f4d170f2a60","jsonId":"rockstar","__params":{"jsonId":"rockstar"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-tech-tech-json-json-id-tsx","path":"/tech/rockstar","result":{"data":{"project":{"id":"rockstar","category":"tech","title":"RockstAR","description":null,"description_short":"RockstAR is an interactive AR experience demoed at Solstice FWD. By coupling the power of Microsoft's HoloLens, Philips Hue Lightbulbs, and a series of stage technologies, users are given the ability to customize a live rock band experience.","description_long":["Augmented reality is making it possible to merge virtual objects into the physical world around us. To explore the possibilities, Adam and fellow Solstice engineers built RockstAR, an interactive AR experience demoed at Solstice FWD. By coupling the power of Microsoft's HoloLens, Philips Hue Lightbulbs, and a series of stage technologies, users are given the ability to customize a live rock band experience.","You can choose your song and color theme preferences using digital menus. Once you're ready to go, the band plays your song as you set the stage for your audience and let the lights groove to the beat. You might look a little odd pointing to things no one else can see, but the joke's on them - you're the star of the show!"],"date":"September 2016","role":"Front-end Developer, Experience Designer","tech":["Unity","C#","HoloLens","Raspberry Pi + Node.js","Phillips Hue Lights","IoT Devices","iPad"],"image":{"sharp":{"original":{"src":"/static/rockstar-painting-2a5c7827553b84947b3d383cff8edfd0.jpg","width":1920,"height":800}}},"buttons":null,"sections":[{"title":"Media","link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/rockstar-screenshot-01-cc3b6c2cad3622dd2af90a05247f05cc.jpg","width":851,"height":1200}}},{"sharp":{"original":{"src":"/static/rockstar-screenshot-02-ccd37aad2c92a17d39af8d80a28e1b94.jpg","width":1000,"height":667}}},{"sharp":{"original":{"src":"/static/rockstar-screenshot-03-16052140a5774e90be85bf0db61587f9.jpg","width":1000,"height":667}}}],"videos":["9VotoUsUsew","fUKUr3F2VVM","zQn6-UV4tGQ"]}]}},"pageContext":{"id":"b3cb1fb7-8edf-50c1-a1f2-8f4d170f2a60","jsonId":"rockstar","__params":{"jsonId":"rockstar"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/tech/vender-vr/page-data.json b/page-data/tech/vender-vr/page-data.json index a16faeb..72c4a1f 100644 --- a/page-data/tech/vender-vr/page-data.json +++ b/page-data/tech/vender-vr/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-tech-tech-json-json-id-js","path":"/tech/vender-vr","result":{"data":{"project":{"id":"vender-vr","category":"tech","title":"Vender VR","description":null,"description_short":"Vender is an IoT connected vending machine that started as an R&D project at Solstice. Less than a month before Solstice's digital innovation summit, Adam expanded Vender to the virtual world, creating the first ever VR vending machine experience.","description_long":["Vender is an IoT connected vending machine that started as an R&D project at Solstice before Adam joined the team. Less than a month before Solstice's digital innovation summit - Solstice FWD - Vender was expanded to the virtual world. Adam took on the project head first and developed the first ever virtual reality vending machine experience.","A user vends the drink of their choice by putting their hand up to one of the drink taps and waiting for the cup to be filled. Once filled, a service call is made to the Raspberry Pi hooked up to the vending machine, which then vends the user's drink. Drink choices are populated from a Hybris Platform which stores and manages all of Vender's data."],"date":"September 2015","role":"Unity Developer","tech":["Unity","C#","Oculus Rift","Leap Motion","Raspberry Pi","Hybris Platform"],"image":{"sharp":{"original":{"src":"/static/vender-vr-painting-a742ca62f33d3eaf903d24170e10bd34.jpg","width":1920,"height":800}}},"buttons":null,"sections":[{"title":"Media","link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/vender-vr-screenshot-01-b8eaf74708cf4d5ad6a9480af31dd274.jpg","width":2560,"height":1326}}},{"sharp":{"original":{"src":"/static/vender-vr-screenshot-02-133eba0e1b25e46f7025823509c6cead.jpg","width":2560,"height":1269}}},{"sharp":{"original":{"src":"/static/vender-vr-screenshot-03-13ab7ef58559ae6613533047826cff3c.jpg","width":2560,"height":1269}}}],"videos":["aBnGN1j3OMM","Y-1ZXwGhHM8","nHNOTxh7Rdg"]}]}},"pageContext":{"id":"00a61dfb-23cc-54f0-acb4-ce0f393efbed","jsonId":"vender-vr","__params":{"jsonId":"vender-vr"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-tech-tech-json-json-id-tsx","path":"/tech/vender-vr","result":{"data":{"project":{"id":"vender-vr","category":"tech","title":"Vender VR","description":null,"description_short":"Vender is an IoT connected vending machine that started as an R&D project at Solstice. Less than a month before Solstice's digital innovation summit, Adam expanded Vender to the virtual world, creating the first ever VR vending machine experience.","description_long":["Vender is an IoT connected vending machine that started as an R&D project at Solstice before Adam joined the team. Less than a month before Solstice's digital innovation summit - Solstice FWD - Vender was expanded to the virtual world. Adam took on the project head first and developed the first ever virtual reality vending machine experience.","A user vends the drink of their choice by putting their hand up to one of the drink taps and waiting for the cup to be filled. Once filled, a service call is made to the Raspberry Pi hooked up to the vending machine, which then vends the user's drink. Drink choices are populated from a Hybris Platform which stores and manages all of Vender's data."],"date":"September 2015","role":"Unity Developer","tech":["Unity","C#","Oculus Rift","Leap Motion","Raspberry Pi","Hybris Platform"],"image":{"sharp":{"original":{"src":"/static/vender-vr-painting-a742ca62f33d3eaf903d24170e10bd34.jpg","width":1920,"height":800}}},"buttons":null,"sections":[{"title":"Media","link":null,"mainImage":null,"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":[{"sharp":{"original":{"src":"/static/vender-vr-screenshot-01-b8eaf74708cf4d5ad6a9480af31dd274.jpg","width":2560,"height":1326}}},{"sharp":{"original":{"src":"/static/vender-vr-screenshot-02-133eba0e1b25e46f7025823509c6cead.jpg","width":2560,"height":1269}}},{"sharp":{"original":{"src":"/static/vender-vr-screenshot-03-13ab7ef58559ae6613533047826cff3c.jpg","width":2560,"height":1269}}}],"videos":["aBnGN1j3OMM","Y-1ZXwGhHM8","nHNOTxh7Rdg"]}]}},"pageContext":{"id":"00a61dfb-23cc-54f0-acb4-ce0f393efbed","jsonId":"vender-vr","__params":{"jsonId":"vender-vr"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/websites/allium/page-data.json b/page-data/websites/allium/page-data.json index 5d67e9f..2c87e60 100644 --- a/page-data/websites/allium/page-data.json +++ b/page-data/websites/allium/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-websites-websites-json-json-id-js","path":"/websites/allium","result":{"data":{"project":{"id":"allium","category":"websites","title":"Allium","description":null,"description_short":"Allium is a home-based floral design studio launched in 2013 by Kim Stanke. After years of working in both retail stores and special event design shops, Kim started her own business to flex her creative muscles.","description_long":["Allium is a home-based floral design studio launched in 2013 by Kim Stanke. After years of working in both retail stores and special event design shops, Kim started her own business to flex her creative muscles.","Adam designed a new website for Allium as an improvement to the old WordPress site. The goal of the new design was to better promote the business and its floral services."],"date":"November 2015","role":"Web Designer","tech":["Adobe Muse","Adobe Photoshop"],"image":{"sharp":{"original":{"src":"/static/allium-painting-20490acb31bcafb163dfdfd8ab014688.jpg","width":1920,"height":800}}},"buttons":[{"name":"Visit Website","url":"https://adamgraham.github.io/preview/allium","icon":"preview"}],"sections":[{"title":null,"link":null,"mainImage":{"sharp":{"original":{"src":"/static/allium-screenshot-spread-c848f77078afad709b64c67513ab3a54.jpg","width":1080,"height":7026}}},"mainImageLink":"https://adamgraham.github.io/preview/allium","mainVideo":null,"paragraphs":null,"gallery":null,"videos":null}]}},"pageContext":{"id":"d3b3afab-edd2-5fe7-b23e-ab5ebb6bd6ce","jsonId":"allium","__params":{"jsonId":"allium"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-websites-websites-json-json-id-tsx","path":"/websites/allium","result":{"data":{"project":{"id":"allium","category":"websites","title":"Allium","description":null,"description_short":"Allium is a home-based floral design studio launched in 2013 by Kim Stanke. After years of working in both retail stores and special event design shops, Kim started her own business to flex her creative muscles.","description_long":["Allium is a home-based floral design studio launched in 2013 by Kim Stanke. After years of working in both retail stores and special event design shops, Kim started her own business to flex her creative muscles.","Adam designed a new website for Allium as an improvement to the old WordPress site. The goal of the new design was to better promote the business and its floral services."],"date":"November 2015","role":"Web Designer","tech":["Adobe Muse","Adobe Photoshop"],"image":{"sharp":{"original":{"src":"/static/allium-painting-20490acb31bcafb163dfdfd8ab014688.jpg","width":1920,"height":800}}},"buttons":[{"to":"https://adamgraham.github.io/preview/allium","name":"Visit Website","icon":"preview"}],"sections":[{"title":null,"link":null,"mainImage":{"sharp":{"original":{"src":"/static/allium-screenshot-spread-c848f77078afad709b64c67513ab3a54.jpg","width":1080,"height":7026}}},"mainImageLink":"https://adamgraham.github.io/preview/allium","mainVideo":null,"paragraphs":null,"gallery":null,"videos":null}]}},"pageContext":{"id":"d3b3afab-edd2-5fe7-b23e-ab5ebb6bd6ce","jsonId":"allium","__params":{"jsonId":"allium"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/websites/ashantis-jones/page-data.json b/page-data/websites/ashantis-jones/page-data.json index e810329..0ab73e0 100644 --- a/page-data/websites/ashantis-jones/page-data.json +++ b/page-data/websites/ashantis-jones/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-websites-websites-json-json-id-js","path":"/websites/ashantis-jones","result":{"data":{"project":{"id":"ashantis-jones","category":"websites","title":"Ashantis Jones","description":"Ashantis Jones is an event planner from Cleaveland, Ohio that entertains and creates memorable events through detail oriented design and calculated execution. Adam designed Ashantis's portfolio to assist in her job hunt as a graduate of the BFA Theatre Management at DePaul University looking for opportunities in the event management space.","description_short":"Ashantis Jones is an event planner from Cleaveland, Ohio that entertains and creates memorable events through detail oriented design and calculated execution.","description_long":null,"date":"June 2016","role":"Web Designer","tech":["Adobe Muse","Adobe Photoshop"],"image":{"sharp":{"original":{"src":"/static/ashantis-jones-painting-3ee0f7c4d4fc33ecef231639d5d96b71.jpg","width":1920,"height":800}}},"buttons":[{"name":"Visit Website","url":"https://adamgraham.github.io/preview/ashantisjones","icon":"preview"}],"sections":[{"title":null,"link":null,"mainImage":{"sharp":{"original":{"src":"/static/ashantis-jones-screenshot-spread-19ccc3114b9c1e7ec88e5eaf22cdd988.jpg","width":1080,"height":3488}}},"mainImageLink":"https://adamgraham.github.io/preview/ashantisjones","mainVideo":null,"paragraphs":null,"gallery":null,"videos":null}]}},"pageContext":{"id":"de58116c-e7d9-56bc-bf48-aa879c8bb45d","jsonId":"ashantis-jones","__params":{"jsonId":"ashantis-jones"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-websites-websites-json-json-id-tsx","path":"/websites/ashantis-jones","result":{"data":{"project":{"id":"ashantis-jones","category":"websites","title":"Ashantis Jones","description":"Ashantis Jones is an event planner from Cleaveland, Ohio that entertains and creates memorable events through detail oriented design and calculated execution. Adam designed Ashantis's portfolio to assist in her job hunt as a graduate of the BFA Theatre Management at DePaul University looking for opportunities in the event management space.","description_short":"Ashantis Jones is an event planner from Cleaveland, Ohio that entertains and creates memorable events through detail oriented design and calculated execution.","description_long":null,"date":"June 2016","role":"Web Designer","tech":["Adobe Muse","Adobe Photoshop"],"image":{"sharp":{"original":{"src":"/static/ashantis-jones-painting-3ee0f7c4d4fc33ecef231639d5d96b71.jpg","width":1920,"height":800}}},"buttons":[{"to":"https://adamgraham.github.io/preview/ashantisjones","name":"Visit Website","icon":"preview"}],"sections":[{"title":null,"link":null,"mainImage":{"sharp":{"original":{"src":"/static/ashantis-jones-screenshot-spread-19ccc3114b9c1e7ec88e5eaf22cdd988.jpg","width":1080,"height":3488}}},"mainImageLink":"https://adamgraham.github.io/preview/ashantisjones","mainVideo":null,"paragraphs":null,"gallery":null,"videos":null}]}},"pageContext":{"id":"de58116c-e7d9-56bc-bf48-aa879c8bb45d","jsonId":"ashantis-jones","__params":{"jsonId":"ashantis-jones"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/websites/be-super/page-data.json b/page-data/websites/be-super/page-data.json index 4bc24c8..6ce1853 100644 --- a/page-data/websites/be-super/page-data.json +++ b/page-data/websites/be-super/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-websites-websites-json-json-id-js","path":"/websites/be-super","result":{"data":{"project":{"id":"be-super","category":"websites","title":"Be Super","description":"Be Super strives to use comic book characters as educational tools to understand social justice issues. A movement calling for everyone to be the hero within. Adam designed Be Super's website to help promote the cause.","description_short":"Be Super strives to use comic book characters as educational tools to understand social justice issues. A movement calling for everyone to be the hero within.","description_long":null,"date":"September 2016","role":"Web Designer","tech":["Adobe Muse","Adobe Photoshop"],"image":{"sharp":{"original":{"src":"/static/be-super-painting-01320e270561aaedd70580e9e1624c66.jpg","width":1920,"height":800}}},"buttons":[{"name":"Visit Website","url":"https://adamgraham.github.io/preview/besuper","icon":"preview"}],"sections":[{"title":null,"link":null,"mainImage":{"sharp":{"original":{"src":"/static/be-super-screenshot-spread-56ae698c05759b825fb8586ddee16e6a.jpg","width":1080,"height":2745}}},"mainImageLink":"https://adamgraham.github.io/preview/besuper","mainVideo":null,"paragraphs":null,"gallery":null,"videos":null}]}},"pageContext":{"id":"fc3eb75f-d402-5134-b9b1-7fa2ea44dc5c","jsonId":"be-super","__params":{"jsonId":"be-super"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-websites-websites-json-json-id-tsx","path":"/websites/be-super","result":{"data":{"project":{"id":"be-super","category":"websites","title":"Be Super","description":"Be Super strives to use comic book characters as educational tools to understand social justice issues. A movement calling for everyone to be the hero within. Adam designed Be Super's website to help promote the cause.","description_short":"Be Super strives to use comic book characters as educational tools to understand social justice issues. A movement calling for everyone to be the hero within.","description_long":null,"date":"September 2016","role":"Web Designer","tech":["Adobe Muse","Adobe Photoshop"],"image":{"sharp":{"original":{"src":"/static/be-super-painting-01320e270561aaedd70580e9e1624c66.jpg","width":1920,"height":800}}},"buttons":[{"to":"https://adamgraham.github.io/preview/besuper","name":"Visit Website","icon":"preview"}],"sections":[{"title":null,"link":null,"mainImage":{"sharp":{"original":{"src":"/static/be-super-screenshot-spread-56ae698c05759b825fb8586ddee16e6a.jpg","width":1080,"height":2745}}},"mainImageLink":"https://adamgraham.github.io/preview/besuper","mainVideo":null,"paragraphs":null,"gallery":null,"videos":null}]}},"pageContext":{"id":"fc3eb75f-d402-5134-b9b1-7fa2ea44dc5c","jsonId":"be-super","__params":{"jsonId":"be-super"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/websites/colorly/page-data.json b/page-data/websites/colorly/page-data.json index 5534067..22c7bbd 100644 --- a/page-data/websites/colorly/page-data.json +++ b/page-data/websites/colorly/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-websites-websites-json-json-id-js","path":"/websites/colorly","result":{"data":{"project":{"id":"colorly","category":"websites","title":"Colorly","description":"Colorly is a versatile collection of color tools for designers and developers encapsulated in one web app - shades, tints, tones, harmonies, contrast, color blindness, gradients, and more!","description_short":"Colorly is a versatile collection of color tools for designers and developers encapsulated in one web app - shades, tints, tones, harmonies, contrast, color blindness, gradients, and more!","description_long":null,"date":"October 2020","role":"Web Designer, Developer","tech":["React","Redux","JavaScript","HTML/CSS"],"image":{"sharp":{"original":{"src":"/static/colorly-painting-c337bc9f4a03e108182b21f3555dd304.jpg","width":1920,"height":800}}},"buttons":[{"name":"Visit Website","url":"https://adamgraham.github.io/colorly/tints-and-shades","icon":"preview"},{"name":"Source Code","url":"https://github.com/adamgraham/colorly","icon":"code"}],"sections":[{"title":null,"link":null,"mainImage":{"sharp":{"original":{"src":"/static/colorly-screenshot-spread-01-2f5dfdead3f720e34187bb984bbbead4.jpg","width":1024,"height":1064}}},"mainImageLink":"https://adamgraham.github.io/colorly/tints-and-shades","mainVideo":null,"paragraphs":null,"gallery":null,"videos":null},{"title":null,"link":null,"mainImage":{"sharp":{"original":{"src":"/static/colorly-screenshot-spread-02-d88b84235f69de54326dbcf358c06bb4.jpg","width":1024,"height":1064}}},"mainImageLink":"https://adamgraham.github.io/colorly/tints-and-shades","mainVideo":null,"paragraphs":null,"gallery":null,"videos":null}]}},"pageContext":{"id":"7eba5924-4986-57e9-a197-f93a885e7fda","jsonId":"colorly","__params":{"jsonId":"colorly"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-websites-websites-json-json-id-tsx","path":"/websites/colorly","result":{"data":{"project":{"id":"colorly","category":"websites","title":"Colorly","description":"Colorly is a versatile collection of color tools for designers and developers encapsulated in one web app - shades, tints, tones, harmonies, contrast, color blindness, gradients, and more!","description_short":"Colorly is a versatile collection of color tools for designers and developers encapsulated in one web app - shades, tints, tones, harmonies, contrast, color blindness, gradients, and more!","description_long":null,"date":"October 2020","role":"Web Designer, Developer","tech":["React","Redux","JavaScript","HTML/CSS"],"image":{"sharp":{"original":{"src":"/static/colorly-painting-c337bc9f4a03e108182b21f3555dd304.jpg","width":1920,"height":800}}},"buttons":[{"to":"https://adamgraham.github.io/colorly/tints-and-shades","name":"Visit Website","icon":"preview"},{"to":"https://github.com/adamgraham/colorly","name":"Source Code","icon":"code"}],"sections":[{"title":null,"link":null,"mainImage":{"sharp":{"original":{"src":"/static/colorly-screenshot-spread-01-2f5dfdead3f720e34187bb984bbbead4.jpg","width":1024,"height":1064}}},"mainImageLink":"https://adamgraham.github.io/colorly/tints-and-shades","mainVideo":null,"paragraphs":null,"gallery":null,"videos":null},{"title":null,"link":null,"mainImage":{"sharp":{"original":{"src":"/static/colorly-screenshot-spread-02-d88b84235f69de54326dbcf358c06bb4.jpg","width":1024,"height":1064}}},"mainImageLink":"https://adamgraham.github.io/colorly/tints-and-shades","mainVideo":null,"paragraphs":null,"gallery":null,"videos":null}]}},"pageContext":{"id":"7eba5924-4986-57e9-a197-f93a885e7fda","jsonId":"colorly","__params":{"jsonId":"colorly"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/websites/demonthon/page-data.json b/page-data/websites/demonthon/page-data.json index 4995da6..42e9442 100644 --- a/page-data/websites/demonthon/page-data.json +++ b/page-data/websites/demonthon/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-websites-websites-json-json-id-js","path":"/websites/demonthon","result":{"data":{"project":{"id":"demonthon","category":"websites","title":"DemonTHON","description":null,"description_short":"DemonTHON is a year-long fundraising organization benefiting Ann & Robert H. Lurie Children's Hospital of Chicago that culminates in a 24-hour Dance Marathon at DePaul University.","description_long":["DemonTHON is a year-long fundraising organization benefiting Ann & Robert H. Lurie Children's Hospital of Chicago that culminates in a 24-hour Dance Marathon at DePaul University.","As the Director of Technology, Adam designed and managed the organization's website from June 2014 to May 2016. The site was awarded \"Best Website\" by Children's Miracle Network Hospitals for the 2014-15 Dance Marathon year."],"date":"June 2014","role":"Director of Technology","tech":["Adobe Muse","Adobe Photoshop"],"image":{"sharp":{"original":{"src":"/static/demonthon-painting-8ff5a00ecb31b9d93202e6c41464b932.jpg","width":1920,"height":800}}},"buttons":[{"name":"Visit Website","url":"https://adamgraham.github.io/preview/demonthon","icon":"preview"}],"sections":[{"title":null,"link":null,"mainImage":{"sharp":{"original":{"src":"/static/demonthon-screenshot-spread-4a10d2cb3c9e443d1e7d00899de2f26d.jpg","width":1080,"height":5250}}},"mainImageLink":"https://adamgraham.github.io/preview/demonthon","mainVideo":null,"paragraphs":null,"gallery":null,"videos":null}]}},"pageContext":{"id":"8ff6cd31-63c5-59b3-9305-6a1175e512d5","jsonId":"demonthon","__params":{"jsonId":"demonthon"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-websites-websites-json-json-id-tsx","path":"/websites/demonthon","result":{"data":{"project":{"id":"demonthon","category":"websites","title":"DemonTHON","description":null,"description_short":"DemonTHON is a year-long fundraising organization benefiting Ann & Robert H. Lurie Children's Hospital of Chicago that culminates in a 24-hour Dance Marathon at DePaul University.","description_long":["DemonTHON is a year-long fundraising organization benefiting Ann & Robert H. Lurie Children's Hospital of Chicago that culminates in a 24-hour Dance Marathon at DePaul University.","As the Director of Technology, Adam designed and managed the organization's website from June 2014 to May 2016. The site was awarded \"Best Website\" by Children's Miracle Network Hospitals for the 2014-15 Dance Marathon year."],"date":"June 2014","role":"Director of Technology","tech":["Adobe Muse","Adobe Photoshop"],"image":{"sharp":{"original":{"src":"/static/demonthon-painting-8ff5a00ecb31b9d93202e6c41464b932.jpg","width":1920,"height":800}}},"buttons":[{"to":"https://adamgraham.github.io/preview/demonthon","name":"Visit Website","icon":"preview"}],"sections":[{"title":null,"link":null,"mainImage":{"sharp":{"original":{"src":"/static/demonthon-screenshot-spread-4a10d2cb3c9e443d1e7d00899de2f26d.jpg","width":1080,"height":5250}}},"mainImageLink":"https://adamgraham.github.io/preview/demonthon","mainVideo":null,"paragraphs":null,"gallery":null,"videos":null}]}},"pageContext":{"id":"8ff6cd31-63c5-59b3-9305-6a1175e512d5","jsonId":"demonthon","__params":{"jsonId":"demonthon"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/websites/let-it-beard/page-data.json b/page-data/websites/let-it-beard/page-data.json index ea916dd..b493f72 100644 --- a/page-data/websites/let-it-beard/page-data.json +++ b/page-data/websites/let-it-beard/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-websites-websites-json-json-id-js","path":"/websites/let-it-beard","result":{"data":{"project":{"id":"let-it-beard","category":"websites","title":"Let It Beard","description":null,"description_short":"Let It Beard is an animated short film that follows the misadventures of an enigmatic religious family known as \"The Cult\". The Captain and his devoted followers aim for truth, inner peace, and run various endeavors on their path to enlightenment.","description_long":["Let It Beard is an animated short film that follows the misadventures of an enigmatic religious family known simply as \"The Cult\". The Captain and his bevy of devoted followers aim for truth, inner peace, and run various entrepreneurial endeavors on their path to transcendent enlightenment.","The Let It Beard website is a simple one-page design to help promote the animated short film. A random animated background is displayed upon each visit alongside various idle animations. Visit multiple times to see different designs. Requires Adobe Flash."],"date":"November 2014","role":"Web Designer","tech":["Adobe Muse","Adobe Photoshop","Adobe Flash"],"image":{"sharp":{"original":{"src":"/static/let-it-beard-painting-4004bc86c65e8e913c130befc7011778.jpg","width":1920,"height":800}}},"buttons":[{"name":"Visit Website","url":"https://adamgraham.github.io/preview/letitbeard","icon":"preview"}],"sections":[{"title":null,"link":null,"mainImage":{"sharp":{"original":{"src":"/static/let-it-beard-screenshot-25b70575f89b17e23cc39d27b0ec634f.jpg","width":1080,"height":960}}},"mainImageLink":"https://adamgraham.github.io/preview/letitbeard","mainVideo":null,"paragraphs":null,"gallery":null,"videos":null}]}},"pageContext":{"id":"9b125f2b-7089-551b-84b9-89547ee29a6d","jsonId":"let-it-beard","__params":{"jsonId":"let-it-beard"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-websites-websites-json-json-id-tsx","path":"/websites/let-it-beard","result":{"data":{"project":{"id":"let-it-beard","category":"websites","title":"Let It Beard","description":null,"description_short":"Let It Beard is an animated short film that follows the misadventures of an enigmatic religious family known as \"The Cult\". The Captain and his devoted followers aim for truth, inner peace, and run various endeavors on their path to enlightenment.","description_long":["Let It Beard is an animated short film that follows the misadventures of an enigmatic religious family known simply as \"The Cult\". The Captain and his bevy of devoted followers aim for truth, inner peace, and run various entrepreneurial endeavors on their path to transcendent enlightenment.","The Let It Beard website is a simple one-page design to help promote the animated short film. A random animated background is displayed upon each visit alongside various idle animations. Visit multiple times to see different designs. Requires Adobe Flash."],"date":"November 2014","role":"Web Designer","tech":["Adobe Muse","Adobe Photoshop","Adobe Flash"],"image":{"sharp":{"original":{"src":"/static/let-it-beard-painting-4004bc86c65e8e913c130befc7011778.jpg","width":1920,"height":800}}},"buttons":[{"to":"https://adamgraham.github.io/preview/letitbeard","name":"Visit Website","icon":"preview"}],"sections":[{"title":null,"link":null,"mainImage":{"sharp":{"original":{"src":"/static/let-it-beard-screenshot-25b70575f89b17e23cc39d27b0ec634f.jpg","width":1080,"height":960}}},"mainImageLink":"https://adamgraham.github.io/preview/letitbeard","mainVideo":null,"paragraphs":null,"gallery":null,"videos":null}]}},"pageContext":{"id":"9b125f2b-7089-551b-84b9-89547ee29a6d","jsonId":"let-it-beard","__params":{"jsonId":"let-it-beard"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/websites/margaret-baughman/page-data.json b/page-data/websites/margaret-baughman/page-data.json index 7d2a8e9..3a1b2f5 100644 --- a/page-data/websites/margaret-baughman/page-data.json +++ b/page-data/websites/margaret-baughman/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-websites-websites-json-json-id-js","path":"/websites/margaret-baughman","result":{"data":{"project":{"id":"margaret-baughman","category":"websites","title":"Margaret Baughman","description":"Director, choreographer, and empathetic human, Margaret Baughman is enchanted by a world of contradictions that allows her to shake up perspectives through theatre, advocacy, and impeccable organization. Adam designed Margaret's portfolio to help showcase her work.","description_short":"Director, choreographer, and empathetic human, Margaret Baughman is enchanted by a world of contradictions that allows her to shake up perspectives through theatre, advocacy, and impeccable organization.","description_long":null,"date":"July 2016","role":"Web Designer","tech":["Adobe Muse","Adobe Photoshop"],"image":{"sharp":{"original":{"src":"/static/margaret-baughman-painting-5f1ea4c73cfc624545863d14b4a7f7b9.jpg","width":1920,"height":800}}},"buttons":[{"name":"Visit Website","url":"https://adamgraham.github.io/preview/margaretbaughman","icon":"preview"}],"sections":[{"title":null,"link":null,"mainImage":{"sharp":{"original":{"src":"/static/margaret-baughman-screenshot-spread-e461c4d8cb9a2d93678032826486a69f.jpg","width":1080,"height":4780}}},"mainImageLink":"https://adamgraham.github.io/preview/margaretbaughman","mainVideo":null,"paragraphs":null,"gallery":null,"videos":null}]}},"pageContext":{"id":"baac6749-c26b-5ab2-8c00-0f23caa29b14","jsonId":"margaret-baughman","__params":{"jsonId":"margaret-baughman"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-websites-websites-json-json-id-tsx","path":"/websites/margaret-baughman","result":{"data":{"project":{"id":"margaret-baughman","category":"websites","title":"Margaret Baughman","description":"Director, choreographer, and empathetic human, Margaret Baughman is enchanted by a world of contradictions that allows her to shake up perspectives through theatre, advocacy, and impeccable organization. Adam designed Margaret's portfolio to help showcase her work.","description_short":"Director, choreographer, and empathetic human, Margaret Baughman is enchanted by a world of contradictions that allows her to shake up perspectives through theatre, advocacy, and impeccable organization.","description_long":null,"date":"July 2016","role":"Web Designer","tech":["Adobe Muse","Adobe Photoshop"],"image":{"sharp":{"original":{"src":"/static/margaret-baughman-painting-5f1ea4c73cfc624545863d14b4a7f7b9.jpg","width":1920,"height":800}}},"buttons":[{"to":"https://adamgraham.github.io/preview/margaretbaughman","name":"Visit Website","icon":"preview"}],"sections":[{"title":null,"link":null,"mainImage":{"sharp":{"original":{"src":"/static/margaret-baughman-screenshot-spread-e461c4d8cb9a2d93678032826486a69f.jpg","width":1080,"height":4780}}},"mainImageLink":"https://adamgraham.github.io/preview/margaretbaughman","mainVideo":null,"paragraphs":null,"gallery":null,"videos":null}]}},"pageContext":{"id":"baac6749-c26b-5ab2-8c00-0f23caa29b14","jsonId":"margaret-baughman","__params":{"jsonId":"margaret-baughman"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/websites/page-data.json b/page-data/websites/page-data.json index a8cd54f..8eef0f5 100644 --- a/page-data/websites/page-data.json +++ b/page-data/websites/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-websites-js","path":"/websites","result":{"data":{"json":{"slides":[{"id":"zigurous","category":"websites","date":"January 2021","title":"Zigurous","description":"Zigurous is an indie game development studio. Adam has designed and managed the website since he founded the game studio in 2012. Below you can see different examples and the progression of the website over time.","description_short":"Zigurous is an indie game development studio. Adam has designed and managed the website since he founded the game studio in 2012. The website has gone through several design iterations over the years.","image":{"sharp":{"original":{"src":"/static/zigurous-painting-a61220284b22e1a8d288977a83e87ff1.jpg","width":1920,"height":800}}},"imageAltText":"Zigurous Painting","imageBorder":null},{"id":"colorly","category":"websites","date":"October 2020","title":"Colorly","description":"Colorly is a versatile collection of color tools for designers and developers encapsulated in one web app - shades, tints, tones, harmonies, contrast, color blindness, gradients, and more!","description_short":"Colorly is a versatile collection of color tools for designers and developers encapsulated in one web app - shades, tints, tones, harmonies, contrast, color blindness, gradients, and more!","image":{"sharp":{"original":{"src":"/static/colorly-painting-c337bc9f4a03e108182b21f3555dd304.jpg","width":1920,"height":800}}},"imageAltText":"Colorly Painting","imageBorder":null},{"id":"polykai","category":"websites","date":"July 2019","title":"Polykai","description":"Polykai is a dark color scheme for code editors inspired by Wimer Hazenberg's Monokai theme. The theme is supported in 20+ code editors and terminals, including a custom VS Code extension.","description_short":"Polykai is a dark color scheme for code editors inspired by Wimer Hazenberg's Monokai theme. The theme is supported in 20+ code editors and terminals, including a custom VS Code extension.","image":{"sharp":{"original":{"src":"/static/polykai-painting-bdc58a58a1c2aed5e90b381d661b2839.jpg","width":1920,"height":800}}},"imageAltText":"Polykai Painting","imageBorder":null},{"id":"allium","category":"websites","date":"November 2015","title":"Allium","description":null,"description_short":"Allium is a home-based floral design studio launched in 2013 by Kim Stanke. After years of working in both retail stores and special event design shops, Kim started her own business to flex her creative muscles.","image":{"sharp":{"original":{"src":"/static/allium-painting-20490acb31bcafb163dfdfd8ab014688.jpg","width":1920,"height":800}}},"imageAltText":"Allium Painting","imageBorder":null},{"id":"demonthon","category":"websites","date":"June 2014","title":"DemonTHON","description":null,"description_short":"DemonTHON is a year-long fundraising organization benefiting Ann & Robert H. Lurie Children's Hospital of Chicago that culminates in a 24-hour Dance Marathon at DePaul University.","image":{"sharp":{"original":{"src":"/static/demonthon-painting-8ff5a00ecb31b9d93202e6c41464b932.jpg","width":1920,"height":800}}},"imageAltText":"DemonTHON Painting","imageBorder":null},{"id":"be-super","category":"websites","date":"September 2016","title":"Be Super","description":"Be Super strives to use comic book characters as educational tools to understand social justice issues. A movement calling for everyone to be the hero within. Adam designed Be Super's website to help promote the cause.","description_short":"Be Super strives to use comic book characters as educational tools to understand social justice issues. A movement calling for everyone to be the hero within.","image":{"sharp":{"original":{"src":"/static/be-super-painting-01320e270561aaedd70580e9e1624c66.jpg","width":1920,"height":800}}},"imageAltText":"Be Super Painting","imageBorder":null},{"id":"ashantis-jones","category":"websites","date":"June 2016","title":"Ashantis Jones","description":"Ashantis Jones is an event planner from Cleaveland, Ohio that entertains and creates memorable events through detail oriented design and calculated execution. Adam designed Ashantis's portfolio to assist in her job hunt as a graduate of the BFA Theatre Management at DePaul University looking for opportunities in the event management space.","description_short":"Ashantis Jones is an event planner from Cleaveland, Ohio that entertains and creates memorable events through detail oriented design and calculated execution.","image":{"sharp":{"original":{"src":"/static/ashantis-jones-painting-3ee0f7c4d4fc33ecef231639d5d96b71.jpg","width":1920,"height":800}}},"imageAltText":"Ashantis Jones Painting","imageBorder":null},{"id":"margaret-baughman","category":"websites","date":"July 2016","title":"Margaret Baughman","description":"Director, choreographer, and empathetic human, Margaret Baughman is enchanted by a world of contradictions that allows her to shake up perspectives through theatre, advocacy, and impeccable organization. Adam designed Margaret's portfolio to help showcase her work.","description_short":"Director, choreographer, and empathetic human, Margaret Baughman is enchanted by a world of contradictions that allows her to shake up perspectives through theatre, advocacy, and impeccable organization.","image":{"sharp":{"original":{"src":"/static/margaret-baughman-painting-5f1ea4c73cfc624545863d14b4a7f7b9.jpg","width":1920,"height":800}}},"imageAltText":"Margaret Baughman Painting","imageBorder":null},{"id":"taylor-cochran-music","category":"websites","date":"December 2013","title":"Taylor Cochran Music","description":null,"description_short":"Taylor Cochran is a singer/songwriter from Nashville, Tennessee who started pursuing his songwriting career in early 2013. Through his music, he aspires to send a message of joy, hope, and love.","image":{"sharp":{"original":{"src":"/static/taylor-cochran-music-painting-086051bf1e9725d9a46b7aa52a43e868.jpg","width":1920,"height":800}}},"imageAltText":"Taylor Cochran Music Painting","imageBorder":null},{"id":"squish-em","category":"websites","date":"April 2015","title":"Squish-em!","description":null,"description_short":"Squish-em! is a simple whack-a-mole re-creation designed for mobile devices. The website is a one-page, artistic cover designed to promote the game and direct users to download the mobile app.","image":{"sharp":{"original":{"src":"/static/squishem-website-painting-5d9f949228abbe50f01993e6fb4e5414.jpg","width":1920,"height":800}}},"imageAltText":"Squish-em! Painting","imageBorder":null},{"id":"let-it-beard","category":"websites","date":"November 2014","title":"Let It Beard","description":null,"description_short":"Let It Beard is an animated short film that follows the misadventures of an enigmatic religious family known as \"The Cult\". The Captain and his devoted followers aim for truth, inner peace, and run various endeavors on their path to enlightenment.","image":{"sharp":{"original":{"src":"/static/let-it-beard-painting-4004bc86c65e8e913c130befc7011778.jpg","width":1920,"height":800}}},"imageAltText":"Let It Beard Painting","imageBorder":null}]}},"pageContext":{}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-websites-tsx","path":"/websites","result":{"data":{"json":{"slides":[{"id":"zigurous","category":"websites","date":"January 2021","title":"Zigurous","description":"Zigurous is an indie game development studio. Adam has designed and managed the website since he founded the game studio in 2012. Below you can see different examples and the progression of the website over time.","description_short":"Zigurous is an indie game development studio. Adam has designed and managed the website since he founded the game studio in 2012. The website has gone through several design iterations over the years.","image":{"sharp":{"original":{"src":"/static/zigurous-painting-a61220284b22e1a8d288977a83e87ff1.jpg","width":1920,"height":800}}},"imageAltText":"Zigurous Painting","imageBorder":null},{"id":"colorly","category":"websites","date":"October 2020","title":"Colorly","description":"Colorly is a versatile collection of color tools for designers and developers encapsulated in one web app - shades, tints, tones, harmonies, contrast, color blindness, gradients, and more!","description_short":"Colorly is a versatile collection of color tools for designers and developers encapsulated in one web app - shades, tints, tones, harmonies, contrast, color blindness, gradients, and more!","image":{"sharp":{"original":{"src":"/static/colorly-painting-c337bc9f4a03e108182b21f3555dd304.jpg","width":1920,"height":800}}},"imageAltText":"Colorly Painting","imageBorder":null},{"id":"polykai","category":"websites","date":"July 2019","title":"Polykai","description":"Polykai is a dark color scheme for code editors inspired by Wimer Hazenberg's Monokai theme. The theme is supported in 20+ code editors and terminals, including a custom VS Code extension.","description_short":"Polykai is a dark color scheme for code editors inspired by Wimer Hazenberg's Monokai theme. The theme is supported in 20+ code editors and terminals, including a custom VS Code extension.","image":{"sharp":{"original":{"src":"/static/polykai-painting-bdc58a58a1c2aed5e90b381d661b2839.jpg","width":1920,"height":800}}},"imageAltText":"Polykai Painting","imageBorder":null},{"id":"allium","category":"websites","date":"November 2015","title":"Allium","description":null,"description_short":"Allium is a home-based floral design studio launched in 2013 by Kim Stanke. After years of working in both retail stores and special event design shops, Kim started her own business to flex her creative muscles.","image":{"sharp":{"original":{"src":"/static/allium-painting-20490acb31bcafb163dfdfd8ab014688.jpg","width":1920,"height":800}}},"imageAltText":"Allium Painting","imageBorder":null},{"id":"demonthon","category":"websites","date":"June 2014","title":"DemonTHON","description":null,"description_short":"DemonTHON is a year-long fundraising organization benefiting Ann & Robert H. Lurie Children's Hospital of Chicago that culminates in a 24-hour Dance Marathon at DePaul University.","image":{"sharp":{"original":{"src":"/static/demonthon-painting-8ff5a00ecb31b9d93202e6c41464b932.jpg","width":1920,"height":800}}},"imageAltText":"DemonTHON Painting","imageBorder":null},{"id":"be-super","category":"websites","date":"September 2016","title":"Be Super","description":"Be Super strives to use comic book characters as educational tools to understand social justice issues. A movement calling for everyone to be the hero within. Adam designed Be Super's website to help promote the cause.","description_short":"Be Super strives to use comic book characters as educational tools to understand social justice issues. A movement calling for everyone to be the hero within.","image":{"sharp":{"original":{"src":"/static/be-super-painting-01320e270561aaedd70580e9e1624c66.jpg","width":1920,"height":800}}},"imageAltText":"Be Super Painting","imageBorder":null},{"id":"ashantis-jones","category":"websites","date":"June 2016","title":"Ashantis Jones","description":"Ashantis Jones is an event planner from Cleaveland, Ohio that entertains and creates memorable events through detail oriented design and calculated execution. Adam designed Ashantis's portfolio to assist in her job hunt as a graduate of the BFA Theatre Management at DePaul University looking for opportunities in the event management space.","description_short":"Ashantis Jones is an event planner from Cleaveland, Ohio that entertains and creates memorable events through detail oriented design and calculated execution.","image":{"sharp":{"original":{"src":"/static/ashantis-jones-painting-3ee0f7c4d4fc33ecef231639d5d96b71.jpg","width":1920,"height":800}}},"imageAltText":"Ashantis Jones Painting","imageBorder":null},{"id":"margaret-baughman","category":"websites","date":"July 2016","title":"Margaret Baughman","description":"Director, choreographer, and empathetic human, Margaret Baughman is enchanted by a world of contradictions that allows her to shake up perspectives through theatre, advocacy, and impeccable organization. Adam designed Margaret's portfolio to help showcase her work.","description_short":"Director, choreographer, and empathetic human, Margaret Baughman is enchanted by a world of contradictions that allows her to shake up perspectives through theatre, advocacy, and impeccable organization.","image":{"sharp":{"original":{"src":"/static/margaret-baughman-painting-5f1ea4c73cfc624545863d14b4a7f7b9.jpg","width":1920,"height":800}}},"imageAltText":"Margaret Baughman Painting","imageBorder":null},{"id":"taylor-cochran-music","category":"websites","date":"December 2013","title":"Taylor Cochran Music","description":null,"description_short":"Taylor Cochran is a singer/songwriter from Nashville, Tennessee who started pursuing his songwriting career in early 2013. Through his music, he aspires to send a message of joy, hope, and love.","image":{"sharp":{"original":{"src":"/static/taylor-cochran-music-painting-086051bf1e9725d9a46b7aa52a43e868.jpg","width":1920,"height":800}}},"imageAltText":"Taylor Cochran Music Painting","imageBorder":null},{"id":"squish-em","category":"websites","date":"April 2015","title":"Squish-em!","description":null,"description_short":"Squish-em! is a simple whack-a-mole re-creation designed for mobile devices. The website is a one-page, artistic cover designed to promote the game and direct users to download the mobile app.","image":{"sharp":{"original":{"src":"/static/squishem-website-painting-5d9f949228abbe50f01993e6fb4e5414.jpg","width":1920,"height":800}}},"imageAltText":"Squish-em! Painting","imageBorder":null},{"id":"let-it-beard","category":"websites","date":"November 2014","title":"Let It Beard","description":null,"description_short":"Let It Beard is an animated short film that follows the misadventures of an enigmatic religious family known as \"The Cult\". The Captain and his devoted followers aim for truth, inner peace, and run various endeavors on their path to enlightenment.","image":{"sharp":{"original":{"src":"/static/let-it-beard-painting-4004bc86c65e8e913c130befc7011778.jpg","width":1920,"height":800}}},"imageAltText":"Let It Beard Painting","imageBorder":null}]}},"pageContext":{}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/websites/polykai/page-data.json b/page-data/websites/polykai/page-data.json index cc92417..f252cb6 100644 --- a/page-data/websites/polykai/page-data.json +++ b/page-data/websites/polykai/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-websites-websites-json-json-id-js","path":"/websites/polykai","result":{"data":{"project":{"id":"polykai","category":"websites","title":"Polykai","description":"Polykai is a dark color scheme for code editors inspired by Wimer Hazenberg's Monokai theme. The theme is supported in 20+ code editors and terminals, including a custom VS Code extension.","description_short":"Polykai is a dark color scheme for code editors inspired by Wimer Hazenberg's Monokai theme. The theme is supported in 20+ code editors and terminals, including a custom VS Code extension.","description_long":null,"date":"July 2019","role":"Web Designer, Developer","tech":["React","JavaScript","HTML/CSS","VSIX"],"image":{"sharp":{"original":{"src":"/static/polykai-painting-bdc58a58a1c2aed5e90b381d661b2839.jpg","width":1920,"height":800}}},"buttons":[{"name":"Visit Website","url":"https://adamgraham.github.io/polykai-website/","icon":"preview"},{"name":"Source Code","url":"https://github.com/adamgraham/polykai","icon":"code"}],"sections":[{"title":null,"link":null,"mainImage":{"sharp":{"original":{"src":"/static/polykai-screenshot-spread-c5ee5c1d06ade720621333d42e5fbcc6.jpg","width":1920,"height":2362}}},"mainImageLink":"https://adamgraham.github.io/polykai-website/","mainVideo":null,"paragraphs":null,"gallery":null,"videos":null}]}},"pageContext":{"id":"bbdfeddf-af97-5d66-85f8-3de1523eb6d4","jsonId":"polykai","__params":{"jsonId":"polykai"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-websites-websites-json-json-id-tsx","path":"/websites/polykai","result":{"data":{"project":{"id":"polykai","category":"websites","title":"Polykai","description":"Polykai is a dark color scheme for code editors inspired by Wimer Hazenberg's Monokai theme. The theme is supported in 20+ code editors and terminals, including a custom VS Code extension.","description_short":"Polykai is a dark color scheme for code editors inspired by Wimer Hazenberg's Monokai theme. The theme is supported in 20+ code editors and terminals, including a custom VS Code extension.","description_long":null,"date":"July 2019","role":"Web Designer, Developer","tech":["React","JavaScript","HTML/CSS","VSIX"],"image":{"sharp":{"original":{"src":"/static/polykai-painting-bdc58a58a1c2aed5e90b381d661b2839.jpg","width":1920,"height":800}}},"buttons":[{"to":"https://adamgraham.github.io/polykai-website/","name":"Visit Website","icon":"preview"},{"to":"https://github.com/adamgraham/polykai","name":"Source Code","icon":"code"}],"sections":[{"title":null,"link":null,"mainImage":{"sharp":{"original":{"src":"/static/polykai-screenshot-spread-c5ee5c1d06ade720621333d42e5fbcc6.jpg","width":1920,"height":2362}}},"mainImageLink":"https://adamgraham.github.io/polykai-website/","mainVideo":null,"paragraphs":null,"gallery":null,"videos":null}]}},"pageContext":{"id":"bbdfeddf-af97-5d66-85f8-3de1523eb6d4","jsonId":"polykai","__params":{"jsonId":"polykai"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/websites/squish-em/page-data.json b/page-data/websites/squish-em/page-data.json index fcf59e2..98366e0 100644 --- a/page-data/websites/squish-em/page-data.json +++ b/page-data/websites/squish-em/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-websites-websites-json-json-id-js","path":"/websites/squish-em","result":{"data":{"project":{"id":"squish-em","category":"websites","title":"Squish-em!","description":null,"description_short":"Squish-em! is a simple whack-a-mole re-creation designed for mobile devices. The website is a one-page, artistic cover designed to promote the game and direct users to download the mobile app.","description_long":["Squish-em! is a simple whack-a-mole re-creation designed for mobile devices. Squish your way to the top of the leaderboards, earn achievements along the way, and brag to your friends when you beat their best score!","The Squish-em! website is a one-page, artistic cover designed to promote the game and direct users to download the mobile app."],"date":"April 2015","role":"Web Designer","tech":["Adobe Muse","Adobe Photoshop","Adobe Flash"],"image":{"sharp":{"original":{"src":"/static/squishem-website-painting-5d9f949228abbe50f01993e6fb4e5414.jpg","width":1920,"height":800}}},"buttons":[{"name":"Visit Website","url":"https://adamgraham.github.io/preview/squishem","icon":"preview"}],"sections":[{"title":null,"link":null,"mainImage":{"sharp":{"original":{"src":"/static/squishem-website-screenshot-spread-5899ef6989fae2d20386a5b1c43f06e8.jpg","width":1080,"height":2569}}},"mainImageLink":"https://adamgraham.github.io/preview/squishem","mainVideo":null,"paragraphs":null,"gallery":null,"videos":null}]}},"pageContext":{"id":"c1157004-d3b9-58d3-8907-f890f3eb546f","jsonId":"squish-em","__params":{"jsonId":"squish-em"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-websites-websites-json-json-id-tsx","path":"/websites/squish-em","result":{"data":{"project":{"id":"squish-em","category":"websites","title":"Squish-em!","description":null,"description_short":"Squish-em! is a simple whack-a-mole re-creation designed for mobile devices. The website is a one-page, artistic cover designed to promote the game and direct users to download the mobile app.","description_long":["Squish-em! is a simple whack-a-mole re-creation designed for mobile devices. Squish your way to the top of the leaderboards, earn achievements along the way, and brag to your friends when you beat their best score!","The Squish-em! website is a one-page, artistic cover designed to promote the game and direct users to download the mobile app."],"date":"April 2015","role":"Web Designer","tech":["Adobe Muse","Adobe Photoshop","Adobe Flash"],"image":{"sharp":{"original":{"src":"/static/squishem-website-painting-5d9f949228abbe50f01993e6fb4e5414.jpg","width":1920,"height":800}}},"buttons":[{"to":"https://adamgraham.github.io/preview/squishem","name":"Visit Website","icon":"preview"}],"sections":[{"title":null,"link":null,"mainImage":{"sharp":{"original":{"src":"/static/squishem-website-screenshot-spread-5899ef6989fae2d20386a5b1c43f06e8.jpg","width":1080,"height":2569}}},"mainImageLink":"https://adamgraham.github.io/preview/squishem","mainVideo":null,"paragraphs":null,"gallery":null,"videos":null}]}},"pageContext":{"id":"c1157004-d3b9-58d3-8907-f890f3eb546f","jsonId":"squish-em","__params":{"jsonId":"squish-em"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/websites/taylor-cochran-music/page-data.json b/page-data/websites/taylor-cochran-music/page-data.json index 6d70e54..f9c0d3d 100644 --- a/page-data/websites/taylor-cochran-music/page-data.json +++ b/page-data/websites/taylor-cochran-music/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-websites-websites-json-json-id-js","path":"/websites/taylor-cochran-music","result":{"data":{"project":{"id":"taylor-cochran-music","category":"websites","title":"Taylor Cochran Music","description":null,"description_short":"Taylor Cochran is a singer/songwriter from Nashville, Tennessee who started pursuing his songwriting career in early 2013. Through his music, he aspires to send a message of joy, hope, and love.","description_long":["Taylor Cochran is a singer/songwriter from Nashville, Tennessee who pursued his songwriting career in early 2013 by gaining experience playing in local bars, venues, and with his church. Through his music, he aspires to send a message of joy, hope, and love.","Adam designed and managed Taylor's website from late 2013 to mid 2014. The website was launched alongside the success of Taylor's debut EP Kickstarter campaign for which he also helped produce the promo video."],"date":"December 2013","role":"Web Designer","tech":["Adobe Muse","Adobe Photoshop"],"image":{"sharp":{"original":{"src":"/static/taylor-cochran-music-painting-086051bf1e9725d9a46b7aa52a43e868.jpg","width":1920,"height":800}}},"buttons":[{"name":"Visit Website","url":"https://adamgraham.github.io/preview/taylorcochranmusic","icon":"preview"}],"sections":[{"title":null,"link":null,"mainImage":{"sharp":{"original":{"src":"/static/taylor-cochran-music-screenshot-spread-68778b2fb2ae5b5c942b589e906e9785.jpg","width":1080,"height":1901}}},"mainImageLink":"https://adamgraham.github.io/preview/taylorcochranmusic","mainVideo":null,"paragraphs":null,"gallery":null,"videos":null}]}},"pageContext":{"id":"21471ffd-d7f0-5a13-b8ef-ebe010f76ec2","jsonId":"taylor-cochran-music","__params":{"jsonId":"taylor-cochran-music"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-websites-websites-json-json-id-tsx","path":"/websites/taylor-cochran-music","result":{"data":{"project":{"id":"taylor-cochran-music","category":"websites","title":"Taylor Cochran Music","description":null,"description_short":"Taylor Cochran is a singer/songwriter from Nashville, Tennessee who started pursuing his songwriting career in early 2013. Through his music, he aspires to send a message of joy, hope, and love.","description_long":["Taylor Cochran is a singer/songwriter from Nashville, Tennessee who pursued his songwriting career in early 2013 by gaining experience playing in local bars, venues, and with his church. Through his music, he aspires to send a message of joy, hope, and love.","Adam designed and managed Taylor's website from late 2013 to mid 2014. The website was launched alongside the success of Taylor's debut EP Kickstarter campaign for which he also helped produce the promo video."],"date":"December 2013","role":"Web Designer","tech":["Adobe Muse","Adobe Photoshop"],"image":{"sharp":{"original":{"src":"/static/taylor-cochran-music-painting-086051bf1e9725d9a46b7aa52a43e868.jpg","width":1920,"height":800}}},"buttons":[{"to":"https://adamgraham.github.io/preview/taylorcochranmusic","name":"Visit Website","icon":"preview"}],"sections":[{"title":null,"link":null,"mainImage":{"sharp":{"original":{"src":"/static/taylor-cochran-music-screenshot-spread-68778b2fb2ae5b5c942b589e906e9785.jpg","width":1080,"height":1901}}},"mainImageLink":"https://adamgraham.github.io/preview/taylorcochranmusic","mainVideo":null,"paragraphs":null,"gallery":null,"videos":null}]}},"pageContext":{"id":"21471ffd-d7f0-5a13-b8ef-ebe010f76ec2","jsonId":"taylor-cochran-music","__params":{"jsonId":"taylor-cochran-music"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/page-data/websites/zigurous/page-data.json b/page-data/websites/zigurous/page-data.json index a4e5349..31e6bc8 100644 --- a/page-data/websites/zigurous/page-data.json +++ b/page-data/websites/zigurous/page-data.json @@ -1 +1 @@ -{"componentChunkName":"component---src-pages-websites-websites-json-json-id-js","path":"/websites/zigurous","result":{"data":{"project":{"id":"zigurous","category":"websites","title":"Zigurous","description":"Zigurous is an indie game development studio. Adam has designed and managed the website since he founded the game studio in 2012. Below you can see different examples and the progression of the website over time.","description_short":"Zigurous is an indie game development studio. Adam has designed and managed the website since he founded the game studio in 2012. The website has gone through several design iterations over the years.","description_long":null,"date":"January 2021","role":"Web Designer, Developer, Maintainer","tech":["React","Gatsby","JavaScript","HTML/CSS","Firebase"],"image":{"sharp":{"original":{"src":"/static/zigurous-painting-a61220284b22e1a8d288977a83e87ff1.jpg","width":1920,"height":800}}},"buttons":[{"name":"Visit Website","url":"https://zigurous.com/","icon":"preview"}],"sections":[{"title":"2021 - Current","link":null,"mainImage":{"sharp":{"original":{"src":"/static/zigurous-screenshot-latest-spread-b68595d7a28490f2ba405da494719df0.jpg","width":1440,"height":1923}}},"mainImageLink":"https://zigurous.com/","mainVideo":null,"paragraphs":null,"gallery":null,"videos":null},{"title":"2017 - Abstract Theme","link":null,"mainImage":{"sharp":{"original":{"src":"/static/zigurous-screenshot-abstract-theme-7c7e48255bc11947b393264fe4675657.jpg","width":2560,"height":1440}}},"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":null,"videos":null},{"title":"2016 - Cube Theme","link":null,"mainImage":{"sharp":{"original":{"src":"/static/zigurous-screenshot-cube-theme-spread-e18d22284bdeb6e30115bde8e716d366.jpg","width":1080,"height":3900}}},"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":null,"videos":null},{"title":"2015 - Adventure Theme","link":null,"mainImage":{"sharp":{"original":{"src":"/static/zigurous-screenshot-adventure-theme-spread-4e745da37c89e669dc3c679a0b552d49.jpg","width":1080,"height":4165}}},"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":null,"videos":null},{"title":"2014 - Medieval Theme","link":null,"mainImage":{"sharp":{"original":{"src":"/static/zigurous-screenshot-medieval-theme-spread-0fbdb90db440ab62c7af8814af005f84.jpg","width":1280,"height":1585}}},"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":null,"videos":null}]}},"pageContext":{"id":"ca90d832-2ff6-51e2-8ac2-f6f9b8f17f1d","jsonId":"zigurous","__params":{"jsonId":"zigurous"}}},"staticQueryHashes":["1995548873","3141325806"]} \ No newline at end of file +{"componentChunkName":"component---src-pages-websites-websites-json-json-id-tsx","path":"/websites/zigurous","result":{"data":{"project":{"id":"zigurous","category":"websites","title":"Zigurous","description":"Zigurous is an indie game development studio. Adam has designed and managed the website since he founded the game studio in 2012. Below you can see different examples and the progression of the website over time.","description_short":"Zigurous is an indie game development studio. Adam has designed and managed the website since he founded the game studio in 2012. The website has gone through several design iterations over the years.","description_long":null,"date":"January 2021","role":"Web Designer, Developer, Maintainer","tech":["React","Gatsby","TypeScript","HTML/CSS","Firebase"],"image":{"sharp":{"original":{"src":"/static/zigurous-painting-a61220284b22e1a8d288977a83e87ff1.jpg","width":1920,"height":800}}},"buttons":[{"to":"https://zigurous.com/","name":"Visit Website","icon":"preview"}],"sections":[{"title":"2021 - Current","link":null,"mainImage":{"sharp":{"original":{"src":"/static/zigurous-screenshot-latest-spread-b68595d7a28490f2ba405da494719df0.jpg","width":1440,"height":1923}}},"mainImageLink":"https://zigurous.com/","mainVideo":null,"paragraphs":null,"gallery":null,"videos":null},{"title":"2017 - Abstract Theme","link":null,"mainImage":{"sharp":{"original":{"src":"/static/zigurous-screenshot-abstract-theme-7c7e48255bc11947b393264fe4675657.jpg","width":2560,"height":1440}}},"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":null,"videos":null},{"title":"2016 - Cube Theme","link":null,"mainImage":{"sharp":{"original":{"src":"/static/zigurous-screenshot-cube-theme-spread-e18d22284bdeb6e30115bde8e716d366.jpg","width":1080,"height":3900}}},"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":null,"videos":null},{"title":"2015 - Adventure Theme","link":null,"mainImage":{"sharp":{"original":{"src":"/static/zigurous-screenshot-adventure-theme-spread-4e745da37c89e669dc3c679a0b552d49.jpg","width":1080,"height":4165}}},"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":null,"videos":null},{"title":"2014 - Medieval Theme","link":null,"mainImage":{"sharp":{"original":{"src":"/static/zigurous-screenshot-medieval-theme-spread-0fbdb90db440ab62c7af8814af005f84.jpg","width":1280,"height":1585}}},"mainImageLink":null,"mainVideo":null,"paragraphs":null,"gallery":null,"videos":null}]}},"pageContext":{"id":"ca90d832-2ff6-51e2-8ac2-f6f9b8f17f1d","jsonId":"zigurous","__params":{"jsonId":"zigurous"}}},"staticQueryHashes":["1995548873","3709745113"]} \ No newline at end of file diff --git a/presentations/3d-application-development-overview/index.html b/presentations/3d-application-development-overview/index.html index 5921f82..3084e8a 100644 --- a/presentations/3d-application-development-overview/index.html +++ b/presentations/3d-application-development-overview/index.html @@ -1 +1 @@ -Adam Graham • 3D Application Development

3D Application Development

April 2016|Designer, Presenter
Unity
C#
Blender

A presentation to teach introductory concepts for 3D application development covering topics across art, design, and tech. The presentation serves as a starting point from which creators can continue to grow their knowledge by providing high-level, easy-to-understand definitions that give a taste of the information they might need to know when developing a 3D application.

The deck is grounded in the Unity engine to provide real, applicable examples of the concepts. Adam presented this deck to around 30 software professionals who were interested in learning more.

GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file +Adam Graham • 3D Application Development

3D Application Development

April 2016|Designer, Presenter
Unity
C#
Blender

A presentation to teach introductory concepts for 3D application development covering topics across art, design, and tech. The presentation serves as a starting point from which creators can continue to grow their knowledge by providing high-level, easy-to-understand definitions that give a taste of the information they might need to know when developing a 3D application.

The deck is grounded in the Unity engine to provide real, applicable examples of the concepts. Adam presented this deck to around 30 software professionals who were interested in learning more.

GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file diff --git a/presentations/an-animation-story/index.html b/presentations/an-animation-story/index.html index 00747fe..7da1149 100644 --- a/presentations/an-animation-story/index.html +++ b/presentations/an-animation-story/index.html @@ -1 +1 @@ -Adam Graham • An Animation Story

An Animation Story

August 2017|Designer, Animator, Narrator
Unity
C#

A love story between a girl named Design and a boy named Animation. Adam created, narrated, and presented this story to a group of 20 developers at Solstice in order to talk about the importance of having a "design-gineering" mindset and the value of the relationship between designers and engineers.

Postface

So, what the heck was that all about? And what ever happened to Engineering? Well, this story highlights the Design-Engineering mindset, or rather the lack of. Too often do I see us breaking designers' hearts. It seems implementing a design exactly as it was created often presents a problem. But instead of solving the problem, we find ways to avoid it. "Oh this increases technical complexity, let's simplify". "Oh this skyrockets our scope, let's do this later" (aka never). Specifically, implementing animations is a common trigger to these excuses.

Why is it so important to not break out designers hearts? In my opinion, a great design tells a story. It evokes emotions and brings character to the product. Animation is a tool in a designer's toolbelt that brings life to a design. It is a story in of itself - the change of values over time from one point to another. You see, when we find reasons to not fulfill a designer's creation, to not implement their animations, or any other design element for that matter, we are taking the life out of the design. We are stripping it of character and emotion.

What ever happened to Engineering? Perhaps he makes an epic return in Chapter 2. Perhaps not. It is our job as engineers to create Chapter 2...to not break our designers hearts. And, so, honestly I don't see the value in sitting here and showing you how to implement animations. Because, I believe that without a "design-gineering" mindset, we will continue to find excuses not to meet design face to face. I don't think you all need to be as passionate about design or animation as I am, but I think we all have to at least appreciate what it is a designer does, and the impact their designs have on a product.

I encourage everyone to work very closely with your designers. Understand what it is they do everyday, what problems they think about, and what tools they use to solve those problems. The best way to understand a designer is to become one. This, in my opinion, is what the "design-gineering" mindset is all about.

GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file +Adam Graham • An Animation Story

An Animation Story

August 2017|Designer, Animator, Narrator
Unity
C#

A love story between a girl named Design and a boy named Animation. Adam created, narrated, and presented this story to a group of 20 developers at Solstice in order to talk about the importance of having a "design-gineering" mindset and the value of the relationship between designers and engineers.

Postface

So, what the heck was that all about? And what ever happened to Engineering? Well, this story highlights the Design-Engineering mindset, or rather the lack of. Too often do I see us breaking designers' hearts. It seems implementing a design exactly as it was created often presents a problem. But instead of solving the problem, we find ways to avoid it. "Oh this increases technical complexity, let's simplify". "Oh this skyrockets our scope, let's do this later" (aka never). Specifically, implementing animations is a common trigger to these excuses.

Why is it so important to not break out designers hearts? In my opinion, a great design tells a story. It evokes emotions and brings character to the product. Animation is a tool in a designer's toolbelt that brings life to a design. It is a story in of itself - the change of values over time from one point to another. You see, when we find reasons to not fulfill a designer's creation, to not implement their animations, or any other design element for that matter, we are taking the life out of the design. We are stripping it of character and emotion.

What ever happened to Engineering? Perhaps he makes an epic return in Chapter 2. Perhaps not. It is our job as engineers to create Chapter 2...to not break our designers hearts. And, so, honestly I don't see the value in sitting here and showing you how to implement animations. Because, I believe that without a "design-gineering" mindset, we will continue to find excuses not to meet design face to face. I don't think you all need to be as passionate about design or animation as I am, but I think we all have to at least appreciate what it is a designer does, and the impact their designs have on a product.

I encourage everyone to work very closely with your designers. Understand what it is they do everyday, what problems they think about, and what tools they use to solve those problems. The best way to understand a designer is to become one. This, in my opinion, is what the "design-gineering" mindset is all about.

GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file diff --git a/presentations/entering-the-new-reality/index.html b/presentations/entering-the-new-reality/index.html index 601ff40..f943d11 100644 --- a/presentations/entering-the-new-reality/index.html +++ b/presentations/entering-the-new-reality/index.html @@ -1 +1 @@ -Adam Graham • Entering the New Reality

Entering the New Reality

May 2016|VR Engineer, Co-Presenter
Unity
Oculus Rift
HTC Vive
Microsoft HoloLens

A presentation exploring the technologies of VR, AR, and MR. What are the differences between these technologies? What industries will it disrupt and who will be building these applications? What problems will they solve? These are the questions to be answered.

Adam presented this deck alongside 3 other Solstice engineers during a monthly Solstice Mobile meetup. There were about 100 people that attended the event and listened to the presentation.

Preface

If you were at or watched Facebook's F8 conference and witnessed their 10 year roadmap, you may have noticed how the company plans to continue to invest in not only Virtual Reality with its Oculus, but also into augmented reality as well. They even stated that future headsets would be the size of a normal pair of glasses and would be able to not only handle AR, but VR as well all in one platform. Considering the social-networking leader's Q1 revenue jumped 52% year over year to $5.38 billion, topping the consensus estimate of $5.26 billion. It would be safe to assume that they have a good idea of where the market is heading.

It is nothing new that these technologies are becoming more and more prominent and focused on by several big name players such as Samsung, HTC, Google, and Microsoft. Rumors have been flying around about a possible Google Headset in the works with the release of Android N's second developer preview where there are references to virtual reality capabilities. Furthermore, "VR" is an entire content track at Google I/O this year, with seven sessions dedicated to virtual or augmented reality, based on the schedule posted by Google.

So ok we established that this is important and worth paying attention to. However, where are we exactly with these reality technologies? Is it at a mature state at this point where the barrier entry for producing a successful application have been reduced that any developer can produce a VR or AR application? What's the difference between VR and AR? What does it take to build one of these new "reality" applications? What problems will they solve? What industries will it disrupt and who will be building these applications? Will it only be important to the gaming industry? Are we scratching the surface with these platforms? What can we predict these platforms will become in the near future?

GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file +Adam Graham • Entering the New Reality

Entering the New Reality

May 2016|VR Engineer, Co-Presenter
Unity
Oculus Rift
HTC Vive
Microsoft HoloLens

A presentation exploring the technologies of VR, AR, and MR. What are the differences between these technologies? What industries will it disrupt and who will be building these applications? What problems will they solve? These are the questions to be answered.

Adam presented this deck alongside 3 other Solstice engineers during a monthly Solstice Mobile meetup. There were about 100 people that attended the event and listened to the presentation.

Preface

If you were at or watched Facebook's F8 conference and witnessed their 10 year roadmap, you may have noticed how the company plans to continue to invest in not only Virtual Reality with its Oculus, but also into augmented reality as well. They even stated that future headsets would be the size of a normal pair of glasses and would be able to not only handle AR, but VR as well all in one platform. Considering the social-networking leader's Q1 revenue jumped 52% year over year to $5.38 billion, topping the consensus estimate of $5.26 billion. It would be safe to assume that they have a good idea of where the market is heading.

It is nothing new that these technologies are becoming more and more prominent and focused on by several big name players such as Samsung, HTC, Google, and Microsoft. Rumors have been flying around about a possible Google Headset in the works with the release of Android N's second developer preview where there are references to virtual reality capabilities. Furthermore, "VR" is an entire content track at Google I/O this year, with seven sessions dedicated to virtual or augmented reality, based on the schedule posted by Google.

So ok we established that this is important and worth paying attention to. However, where are we exactly with these reality technologies? Is it at a mature state at this point where the barrier entry for producing a successful application have been reduced that any developer can produce a VR or AR application? What's the difference between VR and AR? What does it take to build one of these new "reality" applications? What problems will they solve? What industries will it disrupt and who will be building these applications? Will it only be important to the gaming industry? Are we scratching the surface with these platforms? What can we predict these platforms will become in the near future?

GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file diff --git a/presentations/index.html b/presentations/index.html index 2ab21d8..48a5092 100644 --- a/presentations/index.html +++ b/presentations/index.html @@ -1 +1 @@ -Adam Graham • Presentations
GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file +Adam Graham • Presentations
GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file diff --git a/presentations/the-life-of-a-ux-engineer/index.html b/presentations/the-life-of-a-ux-engineer/index.html index 34023f0..e8daae0 100644 --- a/presentations/the-life-of-a-ux-engineer/index.html +++ b/presentations/the-life-of-a-ux-engineer/index.html @@ -1 +1 @@ -Adam Graham • The Life of a UX Engineer

The Life of a UX Engineer

August 2020|Designer, Presenter
React
JavaScript
HTML/CSS
Adobe Illustrator
Figma

What is a UX Engineer? This specialty role sits on a cross-functional design team and helps facilitate collaboration between designers and engineers. This presentation explores the relationship between designers and engineers and how a UX Engineer uses a particular skillset to solve UX problems. Adam presented this deck to around 20 professionals at one of Kin + Carta's monthly design meetups.

GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file +Adam Graham • The Life of a UX Engineer

The Life of a UX Engineer

August 2020|Designer, Presenter
React
JavaScript
HTML/CSS
Adobe Illustrator
Figma

What is a UX Engineer? This specialty role sits on a cross-functional design team and helps facilitate collaboration between designers and engineers. This presentation explores the relationship between designers and engineers and how a UX Engineer uses a particular skillset to solve UX problems. Adam presented this deck to around 20 professionals at one of Kin + Carta's monthly design meetups.

GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file diff --git a/preview/ashantisjones/about.html b/preview/ashantisjones/about.html index f554e85..a613056 100644 --- a/preview/ashantisjones/about.html +++ b/preview/ashantisjones/about.html @@ -18,7 +18,7 @@ - + - + Ashantis Jones | About @@ -48,7 +48,7 @@ - + - + + - + - + - + - + - - - - + + + +
- +
- - + +
- - + +
- - + +
@@ -207,10 +207,10 @@
- -
+ +
- +
@@ -240,7 +240,7 @@
- +

Alphas

June 2013|Team Lead, Lead Programmer & Designer
XNA
C#

Alphas is a top-down twin-stick shooter developed as a university project. The game consists of five interlinked deadly arenas, several unique weapons, and a multitude of engaging enemies lead by the alpha boss. Can you survive the swarm?

Media

GitHub
LinkedIn
Email
Dark Mode
Download
@@ -278,12 +278,12 @@ - + - - - - + + + + - + Ashantis Jones | Arthritis Foundation @@ -49,7 +49,7 @@ - + - + + - + - + - + - + - - - - + + + +
- +
- - + +
- - + +
- - + +
- -
+ +
- +
@@ -258,7 +258,7 @@

Development Intern, Summer 2015

- +
@@ -294,12 +294,12 @@

Development Intern, Summer 2015

- + - - - - + + + + - + Ashantis Jones | Boldface Co @@ -49,7 +49,7 @@ - + - + + - + - + - + - + - - - - + + + +
- +
- - + +
- - + +
- - + +
- -
+ +
- +
@@ -258,7 +258,7 @@

Event Coordination Intern

- +
@@ -294,12 +294,12 @@

Event Coordination Intern

- + - - - - + + + + - + Ashantis Jones | Cor Theatre @@ -49,7 +49,7 @@ - + - + + - + - + - + - + - - - - + + + +
- +
- - + +
- - + +
- - + +
- -
+ +
- +
@@ -258,7 +258,7 @@

Development Intern, Summer 2014

- +
@@ -294,12 +294,12 @@

Development Intern, Summer 2014

- + - - - - + + + + - + Ashantis Jones | DemonTHON @@ -49,7 +49,7 @@ - + - + + - + - + - + - + - - - - + + + +
- +
- - + +
- - + +
- - + +
- -
+ +
- +
@@ -260,7 +260,7 @@

Executive Director, 2015-16

- +
@@ -296,12 +296,12 @@

Executive Director, 2015-16

- + - - - - + + + + - + Ashantis Jones | DePaul University @@ -49,7 +49,7 @@ - + - + + - + - + - + - + - - - - + + + +
- +
- - + +
- - + +
- - + +
- -
+ +
- +
@@ -259,7 +259,7 @@

DePaul University.

- +
@@ -295,12 +295,12 @@

DePaul University.

- + - - - - + + + + - + Ashantis Jones | Events @@ -49,7 +49,7 @@ - + - + + - + - + - + - + - - - - + + + +
- +
- - + +
- - + +
- - + +
- -
+ +
- +
@@ -355,7 +355,7 @@

world-class city"

- +
@@ -391,12 +391,12 @@

world-class city"

- + - - - - + + + + - + Ashantis Jones | Fest @@ -49,7 +49,7 @@ - + - + + - + - + - + - + - - - - + + + +
- +
- - + +
- - + +
- - + +
- -
+ +
- +
@@ -258,7 +258,7 @@

Co-Director of Volunteer Coordinate, 2015

- +
@@ -294,12 +294,12 @@

Co-Director of Volunteer Coordinate, 2015

- + - - - - + + + + - + Ashantis Jones | Fundraising @@ -49,7 +49,7 @@ - + - + + - + - + - + - + - - - - + + + +
- +
- - + +
- - + +
- - + +
- -
+ +
- +
@@ -357,7 +357,7 @@

the development of one another"

- +
@@ -393,12 +393,12 @@

the development of one another"

- + - - - - + + + + - + Ashantis Jones | Home @@ -48,7 +48,7 @@ - + - + + - + - + - + - + - - - - + + + +
- +
- - + +
- - + +
- - + +
@@ -217,10 +217,10 @@
- -
+ +
- +
@@ -386,7 +386,7 @@

 

- +
@@ -428,12 +428,12 @@

 

- + - - - - + + + + - + Ashantis Jones | Portfolio @@ -49,7 +49,7 @@ - + - + + - + - + - + - + - - - - + + + +
- +
- - + +
- - + +
- - + +
- -
+ +
- +
@@ -600,7 +600,7 @@

our city, and the profession"

- +
@@ -636,12 +636,12 @@

our city, and the profession"

- + - - - - + + + + - + Ashantis Jones | Support Tomorrows Rising Stars @@ -49,7 +49,7 @@ - + - + + - + - + - + - + - - - - + + + +
- +
- - + +
- - + +
- - + +
- -
+ +
- +
@@ -258,7 +258,7 @@

Co-Chair of External Events, 2015-16

- +
@@ -294,12 +294,12 @@

Co-Chair of External Events, 2015-16

- + - - - - + + + + - + Ashantis Jones | The Theatre School at DePaul University @@ -49,7 +49,7 @@ - + - + + - + - + - + - + - - - - + + + +
- +
- - + +
- - + +
- - + +
- -
+ +
- +
@@ -258,7 +258,7 @@

Assistant Box Office Manager, Winter 2015

- +
@@ -294,12 +294,12 @@

Assistant Box Office Manager, Winter 2015

- + - - - - + + + + - + Ashantis Jones | Theatre @@ -49,7 +49,7 @@ - + - + + - + - + - + - + - - - - + + + +
- +
- - + +
- - + +
- - + +
- -
+ +
- +
@@ -356,7 +356,7 @@

our city, and the profession"

- +
@@ -392,12 +392,12 @@

our city, and the profession"

- + - - - - + + + + - + Ashantis Jones | These Shining Lives @@ -49,7 +49,7 @@ - + - + + - + - + - + - + - - - - + + + +
- +
- - + +
- - + +
- - + +
- -
+ +
- +
@@ -260,7 +260,7 @@

Marketing Manager, Spring 2015

- +
@@ -296,12 +296,12 @@

Marketing Manager, Spring 2015

- + - - - - + + + +

Projects

Client Work

Tech Showcases

Libraries & Frameworks

Presentations

Games

Websites

Interactive Art

GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file +Adam Graham • Projects

Projects

Client Work

Tech Showcases

Libraries & Frameworks

Presentations

Games

Websites

Interactive Art

GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file diff --git a/sitemap/sitemap-0.xml b/sitemap/sitemap-0.xml index 9f7c93b..4cb756c 100644 --- a/sitemap/sitemap-0.xml +++ b/sitemap/sitemap-0.xml @@ -1 +1 @@ -https://adamgraham.github.io/artdaily0.7https://adamgraham.github.io/gamesdaily0.7https://adamgraham.github.io/daily0.7https://adamgraham.github.io/presentationsdaily0.7https://adamgraham.github.io/projectsdaily0.7https://adamgraham.github.io/softwaredaily0.7https://adamgraham.github.io/techdaily0.7https://adamgraham.github.io/websitesdaily0.7https://adamgraham.github.io/art/canvasdaily0.7https://adamgraham.github.io/art/blackholedaily0.7https://adamgraham.github.io/art/mixeddaily0.7https://adamgraham.github.io/art/hexahedroniksdaily0.7https://adamgraham.github.io/games/the-wandering-darkdaily0.7https://adamgraham.github.io/games/boss-rushdaily0.7https://adamgraham.github.io/games/alphasdaily0.7https://adamgraham.github.io/games/hackathon-for-wildlifedaily0.7https://adamgraham.github.io/games/ferrodaily0.7https://adamgraham.github.io/games/elegydaily0.7https://adamgraham.github.io/games/squish-emdaily0.7https://adamgraham.github.io/games/ancient-odysseydaily0.7https://adamgraham.github.io/games/lunar-escapedaily0.7https://adamgraham.github.io/games/the-risedaily0.7https://adamgraham.github.io/games/escape-the-estatedaily0.7https://adamgraham.github.io/games/escape-the-basementdaily0.7https://adamgraham.github.io/presentations/the-life-of-a-ux-engineerdaily0.7https://adamgraham.github.io/presentations/an-animation-storydaily0.7https://adamgraham.github.io/presentations/entering-the-new-realitydaily0.7https://adamgraham.github.io/presentations/3d-application-development-overviewdaily0.7https://adamgraham.github.io/tech/blockchain-gardensdaily0.7https://adamgraham.github.io/tech/rockstardaily0.7https://adamgraham.github.io/tech/vender-vrdaily0.7https://adamgraham.github.io/websites/zigurousdaily0.7https://adamgraham.github.io/websites/colorlydaily0.7https://adamgraham.github.io/websites/polykaidaily0.7https://adamgraham.github.io/websites/alliumdaily0.7https://adamgraham.github.io/websites/demonthondaily0.7https://adamgraham.github.io/websites/be-superdaily0.7https://adamgraham.github.io/websites/ashantis-jonesdaily0.7https://adamgraham.github.io/websites/margaret-baughmandaily0.7https://adamgraham.github.io/websites/taylor-cochran-musicdaily0.7https://adamgraham.github.io/websites/squish-emdaily0.7https://adamgraham.github.io/websites/let-it-bearddaily0.7 \ No newline at end of file +https://adamgraham.github.io/artdaily0.7https://adamgraham.github.io/gallerydaily0.7https://adamgraham.github.io/gamesdaily0.7https://adamgraham.github.io/daily0.7https://adamgraham.github.io/presentationsdaily0.7https://adamgraham.github.io/projectsdaily0.7https://adamgraham.github.io/softwaredaily0.7https://adamgraham.github.io/techdaily0.7https://adamgraham.github.io/websitesdaily0.7https://adamgraham.github.io/art/canvasdaily0.7https://adamgraham.github.io/art/blackholedaily0.7https://adamgraham.github.io/art/mixeddaily0.7https://adamgraham.github.io/art/hexahedroniksdaily0.7https://adamgraham.github.io/games/the-wandering-darkdaily0.7https://adamgraham.github.io/games/boss-rushdaily0.7https://adamgraham.github.io/games/alphasdaily0.7https://adamgraham.github.io/games/hackathon-for-wildlifedaily0.7https://adamgraham.github.io/games/ferrodaily0.7https://adamgraham.github.io/games/elegydaily0.7https://adamgraham.github.io/games/squish-emdaily0.7https://adamgraham.github.io/games/ancient-odysseydaily0.7https://adamgraham.github.io/games/lunar-escapedaily0.7https://adamgraham.github.io/games/the-risedaily0.7https://adamgraham.github.io/games/escape-the-estatedaily0.7https://adamgraham.github.io/games/escape-the-basementdaily0.7https://adamgraham.github.io/presentations/the-life-of-a-ux-engineerdaily0.7https://adamgraham.github.io/presentations/an-animation-storydaily0.7https://adamgraham.github.io/presentations/entering-the-new-realitydaily0.7https://adamgraham.github.io/presentations/3d-application-development-overviewdaily0.7https://adamgraham.github.io/tech/blockchain-gardensdaily0.7https://adamgraham.github.io/tech/rockstardaily0.7https://adamgraham.github.io/tech/vender-vrdaily0.7https://adamgraham.github.io/websites/zigurousdaily0.7https://adamgraham.github.io/websites/colorlydaily0.7https://adamgraham.github.io/websites/polykaidaily0.7https://adamgraham.github.io/websites/alliumdaily0.7https://adamgraham.github.io/websites/demonthondaily0.7https://adamgraham.github.io/websites/be-superdaily0.7https://adamgraham.github.io/websites/ashantis-jonesdaily0.7https://adamgraham.github.io/websites/margaret-baughmandaily0.7https://adamgraham.github.io/websites/taylor-cochran-musicdaily0.7https://adamgraham.github.io/websites/squish-emdaily0.7https://adamgraham.github.io/websites/let-it-bearddaily0.7 \ No newline at end of file diff --git a/software/index.html b/software/index.html index ac959af..1ce435e 100644 --- a/software/index.html +++ b/software/index.html @@ -1 +1 @@ -
\ No newline at end of file +
\ No newline at end of file diff --git a/styles.4de84519df67d9bc71d6.css b/styles.4de84519df67d9bc71d6.css new file mode 100644 index 0000000..b7ff659 --- /dev/null +++ b/styles.4de84519df67d9bc71d6.css @@ -0,0 +1,3 @@ +@import url(https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&display=swap);@import url(https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;700&display=swap);@keyframes closeWindow{0%{opacity:1}to{opacity:0}}.ril__outer{-ms-content-zooming:none;-ms-touch-select:none;background-color:rgba(0,0,0,.85);bottom:0;height:100%;left:0;outline:none;right:0;top:0;touch-action:none;-ms-user-select:none;width:100%;z-index:1000}.ril__outerClosing{opacity:0}.ril__image,.ril__imageNext,.ril__imagePrev,.ril__inner{bottom:0;left:0;position:absolute;right:0;top:0}.ril__image,.ril__imageNext,.ril__imagePrev{-ms-content-zooming:none;-ms-touch-select:none;margin:auto;max-width:none;touch-action:none;-ms-user-select:none}.ril__imageDiscourager{background-position:50%;background-repeat:no-repeat;background-size:contain}.ril__navButtons{border:none;bottom:0;cursor:pointer;height:34px;margin:auto;opacity:.7;padding:40px 30px;position:absolute;top:0;width:20px}.ril__navButtons:hover{opacity:1}.ril__navButtons:active{opacity:.7}.ril__navButtonPrev{background:rgba(0,0,0,.2) url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIzNCI+PHBhdGggZmlsbD0iI0ZGRiIgZD0ibTE5IDMtMi0yTDEgMTdsMTYgMTYgMS0xTDMgMTcgMTggMnoiLz48L3N2Zz4=") no-repeat 50%;left:0}.ril__navButtonNext{background:rgba(0,0,0,.2) url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIzNCI+PHBhdGggZmlsbD0iI0ZGRiIgZD0ibTEgMyAyLTIgMTYgMTZMMyAzM2wtMS0xIDE1LTE1TDIgMnoiLz48L3N2Zz4=") no-repeat 50%;right:0}.ril__downloadBlocker{background-image:url("data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7");background-size:cover;bottom:0;left:0;position:absolute;right:0;top:0}.ril__caption,.ril__toolbar{background-color:rgba(0,0,0,.5);display:flex;justify-content:space-between;left:0;position:absolute;right:0}.ril__caption{bottom:0;max-height:150px;overflow:auto}.ril__captionContent{color:#fff;padding:10px 20px}.ril__toolbar{height:50px;top:0}.ril__toolbarSide{height:50px;margin:0}.ril__toolbarLeftSide{flex:0 1 auto;overflow:hidden;padding-left:20px;padding-right:0;text-overflow:ellipsis}.ril__toolbarRightSide{flex:0 0 auto;padding-left:0;padding-right:20px}.ril__toolbarItem{color:#fff;display:inline-block;font-size:120%;line-height:50px;max-width:100%;overflow:hidden;padding:0;text-overflow:ellipsis;white-space:nowrap}.ril__toolbarItemChild{vertical-align:middle}.ril__builtinButton{border:none;cursor:pointer;height:35px;opacity:.7;width:40px}.ril__builtinButton:hover{opacity:1}.ril__builtinButton:active{outline:none}.ril__builtinButtonDisabled{cursor:default;opacity:.5}.ril__builtinButtonDisabled:hover{opacity:.5}.ril__closeButton{background:url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCI+PHBhdGggZmlsbD0iI0ZGRiIgZD0ibTEgMyAxLjI1LTEuMjUgNy41IDcuNSA3LjUtNy41TDE4LjUgMyAxMSAxMC41bDcuNSA3LjUtMS4yNSAxLjI1LTcuNS03LjUtNy41IDcuNUwxIDE4bDcuNS03LjVMMSAzeiIvPjwvc3ZnPg==") no-repeat 50%}.ril__zoomInButton{background:url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCI+PGcgc3Ryb2tlPSIjZmZmIiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS13aWR0aD0iMiI+PHBhdGggZD0ibTEgMTkgNi02TTkgOGg2TTEyIDV2NiIvPjwvZz48Y2lyY2xlIGN4PSIxMiIgY3k9IjgiIHI9IjciIGZpbGw9Im5vbmUiIHN0cm9rZT0iI2ZmZiIgc3Ryb2tlLXdpZHRoPSIyIi8+PC9zdmc+") no-repeat 50%}.ril__zoomOutButton{background:url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCI+PGcgc3Ryb2tlPSIjZmZmIiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS13aWR0aD0iMiI+PHBhdGggZD0ibTEgMTkgNi02TTkgOGg2Ii8+PC9nPjxjaXJjbGUgY3g9IjEyIiBjeT0iOCIgcj0iNyIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjZmZmIiBzdHJva2Utd2lkdGg9IjIiLz48L3N2Zz4=") no-repeat 50%}.ril__outerAnimating{animation-name:closeWindow}@keyframes pointFade{0%,19.999%,to{opacity:0}20%{opacity:1}}.ril__loadingCircle{height:60px;position:relative;width:60px}.ril__loadingCirclePoint{height:100%;left:0;position:absolute;top:0;width:100%}.ril__loadingCirclePoint:before{animation:pointFade .8s ease-in-out infinite both;background-color:#fff;border-radius:30%;content:"";display:block;height:30%;margin:0 auto;width:11%}.ril__loadingCirclePoint:first-of-type{transform:rotate(0deg)}.ril__loadingCirclePoint:first-of-type:before,.ril__loadingCirclePoint:nth-of-type(7):before{animation-delay:-.8s}.ril__loadingCirclePoint:nth-of-type(2){transform:rotate(30deg)}.ril__loadingCirclePoint:nth-of-type(8){transform:rotate(210deg)}.ril__loadingCirclePoint:nth-of-type(2):before,.ril__loadingCirclePoint:nth-of-type(8):before{animation-delay:-666ms}.ril__loadingCirclePoint:nth-of-type(3){transform:rotate(60deg)}.ril__loadingCirclePoint:nth-of-type(9){transform:rotate(240deg)}.ril__loadingCirclePoint:nth-of-type(3):before,.ril__loadingCirclePoint:nth-of-type(9):before{animation-delay:-533ms}.ril__loadingCirclePoint:nth-of-type(4){transform:rotate(90deg)}.ril__loadingCirclePoint:nth-of-type(10){transform:rotate(270deg)}.ril__loadingCirclePoint:nth-of-type(10):before,.ril__loadingCirclePoint:nth-of-type(4):before{animation-delay:-.4s}.ril__loadingCirclePoint:nth-of-type(5){transform:rotate(120deg)}.ril__loadingCirclePoint:nth-of-type(11){transform:rotate(300deg)}.ril__loadingCirclePoint:nth-of-type(11):before,.ril__loadingCirclePoint:nth-of-type(5):before{animation-delay:-266ms}.ril__loadingCirclePoint:nth-of-type(6){transform:rotate(150deg)}.ril__loadingCirclePoint:nth-of-type(12){transform:rotate(330deg)}.ril__loadingCirclePoint:nth-of-type(12):before,.ril__loadingCirclePoint:nth-of-type(6):before{animation-delay:-133ms}.ril__loadingCirclePoint:nth-of-type(7){transform:rotate(180deg)}.ril__loadingCirclePoint:nth-of-type(13){transform:rotate(1turn)}.ril__loadingCirclePoint:nth-of-type(13):before,.ril__loadingCirclePoint:nth-of-type(7):before{animation-delay:0ms}.ril__loadingContainer{bottom:0;left:0;position:absolute;right:0;top:0}.ril__imageNext .ril__loadingContainer,.ril__imagePrev .ril__loadingContainer{display:none}.ril__errorContainer{align-items:center;bottom:0;color:#fff;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0}.ril__imageNext .ril__errorContainer,.ril__imagePrev .ril__errorContainer{display:none}.ril__loadingContainer__icon{color:#fff;left:50%;position:absolute;top:50%;transform:translateX(-50%) translateY(-50%)}:root{--spacing-unit:8px;--color-inherit:inherit;--color-transparent:transparent;--color-black:#1f2328;--color-white:#fff;--color-foreground:#1f2328;--color-foreground-muted:#656d76;--color-foreground-subtle:#6e7781;--color-background:#fff;--color-surface-0:#fff;--color-surface-1:#f5f7fa;--color-surface-2:#f0f2f5;--color-surface-3:#ebedf0;--color-surface-4:#e6eaed;--color-surface-5:#e4e7eb;--color-surface-6:#e1e5e8;--color-surface-7:#dce1e6;--color-surface-8:#dadee3;--color-surface-9:#d7dce0;--color-border:#d0d7de;--color-default:#282e34;--color-default-emphasis:#24292f;--color-default-subtle:rgba(var(--rgb-default),var(--opacity-subtle));--color-primary:#0969da;--color-primary-emphasis:#0550ae;--color-primary-subtle:rgba(var(--rgb-primary),var(--opacity-subtle));--color-secondary:#282e34;--color-secondary-emphasis:#24292f;--color-secondary-subtle:rgba(var(--rgb-secondary),var(--opacity-subtle));--color-tertiary:#282e34;--color-tertiary-emphasis:#24292f;--color-tertiary-subtle:rgba(var(--rgb-tertiary),var(--opacity-subtle));--color-success:#198754;--color-success-emphasis:#146c43;--color-success-subtle:rgba(var(--rgb-success),var(--opacity-subtle));--color-danger:#dc3545;--color-danger-emphasis:#b02a37;--color-danger-subtle:rgba(var(--rgb-danger),var(--opacity-subtle));--color-warning:#ffc107;--color-warning-emphasis:#ffcd39;--color-warning-subtle:rgba(var(--rgb-warning),var(--opacity-subtle));--color-info:#0dcaf0;--color-info-emphasis:#3dd5f3;--color-info-subtle:rgba(var(--rgb-info),var(--opacity-subtle));--color-on-default:var(--color-white,#fff);--color-on-primary:var(--color-white,#fff);--color-on-secondary:var(--color-white,#fff);--color-on-tertiary:var(--color-white,#fff);--color-on-success:var(--color-white,#fff);--color-on-danger:var(--color-white,#fff);--color-on-warning:var(--color-black,#000);--color-on-info:var(--color-black,#000);--color-syntax-comment:#57606a;--color-syntax-constant:#99286e;--color-syntax-diff-changed-text:#953800;--color-syntax-diff-changed-bg:#ffd8b5;--color-syntax-diff-deleted-text:#82071e;--color-syntax-diff-deleted-bg:#ffebe9;--color-syntax-diff-ignored-text:#0550ae;--color-syntax-diff-ignored-bg:#eaeef2;--color-syntax-diff-inserted-text:#116329;--color-syntax-diff-inserted-bg:#dafbe1;--color-syntax-entity:#0550ae;--color-syntax-function:#6639ba;--color-syntax-keyword:#cf222e;--color-syntax-property:#116329;--color-syntax-string:#0a3069;--rgb-black:31,35,40;--rgb-white:255,255,255;--rgb-foreground:31,35,40;--rgb-background:255,255,255;--rgb-default:40,46,52;--rgb-primary:9,105,218;--rgb-secondary:40,46,52;--rgb-tertiary:40,46,52;--rgb-success:25,135,84;--rgb-danger:220,53,69;--rgb-warning:255,193,7;--rgb-info:13,202,240;--opacity-transparent:0;--opacity-inactive:0.62;--opacity-disabled:0.38;--opacity-subtle:0.12;--opacity-scrim:0.54;--opacity-active:0.87;--opacity-opaque:1;--z-index-dropdown:1000;--z-index-sticky:1020;--z-index-fixed:1030;--z-index-overlay:1040;--z-index-menu:1050;--z-index-modal:1060;--z-index-popover:1070;--z-index-tooltip:1080;--z-index-toast:1090;--z-index-max:1100;--breakpoint-sm:576px;--breakpoint-md:768px;--breakpoint-lg:992px;--breakpoint-xl:1200px}[data-theme=light],[data-theme=light] *{--color-black:#1f2328;--color-white:#fff;--color-foreground:#1f2328;--color-foreground-muted:#656d76;--color-foreground-subtle:#6e7781;--color-background:#fff;--color-surface-0:#fff;--color-surface-1:#f5f7fa;--color-surface-2:#f0f2f5;--color-surface-3:#ebedf0;--color-surface-4:#e6eaed;--color-surface-5:#e4e7eb;--color-surface-6:#e1e5e8;--color-surface-7:#dce1e6;--color-surface-8:#dadee3;--color-surface-9:#d7dce0;--color-border:#d0d7de;--color-default:#282e34;--color-default-emphasis:#24292f;--color-default-subtle:rgba(var(--rgb-default),var(--opacity-subtle));--color-primary:#0969da;--color-primary-emphasis:#0550ae;--color-primary-subtle:rgba(var(--rgb-primary),var(--opacity-subtle));--color-secondary:#282e34;--color-secondary-emphasis:#24292f;--color-secondary-subtle:rgba(var(--rgb-secondary),var(--opacity-subtle));--color-tertiary:#282e34;--color-tertiary-emphasis:#24292f;--color-tertiary-subtle:rgba(var(--rgb-tertiary),var(--opacity-subtle));--color-success:#198754;--color-success-emphasis:#146c43;--color-success-subtle:rgba(var(--rgb-success),var(--opacity-subtle));--color-danger:#dc3545;--color-danger-emphasis:#b02a37;--color-danger-subtle:rgba(var(--rgb-danger),var(--opacity-subtle));--color-warning:#ffc107;--color-warning-emphasis:#ffcd39;--color-warning-subtle:rgba(var(--rgb-warning),var(--opacity-subtle));--color-info:#0dcaf0;--color-info-emphasis:#3dd5f3;--color-info-subtle:rgba(var(--rgb-info),var(--opacity-subtle));--color-on-default:var(--color-white,#fff);--color-on-primary:var(--color-white,#fff);--color-on-secondary:var(--color-white,#fff);--color-on-tertiary:var(--color-white,#fff);--color-on-success:var(--color-white,#fff);--color-on-danger:var(--color-white,#fff);--color-on-warning:var(--color-black,#000);--color-on-info:var(--color-black,#000);--color-syntax-comment:#57606a;--color-syntax-constant:#99286e;--color-syntax-diff-changed-text:#953800;--color-syntax-diff-changed-bg:#ffd8b5;--color-syntax-diff-deleted-text:#82071e;--color-syntax-diff-deleted-bg:#ffebe9;--color-syntax-diff-ignored-text:#0550ae;--color-syntax-diff-ignored-bg:#eaeef2;--color-syntax-diff-inserted-text:#116329;--color-syntax-diff-inserted-bg:#dafbe1;--color-syntax-entity:#0550ae;--color-syntax-function:#6639ba;--color-syntax-keyword:#cf222e;--color-syntax-property:#116329;--color-syntax-string:#0a3069;--rgb-black:31,35,40;--rgb-white:255,255,255;--rgb-foreground:31,35,40;--rgb-background:255,255,255;--rgb-default:40,46,52;--rgb-primary:9,105,218;--rgb-secondary:40,46,52;--rgb-tertiary:40,46,52;--rgb-success:25,135,84;--rgb-danger:220,53,69;--rgb-warning:255,193,7;--rgb-info:13,202,240;color-scheme:light}[data-theme=dark],[data-theme=dark] *{--color-black:#010409;--color-white:#fff;--color-foreground:#e6edf3;--color-foreground-muted:#7d8590;--color-foreground-subtle:#6e7681;--color-background:#0d1117;--color-surface-0:#0d1117;--color-surface-1:#11151b;--color-surface-2:#191d23;--color-surface-3:#1d2127;--color-surface-4:#21262c;--color-surface-5:#262a30;--color-surface-6:#292d33;--color-surface-7:#2d3137;--color-surface-8:#2f3339;--color-surface-9:#31363c;--color-border:#30363d;--color-default:#e6edf3;--color-default-emphasis:#fff;--color-default-subtle:rgba(var(--rgb-default),var(--opacity-subtle));--color-primary:#2f81f7;--color-primary-emphasis:#1f6feb;--color-primary-subtle:rgba(var(--rgb-primary),var(--opacity-subtle));--color-secondary:#e6edf3;--color-secondary-emphasis:#fff;--color-secondary-subtle:rgba(var(--rgb-secondary),var(--opacity-subtle));--color-tertiary:#e6edf3;--color-tertiary-emphasis:#fff;--color-tertiary-subtle:rgba(var(--rgb-tertiary),var(--opacity-subtle));--color-success:#198754;--color-success-emphasis:#146c43;--color-success-subtle:rgba(var(--rgb-success),var(--opacity-subtle));--color-danger:#dc3545;--color-danger-emphasis:#b02a37;--color-danger-subtle:rgba(var(--rgb-danger),var(--opacity-subtle));--color-warning:#ffcd39;--color-warning-emphasis:#ffc107;--color-warning-subtle:rgba(var(--rgb-warning),var(--opacity-subtle));--color-info:#3dd5f3;--color-info-emphasis:#0dcaf0;--color-info-subtle:rgba(var(--rgb-info),var(--opacity-subtle));--color-on-default:var(--color-black,#000);--color-on-primary:var(--color-white,#fff);--color-on-secondary:var(--color-black,#000);--color-on-tertiary:var(--color-black,#000);--color-on-success:var(--color-white,#fff);--color-on-danger:var(--color-white,#fff);--color-on-warning:var(--color-black,#000);--color-on-info:var(--color-black,#000);--color-syntax-comment:#8b949e;--color-syntax-constant:#ff9bce;--color-syntax-diff-changed-text:#ffdfb6;--color-syntax-diff-changed-bg:#5a1e02;--color-syntax-diff-deleted-text:#ffdcd7;--color-syntax-diff-deleted-bg:#67060c;--color-syntax-diff-ignored-text:#c9d1d9;--color-syntax-diff-ignored-bg:#1158c7;--color-syntax-diff-inserted-text:#aff5b4;--color-syntax-diff-inserted-bg:#033a16;--color-syntax-entity:#79c0ff;--color-syntax-function:#d2a8ff;--color-syntax-keyword:#ff7b72;--color-syntax-property:#7ee787;--color-syntax-string:#a5d6ff;--rgb-black:1,4,9;--rgb-white:255,255,255;--rgb-foreground:230,237,243;--rgb-background:13,17,23;--rgb-default:230,237,243;--rgb-primary:47,129,247;--rgb-secondary:230,237,243;--rgb-tertiary:230,237,243;--rgb-success:25,135,84;--rgb-danger:220,53,69;--rgb-warning:255,205,57;--rgb-info:61,213,243;color-scheme:dark}[data-theme=high-contrast],[data-theme=high-contrast] *{--color-black:#010409;--color-white:#fff;--color-foreground:#f0f3f6;--color-foreground-muted:#f0f3f6;--color-foreground-subtle:#9ea7b3;--color-background:#0a0c10;--color-surface-0:#0a0c10;--color-surface-1:#0f1115;--color-surface-2:#16181c;--color-surface-3:#1a1c20;--color-surface-4:#1f2125;--color-surface-5:#232529;--color-surface-6:#26282c;--color-surface-7:#2a2d30;--color-surface-8:#2c2e32;--color-surface-9:#2f3135;--color-border:#7a828e;--color-default:#f0f3f6;--color-default-emphasis:#fff;--color-default-subtle:rgba(var(--rgb-default),var(--opacity-subtle));--color-primary:#409eff;--color-primary-emphasis:#318bf8;--color-primary-subtle:rgba(var(--rgb-primary),var(--opacity-subtle));--color-secondary:#f0f3f6;--color-secondary-emphasis:#fff;--color-secondary-subtle:rgba(var(--rgb-secondary),var(--opacity-subtle));--color-tertiary:#f0f3f6;--color-tertiary-emphasis:#fff;--color-tertiary-subtle:rgba(var(--rgb-tertiary),var(--opacity-subtle));--color-success:#479f76;--color-success-emphasis:#198754;--color-success-subtle:rgba(var(--rgb-success),var(--opacity-subtle));--color-danger:#e35d6a;--color-danger-emphasis:#dc3545;--color-danger-subtle:rgba(var(--rgb-danger),var(--opacity-subtle));--color-warning:#ffda6a;--color-warning-emphasis:#ffcd39;--color-warning-subtle:rgba(var(--rgb-warning),var(--opacity-subtle));--color-info:#6edff6;--color-info-emphasis:#3dd5f3;--color-info-subtle:rgba(var(--rgb-info),var(--opacity-subtle));--color-on-default:var(--color-black,#000);--color-on-primary:var(--color-black,#000);--color-on-secondary:var(--color-black,#000);--color-on-tertiary:var(--color-black,#000);--color-on-success:var(--color-black,#000);--color-on-danger:var(--color-black,#000);--color-on-warning:var(--color-black,#000);--color-on-info:var(--color-black,#000);--color-syntax-comment:#9ea7b3;--color-syntax-constant:#ffadd4;--color-syntax-diff-changed-text:#ffe1b4;--color-syntax-diff-changed-bg:#a74c00;--color-syntax-diff-deleted-text:#ffdedb;--color-syntax-diff-deleted-bg:#cc1421;--color-syntax-diff-ignored-text:#f0f3f6;--color-syntax-diff-ignored-bg:#318bf8;--color-syntax-diff-inserted-text:#acf7b6;--color-syntax-diff-inserted-bg:#007728;--color-syntax-entity:#91cbff;--color-syntax-function:#dbb7ff;--color-syntax-keyword:#ff9492;--color-syntax-property:#72f088;--color-syntax-string:#addcff;--rgb-black:1,4,9;--rgb-white:255,255,255;--rgb-foreground:240,243,246;--rgb-background:10,12,16;--rgb-default:240,243,246;--rgb-primary:64,158,255;--rgb-secondary:240,243,246;--rgb-tertiary:240,243,246;--rgb-success:71,159,118;--rgb-danger:227,93,106;--rgb-warning:255,218,106;--rgb-info:110,223,246;color-scheme:dark}[data-theme]{background-color:var(--color-background);color:var(--color-foreground,inherit)} + +/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */html{-webkit-text-size-adjust:100%;line-height:1.15}body{margin:0}main{display:block}h1{font-size:2em;margin:.67em 0}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace,monospace;font-size:1em}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring,button:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:.35em .75em .625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{vertical-align:baseline}textarea{overflow:auto}[type=checkbox],[type=radio]{box-sizing:border-box;padding:0}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details{display:block}summary{display:list-item}[hidden],template{display:none}.clearfix:after,.clearfix:before{content:"";display:table}.clearfix:after{clear:both}.clear-left{clear:left}.clear-right{clear:right}.clear-both{clear:both}.clear-none{clear:none}html{box-sizing:border-box}*,:after,:before{box-sizing:inherit}body,html{height:100%}[id=root]{overflow-x:hidden}blockquote{border-left:3px solid var(--color-border);color:var(--color-foreground,inherit);margin-block-end:1rem;margin-block-start:0;margin-inline-end:0;margin-inline-start:0;padding:.5em .75em}blockquote footer{color:var(--color-foreground-muted,inherit);display:block}blockquote footer:before{content:"\2014\00A0"}button{-webkit-appearance:none;appearance:none;background:none;border:none;font-family:inherit;outline:none;padding:0}button:not(:disabled){cursor:pointer}button:disabled{cursor:not-allowed;opacity:var(--opacity-disabled,.38)}button:focus-visible{outline:1px auto -webkit-focus-ring-color;outline-offset:1px}code[class*=language-],pre[class*=language-]{background:var(--color-background);color:var(--color-foreground);direction:ltr;font-family:Fira Code,Fira Mono,Menlo,Consolas,DejaVu Sans Mono,monospace;font-size:.925rem;-webkit-hyphens:none;hyphens:none;line-height:1.5;tab-size:2;text-align:left;white-space:pre;word-break:normal;word-spacing:normal}code[class*=language-] ::selection,code[class*=language-]::selection,pre[class*=language-] ::selection{background:var(--color-surface-9);color:inherit;text-shadow:none}pre[class*=language-]{border:1px solid var(--color-border);border-radius:.3em;margin:1em 0;overflow:auto;overflow-x:auto;padding:1em}pre[class*=language-]::-webkit-scrollbar{height:8px}pre[class*=language-]::-webkit-scrollbar-track{background-color:transparent}pre[class*=language-]::-webkit-scrollbar-thumb{background-clip:content-box;background-color:var(--color-surface-5);border:none;border-radius:6px}pre[class*=language-]::-webkit-scrollbar-thumb:hover{background-color:var(--color-surface-7)}:not(pre)>code{background-color:var(--color-surface-3);border-radius:.25em;padding:.125em .25em;white-space:normal}[data-theme=dark] :not(pre)>code,[data-theme=high-contrast] :not(pre)>code{background-color:var(--color-surface-9)}@media print{code[class*=language-],pre[class*=language-]{text-shadow:none}}.token.punctuation{color:var(--color-syntax-foreground)}.token.cdata,.token.comment,.token.doctype,.token.prolog{color:var(--color-syntax-comment)}.token.atrule,.token.builtin,.token.important,.token.keyword,.token.operator,.token.symbol,.token.tag{color:var(--color-syntax-keyword)}.token.function,.token.function-definition{color:var(--color-syntax-function)}.token.attr-name,.token.class-name,.token.entity,.token.namespace,.token.return-type,.token.selector{color:var(--color-syntax-entity)}.token.property,.token.variable{color:var(--color-syntax-property)}.token.attr-value,.token.char,.token.regex,.token.string,.token.url{color:var(--color-syntax-string)}.token.boolean,.token.constant,.token.number{color:var(--color-syntax-constant)}.token.changed{background-color:var(--color-syntax-diff-changed-bg);color:var(--color-syntax-diff-changed-text)}.token.deleted{background-color:var(--color-syntax-diff-deleted-bg);color:var(--color-syntax-diff-deleted-text)}.token.ignored{background-color:var(--color-syntax-diff-ignored-bg);color:var(--color-syntax-diff-ignored-text)}.token.inserted{background-color:var(--color-syntax-diff-inserted-bg);color:var(--color-syntax-diff-inserted-text)}.token.bold{font-weight:700}.token.italic{font-style:italic}hr{background-color:var(--color-border);border:none;height:1px;margin-block-end:1rem;margin-inline-end:0;margin-inline-start:0}hr,hr.title{margin-block-start:1rem}hr.title{height:2px;margin-block-end:2rem}hr.transparent{background-color:transparent}hr.small{width:64px}hr.medium{width:128px}hr.large{width:256px}hr.full{width:100%}hr.thick{height:2px}img,svg{vertical-align:middle}input,select,textarea{background:none;border:1px solid var(--color-border);border-radius:.25rem;color:inherit;font-family:inherit;font-size:.875em;line-height:1.125rem;outline:none;padding:8px;vertical-align:middle}input::placeholder,select::placeholder,textarea::placeholder{color:var(--color-foreground-subtle,inherit);font-size:1em}input:focus,select:focus,textarea:focus{border-color:var(--color-primary)}input:disabled,select:disabled,textarea:disabled{cursor:not-allowed;opacity:var(--opacity-disabled,.38)}input[type=submit]{color:var(--color-foreground-subtle,inherit);font-weight:500;min-width:80px;transition:color .2s,background-color .2s,border-color .2s}input[type=submit]:not(:disabled){cursor:pointer}input[type=submit]:not(:disabled):focus,input[type=submit]:not(:disabled):hover{background-color:var(--color-default);border-color:var(--color-default);color:var(--color-on-default)}input[type=search]::-ms-clear,input[type=search]::-ms-reveal{display:none;height:0;width:0}input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-decoration,input[type=search]::-webkit-search-results-button,input[type=search]::-webkit-search-results-decoration{display:none}ol,ul{margin-block-end:1rem;margin-block-start:0;padding-inline-start:24px}li::marker{color:var(--color-foreground-muted,inherit)}table{margin-left:-16px;width:calc(100% + 16px)}table td,table th{height:40px;padding:8px 16px}table th{font-weight:600;text-align:left}table.bordered{border-spacing:0;margin-left:0;width:100%}table.bordered td,table.bordered th{border:1px solid var(--color-border);padding:8px}table.bordered tr:first-child td:first-child,table.bordered tr:first-child th:first-child{border-top-left-radius:.25rem}table.bordered tr:first-child td:last-child,table.bordered tr:first-child th:last-child{border-top-right-radius:.25rem}table.bordered tr:last-child td:first-child,table.bordered tr:last-child th:first-child{border-bottom-left-radius:.25rem}table.bordered tr:last-child td:last-child,table.bordered tr:last-child th:last-child{border-bottom-right-radius:.25rem}table.bordered tr:not(:first-child) td,table.bordered tr:not(:first-child) th{border-top:none}table.bordered tr td:not(:first-child),table.bordered tr th:not(:first-child){border-left:none}table.striped tr:nth-child(2n){background-color:var(--color-surface-1)}body,html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--color-foreground,inherit);font-family:Poppins,Roboto,Helvetica,Arial,sans-serif;font-size:1rem;font-weight:400;line-height:1.5}a,a:hover,a:visited{color:inherit;font-weight:inherit;text-decoration:none}a:not(:disabled){cursor:pointer}b,strong{font-weight:600}p{margin-bottom:1rem;margin-top:0}.display-1,.display-2,.display-3,.display-4,.display-5,.display-6,.h1,.h2,.h3,.h4,.h5,.h6,h1,h2,h3,h4,h5,h6{color:inherit;font-family:inherit;font-weight:600;line-height:1.2;margin-bottom:1rem;margin-top:0}.h1,h1{font-size:2.25rem}.h2,h2{font-size:2rem}.h3,h3{font-size:1.75rem}.h4,h4{font-size:1.5rem}.h5,h5{font-size:1.25rem}.h6,h6{font-size:1rem}.display-1{font-size:5rem}.display-2{font-size:4.5rem}.display-3{font-size:4rem}.display-4{font-size:3.5rem}.display-5{font-size:3rem}.display-6{font-size:2.5rem}.font-xxxl{font-size:1.5rem}.font-xxl{font-size:1.375rem}.font-xl{font-size:1.25rem}.font-lg{font-size:1.125rem}.font-md{font-size:1rem}.font-sm{font-size:.875rem}.font-xs{font-size:.75rem}.font-xxs{font-size:.625rem}.font-xxxs{font-size:.5rem}.eyebrow{color:var(--color-foreground-muted,inherit);font-size:.75rem;font-weight:600;letter-spacing:0;margin-bottom:.25rem;text-transform:uppercase}.subtitle{margin-bottom:.5rem;white-space:nowrap}:root{--footer-height:64px}.app-footer{align-items:center;display:flex;min-height:var(--footer-height,64px);overflow:hidden;position:relative;width:100%}.app-footer--bordered{border-top:1px solid var(--color-border)}.app-footer--transparent{background:none!important}.app-footer--sticky{bottom:0;position:sticky;z-index:var(--z-index-sticky,1020)}.app-footer .col{justify-content:space-between}.app-footer .col,.app-footer .col>*{align-items:center;display:flex}.app-footer .links{text-align:center;white-space:nowrap}@media (max-width:767px){.app-footer .col,.app-footer .col>:not(.links){flex-direction:column}.app-footer .copyright,.app-footer .links,.app-footer .logo{margin-bottom:8px}.app-footer .links{flex-wrap:wrap;justify-content:center}.app-footer .link{margin-bottom:4px}}:root{--header-height:80px}.app-header{align-items:center;display:flex;height:var(--header-height,80px);position:relative;width:100%}.app-header--bordered{border-bottom:1px solid var(--color-border)}.app-header--transparent{background:none!important}.app-header--sticky{position:sticky;top:0;z-index:var(--z-index-sticky,1020)}.app-header>.container,.app-header>.container-fluid{align-items:center;display:flex;height:100%;justify-content:space-between;margin:0 auto}.app-header>.container-fluid{max-width:100%}.app-header__content{align-items:center;display:flex;height:100%;justify-content:flex-start}.app-header .logo{z-index:1055}.app-header .navbar,.app-header .social-nav-links{display:none}@media screen and (min-width:1200px){.app-header .navbar,.app-header .social-nav-links{display:block}.app-header .navmenu,.app-header .navmenu__button{display:none}}.app-store-badge{border:none!important;display:inline-block}.app-store-badge>img{height:100%;width:100%}.app-utility-bar{height:32px}.app-utility-bar .container,.app-utility-bar .row{height:100%}.app-utility-bar .row{align-items:center}.app-utility-bar .col{align-items:center;display:flex}.app-utility-bar--left .col{justify-content:flex-start}.app-utility-bar--right .col{justify-content:flex-end}.badge{border-radius:.25rem;display:inline-block;font-size:.75em;font-weight:500;line-height:1;min-width:48px;padding:.5em 1em;text-align:center;vertical-align:baseline;white-space:nowrap}.badge,.badge--solid{background-color:var(--color-foreground);color:var(--color-background)}.badge,.badge--outline,.badge--solid{border:1px solid var(--color-foreground)}.badge--outline{background-color:transparent;color:var(--color-foreground)}.badge--pill{border-radius:50rem!important}.badge-group{display:inline-flex;flex-wrap:wrap;gap:.5em;max-width:100%;position:relative;vertical-align:middle;width:max-content}.badge-group--horizontal{align-items:center;flex-direction:row;justify-content:flex-start}.badge-group--vertical{align-items:flex-start;flex-direction:column;justify-content:center}.btn,.btn--default{--btn-color-primary:var(--color-default);--btn-color-secondary:var(--color-on-default);--btn-color-emphasis:var(--color-default-emphasis);--btn-color-subtle:var(--color-default-subtle)}.btn--primary{--btn-color-primary:var(--color-primary);--btn-color-secondary:var(--color-on-primary);--btn-color-emphasis:var(--color-primary-emphasis);--btn-color-subtle:var(--color-primary-subtle)}.btn--secondary{--btn-color-primary:var(--color-secondary);--btn-color-secondary:var(--color-on-secondary);--btn-color-emphasis:var(--color-secondary-emphasis);--btn-color-subtle:var(--color-secondary-subtle)}.btn--tertiary{--btn-color-primary:var(--color-tertiary);--btn-color-secondary:var(--color-on-tertiary);--btn-color-emphasis:var(--color-tertiary-emphasis);--btn-color-subtle:var(--color-tertiary-subtle)}.btn--success{--btn-color-primary:var(--color-success);--btn-color-secondary:var(--color-on-success);--btn-color-emphasis:var(--color-success-emphasis);--btn-color-subtle:var(--color-success-subtle)}.btn--danger{--btn-color-primary:var(--color-danger);--btn-color-secondary:var(--color-on-danger);--btn-color-emphasis:var(--color-danger-emphasis);--btn-color-subtle:var(--color-danger-subtle)}.btn--warning{--btn-color-primary:var(--color-warning);--btn-color-secondary:var(--color-on-warning);--btn-color-emphasis:var(--color-warning-emphasis);--btn-color-subtle:var(--color-warning-subtle)}.btn--info{--btn-color-primary:var(--color-info);--btn-color-secondary:var(--color-on-info);--btn-color-emphasis:var(--color-info-emphasis);--btn-color-subtle:var(--color-info-subtle)}.btn{fill:var(--btn-color-secondary);align-items:center;background-color:var(--btn-color-primary);border:1px solid transparent;border-radius:.5rem;color:var(--btn-color-secondary);display:inline-flex;font-size:.875rem;font-weight:500;justify-content:center;line-height:20px;padding:8px 16px;text-decoration:none;transform:scale(1);transition:color .2s,background-color .2s,transform .2s;vertical-align:middle;white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:var(--opacity-disabled,.38)}.btn:not(:disabled){cursor:pointer}.btn.active,.btn:active,.btn:hover{text-decoration:none}.btn:not(.btn--unstyled):not(:disabled):active{transform:scale(.975)}.btn:focus-visible{outline:1px auto -webkit-focus-ring-color;outline-offset:1px}.btn--solid{fill:var(--btn-color-secondary);background-color:var(--btn-color-primary);border-color:transparent;color:var(--btn-color-secondary)}.btn--solid:not(:disabled).active,.btn--solid:not(:disabled):active,.btn--solid:not(:disabled):hover{background-color:var(--btn-color-emphasis)}.btn--outline{fill:var(--btn-color-primary);background-color:transparent;border-color:var(--btn-color-primary);color:var(--btn-color-primary)}.btn--outline:not(:disabled).active,.btn--outline:not(:disabled):active,.btn--outline:not(:disabled):hover{fill:var(--btn-color-secondary);background-color:var(--btn-color-primary);color:var(--btn-color-secondary)}.btn--text,.btn--text:visited{fill:var(--btn-color-primary);background-color:transparent;border-color:transparent;color:var(--btn-color-primary)}.btn--text:not(:disabled).active,.btn--text:not(:disabled):active,.btn--text:not(:disabled):hover{background-color:var(--btn-color-subtle)}.btn--unstyled{fill:inherit;background-color:transparent;border-color:transparent;color:inherit}.btn--rounded-corners{border-radius:.5rem}.btn--square{border-radius:0}.btn--rounded{border-radius:24px}.btn--circle{border-radius:50%}.btn--sm,.btn--small{font-size:.875rem;padding:8px 16px}.btn--sm.btn--rounded,.btn--small.btn--rounded{border-radius:24px}.btn--sm.btn--circle,.btn--sm.btn--icon-only,.btn--small.btn--circle,.btn--small.btn--icon-only{padding:8px}.btn--md,.btn--medium{font-size:1rem;padding:12px 24px}.btn--md.btn--rounded,.btn--medium.btn--rounded{border-radius:32px}.btn--md.btn--circle,.btn--md.btn--icon-only,.btn--medium.btn--circle,.btn--medium.btn--icon-only{padding:12px}.btn--large,.btn--lg{font-size:1.125rem;padding:16px 32px}.btn--large.btn--rounded,.btn--lg.btn--rounded{border-radius:40px}.btn--large.btn--circle,.btn--large.btn--icon-only,.btn--lg.btn--circle,.btn--lg.btn--icon-only{padding:16px}.btn .icon svg{transition:fill .2s}.btn>.icon-wrapper{fill:inherit;align-items:center;color:inherit;display:inline-flex;justify-content:center}.btn--sm>.icon-wrapper,.btn--small>.icon-wrapper{max-height:14px;max-width:14px}.btn--md>.icon-wrapper,.btn--medium>.icon-wrapper{max-height:16px;max-width:16px}.btn--large>.icon-wrapper,.btn--lg>.icon-wrapper{max-height:18px;max-width:18px}.btn>.icon-wrapper>.icon{fill:inherit;color:inherit}.btn--sm>.icon-wrapper>.icon,.btn--small>.icon-wrapper>.icon{font-size:15px}.btn--md>.icon-wrapper>.icon,.btn--medium>.icon-wrapper>.icon{font-size:18px}.btn--large>.icon-wrapper>.icon,.btn--lg>.icon-wrapper>.icon{font-size:21px}.btn-group{display:inline-flex;flex-wrap:wrap;gap:8px 16px;max-width:100%;position:relative;vertical-align:middle;width:max-content}.btn-group--horizontal{align-items:center;flex-direction:row;justify-content:flex-start}.btn-group--vertical{align-items:flex-start;flex-direction:column;justify-content:center}.contact-form input,.contact-form textarea{display:block;margin-bottom:12px}.contact-form input:not([type=submit]),.contact-form textarea{max-width:100%;width:100%}.contact-form textarea{min-height:120px;resize:none}.cookie-consent{background-color:var(--color-background);bottom:0;box-shadow:0 -.5rem 1rem rgba(var(--rgb-black),10%);left:0;position:fixed;right:0;width:100%;z-index:var(--z-index-fixed,1030)}.cookie-consent__container{align-items:center;display:flex;justify-content:space-between}.cookie-consent__text{margin:12px 16px}.cookie-consent__text>a,.cookie-consent__text>a:hover,.cookie-consent__text>a:visited{font-weight:400}.cookie-consent__button{height:100%;min-height:48px}.cookie-consent__button:not(.cookie-consent__button--unstyled):not(:disabled):active{transform:none}@media (max-width:784px){.cookie-consent__button{margin-right:16px}}.embedded-video{box-sizing:content-box;max-width:100%;overflow:hidden;position:relative}.embedded-video:before{background-color:var(--color-surface-2);bottom:0;content:"";height:100%;left:0;position:absolute;right:0;top:0;width:100%}.embedded-video__wrapper{height:0;padding-bottom:56.25%;position:relative;width:100%}.embedded-video iframe{left:0;max-height:100%;max-width:100%;position:absolute;top:0}.icon{-webkit-font-smoothing:antialiased;word-wrap:normal;color:inherit;direction:ltr;display:inline-block;font-size:24px;font-style:normal;font-weight:400;letter-spacing:normal;line-height:1;text-transform:none;white-space:nowrap}.icon--material{font-family:Material Icons}.icon--inherit{font-size:inherit}.icon--sm,.icon--small{font-size:18px}.icon--md,.icon--medium{font-size:24px}.icon--large,.icon--lg{font-size:36px}.icon--extraLarge,.icon--xl{font-size:48px}.icon--light.icon--active{opacity:1}.icon--light.icon--inactive{opacity:.3}.icon--dark.icon--active{opacity:.54}.icon--dark.icon--inactive{opacity:.26}.img-fluid{height:auto;max-width:100%}.img-rounded{border-radius:.25rem}.image-gallery{margin-bottom:12px;margin-top:12px;position:relative}.image-gallery__thumbnails{column-gap:12px;display:grid;row-gap:12px}.image-gallery__thumbnail{display:flex;position:relative}.image-gallery__thumbnail--full-width{grid-column:1/-1}.image-gallery__thumbnail img{max-width:100%}.image-gallery__lightbox .ril__toolbar{background-color:transparent;height:10vh}.image-gallery__lightbox .ril__toolbarSide{height:100%}.image-gallery__lightbox .ril__toolbarLeftSide{padding-left:0}.image-gallery__lightbox .ril__toolbarRightSide{padding-right:0}.image-gallery__lightbox .ril__toolbarItem{height:100%;width:100%}.image-gallery__lightbox .ril__navButtons{background-color:transparent;background-position:50%;background-size:25px;height:100%;padding:0;width:10vw}.image-gallery__lightbox .ril__closeButton{background-position:50%;background-size:25%;height:10vh;width:10vh}@media (max-width:767px){.image-gallery__thumbnails{column-gap:8px;row-gap:8px}}@media (hover:none){.image-gallery__thumbnail{animation:0}}.input-wrapper{align-items:center;border:1px solid var(--color-border);border-radius:.25rem;display:inline-flex;height:36px;padding:8px;position:relative;vertical-align:middle}.input-wrapper.focused{border-color:var(--color-primary)}.input-wrapper.disabled{cursor:not-allowed;opacity:var(--opacity-disabled,.38)}.input-wrapper.disabled>input:disabled{opacity:1}.input-wrapper>input{border:none;border-radius:0;height:100%;padding:0;width:100%}.input-wrapper>.icon{color:var(--color-foreground-muted,inherit);font-size:18px;pointer-events:none}.input-wrapper--icon-left{flex-direction:row-reverse}.input-wrapper--icon-left>.icon{margin-right:4px}.input-wrapper--icon-right{flex-direction:row}.input-wrapper--icon-right>.icon{margin-left:4px}.input-wrapper--sm,.input-wrapper--small{height:36px}.input-wrapper--md,.input-wrapper--medium{height:42px}.input-wrapper--large,.input-wrapper--lg{height:48px}.link,.link:hover,.link:visited{color:var(--color-primary,inherit);font-weight:500;text-decoration:none}.link--underlined,.link:hover{text-decoration:underline}.loading-spinner{display:none;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.loading-spinner.loading{display:inline-block}.loading-spinner.sm,.loading-spinner.small{height:20px;width:20px}.loading-spinner.md,.loading-spinner.medium{height:40px;width:40px}.loading-spinner.large,.loading-spinner.lg{height:80px;width:80px}.loading-spinner__animation{display:inline-block;height:80%;left:10%;position:relative;top:10%;width:80%}.loading-spinner__animation div{animation:loading-spinner-animation 1.2s cubic-bezier(.5,0,.5,1) infinite;border:4px solid var(--color-surface-9);border-color:var(--color-surface-9) transparent transparent transparent;border-radius:50%;box-sizing:border-box;display:block;height:100%;position:absolute;width:100%}.loading-spinner__animation div:first-child{animation-delay:-.45s}.loading-spinner__animation div:nth-child(2){animation-delay:-.3s}.loading-spinner__animation div:nth-child(3){animation-delay:-.15s}@keyframes loading-spinner-animation{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.logo{fill:var(--color-foreground);display:inline-block}.logo.extraSmall,.logo.xs{height:32px}.logo.sm,.logo.small{height:48px}.logo.md,.logo.medium{height:72px}.logo.large,.logo.lg{height:96px}.logo.extraLarge,.logo.xl{height:128px}.logo svg{fill:inherit}.logo img,.logo svg{height:100%}.logo button{cursor:pointer;height:100%;pointer-events:all!important}.logo button:focus-visible{outline-offset:-16px}.modal{background-color:rgba(var(--rgb-black,black),0);bottom:0;display:none;left:0;outline:none;overflow:hidden;position:fixed;right:0;top:0;transition:background-color .3s;z-index:var(--z-index-modal,1060)}.modal--open{background-color:rgba(var(--rgb-black,black),var(--opacity-scrim,.54));display:block;overflow-x:hidden;overflow-y:auto}.modal__dialog{align-items:center;display:flex;margin:.5rem;min-height:calc(100% - 4rem);position:relative;width:auto}.modal__content{background-clip:padding-box;background-color:var(--color-surface-1);border:1px solid var(--color-border);border-radius:.25rem;color:var(--color-foreground);display:flex;flex-direction:column;outline:none;overflow:hidden;pointer-events:auto;position:relative;width:100%}.modal__body{flex:1 1 auto;padding:1rem;position:relative}.modal__header{border-bottom:1px solid var(--color-border);justify-content:space-between}.modal__footer,.modal__header{align-items:center;display:flex;padding:1rem}.modal__footer{border-top:1px solid var(--color-border)}.modal__footer--left-aligned{justify-content:flex-start}.modal__footer--right-aligned{justify-content:flex-end}.modal__title{margin:0}.modal__close-button{margin:-1rem -.65rem -1rem auto;opacity:.5;padding:1rem;transition:opacity .2s}.modal__close-button:active,.modal__close-button:focus,.modal__close-button:hover{opacity:1}@media (min-width:576px){.modal__dialog{margin:2rem auto;max-width:500px}}.navbar{justify-content:flex-start}.navbar,.navbar ul{align-items:center;display:inline-flex}.navbar ul{justify-content:space-evenly;list-style:none;margin-block-end:0;margin-block-start:0;padding-inline-end:16px;padding-inline-start:16px}.navbar li{padding-left:4px;padding-right:4px}.navbar li a{align-items:center;background-color:transparent;border:none;border-radius:.5rem;display:inline-flex;font-size:1rem;font-weight:500;justify-content:center;padding:6px 12px;transform:scale(1);transition:background-color .2s,transform .2s}.navbar li a:hover{background-color:var(--color-default-subtle);text-decoration:none}.navbar li a:active{transform:scale(.975)}.navbar li a.active{color:var(--color-primary)}.navbar li a.active:hover{background-color:var(--color-primary-subtle)}.navmenu{background:none!important;position:fixed;z-index:var(--z-index-fixed,1030)}.navmenu,.navmenu__overlay{bottom:0;height:100vh;left:0;right:0;top:0;width:100vw}.navmenu__overlay{background-color:var(--color-background);position:absolute;z-index:var(--z-index-overlay,1040)}.navmenu__container{height:calc(100% - var(--header-height, 80px)*2);margin-bottom:calc(var(--header-height, 80px)*.5);margin-top:calc(var(--header-height, 80px)*1.5);position:relative;z-index:var(--z-index-menu,1050)}.navmenu__container .social-nav-links{fill:var(--color-foreground);margin-left:-8px}.navmenu__wrapper{align-items:flex-start;display:flex;flex-direction:column;height:100%;justify-content:space-between;margin-left:16px}.navmenu__button{align-items:center;color:var(--color-foreground);display:inline-flex;height:56px;justify-content:center;pointer-events:all!important;transition:transform .2s;width:56px}.navmenu__button:hover:not(:disabled){transform:scale(1.1)}.navmenu__list{font-size:2rem;font-weight:600;line-height:1.2;list-style:none;margin-block-end:0;margin-block-start:0;margin-inline-end:0;margin-inline-start:0;padding-inline-start:0;text-align:left;white-space:nowrap}.navmenu__item{color:var(--color-foreground);margin-bottom:.5rem;transition:opacity .2s}.navmenu__item>a{border-bottom:none!important;color:inherit;font-weight:600}.navmenu--open{pointer-events:all;visibility:visible}.navmenu--closed{pointer-events:none;visibility:hidden}.navmenu--animated{transition:visibility .2s}.navmenu--animated .navmenu__item,.navmenu--animated .navmenu__overlay{transition:opacity .2s}.navmenu--animated.navmenu--open .navmenu__item,.navmenu--animated.navmenu--open .navmenu__overlay{opacity:1}.navmenu--animated.navmenu--closed .navmenu__item,.navmenu--animated.navmenu--closed .navmenu__overlay{opacity:0}@media (hover:hover){.navmenu__list:hover .navmenu__item{opacity:var(--opacity-inactive,.62)}.navmenu__item:hover{opacity:1!important}}@media (min-width:360px){.navmenu__list{font-size:2.5rem}}@media (min-width:576px){.navmenu__list{font-size:2.75rem}}@media (min-width:768px){.navmenu__list{font-size:3rem}}.page-banner{position:relative;width:100%;z-index:0}.page-banner:before{background:inherit;bottom:0;content:"";height:100%;left:0;margin-left:50%;pointer-events:none;position:absolute;right:0;top:0;transform:translate3d(-50%,0,0);transform-origin:50% 50%;width:100vw;z-index:-1}.page-banner--transparent:before{background:none!important}.page-banner--extraSmall,.page-banner--xs{padding-bottom:1rem;padding-top:1rem}.page-banner--sm,.page-banner--small{padding-bottom:2rem;padding-top:2rem}.page-banner--md,.page-banner--medium{padding-bottom:4rem;padding-top:4rem}.page-banner--large,.page-banner--lg{padding-bottom:6rem;padding-top:6rem}.page-banner--extraLarge,.page-banner--xl{padding-bottom:8rem;padding-top:8rem}.pagination{align-items:center;display:inline-flex;justify-content:flex-start}.pagination>.btn{border-radius:.25rem;height:36px;margin-left:4px;margin-right:4px;padding:8px;width:36px}.pagination>.btn:first-child{margin-left:0}.pagination>.btn:last-child{margin-right:0}.progressive-image{box-sizing:content-box;display:inline-block;height:auto;max-width:100%;position:relative}.progressive-image__placeholder{clip-path:inset(0);filter:blur(1px);opacity:1;position:absolute}.progressive-image__placeholder.progressive-image--animated{transition:opacity .6s ease-in}.progressive-image--loaded .progressive-image__placeholder{opacity:0}@media (hover:hover){.progressive-image--no-placeholder.progressive-image--animated .progressive-image__source{transition:opacity .2s ease-in,visibility .2s ease-in}.progressive-image--no-placeholder .progressive-image__source{opacity:0;visibility:hidden}.progressive-image--no-placeholder.progressive-image--loaded .progressive-image__source{opacity:1;visibility:visible}}.custom-scrollbar{overflow-y:auto}.custom-scrollbar--auto-hide{overflow-y:overlay}.custom-scrollbar::-webkit-scrollbar{width:8px}.custom-scrollbar::-webkit-scrollbar-track{background-color:var(--color-surface-3)}.custom-scrollbar::-webkit-scrollbar-thumb{background-clip:content-box;background-color:var(--color-surface-6);border:none;border-radius:4px}.custom-scrollbar--auto-hide::-webkit-scrollbar-thumb,.custom-scrollbar--auto-hide::-webkit-scrollbar-track{background-color:transparent}.custom-scrollbar--auto-hide:hover::-webkit-scrollbar-thumb{background-color:var(--color-surface-6)}.custom-scrollbar::-webkit-scrollbar-thumb:hover{background-color:var(--color-surface-9)}.sidedrawer{background:none!important;position:fixed;z-index:var(--z-index-fixed,1030)}.sidedrawer,.sidedrawer__overlay{bottom:0;height:100vh;left:0;right:0;top:0;width:100vw}.sidedrawer__overlay{background-color:var(--color-black,#000);opacity:var(--opacity-scrim,.54);position:absolute;z-index:var(--z-index-overlay,1040)}.sidedrawer__container{background-color:var(--color-background);box-shadow:.25rem 0 .5rem rgba(0,0,0,.1);color:var(--color-foreground);height:100%;left:0;margin-right:auto;position:relative;width:287px;z-index:var(--z-index-menu,1050)}[data-theme=dark] .sidedrawer__container,[data-theme=high-contrast] .sidedrawer__container{box-shadow:none}.sidedrawer__button{align-items:center;color:var(--color-foreground);display:inline-flex;height:56px;justify-content:center;pointer-events:all!important;transition:transform .2s;width:56px}.sidedrawer__button:hover:not(:disabled){transform:scale(1.1)}.sidedrawer--open{pointer-events:all;visibility:visible}.sidedrawer--closed{pointer-events:none;visibility:hidden}.sidedrawer--animated{transition:visibility .2s}.sidedrawer--animated .sidedrawer__overlay{transition:opacity .2s}.sidedrawer--animated .sidedrawer__container{transition:transform .2s}.sidedrawer--animated.sidedrawer--open .sidedrawer__overlay{opacity:var(--opacity-scrim,.54)}.sidedrawer--animated.sidedrawer--closed .sidedrawer__overlay{opacity:0}.sidedrawer--animated.sidedrawer--open .sidedrawer__container{transform:translateX(0)}.sidedrawer--animated.sidedrawer--closed .sidedrawer__container{transform:translateX(-287px)}.social-button.paypal path{transition:fill .1s}.social-button.paypal:active:not(:disabled) path:first-child,.social-button.paypal:active:not(:disabled) path:nth-child(4),.social-button.paypal:focus:not(:disabled) path:first-child,.social-button.paypal:focus:not(:disabled) path:nth-child(4),.social-button.paypal:hover:not(:disabled) path:first-child,.social-button.paypal:hover:not(:disabled) path:nth-child(4){fill:#fff}.social-button.paypal:active:not(:disabled) path:nth-child(2),.social-button.paypal:focus:not(:disabled) path:nth-child(2),.social-button.paypal:hover:not(:disabled) path:nth-child(2){fill:#adcee4}.social-button.paypal:active:not(:disabled) path:nth-child(3),.social-button.paypal:focus:not(:disabled) path:nth-child(3),.social-button.paypal:hover:not(:disabled) path:nth-child(3){fill:#e6eff6}.social-icon{fill:var(--color-foreground,inherit);align-items:center;box-sizing:content-box;display:inline-flex;justify-content:center;max-height:100%;max-width:100%;position:relative}.social-icon,.social-icon:hover{border-bottom:none;text-decoration:none}.social-icon--rounded{border-radius:50%}.social-icon svg{fill:inherit;height:100%;width:100%}.social-nav-links{align-items:center;display:flex;justify-content:flex-start;max-width:100%}.social-nav-links__list{align-items:center;display:flex;list-style:none;margin-block-end:8px;margin-block-start:8px;padding-inline-end:0;padding-inline-start:0}.social-nav-links__item{transition:opacity .2s,transform .2s}@media (hover:hover){.social-nav-links__list:hover .social-nav-links__item{opacity:var(--opacity-disabled,.38)}.social-nav-links__item:hover{opacity:1!important;transform:scale(1.1)}}.thumbnail{border-bottom:none!important;box-sizing:content-box;display:inline-flex;height:auto;max-width:100%;overflow:hidden;position:relative;text-align:center}@media (hover:hover){a.thumbnail{transition:transform .3s cubic-bezier(.23,1,.32,1),box-shadow .3s cubic-bezier(.23,1,.32,1)}a.thumbnail:hover{box-shadow:0 10px 20px rgba(0,0,0,.1);transform:translateY(-4px)}}@media (hover:none){.thumbnail{animation:none!important}}@media (prefers-reduced-motion){.thumbnail{transition:none!important}}.container,.container-fluid,.container-lg,.container-md,.container-sm,.container-xl{margin-left:auto;margin-right:auto;padding-left:16px;padding-right:16px;width:100%}@media (min-width:576px){.container,.container-lg,.container-md,.container-sm,.container-xl{max-width:540px}}@media (min-width:768px){.container,.container-lg,.container-md,.container-xl{max-width:720px}}@media (min-width:992px){.container,.container-lg,.container-xl{max-width:960px}}@media (min-width:1200px){.container,.container-xl{max-width:1140px}}.row{display:flex;flex-wrap:wrap;margin-left:-16px;margin-right:-16px}.col,[class*=col-]{min-height:1px;padding-left:16px;padding-right:16px;position:relative;width:100%}.col{flex-basis:0;flex-grow:1;max-width:100%}.col-0{flex:0 0;max-width:0}.col-1{flex:0 0 8.3333333333%;max-width:8.3333333333%}.col-2{flex:0 0 16.6666666667%;max-width:16.6666666667%}.col-3{flex:0 0 25%;max-width:25%}.col-4{flex:0 0 33.3333333333%;max-width:33.3333333333%}.col-5{flex:0 0 41.6666666667%;max-width:41.6666666667%}.col-6{flex:0 0 50%;max-width:50%}.col-7{flex:0 0 58.3333333333%;max-width:58.3333333333%}.col-8{flex:0 0 66.6666666667%;max-width:66.6666666667%}.col-9{flex:0 0 75%;max-width:75%}.col-10{flex:0 0 83.3333333333%;max-width:83.3333333333%}.col-11{flex:0 0 91.6666666667%;max-width:91.6666666667%}.col-12{flex:0 0 100%;max-width:100%}.col-auto{flex:0 0 auto;max-width:100%;width:auto}.order-first{order:-1}.order-last{order:13}.order-0{order:0}.order-1{order:1}.order-2{order:2}.order-3{order:3}.order-4{order:4}.order-5{order:5}.order-6{order:6}.order-7{order:7}.order-8{order:8}.order-9{order:9}.order-10{order:10}.order-11{order:11}.order-12{order:12}.offset-0{margin-left:0}.offset-1{margin-left:8.3333333333%}.offset-2{margin-left:16.6666666667%}.offset-3{margin-left:25%}.offset-4{margin-left:33.3333333333%}.offset-5{margin-left:41.6666666667%}.offset-6{margin-left:50%}.offset-7{margin-left:58.3333333333%}.offset-8{margin-left:66.6666666667%}.offset-9{margin-left:75%}.offset-10{margin-left:83.3333333333%}.offset-11{margin-left:91.6666666667%}.offset-12{margin-left:100%}.row.gutters-sm{padding-bottom:8px;padding-top:8px}.row.gutters-md{padding-bottom:16px;padding-top:16px}.row.gutters-lg{padding-bottom:32px;padding-top:32px}.col.gutters-sm,[class*=col-].gutters-sm{padding-left:8px;padding-right:8px}.col.gutters-md,[class*=col-].gutters-md{padding-left:16px;padding-right:16px}.col.gutters-lg,[class*=col-].gutters-lg{padding-left:32px;padding-right:32px}.gutters-none{margin-left:0;margin-right:0}.gutters-none>.col,.gutters-none>[class*=col-]{padding-left:0;padding-right:0}@media (min-width:576px){.col-sm{flex-basis:0;flex-grow:1;max-width:100%}.col-sm-0{flex:0 0;max-width:0}.col-sm-1{flex:0 0 8.3333333333%;max-width:8.3333333333%}.col-sm-2{flex:0 0 16.6666666667%;max-width:16.6666666667%}.col-sm-3{flex:0 0 25%;max-width:25%}.col-sm-4{flex:0 0 33.3333333333%;max-width:33.3333333333%}.col-sm-5{flex:0 0 41.6666666667%;max-width:41.6666666667%}.col-sm-6{flex:0 0 50%;max-width:50%}.col-sm-7{flex:0 0 58.3333333333%;max-width:58.3333333333%}.col-sm-8{flex:0 0 66.6666666667%;max-width:66.6666666667%}.col-sm-9{flex:0 0 75%;max-width:75%}.col-sm-10{flex:0 0 83.3333333333%;max-width:83.3333333333%}.col-sm-11{flex:0 0 91.6666666667%;max-width:91.6666666667%}.col-sm-12{flex:0 0 100%;max-width:100%}.col-sm-auto{flex:0 0 auto;max-width:100%;width:auto}.order-sm-first{order:-1}.order-sm-last{order:13}.order-sm-0{order:0}.order-sm-1{order:1}.order-sm-2{order:2}.order-sm-3{order:3}.order-sm-4{order:4}.order-sm-5{order:5}.order-sm-6{order:6}.order-sm-7{order:7}.order-sm-8{order:8}.order-sm-9{order:9}.order-sm-10{order:10}.order-sm-11{order:11}.order-sm-12{order:12}.offset-sm-0{margin-left:0}.offset-sm-1{margin-left:8.3333333333%}.offset-sm-2{margin-left:16.6666666667%}.offset-sm-3{margin-left:25%}.offset-sm-4{margin-left:33.3333333333%}.offset-sm-5{margin-left:41.6666666667%}.offset-sm-6{margin-left:50%}.offset-sm-7{margin-left:58.3333333333%}.offset-sm-8{margin-left:66.6666666667%}.offset-sm-9{margin-left:75%}.offset-sm-10{margin-left:83.3333333333%}.offset-sm-11{margin-left:91.6666666667%}.offset-sm-12{margin-left:100%}}@media (min-width:768px){.col-md{flex-basis:0;flex-grow:1;max-width:100%}.col-md-0{flex:0 0;max-width:0}.col-md-1{flex:0 0 8.3333333333%;max-width:8.3333333333%}.col-md-2{flex:0 0 16.6666666667%;max-width:16.6666666667%}.col-md-3{flex:0 0 25%;max-width:25%}.col-md-4{flex:0 0 33.3333333333%;max-width:33.3333333333%}.col-md-5{flex:0 0 41.6666666667%;max-width:41.6666666667%}.col-md-6{flex:0 0 50%;max-width:50%}.col-md-7{flex:0 0 58.3333333333%;max-width:58.3333333333%}.col-md-8{flex:0 0 66.6666666667%;max-width:66.6666666667%}.col-md-9{flex:0 0 75%;max-width:75%}.col-md-10{flex:0 0 83.3333333333%;max-width:83.3333333333%}.col-md-11{flex:0 0 91.6666666667%;max-width:91.6666666667%}.col-md-12{flex:0 0 100%;max-width:100%}.col-md-auto{flex:0 0 auto;max-width:100%;width:auto}.order-md-first{order:-1}.order-md-last{order:13}.order-md-0{order:0}.order-md-1{order:1}.order-md-2{order:2}.order-md-3{order:3}.order-md-4{order:4}.order-md-5{order:5}.order-md-6{order:6}.order-md-7{order:7}.order-md-8{order:8}.order-md-9{order:9}.order-md-10{order:10}.order-md-11{order:11}.order-md-12{order:12}.offset-md-0{margin-left:0}.offset-md-1{margin-left:8.3333333333%}.offset-md-2{margin-left:16.6666666667%}.offset-md-3{margin-left:25%}.offset-md-4{margin-left:33.3333333333%}.offset-md-5{margin-left:41.6666666667%}.offset-md-6{margin-left:50%}.offset-md-7{margin-left:58.3333333333%}.offset-md-8{margin-left:66.6666666667%}.offset-md-9{margin-left:75%}.offset-md-10{margin-left:83.3333333333%}.offset-md-11{margin-left:91.6666666667%}.offset-md-12{margin-left:100%}}@media (min-width:992px){.col-lg{flex-basis:0;flex-grow:1;max-width:100%}.col-lg-0{flex:0 0;max-width:0}.col-lg-1{flex:0 0 8.3333333333%;max-width:8.3333333333%}.col-lg-2{flex:0 0 16.6666666667%;max-width:16.6666666667%}.col-lg-3{flex:0 0 25%;max-width:25%}.col-lg-4{flex:0 0 33.3333333333%;max-width:33.3333333333%}.col-lg-5{flex:0 0 41.6666666667%;max-width:41.6666666667%}.col-lg-6{flex:0 0 50%;max-width:50%}.col-lg-7{flex:0 0 58.3333333333%;max-width:58.3333333333%}.col-lg-8{flex:0 0 66.6666666667%;max-width:66.6666666667%}.col-lg-9{flex:0 0 75%;max-width:75%}.col-lg-10{flex:0 0 83.3333333333%;max-width:83.3333333333%}.col-lg-11{flex:0 0 91.6666666667%;max-width:91.6666666667%}.col-lg-12{flex:0 0 100%;max-width:100%}.col-lg-auto{flex:0 0 auto;max-width:100%;width:auto}.order-lg-first{order:-1}.order-lg-last{order:13}.order-lg-0{order:0}.order-lg-1{order:1}.order-lg-2{order:2}.order-lg-3{order:3}.order-lg-4{order:4}.order-lg-5{order:5}.order-lg-6{order:6}.order-lg-7{order:7}.order-lg-8{order:8}.order-lg-9{order:9}.order-lg-10{order:10}.order-lg-11{order:11}.order-lg-12{order:12}.offset-lg-0{margin-left:0}.offset-lg-1{margin-left:8.3333333333%}.offset-lg-2{margin-left:16.6666666667%}.offset-lg-3{margin-left:25%}.offset-lg-4{margin-left:33.3333333333%}.offset-lg-5{margin-left:41.6666666667%}.offset-lg-6{margin-left:50%}.offset-lg-7{margin-left:58.3333333333%}.offset-lg-8{margin-left:66.6666666667%}.offset-lg-9{margin-left:75%}.offset-lg-10{margin-left:83.3333333333%}.offset-lg-11{margin-left:91.6666666667%}.offset-lg-12{margin-left:100%}}@media (min-width:1200px){.col-xl{flex-basis:0;flex-grow:1;max-width:100%}.col-xl-0{flex:0 0;max-width:0}.col-xl-1{flex:0 0 8.3333333333%;max-width:8.3333333333%}.col-xl-2{flex:0 0 16.6666666667%;max-width:16.6666666667%}.col-xl-3{flex:0 0 25%;max-width:25%}.col-xl-4{flex:0 0 33.3333333333%;max-width:33.3333333333%}.col-xl-5{flex:0 0 41.6666666667%;max-width:41.6666666667%}.col-xl-6{flex:0 0 50%;max-width:50%}.col-xl-7{flex:0 0 58.3333333333%;max-width:58.3333333333%}.col-xl-8{flex:0 0 66.6666666667%;max-width:66.6666666667%}.col-xl-9{flex:0 0 75%;max-width:75%}.col-xl-10{flex:0 0 83.3333333333%;max-width:83.3333333333%}.col-xl-11{flex:0 0 91.6666666667%;max-width:91.6666666667%}.col-xl-12{flex:0 0 100%;max-width:100%}.col-xl-auto{flex:0 0 auto;max-width:100%;width:auto}.order-xl-first{order:-1}.order-xl-last{order:13}.order-xl-0{order:0}.order-xl-1{order:1}.order-xl-2{order:2}.order-xl-3{order:3}.order-xl-4{order:4}.order-xl-5{order:5}.order-xl-6{order:6}.order-xl-7{order:7}.order-xl-8{order:8}.order-xl-9{order:9}.order-xl-10{order:10}.order-xl-11{order:11}.order-xl-12{order:12}.offset-xl-0{margin-left:0}.offset-xl-1{margin-left:8.3333333333%}.offset-xl-2{margin-left:16.6666666667%}.offset-xl-3{margin-left:25%}.offset-xl-4{margin-left:33.3333333333%}.offset-xl-5{margin-left:41.6666666667%}.offset-xl-6{margin-left:50%}.offset-xl-7{margin-left:58.3333333333%}.offset-xl-8{margin-left:66.6666666667%}.offset-xl-9{margin-left:75%}.offset-xl-10{margin-left:83.3333333333%}.offset-xl-11{margin-left:91.6666666667%}.offset-xl-12{margin-left:100%}}.full-bleed{margin-left:50%;transform:translateX(-50%);width:100vw}.page{margin-left:auto;margin-right:auto;min-height:calc(100vh - var(--header-height, 0));position:relative}.js-parallax .page{transform-style:preserve-3d}.page>article{padding-bottom:128px}.cover{align-items:center;display:flex;flex-direction:column;height:auto;justify-content:center;min-height:100vh;width:100vw}.cover:before{background-attachment:fixed;content:"";height:100%;pointer-events:none;width:100%}.cover:before,.overlay{bottom:0;left:0;position:absolute;right:0;top:0}.overlay{height:100vh;width:100vw;z-index:var(--z-index-overlay,1040)}.app.js-parallax,.parallax{perspective:10px}.parallax{height:100vh;overflow-x:hidden;overflow-y:auto}.parallax__group{position:relative;transform-style:preserve-3d}.parallax__layer{bottom:0;left:0;position:absolute;right:0;top:0}.parallax__layer--base{transform:translateZ(0)}.parallax__layer--bg-1{transform:translateZ(-1px) scale(2)}.parallax__layer--bg-2{transform:translateZ(-2px) scale(3)}.parallax__layer--bg-3{transform:translateZ(-3px) scale(4)}.parallax__layer--bg-4{transform:translateZ(-4px) scale(5)}.parallax__layer--bg-5{transform:translateZ(-5px) scale(6)}.parallax__layer--fg-1{transform:translateZ(1px) scale(.9)}.parallax__layer--fg-2{transform:translateZ(2px) scale(.8)}.parallax__layer--fg-3{transform:translateZ(3px) scale(.7)}.parallax__layer--fg-4{transform:translateZ(4px) scale(.6)}.parallax__layer--fg-5{transform:translateZ(5px) scale(.5)}.align-baseline{vertical-align:baseline}.align-middle{vertical-align:middle}.align-top{vertical-align:top}.align-bottom{vertical-align:bottom}.align-text-top{vertical-align:text-top}.align-text-bottom{vertical-align:text-bottom}.animation-short{animation-duration:.2s;animation-fill-mode:both}.animation-medium{animation-duration:.4s;animation-fill-mode:both}.animation-long{animation-duration:.6s;animation-fill-mode:both}.animation-infinite{animation-iteration-count:infinite}.animation-delay-1{animation-delay:50ms}.animation-delay-2{animation-delay:.1s}.animation-delay-3{animation-delay:.15s}.animation-delay-4{animation-delay:.2s}.animation-delay-5{animation-delay:.25s}.animation-delay-6{animation-delay:.3s}.animation-delay-7{animation-delay:.35s}.animation-delay-8{animation-delay:.4s}.fade-in{animation-name:fade-in}.fade-out{animation-name:fade-out}.translate-in{animation-name:translate-in}.translate-out{animation-name:translate-out}.fade-translate-in{animation-name:fade-translate-in}.fade-translate-out{animation-name:fade-translate-out}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes fade-out{0%{opacity:1}to{opacity:0}}@keyframes translate-in{0%{transform:translate3d(0,10%,0)}to{transform:none}}@keyframes translate-out{0%{transform:none}to{transform:translate3d(0,10%,0)}}@keyframes fade-translate-in{0%{opacity:0;transform:translate3d(0,10%,0)}to{opacity:1;transform:none}}@keyframes fade-translate-out{0%{opacity:1;transform:none}to{opacity:0;transform:translate3d(0,10%,0)}}.aspect-ratio-container{height:0;overflow:hidden;position:relative}.aspect-ratio-content{height:100%;left:0;position:absolute;top:0;width:100%}.aspect-ratio-21x9{padding-bottom:42.85714%}.aspect-ratio-9x21{padding-bottom:233.33333%}.aspect-ratio-16x9{padding-bottom:56.25%}.aspect-ratio-9x16{padding-bottom:177.77778%}.aspect-ratio-4x3{padding-bottom:75%}.aspect-ratio-3x4{padding-bottom:133.33333%}.aspect-ratio-6x4{padding-bottom:66.66667%}.aspect-ratio-4x6{padding-bottom:150%}.aspect-ratio-8x5{padding-bottom:62.5%}.aspect-ratio-5x8{padding-bottom:160%}.aspect-ratio-7x5{padding-bottom:71.42857%}.aspect-ratio-5x7{padding-bottom:140%}.aspect-ratio-2x1{padding-bottom:50%}.aspect-ratio-1x2{padding-bottom:200%}.aspect-ratio-1x1{padding-bottom:100%}.bg-cover{background-size:cover}.bg-contain{background-size:contain}.bg-center{background-position:50%}.bg-center,.bg-top{background-repeat:no-repeat}.bg-top{background-position:top}.bg-bottom{background-position:bottom}.bg-bottom,.bg-left{background-repeat:no-repeat}.bg-left{background-position:0}.bg-right{background-position:100%;background-repeat:no-repeat}.bg-repeat{background-repeat:repeat}.bg-repeat-x{background-repeat:repeat-x}.bg-repeat-y{background-repeat:repeat-y}.bg-norepeat{background-repeat:no-repeat}.border,.border-all{border-style:solid;border-width:1px}.border-top{border-top-style:solid;border-top-width:1px}.border-bottom{border-bottom-style:solid;border-bottom-width:1px}.border-left{border-left-style:solid;border-left-width:1px}.border-right{border-right-style:solid;border-right-width:1px}.border-none{border-style:solid;border-width:0}.rounded,.rounded-md{border-radius:.25rem}.rounded-sm{border-radius:.125rem}.rounded-lg{border-radius:.5rem}.justify-content-around{justify-content:space-around}.justify-content-baseline{justify-content:baseline}.justify-content-between{justify-content:space-between}.justify-content-center{justify-content:center}.justify-content-end{justify-content:end}.justify-content-evenly{justify-content:space-evenly}.justify-content-flex-end{justify-content:flex-end}.justify-content-flex-start{justify-content:flex-start}.justify-content-left{justify-content:left}.justify-content-normal{justify-content:normal}.justify-content-right{justify-content:right}.justify-content-start{justify-content:start}.justify-content-stretch{justify-content:stretch}.justify-items-auto{justify-items:auto}.justify-items-baseline{justify-items:baseline}.justify-items-center{justify-items:center}.justify-items-end{justify-items:end}.justify-items-flex-end{justify-items:flex-end}.justify-items-flex-start{justify-items:flex-start}.justify-items-left{justify-items:left}.justify-items-normal{justify-items:normal}.justify-items-right{justify-items:right}.justify-items-self-end{justify-items:self-end}.justify-items-self-start{justify-items:self-start}.justify-items-start{justify-items:start}.justify-items-stretch{justify-items:stretch}.justify-self-auto{justify-self:auto}.justify-self-baseline{justify-self:baseline}.justify-self-center{justify-self:center}.justify-self-end{justify-self:end}.justify-self-flex-end{justify-self:flex-end}.justify-self-flex-start{justify-self:flex-start}.justify-self-left{justify-self:left}.justify-self-normal{justify-self:normal}.justify-self-right{justify-self:right}.justify-self-self-end{justify-self:self-end}.justify-self-self-start{justify-self:self-start}.justify-self-start{justify-self:start}.justify-self-stretch{justify-self:stretch}.align-content-around{align-content:space-around}.align-content-between{align-content:space-between}.align-content-center{align-content:center}.align-content-end{align-content:flex-end}.align-content-start{align-content:flex-start}.align-content-stretch{align-content:stretch}.align-items-baseline{align-items:baseline}.align-items-center{align-items:center}.align-items-end{align-items:flex-end}.align-items-start{align-items:flex-start}.align-items-stretch{align-items:stretch}.align-self-auto{align-self:auto}.align-self-baseline{align-self:baseline}.align-self-center{align-self:center}.align-self-end{align-self:flex-end}.align-self-start{align-self:flex-start}.align-self-stretch{align-self:stretch}.border-box{box-sizing:border-box}.content-box{box-sizing:content-box}.color-inherit,.color-inherit:visited{color:inherit}.color-transparent{color:transparent}.color-black{color:var(--color-black,#000)}.color-white{color:var(--color-white,#fff)}.color-foreground{color:var(--color-foreground)}.color-foreground-muted{color:var(--color-foreground-muted)}.color-foreground-subtle{color:var(--color-foreground-subtle)}.color-background{color:var(--color-background)}.color-surface-0{color:var(--color-surface-0)}.color-surface-1{color:var(--color-surface-1)}.color-surface-2{color:var(--color-surface-2)}.color-surface-3{color:var(--color-surface-3)}.color-surface-4{color:var(--color-surface-4)}.color-surface-5{color:var(--color-surface-5)}.color-surface-6{color:var(--color-surface-6)}.color-surface-7{color:var(--color-surface-7)}.color-surface-8{color:var(--color-surface-8)}.color-surface-9{color:var(--color-surface-9)}.color-default{color:var(--color-default)}.color-default-emphasis{color:var(--color-default-emphasis)}.color-default-subtle{color:var(--color-default-subtle)}.color-primary{color:var(--color-primary)}.color-primary-emphasis{color:var(--color-primary-emphasis)}.color-primary-subtle{color:var(--color-primary-subtle)}.color-secondary{color:var(--color-secondary)}.color-secondary-emphasis{color:var(--color-secondary-emphasis)}.color-secondary-subtle{color:var(--color-secondary-subtle)}.color-tertiary{color:var(--color-tertiary)}.color-tertiary-emphasis{color:var(--color-tertiary-emphasis)}.color-tertiary-subtle{color:var(--color-tertiary-subtle)}.color-success{color:var(--color-success)}.color-success-emphasis{color:var(--color-success-emphasis)}.color-success-subtle{color:var(--color-success-subtle)}.color-danger{color:var(--color-danger)}.color-danger-emphasis{color:var(--color-danger-emphasis)}.color-danger-subtle{color:var(--color-danger-subtle)}.color-warning{color:var(--color-warning)}.color-warning-emphasis{color:var(--color-warning-emphasis)}.color-warning-subtle{color:var(--color-warning-subtle)}.color-info{color:var(--color-info)}.color-info-emphasis{color:var(--color-info-emphasis)}.color-info-subtle{color:var(--color-info-subtle)}.bg-inherit{background-color:inherit}.bg-transparent{background-color:transparent}.bg-black{background-color:var(--color-black,#000)}.bg-white{background-color:var(--color-white,#fff)}.bg-foreground{background-color:var(--color-foreground)}.bg-foreground-muted{background-color:var(--color-foreground-muted)}.bg-foreground-subtle{background-color:var(--color-foreground-subtle)}.bg-background{background-color:var(--color-background)}.bg-surface-0{background-color:var(--color-surface-0)}.bg-surface-1{background-color:var(--color-surface-1)}.bg-surface-2{background-color:var(--color-surface-2)}.bg-surface-3{background-color:var(--color-surface-3)}.bg-surface-4{background-color:var(--color-surface-4)}.bg-surface-5{background-color:var(--color-surface-5)}.bg-surface-6{background-color:var(--color-surface-6)}.bg-surface-7{background-color:var(--color-surface-7)}.bg-surface-8{background-color:var(--color-surface-8)}.bg-surface-9{background-color:var(--color-surface-9)}.bg-default{background-color:var(--color-default)}.bg-default-emphasis{background-color:var(--color-default-emphasis)}.bg-default-subtle{background-color:var(--color-default-subtle)}.bg-primary{background-color:var(--color-primary)}.bg-primary-emphasis{background-color:var(--color-primary-emphasis)}.bg-primary-subtle{background-color:var(--color-primary-subtle)}.bg-secondary{background-color:var(--color-secondary)}.bg-secondary-emphasis{background-color:var(--color-secondary-emphasis)}.bg-secondary-subtle{background-color:var(--color-secondary-subtle)}.bg-tertiary{background-color:var(--color-tertiary)}.bg-tertiary-emphasis{background-color:var(--color-tertiary-emphasis)}.bg-tertiary-subtle{background-color:var(--color-tertiary-subtle)}.bg-success{background-color:var(--color-success)}.bg-success-emphasis{background-color:var(--color-success-emphasis)}.bg-success-subtle{background-color:var(--color-success-subtle)}.bg-danger{background-color:var(--color-danger)}.bg-danger-emphasis{background-color:var(--color-danger-emphasis)}.bg-danger-subtle{background-color:var(--color-danger-subtle)}.bg-warning{background-color:var(--color-warning)}.bg-warning-emphasis{background-color:var(--color-warning-emphasis)}.bg-warning-subtle{background-color:var(--color-warning-subtle)}.bg-info{background-color:var(--color-info)}.bg-info-emphasis{background-color:var(--color-info-emphasis)}.bg-info-subtle{background-color:var(--color-info-subtle)}.fill-inherit{fill:inherit}.fill-transparent{fill:transparent}.fill-black{fill:var(--color-black,#000)}.fill-white{fill:var(--color-white,#fff)}.fill-foreground{fill:var(--color-foreground)}.fill-foreground-muted{fill:var(--color-foreground-muted)}.fill-foreground-subtle{fill:var(--color-foreground-subtle)}.fill-background{fill:var(--color-background)}.fill-surface-0{fill:var(--color-surface-0)}.fill-surface-1{fill:var(--color-surface-1)}.fill-surface-2{fill:var(--color-surface-2)}.fill-surface-3{fill:var(--color-surface-3)}.fill-surface-4{fill:var(--color-surface-4)}.fill-surface-5{fill:var(--color-surface-5)}.fill-surface-6{fill:var(--color-surface-6)}.fill-surface-7{fill:var(--color-surface-7)}.fill-surface-8{fill:var(--color-surface-8)}.fill-surface-9{fill:var(--color-surface-9)}.fill-default{fill:var(--color-default)}.fill-default-emphasis{fill:var(--color-default-emphasis)}.fill-default-subtle{fill:var(--color-default-subtle)}.fill-primary{fill:var(--color-primary)}.fill-primary-emphasis{fill:var(--color-primary-emphasis)}.fill-primary-subtle{fill:var(--color-primary-subtle)}.fill-secondary{fill:var(--color-secondary)}.fill-secondary-emphasis{fill:var(--color-secondary-emphasis)}.fill-secondary-subtle{fill:var(--color-secondary-subtle)}.fill-tertiary{fill:var(--color-tertiary)}.fill-tertiary-emphasis{fill:var(--color-tertiary-emphasis)}.fill-tertiary-subtle{fill:var(--color-tertiary-subtle)}.fill-success{fill:var(--color-success)}.fill-success-emphasis{fill:var(--color-success-emphasis)}.fill-success-subtle{fill:var(--color-success-subtle)}.fill-danger{fill:var(--color-danger)}.fill-danger-emphasis{fill:var(--color-danger-emphasis)}.fill-danger-subtle{fill:var(--color-danger-subtle)}.fill-warning{fill:var(--color-warning)}.fill-warning-emphasis{fill:var(--color-warning-emphasis)}.fill-warning-subtle{fill:var(--color-warning-subtle)}.fill-info{fill:var(--color-info)}.fill-info-emphasis{fill:var(--color-info-emphasis)}.fill-info-subtle{fill:var(--color-info-subtle)}.cursor-alias{cursor:alias}.cursor-auto{cursor:auto}.cursor-context-menu{cursor:context-menu}.cursor-cell{cursor:cell}.cursor-copy{cursor:copy}.cursor-crosshair{cursor:crosshair}.cursor-default{cursor:default}.cursor-grab{cursor:grab}.cursor-grabbing{cursor:grabbing}.cursor-help{cursor:help}.cursor-move{cursor:move}.cursor-none{cursor:none}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.cursor-progress{cursor:progress}.cursor-text{cursor:text}.cursor-wait{cursor:wait}.cursor-zoom-in{cursor:zoom-in}.cursor-zoom-out{cursor:zoom-out}.display-none{display:none}.display-block{display:block}.display-flex{display:flex}.display-grid{display:grid}.display-inline-block{display:inline-block}.display-inline-flex{display:inline-flex}.display-inline-grid{display:inline-grid}.flex-row{flex-direction:row}.flex-row-reverse{flex-direction:row-reverse}.flex-column{flex-direction:column}.flex-column-reverse{flex-direction:column-reverse}.flex-wrap{flex-wrap:wrap}.flex-wrap-reverse{flex-wrap:wrap-reverse}.flex-nowrap{flex-wrap:nowrap}.flex-grow-1{flex-grow:1}.flex-grow-0{flex-grow:0}.flex-shrink-1{flex-shrink:1}.flex-shrink-0{flex-shrink:0}@media (min-width:576px){.flex-row-sm{flex-direction:row}.flex-row-reverse-sm{flex-direction:row-reverse}.flex-column-sm{flex-direction:column}.flex-column-reverse-sm{flex-direction:column-reverse}.flex-wrap-sm{flex-wrap:wrap}.flex-wrap-reverse-sm{flex-wrap:wrap-reverse}.flex-nowrap-sm{flex-wrap:nowrap}}@media (min-width:768px){.flex-row-md{flex-direction:row}.flex-row-reverse-md{flex-direction:row-reverse}.flex-column-md{flex-direction:column}.flex-column-reverse-md{flex-direction:column-reverse}.flex-wrap-md{flex-wrap:wrap}.flex-wrap-reverse-md{flex-wrap:wrap-reverse}.flex-nowrap-md{flex-wrap:nowrap}}@media (min-width:992px){.flex-row-lg{flex-direction:row}.flex-row-reverse-lg{flex-direction:row-reverse}.flex-column-lg{flex-direction:column}.flex-column-reverse-lg{flex-direction:column-reverse}.flex-wrap-lg{flex-wrap:wrap}.flex-wrap-reverse-lg{flex-wrap:wrap-reverse}.flex-nowrap-lg{flex-wrap:nowrap}}@media (min-width:1200px){.flex-row-xl{flex-direction:row}.flex-row-reverse-xl{flex-direction:row-reverse}.flex-column-xl{flex-direction:column}.flex-column-reverse-xl{flex-direction:column-reverse}.flex-wrap-xl{flex-wrap:wrap}.flex-wrap-reverse-xl{flex-wrap:wrap-reverse}.flex-nowrap-xl{flex-wrap:nowrap}}.float-left{_display:inline;float:left}.float-right{_display:inline;float:right}.float-none{float:none}.height-auto{height:auto}.height-0{height:0}.height-xs{height:calc(var(--spacing-unit, 8px)*.25)}.height-sm{height:calc(var(--spacing-unit, 8px)*.5)}.height-md{height:calc(var(--spacing-unit, 8px)*1)}.height-lg{height:calc(var(--spacing-unit, 8px)*2)}.height-xl{height:calc(var(--spacing-unit, 8px)*3)}.height-xxl{height:calc(var(--spacing-unit, 8px)*4)}.height-xxxl{height:calc(var(--spacing-unit, 8px)*5)}.height-2xl{height:calc(var(--spacing-unit, 8px)*6)}.height-2xxl{height:calc(var(--spacing-unit, 8px)*8)}.height-2xxxl{height:calc(var(--spacing-unit, 8px)*10)}.height-10p{height:10%}.height-20p{height:20%}.height-25p{height:25%}.height-30p{height:30%}.height-33p{height:33%}.height-40p{height:40%}.height-50p{height:50%}.height-60p{height:60%}.height-66p{height:66%}.height-70p{height:70%}.height-75p{height:75%}.height-80p{height:80%}.height-90p{height:90%}.height-100p{height:100%}.height-10vh{height:10vh}.height-20vh{height:20vh}.height-25vh{height:25vh}.height-30vh{height:30vh}.height-33vh{height:33vh}.height-40vh{height:40vh}.height-50vh{height:50vh}.height-60vh{height:60vh}.height-66vh{height:66vh}.height-70vh{height:70vh}.height-75vh{height:75vh}.height-80vh{height:80vh}.height-90vh{height:90vh}.height-100vh{height:100vh}.height-1em{height:1em}.height-2em{height:2em}.height-3em{height:3em}.height-4em{height:4em}.height-5em{height:5em}.height-6em{height:6em}.height-7em{height:7em}.height-8em{height:8em}.margin-0,.margin-none{margin:0}.margin-xs{margin:calc(var(--spacing-unit, 8px)*.25)}.margin-sm{margin:calc(var(--spacing-unit, 8px)*.5)}.margin-md{margin:calc(var(--spacing-unit, 8px)*1)}.margin-lg{margin:calc(var(--spacing-unit, 8px)*2)}.margin-xl{margin:calc(var(--spacing-unit, 8px)*3)}.margin-xxl{margin:calc(var(--spacing-unit, 8px)*4)}.margin-xxxl{margin:calc(var(--spacing-unit, 8px)*5)}.margin-2xl{margin:calc(var(--spacing-unit, 8px)*6)}.margin-2xxl{margin:calc(var(--spacing-unit, 8px)*8)}.margin-2xxxl{margin:calc(var(--spacing-unit, 8px)*10)}.margin-1em{margin:1em}.margin-2em{margin:2em}.margin-3em{margin:3em}.margin-4em{margin:4em}.margin-5em{margin:5em}.margin-6em{margin:6em}.margin-7em{margin:7em}.margin-8em{margin:8em}.margin-1rem{margin:1rem}.margin-2rem{margin:2rem}.margin-3rem{margin:3rem}.margin-4rem{margin:4rem}.margin-5rem{margin:5rem}.margin-6rem{margin:6rem}.margin-7rem{margin:7rem}.margin-8rem{margin:8rem}.margin-left-0,.margin-left-none{margin-left:0}.margin-left-xs{margin-left:calc(var(--spacing-unit, 8px)*.25)}.margin-left-sm{margin-left:calc(var(--spacing-unit, 8px)*.5)}.margin-left-md{margin-left:calc(var(--spacing-unit, 8px)*1)}.margin-left-lg{margin-left:calc(var(--spacing-unit, 8px)*2)}.margin-left-xl{margin-left:calc(var(--spacing-unit, 8px)*3)}.margin-left-xxl{margin-left:calc(var(--spacing-unit, 8px)*4)}.margin-left-xxxl{margin-left:calc(var(--spacing-unit, 8px)*5)}.margin-left-2xl{margin-left:calc(var(--spacing-unit, 8px)*6)}.margin-left-2xxl{margin-left:calc(var(--spacing-unit, 8px)*8)}.margin-left-2xxxl{margin-left:calc(var(--spacing-unit, 8px)*10)}.margin-left-1em{margin-left:1em}.margin-left-2em{margin-left:2em}.margin-left-3em{margin-left:3em}.margin-left-4em{margin-left:4em}.margin-left-5em{margin-left:5em}.margin-left-6em{margin-left:6em}.margin-left-7em{margin-left:7em}.margin-left-8em{margin-left:8em}.margin-left-1rem{margin-left:1rem}.margin-left-2rem{margin-left:2rem}.margin-left-3rem{margin-left:3rem}.margin-left-4rem{margin-left:4rem}.margin-left-5rem{margin-left:5rem}.margin-left-6rem{margin-left:6rem}.margin-left-7rem{margin-left:7rem}.margin-left-8rem{margin-left:8rem}.margin-right-0,.margin-right-none{margin-right:0}.margin-right-xs{margin-right:calc(var(--spacing-unit, 8px)*.25)}.margin-right-sm{margin-right:calc(var(--spacing-unit, 8px)*.5)}.margin-right-md{margin-right:calc(var(--spacing-unit, 8px)*1)}.margin-right-lg{margin-right:calc(var(--spacing-unit, 8px)*2)}.margin-right-xl{margin-right:calc(var(--spacing-unit, 8px)*3)}.margin-right-xxl{margin-right:calc(var(--spacing-unit, 8px)*4)}.margin-right-xxxl{margin-right:calc(var(--spacing-unit, 8px)*5)}.margin-right-2xl{margin-right:calc(var(--spacing-unit, 8px)*6)}.margin-right-2xxl{margin-right:calc(var(--spacing-unit, 8px)*8)}.margin-right-2xxxl{margin-right:calc(var(--spacing-unit, 8px)*10)}.margin-right-1em{margin-right:1em}.margin-right-2em{margin-right:2em}.margin-right-3em{margin-right:3em}.margin-right-4em{margin-right:4em}.margin-right-5em{margin-right:5em}.margin-right-6em{margin-right:6em}.margin-right-7em{margin-right:7em}.margin-right-8em{margin-right:8em}.margin-right-1rem{margin-right:1rem}.margin-right-2rem{margin-right:2rem}.margin-right-3rem{margin-right:3rem}.margin-right-4rem{margin-right:4rem}.margin-right-5rem{margin-right:5rem}.margin-right-6rem{margin-right:6rem}.margin-right-7rem{margin-right:7rem}.margin-right-8rem{margin-right:8rem}.margin-top-0,.margin-top-none{margin-top:0}.margin-top-xs{margin-top:calc(var(--spacing-unit, 8px)*.25)}.margin-top-sm{margin-top:calc(var(--spacing-unit, 8px)*.5)}.margin-top-md{margin-top:calc(var(--spacing-unit, 8px)*1)}.margin-top-lg{margin-top:calc(var(--spacing-unit, 8px)*2)}.margin-top-xl{margin-top:calc(var(--spacing-unit, 8px)*3)}.margin-top-xxl{margin-top:calc(var(--spacing-unit, 8px)*4)}.margin-top-xxxl{margin-top:calc(var(--spacing-unit, 8px)*5)}.margin-top-2xl{margin-top:calc(var(--spacing-unit, 8px)*6)}.margin-top-2xxl{margin-top:calc(var(--spacing-unit, 8px)*8)}.margin-top-2xxxl{margin-top:calc(var(--spacing-unit, 8px)*10)}.margin-top-1em{margin-top:1em}.margin-top-2em{margin-top:2em}.margin-top-3em{margin-top:3em}.margin-top-4em{margin-top:4em}.margin-top-5em{margin-top:5em}.margin-top-6em{margin-top:6em}.margin-top-7em{margin-top:7em}.margin-top-8em{margin-top:8em}.margin-top-1rem{margin-top:1rem}.margin-top-2rem{margin-top:2rem}.margin-top-3rem{margin-top:3rem}.margin-top-4rem{margin-top:4rem}.margin-top-5rem{margin-top:5rem}.margin-top-6rem{margin-top:6rem}.margin-top-7rem{margin-top:7rem}.margin-top-8rem{margin-top:8rem}.margin-bottom-0,.margin-bottom-none{margin-bottom:0}.margin-bottom-xs{margin-bottom:calc(var(--spacing-unit, 8px)*.25)}.margin-bottom-sm{margin-bottom:calc(var(--spacing-unit, 8px)*.5)}.margin-bottom-md{margin-bottom:calc(var(--spacing-unit, 8px)*1)}.margin-bottom-lg{margin-bottom:calc(var(--spacing-unit, 8px)*2)}.margin-bottom-xl{margin-bottom:calc(var(--spacing-unit, 8px)*3)}.margin-bottom-xxl{margin-bottom:calc(var(--spacing-unit, 8px)*4)}.margin-bottom-xxxl{margin-bottom:calc(var(--spacing-unit, 8px)*5)}.margin-bottom-2xl{margin-bottom:calc(var(--spacing-unit, 8px)*6)}.margin-bottom-2xxl{margin-bottom:calc(var(--spacing-unit, 8px)*8)}.margin-bottom-2xxxl{margin-bottom:calc(var(--spacing-unit, 8px)*10)}.margin-bottom-1em{margin-bottom:1em}.margin-bottom-2em{margin-bottom:2em}.margin-bottom-3em{margin-bottom:3em}.margin-bottom-4em{margin-bottom:4em}.margin-bottom-5em{margin-bottom:5em}.margin-bottom-6em{margin-bottom:6em}.margin-bottom-7em{margin-bottom:7em}.margin-bottom-8em{margin-bottom:8em}.margin-bottom-1rem{margin-bottom:1rem}.margin-bottom-2rem{margin-bottom:2rem}.margin-bottom-3rem{margin-bottom:3rem}.margin-bottom-4rem{margin-bottom:4rem}.margin-bottom-5rem{margin-bottom:5rem}.margin-bottom-6rem{margin-bottom:6rem}.margin-bottom-7rem{margin-bottom:7rem}.margin-bottom-8rem{margin-bottom:8rem}.opacity-1,.opacity-100p{opacity:1}.opacity-90p{opacity:.9}.opacity-80p{opacity:.8}.opacity-75p{opacity:.75}.opacity-70p{opacity:.7}.opacity-66p{opacity:.66}.opacity-60p{opacity:.6}.opacity-50p{opacity:.5}.opacity-40p{opacity:.4}.opacity-33p{opacity:.33}.opacity-30p{opacity:.3}.opacity-25p{opacity:.25}.opacity-20p{opacity:.2}.opacity-10p{opacity:.1}.opacity-0,.opacity-0p{opacity:0}.opacity-transparent{opacity:var(--opacity-transparent,0)}.opacity-subtle{opacity:var(--opacity-subtle,.12)}.opacity-disabled{opacity:var(--opacity-disabled,.38)}.opacity-inactive{opacity:var(--opacity-inactive,.62)}.opacity-scrim{opacity:var(--opacity-scrim,.54)}.opacity-active{opacity:var(--opacity-active,.87)}.opacity-opaque{opacity:var(--opacity-opaque,1)}.outline{outline:1px solid}.outline-transparent{outline:1px solid transparent}.outline-0{outline:0}.overflow-auto{overflow:auto}.overflow-scroll{overflow:scroll}.overflow-hidden{overflow:hidden}.overflow-visible{overflow:visible}.overflow-x-auto{overflow-x:auto}.overflow-x-scroll{overflow-x:scroll}.overflow-x-hidden{overflow-x:hidden}.overflow-x-visible{overflow-x:visible}.overflow-y-auto{overflow-y:auto}.overflow-y-scroll{overflow-y:scroll}.overflow-y-hidden{overflow-y:hidden}.overflow-y-visible{overflow-y:visible}.padding-0,.padding-none{padding:0}.padding-xs{padding:calc(var(--spacing-unit, 8px)*.25)}.padding-sm{padding:calc(var(--spacing-unit, 8px)*.5)}.padding-md{padding:calc(var(--spacing-unit, 8px)*1)}.padding-lg{padding:calc(var(--spacing-unit, 8px)*2)}.padding-xl{padding:calc(var(--spacing-unit, 8px)*3)}.padding-xxl{padding:calc(var(--spacing-unit, 8px)*4)}.padding-xxxl{padding:calc(var(--spacing-unit, 8px)*5)}.padding-2xl{padding:calc(var(--spacing-unit, 8px)*6)}.padding-2xxl{padding:calc(var(--spacing-unit, 8px)*8)}.padding-2xxxl{padding:calc(var(--spacing-unit, 8px)*10)}.padding-1em{padding:1em}.padding-2em{padding:2em}.padding-3em{padding:3em}.padding-4em{padding:4em}.padding-5em{padding:5em}.padding-6em{padding:6em}.padding-7em{padding:7em}.padding-8em{padding:8em}.padding-1rem{padding:1rem}.padding-2rem{padding:2rem}.padding-3rem{padding:3rem}.padding-4rem{padding:4rem}.padding-5rem{padding:5rem}.padding-6rem{padding:6rem}.padding-7rem{padding:7rem}.padding-8rem{padding:8rem}.padding-left-0,.padding-left-none{padding-left:0}.padding-left-xs{padding-left:calc(var(--spacing-unit, 8px)*.25)}.padding-left-sm{padding-left:calc(var(--spacing-unit, 8px)*.5)}.padding-left-md{padding-left:calc(var(--spacing-unit, 8px)*1)}.padding-left-lg{padding-left:calc(var(--spacing-unit, 8px)*2)}.padding-left-xl{padding-left:calc(var(--spacing-unit, 8px)*3)}.padding-left-xxl{padding-left:calc(var(--spacing-unit, 8px)*4)}.padding-left-xxxl{padding-left:calc(var(--spacing-unit, 8px)*5)}.padding-left-2xl{padding-left:calc(var(--spacing-unit, 8px)*6)}.padding-left-2xxl{padding-left:calc(var(--spacing-unit, 8px)*8)}.padding-left-2xxxl{padding-left:calc(var(--spacing-unit, 8px)*10)}.padding-left-1em{padding-left:1em}.padding-left-2em{padding-left:2em}.padding-left-3em{padding-left:3em}.padding-left-4em{padding-left:4em}.padding-left-5em{padding-left:5em}.padding-left-6em{padding-left:6em}.padding-left-7em{padding-left:7em}.padding-left-8em{padding-left:8em}.padding-left-1rem{padding-left:1rem}.padding-left-2rem{padding-left:2rem}.padding-left-3rem{padding-left:3rem}.padding-left-4rem{padding-left:4rem}.padding-left-5rem{padding-left:5rem}.padding-left-6rem{padding-left:6rem}.padding-left-7rem{padding-left:7rem}.padding-left-8rem{padding-left:8rem}.padding-right-0,.padding-right-none{padding-right:0}.padding-right-xs{padding-right:calc(var(--spacing-unit, 8px)*.25)}.padding-right-sm{padding-right:calc(var(--spacing-unit, 8px)*.5)}.padding-right-md{padding-right:calc(var(--spacing-unit, 8px)*1)}.padding-right-lg{padding-right:calc(var(--spacing-unit, 8px)*2)}.padding-right-xl{padding-right:calc(var(--spacing-unit, 8px)*3)}.padding-right-xxl{padding-right:calc(var(--spacing-unit, 8px)*4)}.padding-right-xxxl{padding-right:calc(var(--spacing-unit, 8px)*5)}.padding-right-2xl{padding-right:calc(var(--spacing-unit, 8px)*6)}.padding-right-2xxl{padding-right:calc(var(--spacing-unit, 8px)*8)}.padding-right-2xxxl{padding-right:calc(var(--spacing-unit, 8px)*10)}.padding-right-1em{padding-right:1em}.padding-right-2em{padding-right:2em}.padding-right-3em{padding-right:3em}.padding-right-4em{padding-right:4em}.padding-right-5em{padding-right:5em}.padding-right-6em{padding-right:6em}.padding-right-7em{padding-right:7em}.padding-right-8em{padding-right:8em}.padding-right-1rem{padding-right:1rem}.padding-right-2rem{padding-right:2rem}.padding-right-3rem{padding-right:3rem}.padding-right-4rem{padding-right:4rem}.padding-right-5rem{padding-right:5rem}.padding-right-6rem{padding-right:6rem}.padding-right-7rem{padding-right:7rem}.padding-right-8rem{padding-right:8rem}.padding-top-0,.padding-top-none{padding-top:0}.padding-top-xs{padding-top:calc(var(--spacing-unit, 8px)*.25)}.padding-top-sm{padding-top:calc(var(--spacing-unit, 8px)*.5)}.padding-top-md{padding-top:calc(var(--spacing-unit, 8px)*1)}.padding-top-lg{padding-top:calc(var(--spacing-unit, 8px)*2)}.padding-top-xl{padding-top:calc(var(--spacing-unit, 8px)*3)}.padding-top-xxl{padding-top:calc(var(--spacing-unit, 8px)*4)}.padding-top-xxxl{padding-top:calc(var(--spacing-unit, 8px)*5)}.padding-top-2xl{padding-top:calc(var(--spacing-unit, 8px)*6)}.padding-top-2xxl{padding-top:calc(var(--spacing-unit, 8px)*8)}.padding-top-2xxxl{padding-top:calc(var(--spacing-unit, 8px)*10)}.padding-top-1em{padding-top:1em}.padding-top-2em{padding-top:2em}.padding-top-3em{padding-top:3em}.padding-top-4em{padding-top:4em}.padding-top-5em{padding-top:5em}.padding-top-6em{padding-top:6em}.padding-top-7em{padding-top:7em}.padding-top-8em{padding-top:8em}.padding-top-1rem{padding-top:1rem}.padding-top-2rem{padding-top:2rem}.padding-top-3rem{padding-top:3rem}.padding-top-4rem{padding-top:4rem}.padding-top-5rem{padding-top:5rem}.padding-top-6rem{padding-top:6rem}.padding-top-7rem{padding-top:7rem}.padding-top-8rem{padding-top:8rem}.padding-bottom-0,.padding-bottom-none{padding-bottom:0}.padding-bottom-xs{padding-bottom:calc(var(--spacing-unit, 8px)*.25)}.padding-bottom-sm{padding-bottom:calc(var(--spacing-unit, 8px)*.5)}.padding-bottom-md{padding-bottom:calc(var(--spacing-unit, 8px)*1)}.padding-bottom-lg{padding-bottom:calc(var(--spacing-unit, 8px)*2)}.padding-bottom-xl{padding-bottom:calc(var(--spacing-unit, 8px)*3)}.padding-bottom-xxl{padding-bottom:calc(var(--spacing-unit, 8px)*4)}.padding-bottom-xxxl{padding-bottom:calc(var(--spacing-unit, 8px)*5)}.padding-bottom-2xl{padding-bottom:calc(var(--spacing-unit, 8px)*6)}.padding-bottom-2xxl{padding-bottom:calc(var(--spacing-unit, 8px)*8)}.padding-bottom-2xxxl{padding-bottom:calc(var(--spacing-unit, 8px)*10)}.padding-bottom-1em{padding-bottom:1em}.padding-bottom-2em{padding-bottom:2em}.padding-bottom-3em{padding-bottom:3em}.padding-bottom-4em{padding-bottom:4em}.padding-bottom-5em{padding-bottom:5em}.padding-bottom-6em{padding-bottom:6em}.padding-bottom-7em{padding-bottom:7em}.padding-bottom-8em{padding-bottom:8em}.padding-bottom-1rem{padding-bottom:1rem}.padding-bottom-2rem{padding-bottom:2rem}.padding-bottom-3rem{padding-bottom:3rem}.padding-bottom-4rem{padding-bottom:4rem}.padding-bottom-5rem{padding-bottom:5rem}.padding-bottom-6rem{padding-bottom:6rem}.padding-bottom-7rem{padding-bottom:7rem}.padding-bottom-8rem{padding-bottom:8rem}.position-static{position:static}.position-relative{position:relative}.position-absolute{position:absolute}.position-fixed{position:fixed}.shadow,.shadow-hover:hover,.shadow-md,.shadow-md-hover:hover{box-shadow:0 .5rem 1rem rgba(var(--rgb-black),10%)}.shadow-xs,.shadow-xs-hover:hover{box-shadow:0 .125rem .25rem rgba(var(--rgb-black),5%)}.shadow-sm,.shadow-sm-hover:hover{box-shadow:0 .25rem .5rem rgba(var(--rgb-black),7.5%)}.shadow-lg,.shadow-lg-hover:hover{box-shadow:0 1rem 3rem rgba(var(--rgb-black),15%)}.shadow-none,.shadow-none-hover:hover{box-shadow:none}.shadow-hover,.shadow-lg-hover,.shadow-md-hover,.shadow-none-hover,.shadow-sm-hover{transition:box-shadow .2s cubic-bezier(.25,.8,.25,1)}.transition.fade-in{opacity:0;transition:opacity .3s,visibility .3s;visibility:hidden}.transition.fade-in.visible,.transition.fade-out{opacity:1;visibility:visible}.transition.fade-out{transition:opacity .3s,visibility .3s}.transition.fade-out.hidden{opacity:0;pointer-events:none;visibility:hidden}.transition.translate-down,.transition.translate-left,.transition.translate-right,.transition.translate-up{transition:transform .3s,visibility .3s}.transition.translate-up.hidden{pointer-events:none;transform:translateY(-100%);visibility:hidden}.transition.translate-down.hidden{pointer-events:none;transform:translateY(100%);visibility:hidden}.transition.translate-left.hidden{pointer-events:none;transform:translateX(-100%);visibility:hidden}.transition.translate-right.hidden{pointer-events:none;transform:translateX(100%);visibility:hidden}.font-weight-100{font-weight:100}.font-weight-200{font-weight:200}.font-weight-300{font-weight:300}.font-weight-400{font-weight:400}.font-weight-500{font-weight:500}.font-weight-600{font-weight:600}.font-weight-700{font-weight:700}.font-weight-800{font-weight:800}.font-weight-900{font-weight:900}.font-weight-thin{font-weight:100}.font-weight-extraLight{font-weight:200}.font-weight-light{font-weight:300}.font-weight-regular{font-weight:400}.font-weight-medium{font-weight:500}.font-weight-semibold{font-weight:600}.font-weight-bold{font-weight:700}.font-weight-extraBold{font-weight:800}.font-weight-black{font-weight:900}.text-nowrap{white-space:nowrap}.text-lowercase{text-transform:lowercase}.text-uppercase{text-transform:uppercase}.text-capitalize{text-transform:capitalize}.text-left{text-align:left}.text-right{text-align:right}.text-center{text-align:center}.text-justify{text-align:justify}.visible{visibility:visible}.hidden,.invisible{visibility:hidden}.whitespace-normal{white-space:normal}.whitespace-nowrap{white-space:nowrap}.whitespace-pre{white-space:pre}.whitespace-pre-line{white-space:pre-line}.whitespace-pre-wrap{white-space:pre-wrap}.width-auto{width:auto}.width-0{width:0}.width-xs{width:calc(var(--spacing-unit, 8px)*.25)}.width-sm{width:calc(var(--spacing-unit, 8px)*.5)}.width-md{width:calc(var(--spacing-unit, 8px)*1)}.width-lg{width:calc(var(--spacing-unit, 8px)*2)}.width-xl{width:calc(var(--spacing-unit, 8px)*3)}.width-xxl{width:calc(var(--spacing-unit, 8px)*4)}.width-xxxl{width:calc(var(--spacing-unit, 8px)*5)}.width-2xl{width:calc(var(--spacing-unit, 8px)*6)}.width-2xxl{width:calc(var(--spacing-unit, 8px)*8)}.width-2xxxl{width:calc(var(--spacing-unit, 8px)*10)}.width-10p{width:10%}.width-20p{width:20%}.width-25p{width:25%}.width-30p{width:30%}.width-33p{width:33%}.width-40p{width:40%}.width-50p{width:50%}.width-60p{width:60%}.width-66p{width:66%}.width-70p{width:70%}.width-75p{width:75%}.width-80p{width:80%}.width-90p{width:90%}.width-100p{width:100%}.width-10vw{width:10vw}.width-20vw{width:20vw}.width-25vw{width:25vw}.width-30vw{width:30vw}.width-33vw{width:33vw}.width-40vw{width:40vw}.width-50vw{width:50vw}.width-60vw{width:60vw}.width-66vw{width:66vw}.width-70vw{width:70vw}.width-75vw{width:75vw}.width-80vw{width:80vw}.width-90vw{width:90vw}.width-100vw{width:100vw}.width-1em{width:1em}.width-2em{width:2em}.width-3em{width:3em}.width-4em{width:4em}.width-5em{width:5em}.width-6em{width:6em}.width-7em{width:7em}.width-8em{width:8em}.wordbreak-normal,.wordbreak-wrap{word-break:normal}.wordbreak-break-all,.wordbreak-nowrap{word-break:break-all}.wordbreak-keep-all{word-break:keep-all}.z-index-0{z-index:0}.z-index-1{z-index:1}.z-index-2{z-index:2}.z-index-3{z-index:3}.z-index-4{z-index:4}.z-index-5{z-index:5}.z-index-6{z-index:6}.z-index-7{z-index:7}.z-index-8{z-index:8}.z-index-9{z-index:9}.z-index-10{z-index:10}.z-index-dropdown{z-index:var(--z-index-dropdown,1000)}.z-index-sticky{z-index:var(--z-index-sticky,1020)}.z-index-fixed{z-index:var(--z-index-fixed,1030)}.z-index-overlay{z-index:var(--z-index-overlay,1040)}.z-index-menu{z-index:var(--z-index-menu,1050)}.z-index-modal{z-index:var(--z-index-modal,1060)}.z-index-popover{z-index:var(--z-index-popover,1070)}.z-index-tooltip{z-index:var(--z-index-tooltip,1080)}.z-index-toast{z-index:var(--z-index-toast,1090)}.z-index-max{z-index:var(--z-index-max,1100)}.debug{outline:1px solid red}.debug>*{outline:1px solid blue}.debug>*>*{outline:1px solid green}.debug>*>*>*{outline:1px solid #f0f}.debug>*>*>*>*{outline:1px solid gold}.debug-grid{background:transparent url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAAICAYAAADED76LAAAAFElEQVR4AWPAC97/9x0eCsAEPgwAVLshdpENIxcAAAAASUVORK5CYII=) repeat 0 0}.debug-grid-16{background:transparent url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAMklEQVR4AWOgCLz/b0epAa6UGuBOqQHOQHLUgFEDnAbcBZ4UGwDOkiCnkIhdgNgNxAYAiYlD+8sEuo8AAAAASUVORK5CYII=) repeat 0 0}.debug-grid-8-solid{background:#fff url(data:image/gif;base64,R0lGODdhCAAIAPEAAADw/wDx/////wAAACwAAAAACAAIAAACDZQvgaeb/lxbAIKA8y0AOw==) repeat 0 0}.debug-grid-16-solid{background:#fff url(data:image/gif;base64,R0lGODdhEAAQAPEAAADw/wDx/xXy/////ywAAAAAEAAQAAACIZyPKckYDQFsb6ZqD85jZ2+BkwiRFKehhqQCQgDHcgwEBQA7) repeat 0 0}html{font-size:1.25rem}body{overflow-x:hidden;overflow-y:scroll}body,html{font-family:Inter,ui-sans-serif,system-ui,sans-serif;letter-spacing:-.0375em;scroll-behavior:smooth}@media (prefers-reduced-motion){body,html{scroll-behavior:auto}}.page>article{padding-bottom:8rem;padding-top:3rem;position:relative}.page#cover{overflow:hidden}.ReactModal__Overlay{z-index:2000!important}.embedded-video:before{background-color:var(--color-surface-1)}.image-gallery__lightbox .ril-image-current.ril__image{border-radius:1rem}.image-gallery__lightbox .ril__navButtonPrev{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='gray' d='M14.71 6.71a.996.996 0 0 0-1.41 0L8.71 11.3a.996.996 0 0 0 0 1.41l4.59 4.59a.996.996 0 1 0 1.41-1.41L10.83 12l3.88-3.88c.39-.39.38-1.03 0-1.41z'/%3E%3C/svg%3E")}.image-gallery__lightbox .ril__navButtonNext{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='gray' d='M9.29 6.71a.996.996 0 0 0 0 1.41L13.17 12l-3.88 3.88a.996.996 0 1 0 1.41 1.41l4.59-4.59a.996.996 0 0 0 0-1.41L10.7 6.7c-.38-.38-1.02-.38-1.41.01z'/%3E%3C/svg%3E")}.image-gallery__lightbox .ril__closeButton{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 72 72'%3E%3Cpath fill='gray' d='M19 15a4 4 0 0 0-2.828 6.828L30.344 36 16.172 50.172a4 4 0 1 0 5.656 5.656L36 41.656l14.172 14.172a4 4 0 1 0 5.656-5.656L41.656 36l14.172-14.172a4 4 0 1 0-5.656-5.656L36 30.344 21.828 16.172A3.99 3.99 0 0 0 19 15z'/%3E%3C/svg%3E")}.image-gallery__lightbox .ril__navButtons{background-size:48px}.image-gallery__lightbox .ril__closeButton{background-size:32px;width:10vw}.image-gallery__lightbox .ril__closeButton,.image-gallery__lightbox .ril__navButtons{opacity:1}@media (hover:hover){.social-nav-links__item:hover{transform:none}.social-nav-links__list:hover .social-nav-links__item{opacity:var(--opacity-disabled,.38)}}.card-3d{pointer-events:none;position:relative;will-change:transform}.card-3d>*{pointer-events:all}.overlay-text{bottom:0;left:0;padding:2vh 2vw;position:fixed;right:0;top:0}.dock{bottom:1.5rem;justify-content:flex-start;left:50vw;position:fixed;transform:translateX(-50%);z-index:2000}.dock,.dock__container{align-items:center;display:flex}.dock__container{background-color:var(--color-surface-0);border-radius:29px;box-shadow:0 0 80px rgba(42,51,70,.2);gap:8px;justify-content:space-evenly;margin:0 6px;max-height:60px;padding:8px}[data-theme=dark] .dock__container,[data-theme=high-contrast] .dock__container{background-color:var(--color-surface-2);box-shadow:none}.dock__section{align-items:center;display:flex;gap:8px;justify-content:space-evenly}.dock__section#gallery{display:none}.dock__section:not(:last-child):after{content:"";display:block;margin:0 4px;pointer-events:none}.dock__divider,.dock__section:not(:last-child):after{background-color:var(--color-border);height:24px;width:1px}.dock__item{align-items:center;background-color:#eeefef;border-radius:100%;display:flex;height:44px;justify-content:center;position:relative;width:44px}[data-theme=dark] .dock__item{background-color:#292e33}[data-theme=high-contrast] .dock__item{background-color:#27292d}.dock__item>a,.dock__item>button{align-items:center;display:flex;height:100%;justify-content:center;overflow:hidden;width:100%}.dock__item>a>i,.dock__item>button>i{fill:rgba(var(--rgb-default),.4);color:rgba(var(--rgb-default),.4)}.dock__tooltip{background-color:var(--color-surface-0);border:1px solid var(--color-border);border-radius:8px;color:var(--color-foreground-muted);font-size:.625rem;font-weight:500;left:50%;letter-spacing:0;opacity:0;padding:3px 8px;pointer-events:none;position:absolute;top:-50%;transform:translateX(-50%) scale(.9);transition:opacity .2s,visibility .4s,transform .2s;visibility:hidden;white-space:nowrap}.dock__item:hover .dock__tooltip{opacity:1;transform:translateX(-50%) scale(1);visibility:visible}@media (max-width:576px){.dock__section#socials{display:none}.page#art+.dock .dock__section#gallery,.page#games+.dock .dock__section#gallery,.page#presentations+.dock .dock__section#gallery,.page#tech+.dock .dock__section#gallery,.page#websites+.dock .dock__section#gallery{display:flex}}.gallery{align-items:center;display:flex;justify-content:space-between;min-height:calc(100vh - var(--header-height, 80px));position:relative;width:100%}.gallery__slides{flex:1 1 80%;margin-bottom:6rem;margin-top:3rem;position:relative}.gallery__button{align-items:center;display:flex;flex:0 0 10%;font-size:64px;height:100%;justify-content:center;min-height:calc(100vh - var(--header-height, 80px));min-width:48px}.gallery__button.left{left:0}.gallery__button.right{right:0}.gallery__button>svg{fill:var(--color-foreground)}.gallery--vertical .gallery__slides{margin-bottom:8rem}.gallery--vertical .slide{align-items:flex-start;flex-direction:column}.gallery--vertical .slide__text-wrapper{margin-left:0;margin-top:2rem;max-width:100%;transition:none;width:100%}.gallery--vertical .slide__text-container{min-width:100%;width:100%}.gallery--vertical .slide__image>img{aspect-ratio:2.35}@media (max-width:767px){.gallery__slides{margin-left:16px;margin-right:16px}}@media (max-width:576px){.gallery__slides{margin-left:auto;margin-right:auto;padding-left:16px;padding-right:16px}.gallery__button{display:none}}.slide{align-items:center;height:100%;width:100%}.slide,.slide__image-wrapper{display:flex;justify-content:center;position:relative}.slide__image{align-items:center;background-color:var(--color-surface-1);border-radius:1rem;box-shadow:0 20px 40px rgba(42,51,70,.2),0 30px 20px -10px rgba(42,51,70,.2);display:inline-flex;justify-content:center;overflow:hidden}[data-theme=dark] .slide__image,[data-theme=high-contrast] .slide__image{box-shadow:none}.slide__image--no-border{background-color:transparent;border:none;box-shadow:none!important}.slide__image>img{object-fit:cover}.slide__text-wrapper{margin-left:3rem;max-width:40%;position:relative;transition:opacity .3s,width .3s,margin-left .3s}.slide__text-container{width:100%}.slide__text-container>.eyebrow{letter-spacing:-.025em;margin-bottom:0;margin-left:2px;text-transform:capitalize}.slide__text-container>.title{font-weight:700;margin-bottom:.5rem}@media (max-width:1365px){.slide__image{border-width:9px}}@media (max-width:767px){.slide__image{border-width:6px}}.shadow-button{box-shadow:0 0 0 1px rgba(14,63,126,.06),0 1px 1px -.5px rgba(42,51,70,.03),0 2px 2px -1px rgba(42,51,70,.04),0 3px 3px -1.5px rgba(42,51,70,.04),0 5px 5px -2.5px rgba(42,51,70,.03),0 10px 10px -5px rgba(42,51,70,.03),0 24px 24px -8px rgba(42,51,70,.03);color:var(--color-default);font-size:16px;font-weight:600;transform:scale(1);transition:transform .2s,box-shadow .2s}.shadow-button,.shadow-button:not(:disabled):active,.shadow-button:not(:disabled):hover{background-color:var(--color-background)}@media (hover:hover){.shadow-button:not(:disabled):hover{box-shadow:0 0 0 1px rgba(14,63,126,.06),0 1px 1px -.5px rgba(42,51,70,.03),0 2px 2px -1px rgba(42,51,70,.04),0 3px 3px -1.5px rgba(42,51,70,.04),0 5px 5px -2.5px rgba(42,51,70,.03),0 10px 10px -5px rgba(42,51,70,.03),0 24px 24px -8px rgba(42,51,70,.03),0 4px 10px rgba(42,51,70,.06);transform:translateY(-2px)}.shadow-button:not(.btn--unstyled):not(:disabled):active{transform:translateY(-2px) scale(1.04)}}[data-theme=dark] .shadow-button,[data-theme=high-contrast] .shadow-button{background-color:var(--color-surface-9);box-shadow:none}[data-theme=dark] .shadow-button:not(:disabled):active,[data-theme=dark] .shadow-button:not(:disabled):hover,[data-theme=high-contrast] .shadow-button:not(:disabled):active,[data-theme=high-contrast] .shadow-button:not(:disabled):hover{background-color:var(--color-surface-8);box-shadow:none}.grid-3d{display:grid;grid-template-columns:repeat(30,1fr);grid-template-rows:repeat(30,1fr);left:50%;opacity:.87;position:fixed;top:50%;transform:translate(-50%,-50%) rotate(-30deg) skew(30deg) scaleY(cos(30deg));transform-style:preserve-3d}.grid-3d__cell{border:1px solid var(--color-surface-2);display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr);height:80px;position:relative;width:80px}.grid-3d__cell:hover{background-color:var(--color-surface-2)}.header{align-items:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background-color:rgba(240,242,245,.8);border-bottom:1px solid var(--color-border);display:flex;height:var(--header-height,80px);justify-content:space-between;overflow-x:hidden;position:sticky;top:0;width:100%;z-index:var(--z-index-max,1100)}[data-theme=dark] .header{background-color:rgba(25,29,35,.8)}[data-theme=high-contrast] .header{background-color:rgba(22,24,28,.8)}.header__container{align-items:center;display:flex;justify-content:space-between}.header .navbar{margin-left:16px;margin-right:16px}.header .navbar li{margin:0 3px;padding:0}.header .navbar li a{border:none;color:inherit;font-size:.875rem;font-weight:600;letter-spacing:-.025em;opacity:var(--opacity-inactive,.62);transition:color .2s,background-color .2s,opacity .2s,transform .2s;white-space:nowrap}.header .navbar li a.active,.header .navbar li a:hover{background-color:var(--color-default-subtle);opacity:1}.header__title-button{border:none;color:inherit;display:none;font-size:1.125rem;font-weight:700;letter-spacing:-.025em;margin-top:2px;padding:12px;transition:background-color .2s,transform .2s;white-space:nowrap}.header__title-button .icon-wrapper .icon{font-size:21px}.header__menu-button svg{fill:var(--color-foreground)}@media (min-width:576px){.header__container{padding-left:32px;padding-right:32px}}@media (max-width:424px){.header .social-nav-links{display:none}}@media (max-width:852px){.header .navbar{display:none}.header__title-button{display:block}}.ag-logo,.ag-logo svg{position:relative}.ag-logo svg{height:100%;padding:2px;width:100%}.ag-logo svg polygon{fill:var(--color-white,#fff)}.ag-logo__background{background-color:var(--color-default);border-radius:6px;bottom:0;left:0;position:absolute;right:0;top:0;transition:border-radius .6s ease-in-out,transform .4s ease-out}.ag-logo:hover .ag-logo__background{border-radius:50%;transform:rotate(90deg) scale(1.05)}.ag-logo--rounded .ag-logo__background{border-radius:50%}[data-theme=dark] .ag-logo__background,[data-theme=high-contrast] .ag-logo__background{background-color:var(--color-background)}.floating-logo{bottom:1.5rem;left:1.5rem;position:fixed;z-index:2000}.menu-gallery{background-color:var(--color-background);bottom:0;left:0;overflow-x:hidden;overflow-y:auto;position:fixed;right:0;top:0;z-index:var(--z-index-fixed,1030)}.menu-gallery.open{pointer-events:all;visibility:visible}.menu-gallery.closed{pointer-events:none;visibility:hidden}.menu-gallery__container{padding-bottom:4rem;padding-top:2rem;position:relative;top:var(--header-height,80px)}.menu-gallery__list{font-size:2rem;font-weight:600;line-height:1.25;list-style:none;margin-block-end:0;margin-block-start:0;margin-inline-end:0;margin-inline-start:0;padding-inline-start:0;position:relative;text-align:left;white-space:nowrap}.menu-gallery__section>a{align-items:center;color:inherit;display:flex;font-weight:700;justify-content:flex-start;margin-bottom:.25em;width:100%}.menu-gallery__section>a .icon{font-weight:600}.menu-gallery__grid{column-gap:.5rem;display:grid;grid-template-columns:repeat(2,1fr);margin-bottom:2rem;row-gap:.5rem}.menu-gallery__thumbnail{align-items:center;background-color:var(--color-surface-1);border-radius:.25rem;display:flex;height:max-content;overflow:hidden;position:relative}@media (min-width:576px){.menu-gallery__container{padding-left:32px;padding-right:32px}.menu-gallery__list{font-size:2.5rem}.menu-gallery__grid{column-gap:.75rem;grid-template-columns:repeat(3,1fr);row-gap:.75rem}.menu-gallery__thumbnail{border-radius:.4rem}}@media (min-width:1024px){.menu-gallery__list{font-size:3rem}.menu-gallery__grid{grid-template-columns:repeat(4,1fr)}}@media (min-width:1366px){.menu-gallery__grid{grid-template-columns:repeat(5,1fr)}}@media (min-width:1440px){.menu-gallery__grid{grid-template-columns:repeat(6,1fr)}}.project.container-md{max-width:720px;width:100%}.project__title{text-wrap:balance;font-weight:700;line-height:1;margin-bottom:.5rem}.project__subtitle{color:var(--color-foreground-muted,inherit);font-size:.875rem;font-weight:600;letter-spacing:-.025em;margin-bottom:.75rem;margin-left:4px;text-transform:capitalize}.project__subtitle .separator{margin:0 .5rem;opacity:var(--opacity-inactive,.62)}.project__subtitle+.btn-group{width:100%}.project__description{margin-top:1.5rem}.project__badges{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-start}.project__badges .badge{background-color:var(--color-primary-subtle);border:none;color:var(--color-primary);font-size:.75em;font-weight:600;margin:0}.project section{margin-bottom:2rem;margin-top:2rem}.project section:first-child{margin-top:0}.project section:last-child{margin-bottom:0}.project section>.embedded-video,.project section>.progressive-image>img,.project section>a>.progressive-image>img{border-radius:.5rem;box-shadow:0 0 40px rgba(42,51,70,.2)}.project img{max-width:100%}.project .image-link,.project .image-link img{display:block}.project .image-gallery{margin-bottom:12px;margin-top:12px}.project .image-gallery__thumbnails{column-gap:12px;row-gap:12px}.project .image-gallery__thumbnails img{border-radius:.25rem;box-shadow:0 0 0 1px rgba(14,63,126,.06),0 1px 1px -.5px rgba(42,51,70,.03),0 2px 2px -1px rgba(42,51,70,.04),0 3px 3px -1.5px rgba(42,51,70,.04),0 5px 5px -2.5px rgba(42,51,70,.03),0 10px 10px -5px rgba(42,51,70,.03),0 24px 24px -8px rgba(42,51,70,.03)}[data-theme=dark] .project .image-gallery__thumbnails img,[data-theme=dark] .project section>.embedded-video,[data-theme=dark] .project section>.progressive-image>img,[data-theme=dark] .project section>a>.progressive-image>img,[data-theme=high-contrast] .project .image-gallery__thumbnails img,[data-theme=high-contrast] .project section>.embedded-video,[data-theme=high-contrast] .project section>.progressive-image>img,[data-theme=high-contrast] .project section>a>.progressive-image>img{box-shadow:none}@media (max-width:1024px){.project{padding-bottom:144px}}@media (max-width:767px){.project section{margin-bottom:1rem;margin-top:1rem}}@media (max-width:576px){.project__title{font-size:3rem}}@media (max-width:480px){.project__title{font-size:2.5rem}}.vignette{box-shadow:inset 0 0 200px 2vw var(--color-background);height:100vh;left:0;pointer-events:none;position:fixed;top:0;width:100vw}.projects-list{font-size:.75rem;max-width:962px;min-height:105vh;overflow-x:hidden;width:100%}.projects-list__header{margin-bottom:2.5rem}.projects-list__header>h1{font-weight:700;margin-bottom:.5rem}.projects-list__filters{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-start;width:100%}.projects-list__filters .badge{background-color:var(--color-primary-subtle);border:none;color:var(--color-primary);font-size:.875em;font-weight:600}.projects-list__filters .badge--selected,.projects-list__filters .badge:hover{background-color:var(--color-primary);color:var(--color-on-primary)}.projects-list__category{margin-bottom:2rem;margin-top:0;transition:margin .4s,opacity .2s,visibility .4s}.projects-list__category--empty{margin-bottom:0;margin-top:0;opacity:0;pointer-events:none;visibility:hidden}.projects-list__category:last-child{margin-bottom:0}.projects-list__category>h2{font-weight:700;height:24px;margin-bottom:0;padding-left:2px;transition:height .4s}.projects-list__category--empty>h2{height:0}.projects-list__category>ul{list-style:none;margin-block-end:.5rem;margin-block-start:.5rem;margin-inline-end:0;margin-inline-start:0;padding-inline-start:0;transition:margin-block-start .4s,margin-block-end .4s;white-space:nowrap;width:100%}.projects-list__category--empty>ul{margin-block-end:0;margin-block-start:0}.projects-list__item{align-items:center;border-radius:16px;display:flex;height:48px;justify-content:center;transition:height .4s,opacity .2s,visibility .4s;width:100%}.projects-list__item:hover{background-color:var(--color-surface-2)}.projects-list__item--hidden{height:0;opacity:0;pointer-events:none;visibility:hidden}.projects-list__item>a{align-items:center;display:flex;justify-content:space-between;padding:12px;width:100%}.projects-list__text{flex-grow:0;flex-shrink:0;min-height:24px}.projects-list__title{font-weight:600;margin-right:8px}.projects-list__description{color:var(--color-foreground-subtle);display:none}.projects-list__line{flex:1 1 100%;margin:0 .5rem}.projects-list__date{color:var(--color-foreground-subtle);flex-grow:0;flex-shrink:0}@media (min-width:700px){.projects-list__description{display:inline-block}} \ No newline at end of file diff --git a/styles.798d7058577ffdad1e42.css b/styles.798d7058577ffdad1e42.css deleted file mode 100644 index 6d988a7..0000000 --- a/styles.798d7058577ffdad1e42.css +++ /dev/null @@ -1,2 +0,0 @@ -@import url(https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&display=swap);@import url(https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;700&display=swap);@keyframes closeWindow{0%{opacity:1}to{opacity:0}}.ril__outer{-ms-content-zooming:none;-ms-touch-select:none;background-color:rgba(0,0,0,.85);bottom:0;height:100%;left:0;outline:none;right:0;top:0;touch-action:none;-ms-user-select:none;width:100%;z-index:1000}.ril__outerClosing{opacity:0}.ril__image,.ril__imageNext,.ril__imagePrev,.ril__inner{bottom:0;left:0;position:absolute;right:0;top:0}.ril__image,.ril__imageNext,.ril__imagePrev{-ms-content-zooming:none;-ms-touch-select:none;margin:auto;max-width:none;touch-action:none;-ms-user-select:none}.ril__imageDiscourager{background-position:50%;background-repeat:no-repeat;background-size:contain}.ril__navButtons{border:none;bottom:0;cursor:pointer;height:34px;margin:auto;opacity:.7;padding:40px 30px;position:absolute;top:0;width:20px}.ril__navButtons:hover{opacity:1}.ril__navButtons:active{opacity:.7}.ril__navButtonPrev{background:rgba(0,0,0,.2) url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIzNCI+PHBhdGggZmlsbD0iI0ZGRiIgZD0ibTE5IDMtMi0yTDEgMTdsMTYgMTYgMS0xTDMgMTcgMTggMnoiLz48L3N2Zz4=") no-repeat 50%;left:0}.ril__navButtonNext{background:rgba(0,0,0,.2) url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIzNCI+PHBhdGggZmlsbD0iI0ZGRiIgZD0ibTEgMyAyLTIgMTYgMTZMMyAzM2wtMS0xIDE1LTE1TDIgMnoiLz48L3N2Zz4=") no-repeat 50%;right:0}.ril__downloadBlocker{background-image:url("data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7");background-size:cover;bottom:0;left:0;position:absolute;right:0;top:0}.ril__caption,.ril__toolbar{background-color:rgba(0,0,0,.5);display:flex;justify-content:space-between;left:0;position:absolute;right:0}.ril__caption{bottom:0;max-height:150px;overflow:auto}.ril__captionContent{color:#fff;padding:10px 20px}.ril__toolbar{height:50px;top:0}.ril__toolbarSide{height:50px;margin:0}.ril__toolbarLeftSide{flex:0 1 auto;overflow:hidden;padding-left:20px;padding-right:0;text-overflow:ellipsis}.ril__toolbarRightSide{flex:0 0 auto;padding-left:0;padding-right:20px}.ril__toolbarItem{color:#fff;display:inline-block;font-size:120%;line-height:50px;max-width:100%;overflow:hidden;padding:0;text-overflow:ellipsis;white-space:nowrap}.ril__toolbarItemChild{vertical-align:middle}.ril__builtinButton{border:none;cursor:pointer;height:35px;opacity:.7;width:40px}.ril__builtinButton:hover{opacity:1}.ril__builtinButton:active{outline:none}.ril__builtinButtonDisabled{cursor:default;opacity:.5}.ril__builtinButtonDisabled:hover{opacity:.5}.ril__closeButton{background:url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCI+PHBhdGggZmlsbD0iI0ZGRiIgZD0ibTEgMyAxLjI1LTEuMjUgNy41IDcuNSA3LjUtNy41TDE4LjUgMyAxMSAxMC41bDcuNSA3LjUtMS4yNSAxLjI1LTcuNS03LjUtNy41IDcuNUwxIDE4bDcuNS03LjVMMSAzeiIvPjwvc3ZnPg==") no-repeat 50%}.ril__zoomInButton{background:url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCI+PGcgc3Ryb2tlPSIjZmZmIiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS13aWR0aD0iMiI+PHBhdGggZD0ibTEgMTkgNi02TTkgOGg2TTEyIDV2NiIvPjwvZz48Y2lyY2xlIGN4PSIxMiIgY3k9IjgiIHI9IjciIGZpbGw9Im5vbmUiIHN0cm9rZT0iI2ZmZiIgc3Ryb2tlLXdpZHRoPSIyIi8+PC9zdmc+") no-repeat 50%}.ril__zoomOutButton{background:url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCI+PGcgc3Ryb2tlPSIjZmZmIiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS13aWR0aD0iMiI+PHBhdGggZD0ibTEgMTkgNi02TTkgOGg2Ii8+PC9nPjxjaXJjbGUgY3g9IjEyIiBjeT0iOCIgcj0iNyIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjZmZmIiBzdHJva2Utd2lkdGg9IjIiLz48L3N2Zz4=") no-repeat 50%}.ril__outerAnimating{animation-name:closeWindow}@keyframes pointFade{0%,19.999%,to{opacity:0}20%{opacity:1}}.ril__loadingCircle{height:60px;position:relative;width:60px}.ril__loadingCirclePoint{height:100%;left:0;position:absolute;top:0;width:100%}.ril__loadingCirclePoint:before{animation:pointFade .8s ease-in-out infinite both;background-color:#fff;border-radius:30%;content:"";display:block;height:30%;margin:0 auto;width:11%}.ril__loadingCirclePoint:first-of-type{transform:rotate(0deg)}.ril__loadingCirclePoint:first-of-type:before,.ril__loadingCirclePoint:nth-of-type(7):before{animation-delay:-.8s}.ril__loadingCirclePoint:nth-of-type(2){transform:rotate(30deg)}.ril__loadingCirclePoint:nth-of-type(8){transform:rotate(210deg)}.ril__loadingCirclePoint:nth-of-type(2):before,.ril__loadingCirclePoint:nth-of-type(8):before{animation-delay:-666ms}.ril__loadingCirclePoint:nth-of-type(3){transform:rotate(60deg)}.ril__loadingCirclePoint:nth-of-type(9){transform:rotate(240deg)}.ril__loadingCirclePoint:nth-of-type(3):before,.ril__loadingCirclePoint:nth-of-type(9):before{animation-delay:-533ms}.ril__loadingCirclePoint:nth-of-type(4){transform:rotate(90deg)}.ril__loadingCirclePoint:nth-of-type(10){transform:rotate(270deg)}.ril__loadingCirclePoint:nth-of-type(10):before,.ril__loadingCirclePoint:nth-of-type(4):before{animation-delay:-.4s}.ril__loadingCirclePoint:nth-of-type(5){transform:rotate(120deg)}.ril__loadingCirclePoint:nth-of-type(11){transform:rotate(300deg)}.ril__loadingCirclePoint:nth-of-type(11):before,.ril__loadingCirclePoint:nth-of-type(5):before{animation-delay:-266ms}.ril__loadingCirclePoint:nth-of-type(6){transform:rotate(150deg)}.ril__loadingCirclePoint:nth-of-type(12){transform:rotate(330deg)}.ril__loadingCirclePoint:nth-of-type(12):before,.ril__loadingCirclePoint:nth-of-type(6):before{animation-delay:-133ms}.ril__loadingCirclePoint:nth-of-type(7){transform:rotate(180deg)}.ril__loadingCirclePoint:nth-of-type(13){transform:rotate(1turn)}.ril__loadingCirclePoint:nth-of-type(13):before,.ril__loadingCirclePoint:nth-of-type(7):before{animation-delay:0ms}.ril__loadingContainer{bottom:0;left:0;position:absolute;right:0;top:0}.ril__imageNext .ril__loadingContainer,.ril__imagePrev .ril__loadingContainer{display:none}.ril__errorContainer{align-items:center;bottom:0;color:#fff;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0}.ril__imageNext .ril__errorContainer,.ril__imagePrev .ril__errorContainer{display:none}.ril__loadingContainer__icon{color:#fff;left:50%;position:absolute;top:50%;transform:translateX(-50%) translateY(-50%)}:root{--spacing-unit:8px;--color-inherit:inherit;--color-transparent:transparent;--color-black:#1f2328;--color-white:#fff;--color-foreground:#1f2328;--color-foreground-muted:#656d76;--color-foreground-subtle:#6e7781;--color-background:#fff;--color-surface-0:#fff;--color-surface-1:#f5f7fa;--color-surface-2:#f0f2f5;--color-surface-3:#ebedf0;--color-surface-4:#e6eaed;--color-surface-5:#e4e7eb;--color-surface-6:#e1e5e8;--color-surface-7:#dce1e6;--color-surface-8:#dadee3;--color-surface-9:#d7dce0;--color-border:#d0d7de;--color-default:#282e34;--color-default-emphasis:#24292f;--color-default-subtle:rgba(var(--rgb-default),var(--opacity-subtle));--color-primary:#0969da;--color-primary-emphasis:#0550ae;--color-primary-subtle:rgba(var(--rgb-primary),var(--opacity-subtle));--color-secondary:#282e34;--color-secondary-emphasis:#24292f;--color-secondary-subtle:rgba(var(--rgb-secondary),var(--opacity-subtle));--color-tertiary:#282e34;--color-tertiary-emphasis:#24292f;--color-tertiary-subtle:rgba(var(--rgb-tertiary),var(--opacity-subtle));--color-success:#198754;--color-success-emphasis:#146c43;--color-success-subtle:rgba(var(--rgb-success),var(--opacity-subtle));--color-danger:#dc3545;--color-danger-emphasis:#b02a37;--color-danger-subtle:rgba(var(--rgb-danger),var(--opacity-subtle));--color-warning:#ffc107;--color-warning-emphasis:#ffcd39;--color-warning-subtle:rgba(var(--rgb-warning),var(--opacity-subtle));--color-info:#0dcaf0;--color-info-emphasis:#3dd5f3;--color-info-subtle:rgba(var(--rgb-info),var(--opacity-subtle));--color-on-default:var(--color-white,#fff);--color-on-primary:var(--color-white,#fff);--color-on-secondary:var(--color-white,#fff);--color-on-tertiary:var(--color-white,#fff);--color-on-success:var(--color-white,#fff);--color-on-danger:var(--color-white,#fff);--color-on-warning:var(--color-black,#000);--color-on-info:var(--color-black,#000);--color-syntax-comment:#57606a;--color-syntax-constant:#99286e;--color-syntax-diff-changed-text:#953800;--color-syntax-diff-changed-bg:#ffd8b5;--color-syntax-diff-deleted-text:#82071e;--color-syntax-diff-deleted-bg:#ffebe9;--color-syntax-diff-ignored-text:#0550ae;--color-syntax-diff-ignored-bg:#eaeef2;--color-syntax-diff-inserted-text:#116329;--color-syntax-diff-inserted-bg:#dafbe1;--color-syntax-entity:#0550ae;--color-syntax-function:#6639ba;--color-syntax-keyword:#cf222e;--color-syntax-property:#116329;--color-syntax-string:#0a3069;--rgb-black:31,35,40;--rgb-white:255,255,255;--rgb-default:40,46,52;--rgb-primary:9,105,218;--rgb-secondary:40,46,52;--rgb-tertiary:40,46,52;--rgb-success:25,135,84;--rgb-danger:220,53,69;--rgb-warning:255,193,7;--rgb-info:13,202,240;--opacity-inactive:0.62;--opacity-disabled:0.38;--opacity-subtle:0.12;--opacity-scrim:0.54;--z-index-dropdown:1000;--z-index-sticky:1020;--z-index-fixed:1030;--z-index-overlay:1040;--z-index-menu:1050;--z-index-modal:1060;--z-index-popover:1070;--z-index-tooltip:1080;--z-index-toast:1090;--z-index-max:1100;--breakpoint-sm:576px;--breakpoint-md:768px;--breakpoint-lg:992px;--breakpoint-xl:1200px}[data-theme=light],[data-theme=light] *{--color-black:#1f2328;--color-white:#fff;--color-foreground:#1f2328;--color-foreground-muted:#656d76;--color-foreground-subtle:#6e7781;--color-background:#fff;--color-surface-0:#fff;--color-surface-1:#f5f7fa;--color-surface-2:#f0f2f5;--color-surface-3:#ebedf0;--color-surface-4:#e6eaed;--color-surface-5:#e4e7eb;--color-surface-6:#e1e5e8;--color-surface-7:#dce1e6;--color-surface-8:#dadee3;--color-surface-9:#d7dce0;--color-border:#d0d7de;--color-default:#282e34;--color-default-emphasis:#24292f;--color-default-subtle:rgba(var(--rgb-default),var(--opacity-subtle));--color-primary:#0969da;--color-primary-emphasis:#0550ae;--color-primary-subtle:rgba(var(--rgb-primary),var(--opacity-subtle));--color-secondary:#282e34;--color-secondary-emphasis:#24292f;--color-secondary-subtle:rgba(var(--rgb-secondary),var(--opacity-subtle));--color-tertiary:#282e34;--color-tertiary-emphasis:#24292f;--color-tertiary-subtle:rgba(var(--rgb-tertiary),var(--opacity-subtle));--color-success:#198754;--color-success-emphasis:#146c43;--color-success-subtle:rgba(var(--rgb-success),var(--opacity-subtle));--color-danger:#dc3545;--color-danger-emphasis:#b02a37;--color-danger-subtle:rgba(var(--rgb-danger),var(--opacity-subtle));--color-warning:#ffc107;--color-warning-emphasis:#ffcd39;--color-warning-subtle:rgba(var(--rgb-warning),var(--opacity-subtle));--color-info:#0dcaf0;--color-info-emphasis:#3dd5f3;--color-info-subtle:rgba(var(--rgb-info),var(--opacity-subtle));--color-on-default:var(--color-white,#fff);--color-on-primary:var(--color-white,#fff);--color-on-secondary:var(--color-white,#fff);--color-on-tertiary:var(--color-white,#fff);--color-on-success:var(--color-white,#fff);--color-on-danger:var(--color-white,#fff);--color-on-warning:var(--color-black,#000);--color-on-info:var(--color-black,#000);--color-syntax-comment:#57606a;--color-syntax-constant:#99286e;--color-syntax-diff-changed-text:#953800;--color-syntax-diff-changed-bg:#ffd8b5;--color-syntax-diff-deleted-text:#82071e;--color-syntax-diff-deleted-bg:#ffebe9;--color-syntax-diff-ignored-text:#0550ae;--color-syntax-diff-ignored-bg:#eaeef2;--color-syntax-diff-inserted-text:#116329;--color-syntax-diff-inserted-bg:#dafbe1;--color-syntax-entity:#0550ae;--color-syntax-function:#6639ba;--color-syntax-keyword:#cf222e;--color-syntax-property:#116329;--color-syntax-string:#0a3069;--rgb-black:31,35,40;--rgb-white:255,255,255;--rgb-default:40,46,52;--rgb-primary:9,105,218;--rgb-secondary:40,46,52;--rgb-tertiary:40,46,52;--rgb-success:25,135,84;--rgb-danger:220,53,69;--rgb-warning:255,193,7;--rgb-info:13,202,240;color-scheme:light}[data-theme=dark],[data-theme=dark] *{--color-black:#010409;--color-white:#fff;--color-foreground:#e6edf3;--color-foreground-muted:#7d8590;--color-foreground-subtle:#6e7681;--color-background:#0d1117;--color-surface-0:#0d1117;--color-surface-1:#11151b;--color-surface-2:#191d23;--color-surface-3:#1d2127;--color-surface-4:#21262c;--color-surface-5:#262a30;--color-surface-6:#292d33;--color-surface-7:#2d3137;--color-surface-8:#2f3339;--color-surface-9:#31363c;--color-border:#30363d;--color-default:#e6edf3;--color-default-emphasis:#fff;--color-default-subtle:rgba(var(--rgb-default),var(--opacity-subtle));--color-primary:#2f81f7;--color-primary-emphasis:#1f6feb;--color-primary-subtle:rgba(var(--rgb-primary),var(--opacity-subtle));--color-secondary:#e6edf3;--color-secondary-emphasis:#fff;--color-secondary-subtle:rgba(var(--rgb-secondary),var(--opacity-subtle));--color-tertiary:#e6edf3;--color-tertiary-emphasis:#fff;--color-tertiary-subtle:rgba(var(--rgb-tertiary),var(--opacity-subtle));--color-success:#198754;--color-success-emphasis:#146c43;--color-success-subtle:rgba(var(--rgb-success),var(--opacity-subtle));--color-danger:#dc3545;--color-danger-emphasis:#b02a37;--color-danger-subtle:rgba(var(--rgb-danger),var(--opacity-subtle));--color-warning:#ffcd39;--color-warning-emphasis:#ffc107;--color-warning-subtle:rgba(var(--rgb-warning),var(--opacity-subtle));--color-info:#3dd5f3;--color-info-emphasis:#0dcaf0;--color-info-subtle:rgba(var(--rgb-info),var(--opacity-subtle));--color-on-default:var(--color-black,#000);--color-on-primary:var(--color-white,#fff);--color-on-secondary:var(--color-black,#000);--color-on-tertiary:var(--color-black,#000);--color-on-success:var(--color-white,#fff);--color-on-danger:var(--color-white,#fff);--color-on-warning:var(--color-black,#000);--color-on-info:var(--color-black,#000);--color-syntax-comment:#8b949e;--color-syntax-constant:#ff9bce;--color-syntax-diff-changed-text:#ffdfb6;--color-syntax-diff-changed-bg:#5a1e02;--color-syntax-diff-deleted-text:#ffdcd7;--color-syntax-diff-deleted-bg:#67060c;--color-syntax-diff-ignored-text:#c9d1d9;--color-syntax-diff-ignored-bg:#1158c7;--color-syntax-diff-inserted-text:#aff5b4;--color-syntax-diff-inserted-bg:#033a16;--color-syntax-entity:#79c0ff;--color-syntax-function:#d2a8ff;--color-syntax-keyword:#ff7b72;--color-syntax-property:#7ee787;--color-syntax-string:#a5d6ff;--rgb-black:1,4,9;--rgb-white:255,255,255;--rgb-default:230,237,243;--rgb-primary:47,129,247;--rgb-secondary:230,237,243;--rgb-tertiary:230,237,243;--rgb-success:25,135,84;--rgb-danger:220,53,69;--rgb-warning:255,205,57;--rgb-info:61,213,243;color-scheme:dark}[data-theme=high-contrast],[data-theme=high-contrast] *{--color-black:#010409;--color-white:#fff;--color-foreground:#f0f3f6;--color-foreground-muted:#f0f3f6;--color-foreground-subtle:#9ea7b3;--color-background:#0a0c10;--color-surface-0:#0a0c10;--color-surface-1:#0f1115;--color-surface-2:#16181c;--color-surface-3:#1a1c20;--color-surface-4:#1f2125;--color-surface-5:#232529;--color-surface-6:#26282c;--color-surface-7:#2a2d30;--color-surface-8:#2c2e32;--color-surface-9:#2f3135;--color-border:#7a828e;--color-default:#f0f3f6;--color-default-emphasis:#fff;--color-default-subtle:rgba(var(--rgb-default),var(--opacity-subtle));--color-primary:#409eff;--color-primary-emphasis:#318bf8;--color-primary-subtle:rgba(var(--rgb-primary),var(--opacity-subtle));--color-secondary:#f0f3f6;--color-secondary-emphasis:#fff;--color-secondary-subtle:rgba(var(--rgb-secondary),var(--opacity-subtle));--color-tertiary:#f0f3f6;--color-tertiary-emphasis:#fff;--color-tertiary-subtle:rgba(var(--rgb-tertiary),var(--opacity-subtle));--color-success:#479f76;--color-success-emphasis:#198754;--color-success-subtle:rgba(var(--rgb-success),var(--opacity-subtle));--color-danger:#e35d6a;--color-danger-emphasis:#dc3545;--color-danger-subtle:rgba(var(--rgb-danger),var(--opacity-subtle));--color-warning:#ffda6a;--color-warning-emphasis:#ffcd39;--color-warning-subtle:rgba(var(--rgb-warning),var(--opacity-subtle));--color-info:#6edff6;--color-info-emphasis:#3dd5f3;--color-info-subtle:rgba(var(--rgb-info),var(--opacity-subtle));--color-on-default:var(--color-black,#000);--color-on-primary:var(--color-black,#000);--color-on-secondary:var(--color-black,#000);--color-on-tertiary:var(--color-black,#000);--color-on-success:var(--color-black,#000);--color-on-danger:var(--color-black,#000);--color-on-warning:var(--color-black,#000);--color-on-info:var(--color-black,#000);--color-syntax-comment:#9ea7b3;--color-syntax-constant:#ffadd4;--color-syntax-diff-changed-text:#ffe1b4;--color-syntax-diff-changed-bg:#a74c00;--color-syntax-diff-deleted-text:#ffdedb;--color-syntax-diff-deleted-bg:#cc1421;--color-syntax-diff-ignored-text:#f0f3f6;--color-syntax-diff-ignored-bg:#318bf8;--color-syntax-diff-inserted-text:#acf7b6;--color-syntax-diff-inserted-bg:#007728;--color-syntax-entity:#91cbff;--color-syntax-function:#dbb7ff;--color-syntax-keyword:#ff9492;--color-syntax-property:#72f088;--color-syntax-string:#addcff;--rgb-black:1,4,9;--rgb-white:255,255,255;--rgb-default:240,243,246;--rgb-primary:64,158,255;--rgb-secondary:240,243,246;--rgb-tertiary:240,243,246;--rgb-success:71,159,118;--rgb-danger:227,93,106;--rgb-warning:255,218,106;--rgb-info:110,223,246;color-scheme:dark}[data-theme]{background-color:var(--color-background);color:var(--color-foreground,inherit)} -/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */html{-webkit-text-size-adjust:100%;line-height:1.15}body{margin:0}main{display:block}h1{font-size:2em;margin:.67em 0}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace,monospace;font-size:1em}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring,button:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:.35em .75em .625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{vertical-align:baseline}textarea{overflow:auto}[type=checkbox],[type=radio]{box-sizing:border-box;padding:0}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details{display:block}summary{display:list-item}[hidden],template{display:none}.clearfix:after,.clearfix:before{content:"";display:table}.clearfix:after{clear:both}.clear-left{clear:left}.clear-right{clear:right}.clear-both{clear:both}.clear-none{clear:none}html{box-sizing:border-box}*,:after,:before{box-sizing:inherit}body,html{height:100%}[id=root]{overflow-x:hidden}blockquote{border-left:3px solid var(--color-border);color:var(--color-foreground,inherit);margin-block-end:1rem;margin-block-start:0;margin-inline-end:0;margin-inline-start:0;padding:.5em .75em}blockquote footer{color:var(--color-foreground-muted,inherit);display:block}blockquote footer:before{content:"\2014\A0"}button{-webkit-appearance:none;appearance:none;background:none;border:none;font-family:inherit;outline:none;padding:0}button:not(:disabled){cursor:pointer}button:disabled{cursor:not-allowed;opacity:var(--opacity-disabled,.38)}button:focus-visible{outline:1px auto -webkit-focus-ring-color;outline-offset:1px}code[class*=language-],pre[class*=language-]{background:var(--color-background);color:var(--color-foreground);direction:ltr;font-family:Fira Code,Fira Mono,Menlo,Consolas,DejaVu Sans Mono,monospace;font-size:.925rem;-webkit-hyphens:none;hyphens:none;line-height:1.5;tab-size:2;text-align:left;white-space:pre;word-break:normal;word-spacing:normal}code[class*=language-] ::selection,code[class*=language-]::selection,pre[class*=language-] ::selection{background:var(--color-surface-9);color:inherit;text-shadow:none}pre[class*=language-]{border:1px solid var(--color-border);border-radius:.3em;margin:1em 0;overflow:auto;overflow-x:auto;padding:1em}pre[class*=language-]::-webkit-scrollbar{height:8px}pre[class*=language-]::-webkit-scrollbar-track{background-color:transparent}pre[class*=language-]::-webkit-scrollbar-thumb{background-clip:content-box;background-color:var(--color-surface-5);border:none;border-radius:6px}pre[class*=language-]::-webkit-scrollbar-thumb:hover{background-color:var(--color-surface-7)}:not(pre)>code{background-color:var(--color-surface-3);border-radius:.25em;padding:.125em .25em;white-space:normal}[data-theme=dark] :not(pre)>code,[data-theme=high-contrast] :not(pre)>code{background-color:var(--color-surface-9)}@media print{code[class*=language-],pre[class*=language-]{text-shadow:none}}.token.punctuation{color:var(--color-syntax-foreground)}.token.cdata,.token.comment,.token.doctype,.token.prolog{color:var(--color-syntax-comment)}.token.atrule,.token.builtin,.token.important,.token.keyword,.token.operator,.token.symbol,.token.tag{color:var(--color-syntax-keyword)}.token.function,.token.function-definition{color:var(--color-syntax-function)}.token.attr-name,.token.class-name,.token.entity,.token.namespace,.token.return-type,.token.selector{color:var(--color-syntax-entity)}.token.property,.token.variable{color:var(--color-syntax-property)}.token.attr-value,.token.char,.token.regex,.token.string,.token.url{color:var(--color-syntax-string)}.token.boolean,.token.constant,.token.number{color:var(--color-syntax-constant)}.token.changed{background-color:var(--color-syntax-diff-changed-bg);color:var(--color-syntax-diff-changed-text)}.token.deleted{background-color:var(--color-syntax-diff-deleted-bg);color:var(--color-syntax-diff-deleted-text)}.token.ignored{background-color:var(--color-syntax-diff-ignored-bg);color:var(--color-syntax-diff-ignored-text)}.token.inserted{background-color:var(--color-syntax-diff-inserted-bg);color:var(--color-syntax-diff-inserted-text)}.token.bold{font-weight:700}.token.italic{font-style:italic}hr{background-color:var(--color-border);border:none;height:1px;margin-block-end:1rem;margin-inline-end:0;margin-inline-start:0}hr,hr.title{margin-block-start:1rem}hr.title{height:2px;margin-block-end:2rem}hr.transparent{background-color:transparent}hr.small{width:64px}hr.medium{width:128px}hr.large{width:256px}hr.full{width:100%}hr.thick{height:2px}img,svg{vertical-align:middle}input,select,textarea{background:none;border:1px solid var(--color-border);border-radius:.25rem;color:inherit;font-family:inherit;font-size:.875em;line-height:1.125rem;outline:none;padding:8px;vertical-align:middle}input::placeholder,select::placeholder,textarea::placeholder{color:var(--color-foreground-subtle,inherit);font-size:1em}input:focus,select:focus,textarea:focus{border-color:var(--color-primary)}input:disabled,select:disabled,textarea:disabled{cursor:not-allowed;opacity:var(--opacity-disabled,.38)}input[type=submit]{color:var(--color-foreground-subtle,inherit);font-weight:500;min-width:80px;transition:color .2s,background-color .2s,border-color .2s}input[type=submit]:not(:disabled){cursor:pointer}input[type=submit]:not(:disabled):focus,input[type=submit]:not(:disabled):hover{background-color:var(--color-default);border-color:var(--color-default);color:var(--color-on-default)}input[type=search]::-ms-clear,input[type=search]::-ms-reveal{display:none;height:0;width:0}input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-decoration,input[type=search]::-webkit-search-results-button,input[type=search]::-webkit-search-results-decoration{display:none}ol,ul{margin-block-end:1rem;margin-block-start:0;padding-inline-start:24px}li::marker{color:var(--color-foreground-muted,inherit)}table{margin-left:-16px;width:calc(100% + 16px)}table td,table th{height:40px;padding:8px 16px}table th{font-weight:600;text-align:left}table.bordered{border-spacing:0;margin-left:0;width:100%}table.bordered td,table.bordered th{border:1px solid var(--color-border);padding:8px}table.bordered tr:first-child td:first-child,table.bordered tr:first-child th:first-child{border-top-left-radius:.25rem}table.bordered tr:first-child td:last-child,table.bordered tr:first-child th:last-child{border-top-right-radius:.25rem}table.bordered tr:last-child td:first-child,table.bordered tr:last-child th:first-child{border-bottom-left-radius:.25rem}table.bordered tr:last-child td:last-child,table.bordered tr:last-child th:last-child{border-bottom-right-radius:.25rem}table.bordered tr:not(:first-child) td,table.bordered tr:not(:first-child) th{border-top:none}table.bordered tr td:not(:first-child),table.bordered tr th:not(:first-child){border-left:none}table.striped tr:nth-child(2n){background-color:var(--color-surface-1)}body,html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--color-foreground,inherit);font-family:Poppins,Roboto,Helvetica,Arial,sans-serif;font-size:1rem;font-weight:400;line-height:1.5}a,a:hover,a:visited{color:inherit;font-weight:inherit;text-decoration:none}a:not(:disabled){cursor:pointer}b,strong{font-weight:600}p{margin-bottom:1rem;margin-top:0}.display-1,.display-2,.display-3,.display-4,.display-5,.display-6,.h1,.h2,.h3,.h4,.h5,.h6,h1,h2,h3,h4,h5,h6{color:inherit;font-family:inherit;font-weight:600;line-height:1.2;margin-bottom:1rem;margin-top:0}.h1,h1{font-size:2.25rem}.h2,h2{font-size:2rem}.h3,h3{font-size:1.75rem}.h4,h4{font-size:1.5rem}.h5,h5{font-size:1.25rem}.h6,h6{font-size:1rem}.display-1{font-size:5rem}.display-2{font-size:4.5rem}.display-3{font-size:4rem}.display-4{font-size:3.5rem}.display-5{font-size:3rem}.display-6{font-size:2.5rem}.font-xxxl{font-size:1.5rem}.font-xxl{font-size:1.375rem}.font-xl{font-size:1.25rem}.font-lg{font-size:1.125rem}.font-md{font-size:1rem}.font-sm{font-size:.875rem}.font-xs{font-size:.75rem}.font-xxs{font-size:.625rem}.font-xxxs{font-size:.5rem}.eyebrow{color:var(--color-foreground-muted,inherit);font-size:.75rem;font-weight:600;letter-spacing:0;margin-bottom:.25rem;text-transform:uppercase}.subtitle{margin-bottom:.5rem;white-space:nowrap}:root{--footer-height:64px}.app-footer{align-items:center;display:flex;min-height:var(--footer-height,64px);overflow:hidden;position:relative;width:100%}.app-footer--bordered{border-top:1px solid var(--color-border)}.app-footer--transparent{background:none!important}.app-footer--sticky{bottom:0;position:sticky;z-index:var(--z-index-sticky,1020)}.app-footer .col{justify-content:space-between}.app-footer .col,.app-footer .col>*{align-items:center;display:flex}.app-footer .links{text-align:center;white-space:nowrap}@media (max-width:767px){.app-footer .col,.app-footer .col>:not(.links){flex-direction:column}.app-footer .copyright,.app-footer .links,.app-footer .logo{margin-bottom:8px}.app-footer .links{flex-wrap:wrap;justify-content:center}.app-footer .link{margin-bottom:4px}}:root{--header-height:80px}.app-header{align-items:center;display:flex;height:var(--header-height,80px);position:relative;width:100%}.app-header--bordered{border-bottom:1px solid var(--color-border)}.app-header--transparent{background:none!important}.app-header--sticky{position:sticky;top:0;z-index:var(--z-index-sticky,1020)}.app-header>.container,.app-header>.container-fluid{align-items:center;display:flex;height:100%;justify-content:space-between;margin:0 auto}.app-header>.container-fluid{max-width:100%}.app-header__content{align-items:center;display:flex;height:100%;justify-content:flex-start}.app-header .logo{z-index:1055}.app-header .navbar,.app-header .social-nav-links{display:none}@media screen and (min-width:1200px){.app-header .navbar,.app-header .social-nav-links{display:block}.app-header .navmenu,.app-header .navmenu__button{display:none}}.app-store-badge{border:none!important;display:inline-block}.app-store-badge>img{height:100%;width:100%}.app-utility-bar{height:32px}.app-utility-bar .container,.app-utility-bar .row{height:100%}.app-utility-bar .row{align-items:center}.app-utility-bar .col{align-items:center;display:flex}.app-utility-bar--left .col{justify-content:flex-start}.app-utility-bar--right .col{justify-content:flex-end}.badge{border-radius:.25rem;display:inline-block;font-size:.75em;font-weight:500;line-height:1;margin:.5em;min-width:48px;padding:.5em .75em;text-align:center;vertical-align:baseline;white-space:nowrap}.badge:first-child{margin-left:0}.badge:last-child{margin-right:0}.badge,.badge--solid{background-color:var(--color-foreground);color:var(--color-background)}.badge,.badge--outline,.badge--solid{border:1px solid var(--color-foreground)}.badge--outline{background-color:transparent;color:var(--color-foreground)}.badge--pill{border-radius:50rem!important}.btn,.btn--default{--btn-color-primary:var(--color-default);--btn-color-secondary:var(--color-on-default);--btn-color-emphasis:var(--color-default-emphasis);--btn-color-subtle:var(--color-default-subtle)}.btn--primary{--btn-color-primary:var(--color-primary);--btn-color-secondary:var(--color-on-primary);--btn-color-emphasis:var(--color-primary-emphasis);--btn-color-subtle:var(--color-primary-subtle)}.btn--secondary{--btn-color-primary:var(--color-secondary);--btn-color-secondary:var(--color-on-secondary);--btn-color-emphasis:var(--color-secondary-emphasis);--btn-color-subtle:var(--color-secondary-subtle)}.btn--tertiary{--btn-color-primary:var(--color-tertiary);--btn-color-secondary:var(--color-on-tertiary);--btn-color-emphasis:var(--color-tertiary-emphasis);--btn-color-subtle:var(--color-tertiary-subtle)}.btn--success{--btn-color-primary:var(--color-success);--btn-color-secondary:var(--color-on-success);--btn-color-emphasis:var(--color-success-emphasis);--btn-color-subtle:var(--color-success-subtle)}.btn--danger{--btn-color-primary:var(--color-danger);--btn-color-secondary:var(--color-on-danger);--btn-color-emphasis:var(--color-danger-emphasis);--btn-color-subtle:var(--color-danger-subtle)}.btn--warning{--btn-color-primary:var(--color-warning);--btn-color-secondary:var(--color-on-warning);--btn-color-emphasis:var(--color-warning-emphasis);--btn-color-subtle:var(--color-warning-subtle)}.btn--info{--btn-color-primary:var(--color-info);--btn-color-secondary:var(--color-on-info);--btn-color-emphasis:var(--color-info-emphasis);--btn-color-subtle:var(--color-info-subtle)}.btn{fill:var(--btn-color-secondary);align-items:center;background-color:var(--btn-color-primary);border:1px solid transparent;border-radius:.5rem;color:var(--btn-color-secondary);display:inline-flex;font-size:.875rem;font-weight:500;justify-content:center;line-height:20px;padding:8px 16px;text-decoration:none;transform:scale(1);transition:color .2s,background-color .2s,transform .2s;vertical-align:middle;white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:var(--opacity-disabled,.38)}.btn:not(:disabled){cursor:pointer}.btn:active,.btn:hover{text-decoration:none}.btn:not(.btn--unstyled):not(:disabled):active{transform:scale(.975)}.btn:focus-visible{outline:1px auto -webkit-focus-ring-color;outline-offset:1px}.btn--solid{fill:var(--btn-color-secondary);background-color:var(--btn-color-primary);border-color:transparent;color:var(--btn-color-secondary)}.btn--solid:not(:disabled).active,.btn--solid:not(:disabled):active,.btn--solid:not(:disabled):hover{background-color:var(--btn-color-emphasis)}.btn--outline{fill:var(--btn-color-primary);background-color:transparent;border-color:var(--btn-color-primary);color:var(--btn-color-primary)}.btn--outline:not(:disabled).active,.btn--outline:not(:disabled):active,.btn--outline:not(:disabled):hover{fill:var(--btn-color-secondary);background-color:var(--btn-color-primary);color:var(--btn-color-secondary)}.btn--text,.btn--text:visited{fill:var(--btn-color-primary);background-color:transparent;border-color:transparent;color:var(--btn-color-primary)}.btn--text:not(:disabled):active,.btn--text:not(:disabled):hover{background-color:var(--btn-color-subtle)}.btn--unstyled{fill:inherit;background-color:transparent;border-color:transparent;color:inherit}.btn--rounded-corners{border-radius:.5rem}.btn--square{border-radius:0}.btn--rounded{border-radius:24px}.btn--circle{border-radius:50%}.btn--sm,.btn--small{font-size:.875rem;padding:8px 16px}.btn--sm.btn--rounded,.btn--small.btn--rounded{border-radius:24px}.btn--sm.btn--circle,.btn--sm.btn--icon-only,.btn--small.btn--circle,.btn--small.btn--icon-only{padding:8px}.btn--md,.btn--medium{font-size:1rem;padding:12px 24px}.btn--md.btn--rounded,.btn--medium.btn--rounded{border-radius:32px}.btn--md.btn--circle,.btn--md.btn--icon-only,.btn--medium.btn--circle,.btn--medium.btn--icon-only{padding:12px}.btn--large,.btn--lg{font-size:1.125rem;padding:16px 32px}.btn--large.btn--rounded,.btn--lg.btn--rounded{border-radius:40px}.btn--large.btn--circle,.btn--large.btn--icon-only,.btn--lg.btn--circle,.btn--lg.btn--icon-only{padding:16px}.btn>.icon-wrapper{fill:inherit;align-items:center;color:inherit;display:inline-flex;justify-content:center}.btn--sm>.icon-wrapper,.btn--small>.icon-wrapper{max-height:14px;max-width:14px}.btn--md>.icon-wrapper,.btn--medium>.icon-wrapper{max-height:16px;max-width:16px}.btn--large>.icon-wrapper,.btn--lg>.icon-wrapper{max-height:18px;max-width:18px}.btn>.icon-wrapper>.icon{fill:inherit;color:inherit}.btn--sm>.icon-wrapper>.icon,.btn--small>.icon-wrapper>.icon{font-size:15px}.btn--md>.icon-wrapper>.icon,.btn--medium>.icon-wrapper>.icon{font-size:18px}.btn--large>.icon-wrapper>.icon,.btn--lg>.icon-wrapper>.icon{font-size:21px}.btn-group{display:inline-flex;flex-wrap:wrap;max-width:100%;position:relative;vertical-align:middle;width:max-content}.btn-group--horizontal{align-items:center;flex-direction:row;justify-content:flex-start}.btn-group--vertical{align-items:flex-start;flex-direction:column;justify-content:center}.btn-group--spacing.btn-group--horizontal>a,.btn-group--spacing.btn-group--horizontal>button{margin-bottom:8px;margin-top:8px}.btn-group--spacing.btn-group--horizontal>a:not(:last-child),.btn-group--spacing.btn-group--horizontal>button:not(:last-child){margin-right:16px}.btn-group--spacing.btn-group--vertical>a,.btn-group--spacing.btn-group--vertical>button{margin-left:8px;margin-right:8px}.btn-group--spacing.btn-group--vertical>button:not(:last-child) .btn-group--spacing.btn-group--vertical>a:not(:last-child){margin-bottom:16px}.contact-form input,.contact-form textarea{display:block;margin-bottom:12px}.contact-form input:not([type=submit]),.contact-form textarea{max-width:100%;width:100%}.contact-form textarea{min-height:120px;resize:none}.cookie-consent{background-color:var(--color-background);bottom:0;box-shadow:0 -.5rem 1rem rgba(var(--rgb-black),10%);left:0;position:fixed;right:0;width:100%;z-index:var(--z-index-fixed,1030)}.cookie-consent__container{align-items:center;display:flex;justify-content:space-between}.cookie-consent__text{margin:12px 16px}.cookie-consent__text>a,.cookie-consent__text>a:hover,.cookie-consent__text>a:visited{font-weight:400}.cookie-consent__button{height:100%;min-height:48px}.cookie-consent__button:not(.cookie-consent__button--unstyled):not(:disabled):active{transform:none}@media (max-width:784px){.cookie-consent__button{margin-right:16px}}.embedded-video{box-sizing:content-box;max-width:100%;overflow:hidden;position:relative}.embedded-video:before{background-color:var(--color-surface-2);bottom:0;content:"";height:100%;left:0;position:absolute;right:0;top:0;width:100%}.embedded-video__wrapper{height:0;padding-bottom:56.25%;position:relative;width:100%}.embedded-video iframe{left:0;max-height:100%;max-width:100%;position:absolute;top:0}.icon{-webkit-font-smoothing:antialiased;word-wrap:normal;color:inherit;direction:ltr;display:inline-block;font-size:24px;font-style:normal;font-weight:400;letter-spacing:normal;line-height:1;text-transform:none;white-space:nowrap}.icon--material{font-family:Material Icons}.icon--inherit{font-size:inherit}.icon--sm,.icon--small{font-size:18px}.icon--md,.icon--medium{font-size:24px}.icon--large,.icon--lg{font-size:36px}.icon--extraLarge,.icon--xl{font-size:48px}.icon--light.icon--active{opacity:1}.icon--light.icon--inactive{opacity:.3}.icon--dark.icon--active{opacity:.54}.icon--dark.icon--inactive{opacity:.26}.img-fluid{height:auto;max-width:100%}.img-rounded{border-radius:.25rem}.image-gallery{margin-bottom:16px;margin-top:16px;position:relative}.image-gallery__thumbnails{column-gap:16px;display:grid;row-gap:16px}.image-gallery__thumbnail{display:flex;position:relative}.image-gallery__thumbnail--full-width{grid-column:1/-1}.image-gallery__thumbnail img{max-width:100%}.image-gallery__lightbox .ril__toolbar{background-color:transparent;height:10vh}.image-gallery__lightbox .ril__toolbarSide{height:100%}.image-gallery__lightbox .ril__toolbarLeftSide{padding-left:0}.image-gallery__lightbox .ril__toolbarRightSide{padding-right:0}.image-gallery__lightbox .ril__toolbarItem{height:100%;width:100%}.image-gallery__lightbox .ril__navButtons{background-color:transparent;background-position:50%;background-size:25px;height:100%;padding:0;width:10vw}.image-gallery__lightbox .ril__closeButton{background-position:50%;background-size:25%;height:10vh;width:10vh}@media (max-width:767px){.image-gallery__thumbnails{column-gap:8px;row-gap:8px}}@media (hover:none){.image-gallery__thumbnail{animation:0}}.input-wrapper{align-items:center;border:1px solid var(--color-border);border-radius:.25rem;display:inline-flex;height:36px;padding:8px;position:relative;vertical-align:middle}.input-wrapper.focus{border-color:var(--color-primary)}.input-wrapper.disabled{cursor:not-allowed;opacity:var(--opacity-disabled,.38)}.input-wrapper.disabled>input:disabled{opacity:1}.input-wrapper>input{border:none;border-radius:0;height:100%;padding:0;width:100%}.input-wrapper>.icon{color:var(--color-foreground-muted,inherit);font-size:18px;pointer-events:none}.input-wrapper--icon-left{flex-direction:row-reverse}.input-wrapper--icon-left>.icon{margin-right:4px}.input-wrapper--icon-right{flex-direction:row}.input-wrapper--icon-right>.icon{margin-left:4px}.input-wrapper--sm,.input-wrapper--small{height:36px}.input-wrapper--md,.input-wrapper--medium{height:42px}.input-wrapper--large,.input-wrapper--lg{height:48px}.link,.link:hover,.link:visited{color:var(--color-primary,inherit);font-weight:500;text-decoration:none}.link--underlined,.link:hover{text-decoration:underline}.loading-spinner{display:none;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.loading-spinner.loading{display:inline-block}.loading-spinner.sm,.loading-spinner.small{height:20px;width:20px}.loading-spinner.md,.loading-spinner.medium{height:40px;width:40px}.loading-spinner.large,.loading-spinner.lg{height:80px;width:80px}.loading-spinner__animation{display:inline-block;height:80%;left:10%;position:relative;top:10%;width:80%}.loading-spinner__animation div{animation:loading-spinner-animation 1.2s cubic-bezier(.5,0,.5,1) infinite;border:4px solid transparent;border-radius:50%;border-top:4px solid var(--color-surface-9);box-sizing:border-box;display:block;height:100%;position:absolute;width:100%}.loading-spinner__animation div:first-child{animation-delay:-.45s}.loading-spinner__animation div:nth-child(2){animation-delay:-.3s}.loading-spinner__animation div:nth-child(3){animation-delay:-.15s}@keyframes loading-spinner-animation{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.logo{fill:var(--color-foreground);display:inline-block}.logo.extraSmall,.logo.xs{height:32px}.logo.sm,.logo.small{height:48px}.logo.md,.logo.medium{height:72px}.logo.large,.logo.lg{height:96px}.logo.extraLarge,.logo.xl{height:128px}.logo svg{fill:inherit}.logo img,.logo svg{height:100%}.logo button{cursor:pointer;height:100%;pointer-events:all!important}.logo button:focus-visible{outline-offset:-16px}.modal{background-color:rgba(var(--rgb-black,black),0);bottom:0;display:none;left:0;outline:none;overflow:hidden;position:fixed;right:0;top:0;transition:background-color .3s;z-index:var(--z-index-modal,1060)}.modal--open{background-color:rgba(var(--rgb-black,black),var(--opacity-scrim,.54));display:block;overflow-x:hidden;overflow-y:auto}.modal__dialog{align-items:center;display:flex;margin:.5rem;min-height:calc(100% - 4rem);position:relative;width:auto}.modal__content{background-clip:padding-box;background-color:var(--color-surface-1);border:1px solid var(--color-border);border-radius:.25rem;color:var(--color-foreground);display:flex;flex-direction:column;outline:none;overflow:hidden;pointer-events:auto;position:relative;width:100%}.modal__body{flex:1 1 auto;padding:1rem;position:relative}.modal__header{border-bottom:1px solid var(--color-border);justify-content:space-between}.modal__footer,.modal__header{align-items:center;display:flex;padding:1rem}.modal__footer{border-top:1px solid var(--color-border)}.modal__footer--left-aligned{justify-content:flex-start}.modal__footer--right-aligned{justify-content:flex-end}.modal__title{margin:0}.modal__close-button{margin:-1rem -.65rem -1rem auto;opacity:.5;padding:1rem;transition:opacity .2s}.modal__close-button:active,.modal__close-button:focus,.modal__close-button:hover{opacity:1}@media (min-width:576px){.modal__dialog{margin:2rem auto;max-width:500px}}.navbar{justify-content:flex-start}.navbar,.navbar ul{align-items:center;display:inline-flex}.navbar ul{justify-content:space-evenly;list-style:none;margin-block-end:0;margin-block-start:0;padding-inline-end:16px;padding-inline-start:16px}.navbar li{padding-left:4px;padding-right:4px}.navbar li a{align-items:center;background-color:transparent;border:none;border-radius:.5rem;display:inline-flex;font-size:1rem;font-weight:500;justify-content:center;padding:6px 12px;transform:scale(1);transition:background-color .2s,transform .2s}.navbar li a:hover{background-color:var(--color-default-subtle);text-decoration:none}.navbar li a:active{transform:scale(.975)}.navbar li a.active{color:var(--color-primary)}.navbar li a.active:hover{background-color:var(--color-primary-subtle)}.navmenu{background:none!important;position:fixed;z-index:var(--z-index-fixed,1030)}.navmenu,.navmenu__overlay{bottom:0;height:100vh;left:0;right:0;top:0;width:100vw}.navmenu__overlay{background-color:var(--color-background);position:absolute;z-index:var(--z-index-overlay,1040)}.navmenu__container{height:calc(100% - var(--header-height, 80px)*2);margin-bottom:calc(var(--header-height, 80px)*.5);margin-top:calc(var(--header-height, 80px)*1.5);position:relative;z-index:var(--z-index-menu,1050)}.navmenu__container .social-nav-links{fill:var(--color-foreground);margin-left:-8px}.navmenu__wrapper{align-items:flex-start;display:flex;flex-direction:column;height:100%;justify-content:space-between;margin-left:16px}.navmenu__button{align-items:center;color:var(--color-foreground);display:inline-flex;height:56px;justify-content:center;pointer-events:all!important;transition:transform .2s;width:56px}.navmenu__button:hover:not(:disabled){transform:scale(1.1)}.navmenu__list{font-size:2rem;font-weight:600;line-height:1.2;list-style:none;margin-block-end:0;margin-block-start:0;margin-inline-end:0;margin-inline-start:0;padding-inline-start:0;text-align:left;white-space:nowrap}.navmenu__item{color:var(--color-foreground);margin-bottom:.5rem;transition:opacity .2s}.navmenu__item>a{border-bottom:none!important;color:inherit;font-weight:600}.navmenu--open{pointer-events:all;visibility:visible}.navmenu--closed{pointer-events:none;visibility:hidden}.navmenu--animated{transition:visibility .2s}.navmenu--animated .navmenu__item,.navmenu--animated .navmenu__overlay{transition:opacity .2s}.navmenu--animated.navmenu--open .navmenu__item,.navmenu--animated.navmenu--open .navmenu__overlay{opacity:1}.navmenu--animated.navmenu--closed .navmenu__item,.navmenu--animated.navmenu--closed .navmenu__overlay{opacity:0}@media (hover:hover){.navmenu__list:hover .navmenu__item{opacity:var(--opacity-inactive,.62)}.navmenu__item:hover{opacity:1!important}}@media (min-width:360px){.navmenu__list{font-size:2.5rem}}@media (min-width:576px){.navmenu__list{font-size:2.75rem}}@media (min-width:768px){.navmenu__list{font-size:3rem}}.page-banner{position:relative;width:100%;z-index:0}.page-banner:before{background:inherit;bottom:0;content:"";height:100%;left:0;margin-left:50%;pointer-events:none;position:absolute;right:0;top:0;transform:translate3d(-50%,0,0);transform-origin:50% 50%;width:100vw;z-index:-1}.page-banner--transparent:before{background:none!important}.page-banner--extraSmall,.page-banner--xs{padding-bottom:1rem;padding-top:1rem}.page-banner--sm,.page-banner--small{padding-bottom:2rem;padding-top:2rem}.page-banner--md,.page-banner--medium{padding-bottom:4rem;padding-top:4rem}.page-banner--large,.page-banner--lg{padding-bottom:6rem;padding-top:6rem}.page-banner--extraLarge,.page-banner--xl{padding-bottom:8rem;padding-top:8rem}.pagination{align-items:center;display:inline-flex;justify-content:flex-start}.pagination>.btn{border-radius:.25rem;height:36px;margin-left:4px;margin-right:4px;padding:8px;width:36px}.pagination>.btn:first-child{margin-left:0}.pagination>.btn:last-child{margin-right:0}.progressive-image{box-sizing:content-box;display:inline-block;height:auto;max-width:100%;position:relative}.progressive-image__placeholder{clip-path:inset(0);filter:blur(1px);opacity:1;position:absolute}.progressive-image__placeholder.progressive-image--animated{transition:opacity .6s ease-in}.progressive-image--loaded .progressive-image__placeholder{opacity:0}@media (hover:hover){.progressive-image--no-placeholder.progressive-image--animated .progressive-image__source{transition:opacity .2s ease-in,visibility .2s ease-in}.progressive-image--no-placeholder .progressive-image__source{opacity:0;visibility:hidden}.progressive-image--no-placeholder.progressive-image--loaded .progressive-image__source{opacity:1;visibility:visible}}.custom-scrollbar{overflow-y:auto}.custom-scrollbar--auto-hide{overflow-y:overlay}.custom-scrollbar::-webkit-scrollbar{width:8px}.custom-scrollbar::-webkit-scrollbar-track{background-color:var(--color-surface-3)}.custom-scrollbar::-webkit-scrollbar-thumb{background-clip:content-box;background-color:var(--color-surface-6);border:none;border-radius:4px}.custom-scrollbar--auto-hide::-webkit-scrollbar-thumb,.custom-scrollbar--auto-hide::-webkit-scrollbar-track{background-color:transparent}.custom-scrollbar--auto-hide:hover::-webkit-scrollbar-thumb{background-color:var(--color-surface-6)}.custom-scrollbar::-webkit-scrollbar-thumb:hover{background-color:var(--color-surface-9)}.sidedrawer{background:none!important;position:fixed;z-index:var(--z-index-fixed,1030)}.sidedrawer,.sidedrawer__overlay{bottom:0;height:100vh;left:0;right:0;top:0;width:100vw}.sidedrawer__overlay{background-color:var(--color-black,#000);opacity:var(--opacity-scrim,.54);position:absolute;z-index:var(--z-index-overlay,1040)}.sidedrawer__container{background-color:var(--color-background);box-shadow:.25rem 0 .5rem rgba(0,0,0,.1);color:var(--color-foreground);height:100%;left:0;margin-right:auto;position:relative;width:287px;z-index:var(--z-index-menu,1050)}[data-theme=dark] .sidedrawer__container,[data-theme=high-contrast] .sidedrawer__container{box-shadow:none}.sidedrawer__button{align-items:center;color:var(--color-foreground);display:inline-flex;height:56px;justify-content:center;pointer-events:all!important;transition:transform .2s;width:56px}.sidedrawer__button:hover:not(:disabled){transform:scale(1.1)}.sidedrawer--open{pointer-events:all;visibility:visible}.sidedrawer--closed{pointer-events:none;visibility:hidden}.sidedrawer--animated{transition:visibility .2s}.sidedrawer--animated .sidedrawer__overlay{transition:opacity .2s}.sidedrawer--animated .sidedrawer__container{transition:transform .2s}.sidedrawer--animated.sidedrawer--open .sidedrawer__overlay{opacity:var(--opacity-scrim,.54)}.sidedrawer--animated.sidedrawer--closed .sidedrawer__overlay{opacity:0}.sidedrawer--animated.sidedrawer--open .sidedrawer__container{transform:translateX(0)}.sidedrawer--animated.sidedrawer--closed .sidedrawer__container{transform:translateX(-287px)}.social-button.paypal path{transition:fill .1s}.social-button.paypal:active:not(:disabled) path:first-child,.social-button.paypal:active:not(:disabled) path:nth-child(4),.social-button.paypal:focus:not(:disabled) path:first-child,.social-button.paypal:focus:not(:disabled) path:nth-child(4),.social-button.paypal:hover:not(:disabled) path:first-child,.social-button.paypal:hover:not(:disabled) path:nth-child(4){fill:#fff}.social-button.paypal:active:not(:disabled) path:nth-child(2),.social-button.paypal:focus:not(:disabled) path:nth-child(2),.social-button.paypal:hover:not(:disabled) path:nth-child(2){fill:#adcee4}.social-button.paypal:active:not(:disabled) path:nth-child(3),.social-button.paypal:focus:not(:disabled) path:nth-child(3),.social-button.paypal:hover:not(:disabled) path:nth-child(3){fill:#e6eff6}.social-icon{fill:var(--color-foreground,inherit);align-items:center;box-sizing:content-box;display:inline-flex;justify-content:center;max-height:100%;max-width:100%;position:relative}.social-icon,.social-icon:hover{border-bottom:none;text-decoration:none}.social-icon--rounded{border-radius:50%}.social-icon svg{fill:inherit;height:100%;transition:fill .2s;width:100%}.social-nav-links{align-items:center;display:flex;justify-content:flex-start;max-width:100%}.social-nav-links__list{align-items:center;display:flex;list-style:none;margin-block-end:8px;margin-block-start:8px;padding-inline-end:0;padding-inline-start:0}.social-nav-links__item{transition:opacity .2s,transform .2s}@media (hover:hover){.social-nav-links__list:hover .social-nav-links__item{opacity:var(--opacity-inactive,.62)}.social-nav-links__item:hover{opacity:1!important;transform:scale(1.1)}}.thumbnail{border-bottom:none!important;box-sizing:content-box;display:inline-flex;height:auto;max-width:100%;overflow:hidden;position:relative;text-align:center}@media (hover:hover){a.thumbnail{transition:transform .3s cubic-bezier(.23,1,.32,1),box-shadow .3s cubic-bezier(.23,1,.32,1)}a.thumbnail:hover{box-shadow:0 10px 20px rgba(0,0,0,.1);transform:translateY(-4px)}}@media (hover:none){.thumbnail{animation:0}}.container,.container-fluid,.container-lg,.container-md,.container-sm,.container-xl{margin-left:auto;margin-right:auto;padding-left:16px;padding-right:16px;width:100%}@media (min-width:576px){.container,.container-lg,.container-md,.container-sm,.container-xl{max-width:540px}}@media (min-width:768px){.container,.container-lg,.container-md,.container-xl{max-width:720px}}@media (min-width:992px){.container,.container-lg,.container-xl{max-width:960px}}@media (min-width:1200px){.container,.container-xl{max-width:1140px}}.row{display:flex;flex-wrap:wrap;margin-left:-16px;margin-right:-16px}.col,[class*=col-]{min-height:1px;padding-left:16px;padding-right:16px;position:relative;width:100%}.col{flex-basis:0;flex-grow:1;max-width:100%}.col-0{flex:0 0;max-width:0}.col-1{flex:0 0 8.3333333333%;max-width:8.3333333333%}.col-2{flex:0 0 16.6666666667%;max-width:16.6666666667%}.col-3{flex:0 0 25%;max-width:25%}.col-4{flex:0 0 33.3333333333%;max-width:33.3333333333%}.col-5{flex:0 0 41.6666666667%;max-width:41.6666666667%}.col-6{flex:0 0 50%;max-width:50%}.col-7{flex:0 0 58.3333333333%;max-width:58.3333333333%}.col-8{flex:0 0 66.6666666667%;max-width:66.6666666667%}.col-9{flex:0 0 75%;max-width:75%}.col-10{flex:0 0 83.3333333333%;max-width:83.3333333333%}.col-11{flex:0 0 91.6666666667%;max-width:91.6666666667%}.col-12{flex:0 0 100%;max-width:100%}.col-auto{flex:0 0 auto;max-width:100%;width:auto}.order-first{order:-1}.order-last{order:13}.order-0{order:0}.order-1{order:1}.order-2{order:2}.order-3{order:3}.order-4{order:4}.order-5{order:5}.order-6{order:6}.order-7{order:7}.order-8{order:8}.order-9{order:9}.order-10{order:10}.order-11{order:11}.order-12{order:12}.offset-0{margin-left:0}.offset-1{margin-left:8.3333333333%}.offset-2{margin-left:16.6666666667%}.offset-3{margin-left:25%}.offset-4{margin-left:33.3333333333%}.offset-5{margin-left:41.6666666667%}.offset-6{margin-left:50%}.offset-7{margin-left:58.3333333333%}.offset-8{margin-left:66.6666666667%}.offset-9{margin-left:75%}.offset-10{margin-left:83.3333333333%}.offset-11{margin-left:91.6666666667%}.offset-12{margin-left:100%}.row.gutters-sm{padding-bottom:8px;padding-top:8px}.row.gutters-md{padding-bottom:16px;padding-top:16px}.row.gutters-lg{padding-bottom:32px;padding-top:32px}.col.gutters-sm,[class*=col-].gutters-sm{padding-left:8px;padding-right:8px}.col.gutters-md,[class*=col-].gutters-md{padding-left:16px;padding-right:16px}.col.gutters-lg,[class*=col-].gutters-lg{padding-left:32px;padding-right:32px}.gutters-none{margin-left:0;margin-right:0}.gutters-none>.col,.gutters-none>[class*=col-]{padding-left:0;padding-right:0}@media (min-width:576px){.col-sm{flex-basis:0;flex-grow:1;max-width:100%}.col-sm-0{flex:0 0;max-width:0}.col-sm-1{flex:0 0 8.3333333333%;max-width:8.3333333333%}.col-sm-2{flex:0 0 16.6666666667%;max-width:16.6666666667%}.col-sm-3{flex:0 0 25%;max-width:25%}.col-sm-4{flex:0 0 33.3333333333%;max-width:33.3333333333%}.col-sm-5{flex:0 0 41.6666666667%;max-width:41.6666666667%}.col-sm-6{flex:0 0 50%;max-width:50%}.col-sm-7{flex:0 0 58.3333333333%;max-width:58.3333333333%}.col-sm-8{flex:0 0 66.6666666667%;max-width:66.6666666667%}.col-sm-9{flex:0 0 75%;max-width:75%}.col-sm-10{flex:0 0 83.3333333333%;max-width:83.3333333333%}.col-sm-11{flex:0 0 91.6666666667%;max-width:91.6666666667%}.col-sm-12{flex:0 0 100%;max-width:100%}.col-sm-auto{flex:0 0 auto;max-width:100%;width:auto}.order-sm-first{order:-1}.order-sm-last{order:13}.order-sm-0{order:0}.order-sm-1{order:1}.order-sm-2{order:2}.order-sm-3{order:3}.order-sm-4{order:4}.order-sm-5{order:5}.order-sm-6{order:6}.order-sm-7{order:7}.order-sm-8{order:8}.order-sm-9{order:9}.order-sm-10{order:10}.order-sm-11{order:11}.order-sm-12{order:12}.offset-sm-0{margin-left:0}.offset-sm-1{margin-left:8.3333333333%}.offset-sm-2{margin-left:16.6666666667%}.offset-sm-3{margin-left:25%}.offset-sm-4{margin-left:33.3333333333%}.offset-sm-5{margin-left:41.6666666667%}.offset-sm-6{margin-left:50%}.offset-sm-7{margin-left:58.3333333333%}.offset-sm-8{margin-left:66.6666666667%}.offset-sm-9{margin-left:75%}.offset-sm-10{margin-left:83.3333333333%}.offset-sm-11{margin-left:91.6666666667%}.offset-sm-12{margin-left:100%}}@media (min-width:768px){.col-md{flex-basis:0;flex-grow:1;max-width:100%}.col-md-0{flex:0 0;max-width:0}.col-md-1{flex:0 0 8.3333333333%;max-width:8.3333333333%}.col-md-2{flex:0 0 16.6666666667%;max-width:16.6666666667%}.col-md-3{flex:0 0 25%;max-width:25%}.col-md-4{flex:0 0 33.3333333333%;max-width:33.3333333333%}.col-md-5{flex:0 0 41.6666666667%;max-width:41.6666666667%}.col-md-6{flex:0 0 50%;max-width:50%}.col-md-7{flex:0 0 58.3333333333%;max-width:58.3333333333%}.col-md-8{flex:0 0 66.6666666667%;max-width:66.6666666667%}.col-md-9{flex:0 0 75%;max-width:75%}.col-md-10{flex:0 0 83.3333333333%;max-width:83.3333333333%}.col-md-11{flex:0 0 91.6666666667%;max-width:91.6666666667%}.col-md-12{flex:0 0 100%;max-width:100%}.col-md-auto{flex:0 0 auto;max-width:100%;width:auto}.order-md-first{order:-1}.order-md-last{order:13}.order-md-0{order:0}.order-md-1{order:1}.order-md-2{order:2}.order-md-3{order:3}.order-md-4{order:4}.order-md-5{order:5}.order-md-6{order:6}.order-md-7{order:7}.order-md-8{order:8}.order-md-9{order:9}.order-md-10{order:10}.order-md-11{order:11}.order-md-12{order:12}.offset-md-0{margin-left:0}.offset-md-1{margin-left:8.3333333333%}.offset-md-2{margin-left:16.6666666667%}.offset-md-3{margin-left:25%}.offset-md-4{margin-left:33.3333333333%}.offset-md-5{margin-left:41.6666666667%}.offset-md-6{margin-left:50%}.offset-md-7{margin-left:58.3333333333%}.offset-md-8{margin-left:66.6666666667%}.offset-md-9{margin-left:75%}.offset-md-10{margin-left:83.3333333333%}.offset-md-11{margin-left:91.6666666667%}.offset-md-12{margin-left:100%}}@media (min-width:992px){.col-lg{flex-basis:0;flex-grow:1;max-width:100%}.col-lg-0{flex:0 0;max-width:0}.col-lg-1{flex:0 0 8.3333333333%;max-width:8.3333333333%}.col-lg-2{flex:0 0 16.6666666667%;max-width:16.6666666667%}.col-lg-3{flex:0 0 25%;max-width:25%}.col-lg-4{flex:0 0 33.3333333333%;max-width:33.3333333333%}.col-lg-5{flex:0 0 41.6666666667%;max-width:41.6666666667%}.col-lg-6{flex:0 0 50%;max-width:50%}.col-lg-7{flex:0 0 58.3333333333%;max-width:58.3333333333%}.col-lg-8{flex:0 0 66.6666666667%;max-width:66.6666666667%}.col-lg-9{flex:0 0 75%;max-width:75%}.col-lg-10{flex:0 0 83.3333333333%;max-width:83.3333333333%}.col-lg-11{flex:0 0 91.6666666667%;max-width:91.6666666667%}.col-lg-12{flex:0 0 100%;max-width:100%}.col-lg-auto{flex:0 0 auto;max-width:100%;width:auto}.order-lg-first{order:-1}.order-lg-last{order:13}.order-lg-0{order:0}.order-lg-1{order:1}.order-lg-2{order:2}.order-lg-3{order:3}.order-lg-4{order:4}.order-lg-5{order:5}.order-lg-6{order:6}.order-lg-7{order:7}.order-lg-8{order:8}.order-lg-9{order:9}.order-lg-10{order:10}.order-lg-11{order:11}.order-lg-12{order:12}.offset-lg-0{margin-left:0}.offset-lg-1{margin-left:8.3333333333%}.offset-lg-2{margin-left:16.6666666667%}.offset-lg-3{margin-left:25%}.offset-lg-4{margin-left:33.3333333333%}.offset-lg-5{margin-left:41.6666666667%}.offset-lg-6{margin-left:50%}.offset-lg-7{margin-left:58.3333333333%}.offset-lg-8{margin-left:66.6666666667%}.offset-lg-9{margin-left:75%}.offset-lg-10{margin-left:83.3333333333%}.offset-lg-11{margin-left:91.6666666667%}.offset-lg-12{margin-left:100%}}@media (min-width:1200px){.col-xl{flex-basis:0;flex-grow:1;max-width:100%}.col-xl-0{flex:0 0;max-width:0}.col-xl-1{flex:0 0 8.3333333333%;max-width:8.3333333333%}.col-xl-2{flex:0 0 16.6666666667%;max-width:16.6666666667%}.col-xl-3{flex:0 0 25%;max-width:25%}.col-xl-4{flex:0 0 33.3333333333%;max-width:33.3333333333%}.col-xl-5{flex:0 0 41.6666666667%;max-width:41.6666666667%}.col-xl-6{flex:0 0 50%;max-width:50%}.col-xl-7{flex:0 0 58.3333333333%;max-width:58.3333333333%}.col-xl-8{flex:0 0 66.6666666667%;max-width:66.6666666667%}.col-xl-9{flex:0 0 75%;max-width:75%}.col-xl-10{flex:0 0 83.3333333333%;max-width:83.3333333333%}.col-xl-11{flex:0 0 91.6666666667%;max-width:91.6666666667%}.col-xl-12{flex:0 0 100%;max-width:100%}.col-xl-auto{flex:0 0 auto;max-width:100%;width:auto}.order-xl-first{order:-1}.order-xl-last{order:13}.order-xl-0{order:0}.order-xl-1{order:1}.order-xl-2{order:2}.order-xl-3{order:3}.order-xl-4{order:4}.order-xl-5{order:5}.order-xl-6{order:6}.order-xl-7{order:7}.order-xl-8{order:8}.order-xl-9{order:9}.order-xl-10{order:10}.order-xl-11{order:11}.order-xl-12{order:12}.offset-xl-0{margin-left:0}.offset-xl-1{margin-left:8.3333333333%}.offset-xl-2{margin-left:16.6666666667%}.offset-xl-3{margin-left:25%}.offset-xl-4{margin-left:33.3333333333%}.offset-xl-5{margin-left:41.6666666667%}.offset-xl-6{margin-left:50%}.offset-xl-7{margin-left:58.3333333333%}.offset-xl-8{margin-left:66.6666666667%}.offset-xl-9{margin-left:75%}.offset-xl-10{margin-left:83.3333333333%}.offset-xl-11{margin-left:91.6666666667%}.offset-xl-12{margin-left:100%}}.page{margin-left:auto;margin-right:auto;min-height:calc(100vh - var(--header-height, 0));position:relative}.js-parallax .page{transform-style:preserve-3d}.page>article{padding-bottom:128px}.cover{align-items:center;display:flex;flex-direction:column;height:100vh;justify-content:center;overflow:hidden;width:100vw}.cover:before{background-attachment:fixed;bottom:0;content:"";height:100%;left:0;pointer-events:none;position:absolute;right:0;top:0;width:100%}.full-bleed{margin-left:50%;transform:translateX(-50%);width:100vw}.app.js-parallax,.parallax{perspective:10px}.parallax{height:100vh;overflow-x:hidden;overflow-y:auto}.parallax__group{position:relative;transform-style:preserve-3d}.parallax__layer{bottom:0;left:0;position:absolute;right:0;top:0}.parallax__layer--base{transform:translateZ(0)}.parallax__layer--bg-1{transform:translateZ(-1px) scale(2)}.parallax__layer--bg-2{transform:translateZ(-2px) scale(3)}.parallax__layer--bg-3{transform:translateZ(-3px) scale(4)}.parallax__layer--bg-4{transform:translateZ(-4px) scale(5)}.parallax__layer--bg-5{transform:translateZ(-5px) scale(6)}.parallax__layer--fg-1{transform:translateZ(1px) scale(.9)}.parallax__layer--fg-2{transform:translateZ(2px) scale(.8)}.parallax__layer--fg-3{transform:translateZ(3px) scale(.7)}.parallax__layer--fg-4{transform:translateZ(4px) scale(.6)}.parallax__layer--fg-5{transform:translateZ(5px) scale(.5)}.align-baseline{vertical-align:baseline}.align-middle{vertical-align:middle}.align-top{vertical-align:top}.align-bottom{vertical-align:bottom}.align-text-top{vertical-align:text-top}.align-text-bottom{vertical-align:text-bottom}.animation-short{animation-duration:.2s;animation-fill-mode:both}.animation-medium{animation-duration:.4s;animation-fill-mode:both}.animation-long{animation-duration:.6s;animation-fill-mode:both}.animation-infinite{animation-iteration-count:infinite}.animation-delay-1{animation-delay:50ms}.animation-delay-2{animation-delay:.1s}.animation-delay-3{animation-delay:.15s}.animation-delay-4{animation-delay:.2s}.animation-delay-5{animation-delay:.25s}.animation-delay-6{animation-delay:.3s}.animation-delay-7{animation-delay:.35s}.animation-delay-8{animation-delay:.4s}.fade-in{animation-name:fade-in}.fade-out{animation-name:fade-out}.translate-in{animation-name:translate-in}.translate-out{animation-name:translate-out}.fade-translate-in{animation-name:fade-translate-in}.fade-translate-out{animation-name:fade-translate-out}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes fade-out{0%{opacity:1}to{opacity:0}}@keyframes translate-in{0%{transform:translate3d(0,10%,0)}to{transform:none}}@keyframes translate-out{0%{transform:none}to{transform:translate3d(0,10%,0)}}@keyframes fade-translate-in{0%{opacity:0;transform:translate3d(0,10%,0)}to{opacity:1;transform:none}}@keyframes fade-translate-out{0%{opacity:1;transform:none}to{opacity:0;transform:translate3d(0,10%,0)}}.aspect-ratio-container{height:0;overflow:hidden;position:relative}.aspect-ratio-content{height:100%;left:0;position:absolute;top:0;width:100%}.aspect-ratio-21x9{padding-bottom:42.85714%}.aspect-ratio-9x21{padding-bottom:233.33333%}.aspect-ratio-16x9{padding-bottom:56.25%}.aspect-ratio-9x16{padding-bottom:177.77778%}.aspect-ratio-4x3{padding-bottom:75%}.aspect-ratio-3x4{padding-bottom:133.33333%}.aspect-ratio-6x4{padding-bottom:66.66667%}.aspect-ratio-4x6{padding-bottom:150%}.aspect-ratio-8x5{padding-bottom:62.5%}.aspect-ratio-5x8{padding-bottom:160%}.aspect-ratio-7x5{padding-bottom:71.42857%}.aspect-ratio-5x7{padding-bottom:140%}.aspect-ratio-2x1{padding-bottom:50%}.aspect-ratio-1x2{padding-bottom:200%}.aspect-ratio-1x1{padding-bottom:100%}.bg-cover{background-size:cover}.bg-contain{background-size:contain}.bg-center{background-position:50%}.bg-center,.bg-top{background-repeat:no-repeat}.bg-top{background-position:top}.bg-bottom{background-position:bottom}.bg-bottom,.bg-left{background-repeat:no-repeat}.bg-left{background-position:0}.bg-right{background-position:100%;background-repeat:no-repeat}.bg-repeat{background-repeat:repeat}.bg-repeat-x{background-repeat:repeat-x}.bg-repeat-y{background-repeat:repeat-y}.bg-norepeat{background-repeat:no-repeat}.border,.border-all{border-style:solid;border-width:1px}.border-top{border-top-style:solid;border-top-width:1px}.border-bottom{border-bottom-style:solid;border-bottom-width:1px}.border-left{border-left-style:solid;border-left-width:1px}.border-right{border-right-style:solid;border-right-width:1px}.border-none{border-style:solid;border-width:0}.rounded,.rounded-md{border-radius:.25rem}.rounded-sm{border-radius:.125rem}.rounded-lg{border-radius:.5rem}.justify-content-around{justify-content:space-around}.justify-content-baseline{justify-content:baseline}.justify-content-between{justify-content:space-between}.justify-content-center{justify-content:center}.justify-content-end{justify-content:end}.justify-content-evenly{justify-content:space-evenly}.justify-content-flex-end{justify-content:flex-end}.justify-content-flex-start{justify-content:flex-start}.justify-content-left{justify-content:left}.justify-content-normal{justify-content:normal}.justify-content-right{justify-content:right}.justify-content-start{justify-content:start}.justify-content-stretch{justify-content:stretch}.justify-items-auto{justify-items:auto}.justify-items-baseline{justify-items:baseline}.justify-items-center{justify-items:center}.justify-items-end{justify-items:end}.justify-items-flex-end{justify-items:flex-end}.justify-items-flex-start{justify-items:flex-start}.justify-items-left{justify-items:left}.justify-items-normal{justify-items:normal}.justify-items-right{justify-items:right}.justify-items-self-end{justify-items:self-end}.justify-items-self-start{justify-items:self-start}.justify-items-start{justify-items:start}.justify-items-stretch{justify-items:stretch}.justify-self-auto{justify-self:auto}.justify-self-baseline{justify-self:baseline}.justify-self-center{justify-self:center}.justify-self-end{justify-self:end}.justify-self-flex-end{justify-self:flex-end}.justify-self-flex-start{justify-self:flex-start}.justify-self-left{justify-self:left}.justify-self-normal{justify-self:normal}.justify-self-right{justify-self:right}.justify-self-self-end{justify-self:self-end}.justify-self-self-start{justify-self:self-start}.justify-self-start{justify-self:start}.justify-self-stretch{justify-self:stretch}.align-content-around{align-content:space-around}.align-content-between{align-content:space-between}.align-content-center{align-content:center}.align-content-end{align-content:flex-end}.align-content-start{align-content:flex-start}.align-content-stretch{align-content:stretch}.align-items-baseline{align-items:baseline}.align-items-center{align-items:center}.align-items-end{align-items:flex-end}.align-items-start{align-items:flex-start}.align-items-stretch{align-items:stretch}.align-self-auto{align-self:auto}.align-self-baseline{align-self:baseline}.align-self-center{align-self:center}.align-self-end{align-self:flex-end}.align-self-start{align-self:flex-start}.align-self-stretch{align-self:stretch}.border-box{box-sizing:border-box}.content-box{box-sizing:content-box}.color-inherit,.color-inherit:visited{color:inherit}.color-transparent{color:transparent}.color-black{color:var(--color-black,#000)}.color-white{color:var(--color-white,#fff)}.color-foreground{color:var(--color-foreground)}.color-foreground-muted{color:var(--color-foreground-muted)}.color-foreground-subtle{color:var(--color-foreground-subtle)}.color-background{color:var(--color-background)}.color-surface-0{color:var(--color-surface-0)}.color-surface-1{color:var(--color-surface-1)}.color-surface-2{color:var(--color-surface-2)}.color-surface-3{color:var(--color-surface-3)}.color-surface-4{color:var(--color-surface-4)}.color-surface-5{color:var(--color-surface-5)}.color-surface-6{color:var(--color-surface-6)}.color-surface-7{color:var(--color-surface-7)}.color-surface-8{color:var(--color-surface-8)}.color-surface-9{color:var(--color-surface-9)}.color-default{color:var(--color-default)}.color-default-emphasis{color:var(--color-default-emphasis)}.color-default-subtle{color:var(--color-default-subtle)}.color-primary{color:var(--color-primary)}.color-primary-emphasis{color:var(--color-primary-emphasis)}.color-primary-subtle{color:var(--color-primary-subtle)}.color-secondary{color:var(--color-secondary)}.color-secondary-emphasis{color:var(--color-secondary-emphasis)}.color-secondary-subtle{color:var(--color-secondary-subtle)}.color-tertiary{color:var(--color-tertiary)}.color-tertiary-emphasis{color:var(--color-tertiary-emphasis)}.color-tertiary-subtle{color:var(--color-tertiary-subtle)}.color-success{color:var(--color-success)}.color-success-emphasis{color:var(--color-success-emphasis)}.color-success-subtle{color:var(--color-success-subtle)}.color-danger{color:var(--color-danger)}.color-danger-emphasis{color:var(--color-danger-emphasis)}.color-danger-subtle{color:var(--color-danger-subtle)}.color-warning{color:var(--color-warning)}.color-warning-emphasis{color:var(--color-warning-emphasis)}.color-warning-subtle{color:var(--color-warning-subtle)}.color-info{color:var(--color-info)}.color-info-emphasis{color:var(--color-info-emphasis)}.color-info-subtle{color:var(--color-info-subtle)}.bg-inherit{background-color:inherit}.bg-transparent{background-color:transparent}.bg-black{background-color:var(--color-black,#000)}.bg-white{background-color:var(--color-white,#fff)}.bg-foreground{background-color:var(--color-foreground)}.bg-foreground-muted{background-color:var(--color-foreground-muted)}.bg-foreground-subtle{background-color:var(--color-foreground-subtle)}.bg-background{background-color:var(--color-background)}.bg-surface-0{background-color:var(--color-surface-0)}.bg-surface-1{background-color:var(--color-surface-1)}.bg-surface-2{background-color:var(--color-surface-2)}.bg-surface-3{background-color:var(--color-surface-3)}.bg-surface-4{background-color:var(--color-surface-4)}.bg-surface-5{background-color:var(--color-surface-5)}.bg-surface-6{background-color:var(--color-surface-6)}.bg-surface-7{background-color:var(--color-surface-7)}.bg-surface-8{background-color:var(--color-surface-8)}.bg-surface-9{background-color:var(--color-surface-9)}.bg-default{background-color:var(--color-default)}.bg-default-emphasis{background-color:var(--color-default-emphasis)}.bg-default-subtle{background-color:var(--color-default-subtle)}.bg-primary{background-color:var(--color-primary)}.bg-primary-emphasis{background-color:var(--color-primary-emphasis)}.bg-primary-subtle{background-color:var(--color-primary-subtle)}.bg-secondary{background-color:var(--color-secondary)}.bg-secondary-emphasis{background-color:var(--color-secondary-emphasis)}.bg-secondary-subtle{background-color:var(--color-secondary-subtle)}.bg-tertiary{background-color:var(--color-tertiary)}.bg-tertiary-emphasis{background-color:var(--color-tertiary-emphasis)}.bg-tertiary-subtle{background-color:var(--color-tertiary-subtle)}.bg-success{background-color:var(--color-success)}.bg-success-emphasis{background-color:var(--color-success-emphasis)}.bg-success-subtle{background-color:var(--color-success-subtle)}.bg-danger{background-color:var(--color-danger)}.bg-danger-emphasis{background-color:var(--color-danger-emphasis)}.bg-danger-subtle{background-color:var(--color-danger-subtle)}.bg-warning{background-color:var(--color-warning)}.bg-warning-emphasis{background-color:var(--color-warning-emphasis)}.bg-warning-subtle{background-color:var(--color-warning-subtle)}.bg-info{background-color:var(--color-info)}.bg-info-emphasis{background-color:var(--color-info-emphasis)}.bg-info-subtle{background-color:var(--color-info-subtle)}.fill-inherit{fill:inherit}.fill-transparent{fill:transparent}.fill-black{fill:var(--color-black,#000)}.fill-white{fill:var(--color-white,#fff)}.fill-foreground{fill:var(--color-foreground)}.fill-foreground-muted{fill:var(--color-foreground-muted)}.fill-foreground-subtle{fill:var(--color-foreground-subtle)}.fill-background{fill:var(--color-background)}.fill-surface-0{fill:var(--color-surface-0)}.fill-surface-1{fill:var(--color-surface-1)}.fill-surface-2{fill:var(--color-surface-2)}.fill-surface-3{fill:var(--color-surface-3)}.fill-surface-4{fill:var(--color-surface-4)}.fill-surface-5{fill:var(--color-surface-5)}.fill-surface-6{fill:var(--color-surface-6)}.fill-surface-7{fill:var(--color-surface-7)}.fill-surface-8{fill:var(--color-surface-8)}.fill-surface-9{fill:var(--color-surface-9)}.fill-default{fill:var(--color-default)}.fill-default-emphasis{fill:var(--color-default-emphasis)}.fill-default-subtle{fill:var(--color-default-subtle)}.fill-primary{fill:var(--color-primary)}.fill-primary-emphasis{fill:var(--color-primary-emphasis)}.fill-primary-subtle{fill:var(--color-primary-subtle)}.fill-secondary{fill:var(--color-secondary)}.fill-secondary-emphasis{fill:var(--color-secondary-emphasis)}.fill-secondary-subtle{fill:var(--color-secondary-subtle)}.fill-tertiary{fill:var(--color-tertiary)}.fill-tertiary-emphasis{fill:var(--color-tertiary-emphasis)}.fill-tertiary-subtle{fill:var(--color-tertiary-subtle)}.fill-success{fill:var(--color-success)}.fill-success-emphasis{fill:var(--color-success-emphasis)}.fill-success-subtle{fill:var(--color-success-subtle)}.fill-danger{fill:var(--color-danger)}.fill-danger-emphasis{fill:var(--color-danger-emphasis)}.fill-danger-subtle{fill:var(--color-danger-subtle)}.fill-warning{fill:var(--color-warning)}.fill-warning-emphasis{fill:var(--color-warning-emphasis)}.fill-warning-subtle{fill:var(--color-warning-subtle)}.fill-info{fill:var(--color-info)}.fill-info-emphasis{fill:var(--color-info-emphasis)}.fill-info-subtle{fill:var(--color-info-subtle)}.cursor-alias{cursor:alias}.cursor-auto{cursor:auto}.cursor-context-menu{cursor:context-menu}.cursor-cell{cursor:cell}.cursor-copy{cursor:copy}.cursor-crosshair{cursor:crosshair}.cursor-default{cursor:default}.cursor-grab{cursor:grab}.cursor-grabbing{cursor:grabbing}.cursor-help{cursor:help}.cursor-move{cursor:move}.cursor-none{cursor:none}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.cursor-progress{cursor:progress}.cursor-text{cursor:text}.cursor-wait{cursor:wait}.cursor-zoom-in{cursor:zoom-in}.cursor-zoom-out{cursor:zoom-out}.display-none{display:none}.display-block{display:block}.display-flex{display:flex}.display-grid{display:grid}.display-inline-block{display:inline-block}.display-inline-flex{display:inline-flex}.display-inline-grid{display:inline-grid}.flex-row{flex-direction:row}.flex-row-reverse{flex-direction:row-reverse}.flex-column{flex-direction:column}.flex-column-reverse{flex-direction:column-reverse}.flex-wrap{flex-wrap:wrap}.flex-wrap-reverse{flex-wrap:wrap-reverse}.flex-nowrap{flex-wrap:nowrap}.flex-grow-1{flex-grow:1}.flex-grow-0{flex-grow:0}.flex-shrink-1{flex-shrink:1}.flex-shrink-0{flex-shrink:0}@media (min-width:576px){.flex-row-sm{flex-direction:row}.flex-row-reverse-sm{flex-direction:row-reverse}.flex-column-sm{flex-direction:column}.flex-column-reverse-sm{flex-direction:column-reverse}.flex-wrap-sm{flex-wrap:wrap}.flex-wrap-reverse-sm{flex-wrap:wrap-reverse}.flex-nowrap-sm{flex-wrap:nowrap}}@media (min-width:768px){.flex-row-md{flex-direction:row}.flex-row-reverse-md{flex-direction:row-reverse}.flex-column-md{flex-direction:column}.flex-column-reverse-md{flex-direction:column-reverse}.flex-wrap-md{flex-wrap:wrap}.flex-wrap-reverse-md{flex-wrap:wrap-reverse}.flex-nowrap-md{flex-wrap:nowrap}}@media (min-width:992px){.flex-row-lg{flex-direction:row}.flex-row-reverse-lg{flex-direction:row-reverse}.flex-column-lg{flex-direction:column}.flex-column-reverse-lg{flex-direction:column-reverse}.flex-wrap-lg{flex-wrap:wrap}.flex-wrap-reverse-lg{flex-wrap:wrap-reverse}.flex-nowrap-lg{flex-wrap:nowrap}}@media (min-width:1200px){.flex-row-xl{flex-direction:row}.flex-row-reverse-xl{flex-direction:row-reverse}.flex-column-xl{flex-direction:column}.flex-column-reverse-xl{flex-direction:column-reverse}.flex-wrap-xl{flex-wrap:wrap}.flex-wrap-reverse-xl{flex-wrap:wrap-reverse}.flex-nowrap-xl{flex-wrap:nowrap}}.float-left{_display:inline;float:left}.float-right{_display:inline;float:right}.float-none{float:none}.height-auto{height:auto}.height-0{height:0}.height-xs{height:calc(var(--spacing-unit, 8px)*.25)}.height-sm{height:calc(var(--spacing-unit, 8px)*.5)}.height-md{height:calc(var(--spacing-unit, 8px)*1)}.height-lg{height:calc(var(--spacing-unit, 8px)*2)}.height-xl{height:calc(var(--spacing-unit, 8px)*3)}.height-xxl{height:calc(var(--spacing-unit, 8px)*4)}.height-xxxl{height:calc(var(--spacing-unit, 8px)*5)}.height-2xl{height:calc(var(--spacing-unit, 8px)*6)}.height-2xxl{height:calc(var(--spacing-unit, 8px)*8)}.height-2xxxl{height:calc(var(--spacing-unit, 8px)*10)}.height-10p{height:10%}.height-20p{height:20%}.height-25p{height:25%}.height-30p{height:30%}.height-33p{height:33%}.height-40p{height:40%}.height-50p{height:50%}.height-60p{height:60%}.height-66p{height:66%}.height-70p{height:70%}.height-75p{height:75%}.height-80p{height:80%}.height-90p{height:90%}.height-100p{height:100%}.height-10vh{height:10vh}.height-20vh{height:20vh}.height-25vh{height:25vh}.height-30vh{height:30vh}.height-33vh{height:33vh}.height-40vh{height:40vh}.height-50vh{height:50vh}.height-60vh{height:60vh}.height-66vh{height:66vh}.height-70vh{height:70vh}.height-75vh{height:75vh}.height-80vh{height:80vh}.height-90vh{height:90vh}.height-100vh{height:100vh}.height-1em{height:1em}.height-2em{height:2em}.height-3em{height:3em}.height-4em{height:4em}.height-5em{height:5em}.height-6em{height:6em}.height-7em{height:7em}.height-8em{height:8em}.margin-0,.margin-none{margin:0}.margin-xs{margin:calc(var(--spacing-unit, 8px)*.25)}.margin-sm{margin:calc(var(--spacing-unit, 8px)*.5)}.margin-md{margin:calc(var(--spacing-unit, 8px)*1)}.margin-lg{margin:calc(var(--spacing-unit, 8px)*2)}.margin-xl{margin:calc(var(--spacing-unit, 8px)*3)}.margin-xxl{margin:calc(var(--spacing-unit, 8px)*4)}.margin-xxxl{margin:calc(var(--spacing-unit, 8px)*5)}.margin-2xl{margin:calc(var(--spacing-unit, 8px)*6)}.margin-2xxl{margin:calc(var(--spacing-unit, 8px)*8)}.margin-2xxxl{margin:calc(var(--spacing-unit, 8px)*10)}.margin-1em{margin:1em}.margin-2em{margin:2em}.margin-3em{margin:3em}.margin-4em{margin:4em}.margin-5em{margin:5em}.margin-6em{margin:6em}.margin-7em{margin:7em}.margin-8em{margin:8em}.margin-1rem{margin:1rem}.margin-2rem{margin:2rem}.margin-3rem{margin:3rem}.margin-4rem{margin:4rem}.margin-5rem{margin:5rem}.margin-6rem{margin:6rem}.margin-7rem{margin:7rem}.margin-8rem{margin:8rem}.margin-left-0,.margin-left-none{margin-left:0}.margin-left-xs{margin-left:calc(var(--spacing-unit, 8px)*.25)}.margin-left-sm{margin-left:calc(var(--spacing-unit, 8px)*.5)}.margin-left-md{margin-left:calc(var(--spacing-unit, 8px)*1)}.margin-left-lg{margin-left:calc(var(--spacing-unit, 8px)*2)}.margin-left-xl{margin-left:calc(var(--spacing-unit, 8px)*3)}.margin-left-xxl{margin-left:calc(var(--spacing-unit, 8px)*4)}.margin-left-xxxl{margin-left:calc(var(--spacing-unit, 8px)*5)}.margin-left-2xl{margin-left:calc(var(--spacing-unit, 8px)*6)}.margin-left-2xxl{margin-left:calc(var(--spacing-unit, 8px)*8)}.margin-left-2xxxl{margin-left:calc(var(--spacing-unit, 8px)*10)}.margin-left-1em{margin-left:1em}.margin-left-2em{margin-left:2em}.margin-left-3em{margin-left:3em}.margin-left-4em{margin-left:4em}.margin-left-5em{margin-left:5em}.margin-left-6em{margin-left:6em}.margin-left-7em{margin-left:7em}.margin-left-8em{margin-left:8em}.margin-left-1rem{margin-left:1rem}.margin-left-2rem{margin-left:2rem}.margin-left-3rem{margin-left:3rem}.margin-left-4rem{margin-left:4rem}.margin-left-5rem{margin-left:5rem}.margin-left-6rem{margin-left:6rem}.margin-left-7rem{margin-left:7rem}.margin-left-8rem{margin-left:8rem}.margin-right-0,.margin-right-none{margin-right:0}.margin-right-xs{margin-right:calc(var(--spacing-unit, 8px)*.25)}.margin-right-sm{margin-right:calc(var(--spacing-unit, 8px)*.5)}.margin-right-md{margin-right:calc(var(--spacing-unit, 8px)*1)}.margin-right-lg{margin-right:calc(var(--spacing-unit, 8px)*2)}.margin-right-xl{margin-right:calc(var(--spacing-unit, 8px)*3)}.margin-right-xxl{margin-right:calc(var(--spacing-unit, 8px)*4)}.margin-right-xxxl{margin-right:calc(var(--spacing-unit, 8px)*5)}.margin-right-2xl{margin-right:calc(var(--spacing-unit, 8px)*6)}.margin-right-2xxl{margin-right:calc(var(--spacing-unit, 8px)*8)}.margin-right-2xxxl{margin-right:calc(var(--spacing-unit, 8px)*10)}.margin-right-1em{margin-right:1em}.margin-right-2em{margin-right:2em}.margin-right-3em{margin-right:3em}.margin-right-4em{margin-right:4em}.margin-right-5em{margin-right:5em}.margin-right-6em{margin-right:6em}.margin-right-7em{margin-right:7em}.margin-right-8em{margin-right:8em}.margin-right-1rem{margin-right:1rem}.margin-right-2rem{margin-right:2rem}.margin-right-3rem{margin-right:3rem}.margin-right-4rem{margin-right:4rem}.margin-right-5rem{margin-right:5rem}.margin-right-6rem{margin-right:6rem}.margin-right-7rem{margin-right:7rem}.margin-right-8rem{margin-right:8rem}.margin-top-0,.margin-top-none{margin-top:0}.margin-top-xs{margin-top:calc(var(--spacing-unit, 8px)*.25)}.margin-top-sm{margin-top:calc(var(--spacing-unit, 8px)*.5)}.margin-top-md{margin-top:calc(var(--spacing-unit, 8px)*1)}.margin-top-lg{margin-top:calc(var(--spacing-unit, 8px)*2)}.margin-top-xl{margin-top:calc(var(--spacing-unit, 8px)*3)}.margin-top-xxl{margin-top:calc(var(--spacing-unit, 8px)*4)}.margin-top-xxxl{margin-top:calc(var(--spacing-unit, 8px)*5)}.margin-top-2xl{margin-top:calc(var(--spacing-unit, 8px)*6)}.margin-top-2xxl{margin-top:calc(var(--spacing-unit, 8px)*8)}.margin-top-2xxxl{margin-top:calc(var(--spacing-unit, 8px)*10)}.margin-top-1em{margin-top:1em}.margin-top-2em{margin-top:2em}.margin-top-3em{margin-top:3em}.margin-top-4em{margin-top:4em}.margin-top-5em{margin-top:5em}.margin-top-6em{margin-top:6em}.margin-top-7em{margin-top:7em}.margin-top-8em{margin-top:8em}.margin-top-1rem{margin-top:1rem}.margin-top-2rem{margin-top:2rem}.margin-top-3rem{margin-top:3rem}.margin-top-4rem{margin-top:4rem}.margin-top-5rem{margin-top:5rem}.margin-top-6rem{margin-top:6rem}.margin-top-7rem{margin-top:7rem}.margin-top-8rem{margin-top:8rem}.margin-bottom-0,.margin-bottom-none{margin-bottom:0}.margin-bottom-xs{margin-bottom:calc(var(--spacing-unit, 8px)*.25)}.margin-bottom-sm{margin-bottom:calc(var(--spacing-unit, 8px)*.5)}.margin-bottom-md{margin-bottom:calc(var(--spacing-unit, 8px)*1)}.margin-bottom-lg{margin-bottom:calc(var(--spacing-unit, 8px)*2)}.margin-bottom-xl{margin-bottom:calc(var(--spacing-unit, 8px)*3)}.margin-bottom-xxl{margin-bottom:calc(var(--spacing-unit, 8px)*4)}.margin-bottom-xxxl{margin-bottom:calc(var(--spacing-unit, 8px)*5)}.margin-bottom-2xl{margin-bottom:calc(var(--spacing-unit, 8px)*6)}.margin-bottom-2xxl{margin-bottom:calc(var(--spacing-unit, 8px)*8)}.margin-bottom-2xxxl{margin-bottom:calc(var(--spacing-unit, 8px)*10)}.margin-bottom-1em{margin-bottom:1em}.margin-bottom-2em{margin-bottom:2em}.margin-bottom-3em{margin-bottom:3em}.margin-bottom-4em{margin-bottom:4em}.margin-bottom-5em{margin-bottom:5em}.margin-bottom-6em{margin-bottom:6em}.margin-bottom-7em{margin-bottom:7em}.margin-bottom-8em{margin-bottom:8em}.margin-bottom-1rem{margin-bottom:1rem}.margin-bottom-2rem{margin-bottom:2rem}.margin-bottom-3rem{margin-bottom:3rem}.margin-bottom-4rem{margin-bottom:4rem}.margin-bottom-5rem{margin-bottom:5rem}.margin-bottom-6rem{margin-bottom:6rem}.margin-bottom-7rem{margin-bottom:7rem}.margin-bottom-8rem{margin-bottom:8rem}.opacity-100p{opacity:1}.opacity-90p{opacity:.9}.opacity-80p{opacity:.8}.opacity-75p{opacity:.75}.opacity-70p{opacity:.7}.opacity-66p{opacity:.66}.opacity-60p{opacity:.6}.opacity-50p{opacity:.5}.opacity-40p{opacity:.4}.opacity-33p{opacity:.33}.opacity-30p{opacity:.3}.opacity-25p{opacity:.25}.opacity-20p{opacity:.2}.opacity-10p{opacity:.1}.opacity-0,.opacity-0p{opacity:0}.outline{outline:1px solid}.outline-transparent{outline:1px solid transparent}.outline-0{outline:0}.overflow-auto{overflow:auto}.overflow-scroll{overflow:scroll}.overflow-hidden{overflow:hidden}.overflow-visible{overflow:visible}.overflow-x-auto{overflow-x:auto}.overflow-x-scroll{overflow-x:scroll}.overflow-x-hidden{overflow-x:hidden}.overflow-x-visible{overflow-x:visible}.overflow-y-auto{overflow-y:auto}.overflow-y-scroll{overflow-y:scroll}.overflow-y-hidden{overflow-y:hidden}.overflow-y-visible{overflow-y:visible}.padding-0,.padding-none{padding:0}.padding-xs{padding:calc(var(--spacing-unit, 8px)*.25)}.padding-sm{padding:calc(var(--spacing-unit, 8px)*.5)}.padding-md{padding:calc(var(--spacing-unit, 8px)*1)}.padding-lg{padding:calc(var(--spacing-unit, 8px)*2)}.padding-xl{padding:calc(var(--spacing-unit, 8px)*3)}.padding-xxl{padding:calc(var(--spacing-unit, 8px)*4)}.padding-xxxl{padding:calc(var(--spacing-unit, 8px)*5)}.padding-2xl{padding:calc(var(--spacing-unit, 8px)*6)}.padding-2xxl{padding:calc(var(--spacing-unit, 8px)*8)}.padding-2xxxl{padding:calc(var(--spacing-unit, 8px)*10)}.padding-1em{padding:1em}.padding-2em{padding:2em}.padding-3em{padding:3em}.padding-4em{padding:4em}.padding-5em{padding:5em}.padding-6em{padding:6em}.padding-7em{padding:7em}.padding-8em{padding:8em}.padding-1rem{padding:1rem}.padding-2rem{padding:2rem}.padding-3rem{padding:3rem}.padding-4rem{padding:4rem}.padding-5rem{padding:5rem}.padding-6rem{padding:6rem}.padding-7rem{padding:7rem}.padding-8rem{padding:8rem}.padding-left-0,.padding-left-none{padding-left:0}.padding-left-xs{padding-left:calc(var(--spacing-unit, 8px)*.25)}.padding-left-sm{padding-left:calc(var(--spacing-unit, 8px)*.5)}.padding-left-md{padding-left:calc(var(--spacing-unit, 8px)*1)}.padding-left-lg{padding-left:calc(var(--spacing-unit, 8px)*2)}.padding-left-xl{padding-left:calc(var(--spacing-unit, 8px)*3)}.padding-left-xxl{padding-left:calc(var(--spacing-unit, 8px)*4)}.padding-left-xxxl{padding-left:calc(var(--spacing-unit, 8px)*5)}.padding-left-2xl{padding-left:calc(var(--spacing-unit, 8px)*6)}.padding-left-2xxl{padding-left:calc(var(--spacing-unit, 8px)*8)}.padding-left-2xxxl{padding-left:calc(var(--spacing-unit, 8px)*10)}.padding-left-1em{padding-left:1em}.padding-left-2em{padding-left:2em}.padding-left-3em{padding-left:3em}.padding-left-4em{padding-left:4em}.padding-left-5em{padding-left:5em}.padding-left-6em{padding-left:6em}.padding-left-7em{padding-left:7em}.padding-left-8em{padding-left:8em}.padding-left-1rem{padding-left:1rem}.padding-left-2rem{padding-left:2rem}.padding-left-3rem{padding-left:3rem}.padding-left-4rem{padding-left:4rem}.padding-left-5rem{padding-left:5rem}.padding-left-6rem{padding-left:6rem}.padding-left-7rem{padding-left:7rem}.padding-left-8rem{padding-left:8rem}.padding-right-0,.padding-right-none{padding-right:0}.padding-right-xs{padding-right:calc(var(--spacing-unit, 8px)*.25)}.padding-right-sm{padding-right:calc(var(--spacing-unit, 8px)*.5)}.padding-right-md{padding-right:calc(var(--spacing-unit, 8px)*1)}.padding-right-lg{padding-right:calc(var(--spacing-unit, 8px)*2)}.padding-right-xl{padding-right:calc(var(--spacing-unit, 8px)*3)}.padding-right-xxl{padding-right:calc(var(--spacing-unit, 8px)*4)}.padding-right-xxxl{padding-right:calc(var(--spacing-unit, 8px)*5)}.padding-right-2xl{padding-right:calc(var(--spacing-unit, 8px)*6)}.padding-right-2xxl{padding-right:calc(var(--spacing-unit, 8px)*8)}.padding-right-2xxxl{padding-right:calc(var(--spacing-unit, 8px)*10)}.padding-right-1em{padding-right:1em}.padding-right-2em{padding-right:2em}.padding-right-3em{padding-right:3em}.padding-right-4em{padding-right:4em}.padding-right-5em{padding-right:5em}.padding-right-6em{padding-right:6em}.padding-right-7em{padding-right:7em}.padding-right-8em{padding-right:8em}.padding-right-1rem{padding-right:1rem}.padding-right-2rem{padding-right:2rem}.padding-right-3rem{padding-right:3rem}.padding-right-4rem{padding-right:4rem}.padding-right-5rem{padding-right:5rem}.padding-right-6rem{padding-right:6rem}.padding-right-7rem{padding-right:7rem}.padding-right-8rem{padding-right:8rem}.padding-top-0,.padding-top-none{padding-top:0}.padding-top-xs{padding-top:calc(var(--spacing-unit, 8px)*.25)}.padding-top-sm{padding-top:calc(var(--spacing-unit, 8px)*.5)}.padding-top-md{padding-top:calc(var(--spacing-unit, 8px)*1)}.padding-top-lg{padding-top:calc(var(--spacing-unit, 8px)*2)}.padding-top-xl{padding-top:calc(var(--spacing-unit, 8px)*3)}.padding-top-xxl{padding-top:calc(var(--spacing-unit, 8px)*4)}.padding-top-xxxl{padding-top:calc(var(--spacing-unit, 8px)*5)}.padding-top-2xl{padding-top:calc(var(--spacing-unit, 8px)*6)}.padding-top-2xxl{padding-top:calc(var(--spacing-unit, 8px)*8)}.padding-top-2xxxl{padding-top:calc(var(--spacing-unit, 8px)*10)}.padding-top-1em{padding-top:1em}.padding-top-2em{padding-top:2em}.padding-top-3em{padding-top:3em}.padding-top-4em{padding-top:4em}.padding-top-5em{padding-top:5em}.padding-top-6em{padding-top:6em}.padding-top-7em{padding-top:7em}.padding-top-8em{padding-top:8em}.padding-top-1rem{padding-top:1rem}.padding-top-2rem{padding-top:2rem}.padding-top-3rem{padding-top:3rem}.padding-top-4rem{padding-top:4rem}.padding-top-5rem{padding-top:5rem}.padding-top-6rem{padding-top:6rem}.padding-top-7rem{padding-top:7rem}.padding-top-8rem{padding-top:8rem}.padding-bottom-0,.padding-bottom-none{padding-bottom:0}.padding-bottom-xs{padding-bottom:calc(var(--spacing-unit, 8px)*.25)}.padding-bottom-sm{padding-bottom:calc(var(--spacing-unit, 8px)*.5)}.padding-bottom-md{padding-bottom:calc(var(--spacing-unit, 8px)*1)}.padding-bottom-lg{padding-bottom:calc(var(--spacing-unit, 8px)*2)}.padding-bottom-xl{padding-bottom:calc(var(--spacing-unit, 8px)*3)}.padding-bottom-xxl{padding-bottom:calc(var(--spacing-unit, 8px)*4)}.padding-bottom-xxxl{padding-bottom:calc(var(--spacing-unit, 8px)*5)}.padding-bottom-2xl{padding-bottom:calc(var(--spacing-unit, 8px)*6)}.padding-bottom-2xxl{padding-bottom:calc(var(--spacing-unit, 8px)*8)}.padding-bottom-2xxxl{padding-bottom:calc(var(--spacing-unit, 8px)*10)}.padding-bottom-1em{padding-bottom:1em}.padding-bottom-2em{padding-bottom:2em}.padding-bottom-3em{padding-bottom:3em}.padding-bottom-4em{padding-bottom:4em}.padding-bottom-5em{padding-bottom:5em}.padding-bottom-6em{padding-bottom:6em}.padding-bottom-7em{padding-bottom:7em}.padding-bottom-8em{padding-bottom:8em}.padding-bottom-1rem{padding-bottom:1rem}.padding-bottom-2rem{padding-bottom:2rem}.padding-bottom-3rem{padding-bottom:3rem}.padding-bottom-4rem{padding-bottom:4rem}.padding-bottom-5rem{padding-bottom:5rem}.padding-bottom-6rem{padding-bottom:6rem}.padding-bottom-7rem{padding-bottom:7rem}.padding-bottom-8rem{padding-bottom:8rem}.position-static{position:static}.position-relative{position:relative}.position-absolute{position:absolute}.position-fixed{position:fixed}.shadow,.shadow-hover:hover,.shadow-md,.shadow-md-hover:hover{box-shadow:0 .5rem 1rem rgba(var(--rgb-black),10%)}.shadow-xs,.shadow-xs-hover:hover{box-shadow:0 .125rem .25rem rgba(var(--rgb-black),5%)}.shadow-sm,.shadow-sm-hover:hover{box-shadow:0 .25rem .5rem rgba(var(--rgb-black),7.5%)}.shadow-lg,.shadow-lg-hover:hover{box-shadow:0 1rem 3rem rgba(var(--rgb-black),15%)}.shadow-none,.shadow-none-hover:hover{box-shadow:none}.shadow-hover,.shadow-lg-hover,.shadow-md-hover,.shadow-none-hover,.shadow-sm-hover{transition:box-shadow .2s cubic-bezier(.25,.8,.25,1)}.transition.fade-in{opacity:0;transition:opacity .3s,visibility .3s;visibility:hidden}.transition.fade-in.visible,.transition.fade-out{opacity:1;visibility:visible}.transition.fade-out{transition:opacity .3s,visibility .3s}.transition.fade-out.hidden{opacity:0;pointer-events:none;visibility:hidden}.transition.translate-down,.transition.translate-left,.transition.translate-right,.transition.translate-up{transition:transform .3s,visibility .3s}.transition.translate-up.hidden{pointer-events:none;transform:translateY(-100%);visibility:hidden}.transition.translate-down.hidden{pointer-events:none;transform:translateY(100%);visibility:hidden}.transition.translate-left.hidden{pointer-events:none;transform:translateX(-100%);visibility:hidden}.transition.translate-right.hidden{pointer-events:none;transform:translateX(100%);visibility:hidden}.font-weight-100{font-weight:100}.font-weight-200{font-weight:200}.font-weight-300{font-weight:300}.font-weight-400{font-weight:400}.font-weight-500{font-weight:500}.font-weight-600{font-weight:600}.font-weight-700{font-weight:700}.font-weight-800{font-weight:800}.font-weight-900{font-weight:900}.font-weight-thin{font-weight:100}.font-weight-extraLight{font-weight:200}.font-weight-light{font-weight:300}.font-weight-regular{font-weight:400}.font-weight-medium{font-weight:500}.font-weight-semibold{font-weight:600}.font-weight-bold{font-weight:700}.font-weight-extraBold{font-weight:800}.font-weight-black{font-weight:900}.text-nowrap{white-space:nowrap}.text-lowercase{text-transform:lowercase}.text-uppercase{text-transform:uppercase}.text-capitalize{text-transform:capitalize}.text-left{text-align:left}.text-right{text-align:right}.text-center{text-align:center}.text-justify{text-align:justify}.visible{visibility:visible}.hidden,.invisible{visibility:hidden}.whitespace-normal{white-space:normal}.whitespace-nowrap{white-space:nowrap}.whitespace-pre{white-space:pre}.whitespace-pre-line{white-space:pre-line}.whitespace-pre-wrap{white-space:pre-wrap}.width-auto{width:auto}.width-0{width:0}.width-xs{width:calc(var(--spacing-unit, 8px)*.25)}.width-sm{width:calc(var(--spacing-unit, 8px)*.5)}.width-md{width:calc(var(--spacing-unit, 8px)*1)}.width-lg{width:calc(var(--spacing-unit, 8px)*2)}.width-xl{width:calc(var(--spacing-unit, 8px)*3)}.width-xxl{width:calc(var(--spacing-unit, 8px)*4)}.width-xxxl{width:calc(var(--spacing-unit, 8px)*5)}.width-2xl{width:calc(var(--spacing-unit, 8px)*6)}.width-2xxl{width:calc(var(--spacing-unit, 8px)*8)}.width-2xxxl{width:calc(var(--spacing-unit, 8px)*10)}.width-10p{width:10%}.width-20p{width:20%}.width-25p{width:25%}.width-30p{width:30%}.width-33p{width:33%}.width-40p{width:40%}.width-50p{width:50%}.width-60p{width:60%}.width-66p{width:66%}.width-70p{width:70%}.width-75p{width:75%}.width-80p{width:80%}.width-90p{width:90%}.width-100p{width:100%}.width-10vw{width:10vw}.width-20vw{width:20vw}.width-25vw{width:25vw}.width-30vw{width:30vw}.width-33vw{width:33vw}.width-40vw{width:40vw}.width-50vw{width:50vw}.width-60vw{width:60vw}.width-66vw{width:66vw}.width-70vw{width:70vw}.width-75vw{width:75vw}.width-80vw{width:80vw}.width-90vw{width:90vw}.width-100vw{width:100vw}.width-1em{width:1em}.width-2em{width:2em}.width-3em{width:3em}.width-4em{width:4em}.width-5em{width:5em}.width-6em{width:6em}.width-7em{width:7em}.width-8em{width:8em}.wordbreak-normal,.wordbreak-wrap{word-break:normal}.wordbreak-break-all,.wordbreak-nowrap{word-break:break-all}.wordbreak-keep-all{word-break:keep-all}.z-index-0{z-index:0}.z-index-1{z-index:1}.z-index-2{z-index:2}.z-index-3{z-index:3}.z-index-4{z-index:4}.z-index-5{z-index:5}.z-index-6{z-index:6}.z-index-7{z-index:7}.z-index-8{z-index:8}.z-index-9{z-index:9}.z-index-10{z-index:10}.z-index-dropdown{z-index:var(--z-index-dropdown,1000)}.z-index-sticky{z-index:var(--z-index-sticky,1020)}.z-index-fixed{z-index:var(--z-index-fixed,1030)}.z-index-overlay{z-index:var(--z-index-overlay,1040)}.z-index-menu{z-index:var(--z-index-menu,1050)}.z-index-modal{z-index:var(--z-index-modal,1060)}.z-index-popover{z-index:var(--z-index-popover,1070)}.z-index-tooltip{z-index:var(--z-index-tooltip,1080)}.z-index-toast{z-index:var(--z-index-toast,1090)}.z-index-max{z-index:var(--z-index-max,1100)}.debug{outline:1px solid red}.debug>*{outline:1px solid #00f}.debug>*>*{outline:1px solid green}.debug>*>*>*{outline:1px solid #f0f}.debug>*>*>*>*{outline:1px solid gold}.debug-grid{background:transparent url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAAICAYAAADED76LAAAAFElEQVR4AWPAC97/9x0eCsAEPgwAVLshdpENIxcAAAAASUVORK5CYII=) repeat 0 0}.debug-grid-16{background:transparent url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAMklEQVR4AWOgCLz/b0epAa6UGuBOqQHOQHLUgFEDnAbcBZ4UGwDOkiCnkIhdgNgNxAYAiYlD+8sEuo8AAAAASUVORK5CYII=) repeat 0 0}.debug-grid-8-solid{background:#fff url(data:image/gif;base64,R0lGODdhCAAIAPEAAADw/wDx/////wAAACwAAAAACAAIAAACDZQvgaeb/lxbAIKA8y0AOw==) repeat 0 0}.debug-grid-16-solid{background:#fff url(data:image/gif;base64,R0lGODdhEAAQAPEAAADw/wDx/xXy/////ywAAAAAEAAQAAACIZyPKckYDQFsb6ZqD85jZ2+BkwiRFKehhqQCQgDHcgwEBQA7) repeat 0 0}html{font-size:1.25rem}body{overflow-x:hidden;overflow-y:scroll}body,html{font-family:Inter,ui-sans-serif,system-ui,sans-serif;letter-spacing:-.0375em;scroll-behavior:smooth}@media (prefers-reduced-motion){body,html{scroll-behavior:auto}}.page{overflow-x:hidden}.page>article{padding-bottom:8rem;padding-top:3rem;position:relative}.page#cover>.cover{height:auto;min-height:100vh;overflow-y:auto}.page#cover .introduction .btn .icon{transform:translateY(1px)}.ReactModal__Overlay{z-index:2000!important}.embedded-video:before{background-color:var(--color-surface-1)}.image-gallery__lightbox .ril-image-current.ril__image{border-radius:1rem}.image-gallery__lightbox .ril__navButtonPrev{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='gray' d='M14.71 6.71a.996.996 0 0 0-1.41 0L8.71 11.3a.996.996 0 0 0 0 1.41l4.59 4.59a.996.996 0 1 0 1.41-1.41L10.83 12l3.88-3.88c.39-.39.38-1.03 0-1.41z'/%3E%3C/svg%3E")}.image-gallery__lightbox .ril__navButtonNext{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='gray' d='M9.29 6.71a.996.996 0 0 0 0 1.41L13.17 12l-3.88 3.88a.996.996 0 1 0 1.41 1.41l4.59-4.59a.996.996 0 0 0 0-1.41L10.7 6.7c-.38-.38-1.02-.38-1.41.01z'/%3E%3C/svg%3E")}.image-gallery__lightbox .ril__closeButton{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 72 72'%3E%3Cpath fill='gray' d='M19 15a4 4 0 0 0-2.828 6.828L30.344 36 16.172 50.172a4 4 0 1 0 5.656 5.656L36 41.656l14.172 14.172a4 4 0 1 0 5.656-5.656L41.656 36l14.172-14.172a4 4 0 1 0-5.656-5.656L36 30.344 21.828 16.172A3.99 3.99 0 0 0 19 15z'/%3E%3C/svg%3E")}.image-gallery__lightbox .ril__navButtons{background-size:48px}.image-gallery__lightbox .ril__closeButton{background-size:32px;width:10vw}.image-gallery__lightbox .ril__closeButton,.image-gallery__lightbox .ril__navButtons{opacity:1}@media (hover:hover){.social-nav-links__item:hover{transform:none}.social-nav-links__list:hover .social-nav-links__item{opacity:var(--opacity-disabled,.38)}}.dock{bottom:1.5rem;justify-content:flex-start;left:50vw;position:fixed;transform:translateX(-50%);z-index:2000}.dock,.dock__container{align-items:center;display:flex}.dock__container{background-color:var(--color-surface-0);border-radius:29px;box-shadow:0 0 80px rgba(42,51,70,.2);gap:8px;justify-content:space-evenly;margin:0 6px;padding:8px}[data-theme=dark] .dock__container,[data-theme=high-contrast] .dock__container{background-color:var(--color-surface-2);box-shadow:none}.dock__section{align-items:center;display:flex;gap:8px;justify-content:space-evenly}.dock__section#gallery{display:none}.dock__section:not(:last-child):after{content:"";display:block;margin:0 4px;pointer-events:none}.dock__divider,.dock__section:not(:last-child):after{background-color:var(--color-border);height:24px;width:1px}.dock__item{align-items:center;background-color:rgba(var(--rgb-default),.08);border-radius:100%;display:flex;height:42px;justify-content:center;position:relative;transition:transform .2s;width:42px}.dock__item:hover{transform:translateY(-4px) scale(1.2)}.dock__item:active{transform:translateY(-1px) scale(1.1)}.dock__item>a,.dock__item>button{align-items:center;display:flex;height:100%;justify-content:center;overflow:hidden;width:100%}.dock__item>a>i,.dock__item>button>i{fill:rgba(var(--rgb-default),.4);color:rgba(var(--rgb-default),.4);font-size:20px}.dock__tooltip{background-color:var(--color-surface-0);border:1px solid var(--color-border);border-radius:8px;color:var(--color-foreground-muted);font-size:.625rem;font-weight:500;left:50%;letter-spacing:0;opacity:0;padding:3px 8px;pointer-events:none;position:absolute;top:-75%;transform:translateX(-50%) scale(.9);transition:opacity .2s,visibility .4s,transform .2s;visibility:hidden;white-space:nowrap}.dock__item:hover .dock__tooltip{opacity:1;transform:translateX(-50%) scale(1);visibility:visible}@media (max-width:576px){.dock__section#socials{display:none}.page#art+.dock .dock__section#gallery,.page#games+.dock .dock__section#gallery,.page#presentations+.dock .dock__section#gallery,.page#tech+.dock .dock__section#gallery,.page#websites+.dock .dock__section#gallery{display:flex}}.gallery{align-items:center;display:flex;justify-content:space-between;min-height:calc(100vh - var(--header-height, 80px));position:relative;width:100%}.gallery__slides{flex:1 1 80%;margin-bottom:6rem;margin-top:3rem;position:relative}.gallery__button{align-items:center;display:flex;flex:0 0 10%;font-size:64px;height:100%;justify-content:center;min-height:calc(100vh - var(--header-height, 80px));min-width:48px}.gallery__button.left{left:0}.gallery__button.right{right:0}.gallery__button>svg{fill:var(--color-foreground)}.gallery--vertical .gallery__slides{margin-bottom:8rem}.gallery--vertical .slide{align-items:flex-start;flex-direction:column}.gallery--vertical .slide__text-wrapper{margin-left:0;margin-top:2rem;max-width:100%;transition:none;width:100%}.gallery--vertical .slide__text-container{min-width:100%;width:100%}.gallery--vertical .slide__image>img{aspect-ratio:2.35}@media (max-width:767px){.gallery__slides{margin-left:16px;margin-right:16px}}@media (max-width:576px){.gallery__slides{margin-left:auto;margin-right:auto;padding-left:16px;padding-right:16px}.gallery__button{display:none}}.slide{align-items:center;height:100%;width:100%}.slide,.slide__image-wrapper{display:flex;justify-content:center;position:relative}.slide__image{align-items:center;background-color:var(--color-surface-1);border-radius:1rem;box-shadow:0 20px 40px rgba(42,51,70,.2),0 30px 20px -10px rgba(42,51,70,.2);display:inline-flex;justify-content:center;overflow:hidden}[data-theme=dark] .slide__image,[data-theme=high-contrast] .slide__image{box-shadow:none}.slide__image--border-none{background-color:transparent;border:none;box-shadow:none!important}.slide__image>img{object-fit:cover}.slide__text-wrapper{margin-left:3rem;max-width:40%;position:relative;transition:opacity .3s,width .3s,margin-left .3s}.slide__text-container{width:100%}.slide__text-container>.eyebrow{letter-spacing:-.025em;margin-bottom:0;margin-left:2px;text-transform:capitalize}.slide__text-container>.title{font-weight:700;margin-bottom:.5rem}@media (max-width:1365px){.slide__image{border-width:9px}}@media (max-width:767px){.slide__image{border-width:6px}}.shadow-button{background-color:var(--color-background);box-shadow:0 0 0 1px rgba(14,63,126,.06),0 1px 1px -.5px rgba(42,51,70,.03),0 2px 2px -1px rgba(42,51,70,.04),0 3px 3px -1.5px rgba(42,51,70,.04),0 5px 5px -2.5px rgba(42,51,70,.03),0 10px 10px -5px rgba(42,51,70,.03),0 24px 24px -8px rgba(42,51,70,.03);color:var(--color-default);font-size:16px;font-weight:600;transform:scale(1);transition:transform .2s,box-shadow .2s}.shadow-button:not(:disabled):hover{box-shadow:0 0 0 1px rgba(14,63,126,.06),0 1px 1px -.5px rgba(42,51,70,.03),0 2px 2px -1px rgba(42,51,70,.04),0 3px 3px -1.5px rgba(42,51,70,.04),0 5px 5px -2.5px rgba(42,51,70,.03),0 10px 10px -5px rgba(42,51,70,.03),0 24px 24px -8px rgba(42,51,70,.03),0 4px 10px rgba(42,51,70,.06);transform:translateY(-2px)}.shadow-button:not(.btn--unstyled):not(:disabled):active{transform:translateY(-2px) scale(1.04)}.shadow-button:not(:disabled):active,.shadow-button:not(:disabled):hover{background-color:var(--color-background)}[data-theme=dark] .shadow-button,[data-theme=high-contrast] .shadow-button{background-color:var(--color-default-subtle);box-shadow:none}[data-theme=dark] .shadow-button:not(:disabled):active,[data-theme=dark] .shadow-button:not(:disabled):hover,[data-theme=high-contrast] .shadow-button:not(:disabled):active,[data-theme=high-contrast] .shadow-button:not(:disabled):hover{background-color:var(--color-surface-9);box-shadow:none}.header{align-items:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background-color:rgba(240,242,245,.8);border-bottom:1px solid var(--color-border);display:flex;height:var(--header-height,80px);justify-content:space-between;position:sticky;top:0;width:100%;z-index:var(--z-index-max,1100)}[data-theme=dark] .header{background-color:rgba(25,29,35,.8)}[data-theme=high-contrast] .header{background-color:rgba(22,24,28,.8)}.header__container{align-items:center;display:flex;justify-content:space-between}.header .navbar{margin-left:16px;margin-right:16px}.header .navbar li{margin:0 3px;padding:0}.header .navbar li a{border:none;color:inherit;font-size:.875rem;font-weight:600;opacity:var(--opacity-inactive,.62);transition:color .2s,background-color .2s,opacity .2s,transform .2s;white-space:nowrap}.header .navbar li a.active,.header .navbar li a:hover{background-color:var(--color-default-subtle);opacity:1}.header__title-button{border:none;color:inherit;display:none;font-size:1.125rem;font-weight:700;letter-spacing:-.025em;margin-top:2px;padding:12px;transition:background-color .2s,transform .2s;white-space:nowrap}.header__title-button .icon-wrapper .icon{font-size:21px}.header__menu-button svg{fill:var(--color-foreground)}@media (min-width:576px){.header__container{padding-left:32px;padding-right:32px}}@media (max-width:424px){.header .social-nav-links{display:none}}@media (max-width:819px){.header .navbar{display:none}.header__title-button{display:block}}.ag-logo,.ag-logo svg{position:relative}.ag-logo svg{height:100%;padding:2px;width:100%}.ag-logo svg polygon{fill:var(--color-white,#fff)}.ag-logo__background{background-color:var(--color-default);border-radius:6px;bottom:0;left:0;position:absolute;right:0;top:0;transition:border-radius .6s ease-in-out,transform .4s ease-out}.ag-logo:hover .ag-logo__background{border-radius:50%;transform:rotate(90deg) scale(1.05)}.ag-logo--rounded .ag-logo__background{border-radius:50%}[data-theme=dark] .ag-logo__background,[data-theme=high-contrast] .ag-logo__background{background-color:var(--color-background)}.floating-logo{bottom:1.5rem;left:1.5rem;position:fixed;z-index:2000}.menu-gallery{background-color:var(--color-background);bottom:0;left:0;overflow-x:hidden;overflow-y:auto;position:fixed;right:0;top:0;z-index:var(--z-index-fixed,1030)}.menu-gallery.open{pointer-events:all;visibility:visible}.menu-gallery.closed{pointer-events:none;visibility:hidden}.menu-gallery__container{padding-bottom:4rem;padding-top:2rem;position:relative;top:var(--header-height,80px)}.menu-gallery__list{font-size:2rem;font-weight:600;line-height:1.25;list-style:none;margin-block-end:0;margin-block-start:0;margin-inline-end:0;margin-inline-start:0;padding-inline-start:0;position:relative;text-align:left;white-space:nowrap}.menu-gallery__section>a{align-items:center;color:inherit;display:flex;font-weight:700;justify-content:flex-start;margin-bottom:.25em;width:100%}.menu-gallery__section>a .icon{font-weight:600}.menu-gallery__grid{column-gap:.5rem;display:grid;grid-template-columns:repeat(2,1fr);margin-bottom:2rem;row-gap:.5rem}.menu-gallery__thumbnail{align-items:center;background-color:var(--color-surface-1);border-radius:.25rem;display:flex;height:max-content;overflow:hidden;position:relative}@media (min-width:576px){.menu-gallery__container{padding-left:32px;padding-right:32px}.menu-gallery__list{font-size:2.5rem}.menu-gallery__grid{column-gap:.75rem;grid-template-columns:repeat(3,1fr);row-gap:.75rem}.menu-gallery__thumbnail{border-radius:.4rem}}@media (min-width:1024px){.menu-gallery__list{font-size:3rem}.menu-gallery__grid{grid-template-columns:repeat(4,1fr)}}@media (min-width:1366px){.menu-gallery__grid{grid-template-columns:repeat(5,1fr)}}@media (min-width:1440px){.menu-gallery__grid{grid-template-columns:repeat(6,1fr)}}.project.container-md{max-width:720px;overflow-x:hidden;width:100%}.project__title{text-wrap:balance;font-weight:700;line-height:1;margin-bottom:.5rem}.project__subtitle{color:var(--color-foreground-muted,inherit);font-size:.875rem;font-weight:600;letter-spacing:-.025em;margin-bottom:.75rem;margin-left:4px;text-transform:capitalize}.project__subtitle .separator{margin:0 .5rem;opacity:var(--opacity-inactive,.62)}.project__subtitle+.btn-group{width:100%}.project__description{margin-top:1.5rem}.project__badges{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-start}.project__badges .badge{background-color:var(--color-primary-subtle);border:none;color:var(--color-primary);font-size:.75em;font-weight:600;margin:0}.project section{margin-bottom:2rem;margin-top:2rem}.project section:first-child{margin-top:0}.project section:last-child{margin-bottom:0}.project section>.embedded-video,.project section>.progressive-image>img,.project section>a>.progressive-image>img{border-radius:.5rem;box-shadow:0 0 40px rgba(42,51,70,.2)}.project img{max-width:100%}.project .image-link,.project .image-link img{display:block}.project .image-gallery{margin-bottom:12px;margin-top:12px}.project .image-gallery__thumbnails{column-gap:12px;row-gap:12px}.project .image-gallery__thumbnails img{border-radius:.25rem;box-shadow:0 0 0 1px rgba(14,63,126,.06),0 1px 1px -.5px rgba(42,51,70,.03),0 2px 2px -1px rgba(42,51,70,.04),0 3px 3px -1.5px rgba(42,51,70,.04),0 5px 5px -2.5px rgba(42,51,70,.03),0 10px 10px -5px rgba(42,51,70,.03),0 24px 24px -8px rgba(42,51,70,.03)}[data-theme=dark] .project .image-gallery__thumbnails img,[data-theme=dark] .project section>.embedded-video,[data-theme=dark] .project section>.progressive-image>img,[data-theme=dark] .project section>a>.progressive-image>img,[data-theme=high-contrast] .project .image-gallery__thumbnails img,[data-theme=high-contrast] .project section>.embedded-video,[data-theme=high-contrast] .project section>.progressive-image>img,[data-theme=high-contrast] .project section>a>.progressive-image>img{box-shadow:none}@media (max-width:1024px){.project{padding-bottom:144px}}@media (max-width:767px){.project section{margin-bottom:1rem;margin-top:1rem}}@media (max-width:576px){.project__title{font-size:3rem}}@media (max-width:480px){.project__title{font-size:2.5rem}}.projects-list{font-size:.75rem;max-width:962px;min-height:105vh;overflow-x:hidden;width:100%}.projects-list__header{margin-bottom:2.5rem}.projects-list__header>h1{font-weight:700;margin-bottom:.5rem}.projects-list__filters{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-start;width:100%}.projects-list__filters .badge{background-color:var(--color-primary-subtle);border:none;color:var(--color-primary);font-size:.875em;font-weight:600}.projects-list__filters .badge--selected,.projects-list__filters .badge:hover{background-color:var(--color-primary);color:var(--color-on-primary)}.projects-list__category{margin-bottom:2rem;margin-top:0;transition:margin .4s,opacity .4s,visibility .4s}.projects-list__category--empty{margin-bottom:0;margin-top:0;opacity:0;pointer-events:none;visibility:hidden}.projects-list__category:last-child{margin-bottom:0}.projects-list__category>h2{font-weight:700;height:24px;margin-bottom:0;padding-left:2px;transition:height .4s}.projects-list__category--empty>h2{height:0}.projects-list__category>ul{list-style:none;margin-block-end:.5rem;margin-block-start:.5rem;margin-inline-end:0;margin-inline-start:0;padding-inline-start:0;transition:margin-block-start .4s,margin-block-end .4s;white-space:nowrap;width:100%}.projects-list__category--empty>ul{margin-block-end:0;margin-block-start:0}.projects-list__item{align-items:center;border-radius:16px;display:flex;height:48px;justify-content:center;transition:height .4s,opacity .4s,visibility .4s;width:100%}.projects-list__item:hover{background-color:var(--color-surface-2)}.projects-list__item--hidden{height:0;opacity:0;pointer-events:none;visibility:hidden}.projects-list__item>a{align-items:center;display:flex;justify-content:space-between;padding:12px;width:100%}.projects-list__text{flex-grow:0;flex-shrink:0;min-height:24px}.projects-list__title{font-weight:600;margin-right:8px}.projects-list__description{color:var(--color-foreground-subtle);display:none}.projects-list__line{flex:1 1 100%;margin:0 .5rem}.projects-list__date{color:var(--color-foreground-subtle);flex-grow:0;flex-shrink:0}@media (min-width:700px){.projects-list__description{display:inline-block}} \ No newline at end of file diff --git a/tech/blockchain-gardens/index.html b/tech/blockchain-gardens/index.html index 6a733d4..3ee77fc 100644 --- a/tech/blockchain-gardens/index.html +++ b/tech/blockchain-gardens/index.html @@ -1 +1 @@ -Adam Graham • Blockchain Gardens

Blockchain Gardens

June 2018|Front-end Developer, 3D Designer
Unity
C#
Ethereum
Firebase
RFID
AWS
PCF

The blockchain is as complicated, misunderstood and powerfully compelling as any emerging technology that currently exists. It's no longer sufficient to merely explain the technical nuances and intricacies, the time has come for you to experience them. Built on the Ethereum backbone, Solstice FWD attendees participated in one of the first human blockchain experiments in history. Interactions and exchanges were recorded on the FWD ledger and the "future of trust in a trustless world" was on full display.

Blockchain Gardens is a real-time 3D visualization of a private Ethereum blockchain instance displayed at Solstice's annual digital innovation summit. Attendees at the event were tracked throughout the space by an RFID in their badge. As they visited each event booth, these moments and experiences were recorded on the blockchain. We wanted to explore what it would be like to put humans at the center of this emerging technology.

Media

GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file +Adam Graham • Blockchain Gardens

Blockchain Gardens

June 2018|Front-end Developer, 3D Designer
Unity
C#
Ethereum
Firebase
RFID
AWS
PCF

The blockchain is as complicated, misunderstood and powerfully compelling as any emerging technology that currently exists. It's no longer sufficient to merely explain the technical nuances and intricacies, the time has come for you to experience them. Built on the Ethereum backbone, Solstice FWD attendees participated in one of the first human blockchain experiments in history. Interactions and exchanges were recorded on the FWD ledger and the "future of trust in a trustless world" was on full display.

Blockchain Gardens is a real-time 3D visualization of a private Ethereum blockchain instance displayed at Solstice's annual digital innovation summit. Attendees at the event were tracked throughout the space by an RFID in their badge. As they visited each event booth, these moments and experiences were recorded on the blockchain. We wanted to explore what it would be like to put humans at the center of this emerging technology.

Media

GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file diff --git a/tech/index.html b/tech/index.html index 36cc314..a3fcb9e 100644 --- a/tech/index.html +++ b/tech/index.html @@ -1 +1 @@ -Adam Graham • Tech Showcases
GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file +Adam Graham • Tech Showcases
GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file diff --git a/tech/rockstar/index.html b/tech/rockstar/index.html index c0be246..faa8eb9 100644 --- a/tech/rockstar/index.html +++ b/tech/rockstar/index.html @@ -1 +1 @@ -Adam Graham • RockstAR

RockstAR

September 2016|Front-end Developer, Experience Designer
Unity
C#
HoloLens
Raspberry Pi + Node.js
Phillips Hue Lights
IoT Devices
iPad

Augmented reality is making it possible to merge virtual objects into the physical world around us. To explore the possibilities, Adam and fellow Solstice engineers built RockstAR, an interactive AR experience demoed at Solstice FWD. By coupling the power of Microsoft's HoloLens, Philips Hue Lightbulbs, and a series of stage technologies, users are given the ability to customize a live rock band experience.

You can choose your song and color theme preferences using digital menus. Once you're ready to go, the band plays your song as you set the stage for your audience and let the lights groove to the beat. You might look a little odd pointing to things no one else can see, but the joke's on them - you're the star of the show!

Media

GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file +Adam Graham • RockstAR

RockstAR

September 2016|Front-end Developer, Experience Designer
Unity
C#
HoloLens
Raspberry Pi + Node.js
Phillips Hue Lights
IoT Devices
iPad

Augmented reality is making it possible to merge virtual objects into the physical world around us. To explore the possibilities, Adam and fellow Solstice engineers built RockstAR, an interactive AR experience demoed at Solstice FWD. By coupling the power of Microsoft's HoloLens, Philips Hue Lightbulbs, and a series of stage technologies, users are given the ability to customize a live rock band experience.

You can choose your song and color theme preferences using digital menus. Once you're ready to go, the band plays your song as you set the stage for your audience and let the lights groove to the beat. You might look a little odd pointing to things no one else can see, but the joke's on them - you're the star of the show!

Media

GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file diff --git a/tech/vender-vr/index.html b/tech/vender-vr/index.html index 832ea21..64bd708 100644 --- a/tech/vender-vr/index.html +++ b/tech/vender-vr/index.html @@ -1 +1 @@ -Adam Graham • Vender VR

Vender VR

September 2015|Unity Developer
Unity
C#
Oculus Rift
Leap Motion
Raspberry Pi
Hybris Platform

Vender is an IoT connected vending machine that started as an R&D project at Solstice before Adam joined the team. Less than a month before Solstice's digital innovation summit - Solstice FWD - Vender was expanded to the virtual world. Adam took on the project head first and developed the first ever virtual reality vending machine experience.

A user vends the drink of their choice by putting their hand up to one of the drink taps and waiting for the cup to be filled. Once filled, a service call is made to the Raspberry Pi hooked up to the vending machine, which then vends the user's drink. Drink choices are populated from a Hybris Platform which stores and manages all of Vender's data.

Media

GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file +Adam Graham • Vender VR

Vender VR

September 2015|Unity Developer
Unity
C#
Oculus Rift
Leap Motion
Raspberry Pi
Hybris Platform

Vender is an IoT connected vending machine that started as an R&D project at Solstice before Adam joined the team. Less than a month before Solstice's digital innovation summit - Solstice FWD - Vender was expanded to the virtual world. Adam took on the project head first and developed the first ever virtual reality vending machine experience.

A user vends the drink of their choice by putting their hand up to one of the drink taps and waiting for the cup to be filled. Once filled, a service call is made to the Raspberry Pi hooked up to the vending machine, which then vends the user's drink. Drink choices are populated from a Hybris Platform which stores and manages all of Vender's data.

Media

GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file diff --git a/webpack-runtime-284d8f587ec3a9957b06.js b/webpack-runtime-284d8f587ec3a9957b06.js deleted file mode 100644 index 9d70554..0000000 --- a/webpack-runtime-284d8f587ec3a9957b06.js +++ /dev/null @@ -1,2 +0,0 @@ -!function(){"use strict";var e,n,t,r={},o={};function s(e){var n=o[e];if(void 0!==n)return n.exports;var t=o[e]={exports:{}};return r[e](t,t.exports,s),t.exports}s.m=r,e=[],s.O=function(n,t,r,o){if(!t){var a=1/0;for(u=0;u=o)&&Object.keys(s.O).every((function(e){return s.O[e](t[i])}))?t.splice(i--,1):(c=!1,o0&&e[u-1][2]>o;u--)e[u]=e[u-1];e[u]=[t,r,o]},s.n=function(e){var n=e&&e.__esModule?function(){return e.default}:function(){return e};return s.d(n,{a:n}),n},s.d=function(e,n){for(var t in n)s.o(n,t)&&!s.o(e,t)&&Object.defineProperty(e,t,{enumerable:!0,get:n[t]})},s.f={},s.e=function(e){return Promise.all(Object.keys(s.f).reduce((function(n,t){return s.f[t](e,n),n}),[]))},s.u=function(e){return{120:"component---src-pages-art-js",125:"component---src-pages-404-js",156:"component---src-pages-art-art-json-json-id-js",293:"component---src-pages-index-js",324:"component---src-pages-presentations-presentations-json-json-id-js",429:"component---src-pages-projects-js",464:"component---src-pages-presentations-js",506:"component---src-pages-software-js",520:"component---src-pages-games-games-json-json-id-js",746:"component---src-pages-tech-tech-json-json-id-js",771:"7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30",830:"component---src-pages-games-js",922:"component---src-pages-websites-websites-json-json-id-js",933:"component---src-pages-websites-js",935:"component---src-pages-tech-js"}[e]+"-"+{120:"72f0f3bdbc61943bc2cb",125:"d1203087144cbdfbf0bc",156:"4e8a242549dc50ff49f1",293:"186dac701b65cc23788b",324:"c28b828410e6f33d9245",429:"a15f4187e03e2bc882ac",464:"ef338db105d67c97982b",506:"ea75cd86f29da1c9979a",520:"ad38f6099c7f2a1cb117",746:"fd719b20aee8818d9dec",771:"a2b573f288bb94ad12ca",830:"dfbada6fbd2ff8012889",922:"0a43b2c359f70cc28297",933:"e6f8e60d3f29edbfcba7",935:"66907ecb2446d2b384e2"}[e]+".js"},s.miniCssF=function(e){return"styles.798d7058577ffdad1e42.css"},s.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),s.o=function(e,n){return Object.prototype.hasOwnProperty.call(e,n)},n={},t="@adamgraham/portfolio:",s.l=function(e,r,o,a){if(n[e])n[e].push(r);else{var c,i;if(void 0!==o)for(var f=document.getElementsByTagName("script"),u=0;u 0 && deferred[i - 1][2] > priority; i--) deferred[i] = deferred[i - 1];\n\t\tdeferred[i] = [chunkIds, fn, priority];\n\t\treturn;\n\t}\n\tvar notFulfilled = Infinity;\n\tfor (var i = 0; i < deferred.length; i++) {\n\t\tvar chunkIds = deferred[i][0];\n\t\tvar fn = deferred[i][1];\n\t\tvar priority = deferred[i][2];\n\t\tvar fulfilled = true;\n\t\tfor (var j = 0; j < chunkIds.length; j++) {\n\t\t\tif ((priority & 1 === 0 || notFulfilled >= priority) && Object.keys(__webpack_require__.O).every(function(key) { return __webpack_require__.O[key](chunkIds[j]); })) {\n\t\t\t\tchunkIds.splice(j--, 1);\n\t\t\t} else {\n\t\t\t\tfulfilled = false;\n\t\t\t\tif(priority < notFulfilled) notFulfilled = priority;\n\t\t\t}\n\t\t}\n\t\tif(fulfilled) {\n\t\t\tdeferred.splice(i--, 1)\n\t\t\tvar r = fn();\n\t\t\tif (r !== undefined) result = r;\n\t\t}\n\t}\n\treturn result;\n};","var inProgress = {};\nvar dataWebpackPrefix = \"@adamgraham/portfolio:\";\n// loadScript function to load a script via script tag\n__webpack_require__.l = function(url, done, key, chunkId) {\n\tif(inProgress[url]) { inProgress[url].push(done); return; }\n\tvar script, needAttach;\n\tif(key !== undefined) {\n\t\tvar scripts = document.getElementsByTagName(\"script\");\n\t\tfor(var i = 0; i < scripts.length; i++) {\n\t\t\tvar s = scripts[i];\n\t\t\tif(s.getAttribute(\"src\") == url || s.getAttribute(\"data-webpack\") == dataWebpackPrefix + key) { script = s; break; }\n\t\t}\n\t}\n\tif(!script) {\n\t\tneedAttach = true;\n\t\tscript = document.createElement('script');\n\n\t\tscript.charset = 'utf-8';\n\t\tscript.timeout = 120;\n\t\tif (__webpack_require__.nc) {\n\t\t\tscript.setAttribute(\"nonce\", __webpack_require__.nc);\n\t\t}\n\t\tscript.setAttribute(\"data-webpack\", dataWebpackPrefix + key);\n\n\t\tscript.src = url;\n\t}\n\tinProgress[url] = [done];\n\tvar onScriptComplete = function(prev, event) {\n\t\t// avoid mem leaks in IE.\n\t\tscript.onerror = script.onload = null;\n\t\tclearTimeout(timeout);\n\t\tvar doneFns = inProgress[url];\n\t\tdelete inProgress[url];\n\t\tscript.parentNode && script.parentNode.removeChild(script);\n\t\tdoneFns && doneFns.forEach(function(fn) { return fn(event); });\n\t\tif(prev) return prev(event);\n\t}\n\tvar timeout = setTimeout(onScriptComplete.bind(null, undefined, { type: 'timeout', target: script }), 120000);\n\tscript.onerror = onScriptComplete.bind(null, script.onerror);\n\tscript.onload = onScriptComplete.bind(null, script.onload);\n\tneedAttach && document.head.appendChild(script);\n};","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = function(module) {\n\tvar getter = module && module.__esModule ?\n\t\tfunction() { return module['default']; } :\n\t\tfunction() { return module; };\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = function(exports, definition) {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.f = {};\n// This file contains only the entry chunk.\n// The chunk loading function for additional chunks\n__webpack_require__.e = function(chunkId) {\n\treturn Promise.all(Object.keys(__webpack_require__.f).reduce(function(promises, key) {\n\t\t__webpack_require__.f[key](chunkId, promises);\n\t\treturn promises;\n\t}, []));\n};","// This function allow to reference async chunks\n__webpack_require__.u = function(chunkId) {\n\t// return url for filenames based on template\n\treturn \"\" + {\"120\":\"component---src-pages-art-js\",\"125\":\"component---src-pages-404-js\",\"156\":\"component---src-pages-art-art-json-json-id-js\",\"293\":\"component---src-pages-index-js\",\"324\":\"component---src-pages-presentations-presentations-json-json-id-js\",\"429\":\"component---src-pages-projects-js\",\"464\":\"component---src-pages-presentations-js\",\"506\":\"component---src-pages-software-js\",\"520\":\"component---src-pages-games-games-json-json-id-js\",\"746\":\"component---src-pages-tech-tech-json-json-id-js\",\"771\":\"7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30\",\"830\":\"component---src-pages-games-js\",\"922\":\"component---src-pages-websites-websites-json-json-id-js\",\"933\":\"component---src-pages-websites-js\",\"935\":\"component---src-pages-tech-js\"}[chunkId] + \"-\" + {\"120\":\"72f0f3bdbc61943bc2cb\",\"125\":\"d1203087144cbdfbf0bc\",\"156\":\"4e8a242549dc50ff49f1\",\"293\":\"186dac701b65cc23788b\",\"324\":\"c28b828410e6f33d9245\",\"429\":\"a15f4187e03e2bc882ac\",\"464\":\"ef338db105d67c97982b\",\"506\":\"ea75cd86f29da1c9979a\",\"520\":\"ad38f6099c7f2a1cb117\",\"746\":\"fd719b20aee8818d9dec\",\"771\":\"a2b573f288bb94ad12ca\",\"830\":\"dfbada6fbd2ff8012889\",\"922\":\"0a43b2c359f70cc28297\",\"933\":\"e6f8e60d3f29edbfcba7\",\"935\":\"66907ecb2446d2b384e2\"}[chunkId] + \".js\";\n};","// This function allow to reference all chunks\n__webpack_require__.miniCssF = function(chunkId) {\n\t// return url for filenames based on template\n\treturn \"\" + \"styles\" + \".\" + \"798d7058577ffdad1e42\" + \".css\";\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }","// define __esModule on exports\n__webpack_require__.r = function(exports) {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","__webpack_require__.p = \"/\";","// no baseURI\n\n// object to store loaded and loading chunks\n// undefined = chunk not loaded, null = chunk preloaded/prefetched\n// [resolve, reject, Promise] = chunk loading, 0 = chunk loaded\nvar installedChunks = {\n\t311: 0,\n\t869: 0\n};\n\n__webpack_require__.f.j = function(chunkId, promises) {\n\t\t// JSONP chunk loading for javascript\n\t\tvar installedChunkData = __webpack_require__.o(installedChunks, chunkId) ? installedChunks[chunkId] : undefined;\n\t\tif(installedChunkData !== 0) { // 0 means \"already installed\".\n\n\t\t\t// a Promise means \"currently loading\".\n\t\t\tif(installedChunkData) {\n\t\t\t\tpromises.push(installedChunkData[2]);\n\t\t\t} else {\n\t\t\t\tif(!/^(311|869)$/.test(chunkId)) {\n\t\t\t\t\t// setup Promise in chunk cache\n\t\t\t\t\tvar promise = new Promise(function(resolve, reject) { installedChunkData = installedChunks[chunkId] = [resolve, reject]; });\n\t\t\t\t\tpromises.push(installedChunkData[2] = promise);\n\n\t\t\t\t\t// start chunk loading\n\t\t\t\t\tvar url = __webpack_require__.p + __webpack_require__.u(chunkId);\n\t\t\t\t\t// create error before stack unwound to get useful stacktrace later\n\t\t\t\t\tvar error = new Error();\n\t\t\t\t\tvar loadingEnded = function(event) {\n\t\t\t\t\t\tif(__webpack_require__.o(installedChunks, chunkId)) {\n\t\t\t\t\t\t\tinstalledChunkData = installedChunks[chunkId];\n\t\t\t\t\t\t\tif(installedChunkData !== 0) installedChunks[chunkId] = undefined;\n\t\t\t\t\t\t\tif(installedChunkData) {\n\t\t\t\t\t\t\t\tvar errorType = event && (event.type === 'load' ? 'missing' : event.type);\n\t\t\t\t\t\t\t\tvar realSrc = event && event.target && event.target.src;\n\t\t\t\t\t\t\t\terror.message = 'Loading chunk ' + chunkId + ' failed.\\n(' + errorType + ': ' + realSrc + ')';\n\t\t\t\t\t\t\t\terror.name = 'ChunkLoadError';\n\t\t\t\t\t\t\t\terror.type = errorType;\n\t\t\t\t\t\t\t\terror.request = realSrc;\n\t\t\t\t\t\t\t\tinstalledChunkData[1](error);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\t\t\t\t\t__webpack_require__.l(url, loadingEnded, \"chunk-\" + chunkId, chunkId);\n\t\t\t\t} else installedChunks[chunkId] = 0;\n\t\t\t}\n\t\t}\n};\n\n// no prefetching\n\n// no preloaded\n\n// no HMR\n\n// no HMR manifest\n\n__webpack_require__.O.j = function(chunkId) { return installedChunks[chunkId] === 0; };\n\n// install a JSONP callback for chunk loading\nvar webpackJsonpCallback = function(parentChunkLoadingFunction, data) {\n\tvar chunkIds = data[0];\n\tvar moreModules = data[1];\n\tvar runtime = data[2];\n\t// add \"moreModules\" to the modules object,\n\t// then flag all \"chunkIds\" as loaded and fire callback\n\tvar moduleId, chunkId, i = 0;\n\tif(chunkIds.some(function(id) { return installedChunks[id] !== 0; })) {\n\t\tfor(moduleId in moreModules) {\n\t\t\tif(__webpack_require__.o(moreModules, moduleId)) {\n\t\t\t\t__webpack_require__.m[moduleId] = moreModules[moduleId];\n\t\t\t}\n\t\t}\n\t\tif(runtime) var result = runtime(__webpack_require__);\n\t}\n\tif(parentChunkLoadingFunction) parentChunkLoadingFunction(data);\n\tfor(;i < chunkIds.length; i++) {\n\t\tchunkId = chunkIds[i];\n\t\tif(__webpack_require__.o(installedChunks, chunkId) && installedChunks[chunkId]) {\n\t\t\tinstalledChunks[chunkId][0]();\n\t\t}\n\t\tinstalledChunks[chunkId] = 0;\n\t}\n\treturn __webpack_require__.O(result);\n}\n\nvar chunkLoadingGlobal = self[\"webpackChunk_adamgraham_portfolio\"] = self[\"webpackChunk_adamgraham_portfolio\"] || [];\nchunkLoadingGlobal.forEach(webpackJsonpCallback.bind(null, 0));\nchunkLoadingGlobal.push = webpackJsonpCallback.bind(null, chunkLoadingGlobal.push.bind(chunkLoadingGlobal));"],"names":["deferred","inProgress","dataWebpackPrefix","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","undefined","exports","module","__webpack_modules__","m","O","result","chunkIds","fn","priority","notFulfilled","Infinity","i","length","fulfilled","j","Object","keys","every","key","splice","r","n","getter","__esModule","d","a","definition","o","defineProperty","enumerable","get","f","e","chunkId","Promise","all","reduce","promises","u","miniCssF","g","globalThis","this","Function","window","obj","prop","prototype","hasOwnProperty","call","l","url","done","push","script","needAttach","scripts","document","getElementsByTagName","s","getAttribute","createElement","charset","timeout","nc","setAttribute","src","onScriptComplete","prev","event","onerror","onload","clearTimeout","doneFns","parentNode","removeChild","forEach","setTimeout","bind","type","target","head","appendChild","Symbol","toStringTag","value","p","installedChunks","installedChunkData","test","promise","resolve","reject","error","Error","errorType","realSrc","message","name","request","webpackJsonpCallback","parentChunkLoadingFunction","data","moreModules","runtime","some","id","chunkLoadingGlobal","self"],"sourceRoot":""} \ No newline at end of file diff --git a/webpack-runtime-5fb14cc844aad905efef.js b/webpack-runtime-5fb14cc844aad905efef.js new file mode 100644 index 0000000..9ce566d --- /dev/null +++ b/webpack-runtime-5fb14cc844aad905efef.js @@ -0,0 +1,2 @@ +!function(){"use strict";var e,t,n,r={},o={};function a(e){var t=o[e];if(void 0!==t)return t.exports;var n=o[e]={exports:{}};return r[e](n,n.exports,a),n.exports}a.m=r,e=[],a.O=function(t,n,r,o){if(!n){var s=1/0;for(u=0;u=o)&&Object.keys(a.O).every((function(e){return a.O[e](n[i])}))?n.splice(i--,1):(c=!1,o0&&e[u-1][2]>o;u--)e[u]=e[u-1];e[u]=[n,r,o]},a.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return a.d(t,{a:t}),t},a.d=function(e,t){for(var n in t)a.o(t,n)&&!a.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})},a.f={},a.e=function(e){return Promise.all(Object.keys(a.f).reduce((function(t,n){return a.f[n](e,t),t}),[]))},a.u=function(e){return{34:"component---src-pages-presentations-tsx",130:"component---src-pages-games-games-json-json-id-tsx",148:"component---src-pages-websites-websites-json-json-id-tsx",245:"component---src-pages-index-tsx",355:"component---src-pages-gallery-tsx",359:"component---src-pages-tech-tsx",446:"component---src-pages-art-art-json-json-id-tsx",453:"component---src-pages-404-tsx",560:"component---src-pages-games-tsx",564:"component---src-pages-software-tsx",708:"component---src-pages-tech-tech-json-json-id-tsx",713:"bb2a438c5d749940577b6da90d079ffc6be879e5",781:"component---src-pages-websites-tsx",789:"component---src-pages-projects-tsx",886:"component---src-pages-presentations-presentations-json-json-id-tsx",970:"component---src-pages-art-tsx"}[e]+"-"+{34:"bafbf6b4a4a8750b21b0",130:"af2fe7f1bbff9c002bc2",148:"e1498755bd2c989d20b3",245:"04d7db7b20b674f22098",355:"482ef72b34404869fafb",359:"9ee90f481db012c17642",446:"5edc4c77927e975ada02",453:"616a846c6313980ead8b",560:"a7cbe020e3366b17fca6",564:"c4b83ef2f542ba23efe6",708:"d1520a20b9413dd07cd2",713:"d46bc632d9a40ea835fc",781:"9b48b666ace10a338012",789:"eec5de8bb09262d73b14",886:"0a058075e95972f501e1",970:"6aa6e8ebf5e3e301a735"}[e]+".js"},a.miniCssF=function(e){return"styles.4de84519df67d9bc71d6.css"},a.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),a.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t={},n="@adamgraham/portfolio:",a.l=function(e,r,o,s){if(t[e])t[e].push(r);else{var c,i;if(void 0!==o)for(var f=document.getElementsByTagName("script"),u=0;u 0 && deferred[i - 1][2] > priority; i--) deferred[i] = deferred[i - 1];\n\t\tdeferred[i] = [chunkIds, fn, priority];\n\t\treturn;\n\t}\n\tvar notFulfilled = Infinity;\n\tfor (var i = 0; i < deferred.length; i++) {\n\t\tvar chunkIds = deferred[i][0];\n\t\tvar fn = deferred[i][1];\n\t\tvar priority = deferred[i][2];\n\t\tvar fulfilled = true;\n\t\tfor (var j = 0; j < chunkIds.length; j++) {\n\t\t\tif ((priority & 1 === 0 || notFulfilled >= priority) && Object.keys(__webpack_require__.O).every(function(key) { return __webpack_require__.O[key](chunkIds[j]); })) {\n\t\t\t\tchunkIds.splice(j--, 1);\n\t\t\t} else {\n\t\t\t\tfulfilled = false;\n\t\t\t\tif(priority < notFulfilled) notFulfilled = priority;\n\t\t\t}\n\t\t}\n\t\tif(fulfilled) {\n\t\t\tdeferred.splice(i--, 1)\n\t\t\tvar r = fn();\n\t\t\tif (r !== undefined) result = r;\n\t\t}\n\t}\n\treturn result;\n};","var inProgress = {};\nvar dataWebpackPrefix = \"@adamgraham/portfolio:\";\n// loadScript function to load a script via script tag\n__webpack_require__.l = function(url, done, key, chunkId) {\n\tif(inProgress[url]) { inProgress[url].push(done); return; }\n\tvar script, needAttach;\n\tif(key !== undefined) {\n\t\tvar scripts = document.getElementsByTagName(\"script\");\n\t\tfor(var i = 0; i < scripts.length; i++) {\n\t\t\tvar s = scripts[i];\n\t\t\tif(s.getAttribute(\"src\") == url || s.getAttribute(\"data-webpack\") == dataWebpackPrefix + key) { script = s; break; }\n\t\t}\n\t}\n\tif(!script) {\n\t\tneedAttach = true;\n\t\tscript = document.createElement('script');\n\n\t\tscript.charset = 'utf-8';\n\t\tscript.timeout = 120;\n\t\tif (__webpack_require__.nc) {\n\t\t\tscript.setAttribute(\"nonce\", __webpack_require__.nc);\n\t\t}\n\t\tscript.setAttribute(\"data-webpack\", dataWebpackPrefix + key);\n\n\t\tscript.src = url;\n\t}\n\tinProgress[url] = [done];\n\tvar onScriptComplete = function(prev, event) {\n\t\t// avoid mem leaks in IE.\n\t\tscript.onerror = script.onload = null;\n\t\tclearTimeout(timeout);\n\t\tvar doneFns = inProgress[url];\n\t\tdelete inProgress[url];\n\t\tscript.parentNode && script.parentNode.removeChild(script);\n\t\tdoneFns && doneFns.forEach(function(fn) { return fn(event); });\n\t\tif(prev) return prev(event);\n\t}\n\tvar timeout = setTimeout(onScriptComplete.bind(null, undefined, { type: 'timeout', target: script }), 120000);\n\tscript.onerror = onScriptComplete.bind(null, script.onerror);\n\tscript.onload = onScriptComplete.bind(null, script.onload);\n\tneedAttach && document.head.appendChild(script);\n};","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = function(module) {\n\tvar getter = module && module.__esModule ?\n\t\tfunction() { return module['default']; } :\n\t\tfunction() { return module; };\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = function(exports, definition) {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.f = {};\n// This file contains only the entry chunk.\n// The chunk loading function for additional chunks\n__webpack_require__.e = function(chunkId) {\n\treturn Promise.all(Object.keys(__webpack_require__.f).reduce(function(promises, key) {\n\t\t__webpack_require__.f[key](chunkId, promises);\n\t\treturn promises;\n\t}, []));\n};","// This function allow to reference async chunks\n__webpack_require__.u = function(chunkId) {\n\t// return url for filenames based on template\n\treturn \"\" + {\"34\":\"component---src-pages-presentations-tsx\",\"130\":\"component---src-pages-games-games-json-json-id-tsx\",\"148\":\"component---src-pages-websites-websites-json-json-id-tsx\",\"245\":\"component---src-pages-index-tsx\",\"355\":\"component---src-pages-gallery-tsx\",\"359\":\"component---src-pages-tech-tsx\",\"446\":\"component---src-pages-art-art-json-json-id-tsx\",\"453\":\"component---src-pages-404-tsx\",\"560\":\"component---src-pages-games-tsx\",\"564\":\"component---src-pages-software-tsx\",\"708\":\"component---src-pages-tech-tech-json-json-id-tsx\",\"713\":\"bb2a438c5d749940577b6da90d079ffc6be879e5\",\"781\":\"component---src-pages-websites-tsx\",\"789\":\"component---src-pages-projects-tsx\",\"886\":\"component---src-pages-presentations-presentations-json-json-id-tsx\",\"970\":\"component---src-pages-art-tsx\"}[chunkId] + \"-\" + {\"34\":\"bafbf6b4a4a8750b21b0\",\"130\":\"af2fe7f1bbff9c002bc2\",\"148\":\"e1498755bd2c989d20b3\",\"245\":\"04d7db7b20b674f22098\",\"355\":\"482ef72b34404869fafb\",\"359\":\"9ee90f481db012c17642\",\"446\":\"5edc4c77927e975ada02\",\"453\":\"616a846c6313980ead8b\",\"560\":\"a7cbe020e3366b17fca6\",\"564\":\"c4b83ef2f542ba23efe6\",\"708\":\"d1520a20b9413dd07cd2\",\"713\":\"d46bc632d9a40ea835fc\",\"781\":\"9b48b666ace10a338012\",\"789\":\"eec5de8bb09262d73b14\",\"886\":\"0a058075e95972f501e1\",\"970\":\"6aa6e8ebf5e3e301a735\"}[chunkId] + \".js\";\n};","// This function allow to reference all chunks\n__webpack_require__.miniCssF = function(chunkId) {\n\t// return url for filenames based on template\n\treturn \"\" + \"styles\" + \".\" + \"4de84519df67d9bc71d6\" + \".css\";\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }","// define __esModule on exports\n__webpack_require__.r = function(exports) {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","__webpack_require__.p = \"/\";","// no baseURI\n\n// object to store loaded and loading chunks\n// undefined = chunk not loaded, null = chunk preloaded/prefetched\n// [resolve, reject, Promise] = chunk loading, 0 = chunk loaded\nvar installedChunks = {\n\t311: 0,\n\t869: 0\n};\n\n__webpack_require__.f.j = function(chunkId, promises) {\n\t\t// JSONP chunk loading for javascript\n\t\tvar installedChunkData = __webpack_require__.o(installedChunks, chunkId) ? installedChunks[chunkId] : undefined;\n\t\tif(installedChunkData !== 0) { // 0 means \"already installed\".\n\n\t\t\t// a Promise means \"currently loading\".\n\t\t\tif(installedChunkData) {\n\t\t\t\tpromises.push(installedChunkData[2]);\n\t\t\t} else {\n\t\t\t\tif(!/^(311|869)$/.test(chunkId)) {\n\t\t\t\t\t// setup Promise in chunk cache\n\t\t\t\t\tvar promise = new Promise(function(resolve, reject) { installedChunkData = installedChunks[chunkId] = [resolve, reject]; });\n\t\t\t\t\tpromises.push(installedChunkData[2] = promise);\n\n\t\t\t\t\t// start chunk loading\n\t\t\t\t\tvar url = __webpack_require__.p + __webpack_require__.u(chunkId);\n\t\t\t\t\t// create error before stack unwound to get useful stacktrace later\n\t\t\t\t\tvar error = new Error();\n\t\t\t\t\tvar loadingEnded = function(event) {\n\t\t\t\t\t\tif(__webpack_require__.o(installedChunks, chunkId)) {\n\t\t\t\t\t\t\tinstalledChunkData = installedChunks[chunkId];\n\t\t\t\t\t\t\tif(installedChunkData !== 0) installedChunks[chunkId] = undefined;\n\t\t\t\t\t\t\tif(installedChunkData) {\n\t\t\t\t\t\t\t\tvar errorType = event && (event.type === 'load' ? 'missing' : event.type);\n\t\t\t\t\t\t\t\tvar realSrc = event && event.target && event.target.src;\n\t\t\t\t\t\t\t\terror.message = 'Loading chunk ' + chunkId + ' failed.\\n(' + errorType + ': ' + realSrc + ')';\n\t\t\t\t\t\t\t\terror.name = 'ChunkLoadError';\n\t\t\t\t\t\t\t\terror.type = errorType;\n\t\t\t\t\t\t\t\terror.request = realSrc;\n\t\t\t\t\t\t\t\tinstalledChunkData[1](error);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\t\t\t\t\t__webpack_require__.l(url, loadingEnded, \"chunk-\" + chunkId, chunkId);\n\t\t\t\t} else installedChunks[chunkId] = 0;\n\t\t\t}\n\t\t}\n};\n\n// no prefetching\n\n// no preloaded\n\n// no HMR\n\n// no HMR manifest\n\n__webpack_require__.O.j = function(chunkId) { return installedChunks[chunkId] === 0; };\n\n// install a JSONP callback for chunk loading\nvar webpackJsonpCallback = function(parentChunkLoadingFunction, data) {\n\tvar chunkIds = data[0];\n\tvar moreModules = data[1];\n\tvar runtime = data[2];\n\t// add \"moreModules\" to the modules object,\n\t// then flag all \"chunkIds\" as loaded and fire callback\n\tvar moduleId, chunkId, i = 0;\n\tif(chunkIds.some(function(id) { return installedChunks[id] !== 0; })) {\n\t\tfor(moduleId in moreModules) {\n\t\t\tif(__webpack_require__.o(moreModules, moduleId)) {\n\t\t\t\t__webpack_require__.m[moduleId] = moreModules[moduleId];\n\t\t\t}\n\t\t}\n\t\tif(runtime) var result = runtime(__webpack_require__);\n\t}\n\tif(parentChunkLoadingFunction) parentChunkLoadingFunction(data);\n\tfor(;i < chunkIds.length; i++) {\n\t\tchunkId = chunkIds[i];\n\t\tif(__webpack_require__.o(installedChunks, chunkId) && installedChunks[chunkId]) {\n\t\t\tinstalledChunks[chunkId][0]();\n\t\t}\n\t\tinstalledChunks[chunkId] = 0;\n\t}\n\treturn __webpack_require__.O(result);\n}\n\nvar chunkLoadingGlobal = self[\"webpackChunk_adamgraham_portfolio\"] = self[\"webpackChunk_adamgraham_portfolio\"] || [];\nchunkLoadingGlobal.forEach(webpackJsonpCallback.bind(null, 0));\nchunkLoadingGlobal.push = webpackJsonpCallback.bind(null, chunkLoadingGlobal.push.bind(chunkLoadingGlobal));"],"names":["deferred","inProgress","dataWebpackPrefix","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","undefined","exports","module","__webpack_modules__","m","O","result","chunkIds","fn","priority","notFulfilled","Infinity","i","length","fulfilled","j","Object","keys","every","key","splice","r","n","getter","__esModule","d","a","definition","o","defineProperty","enumerable","get","f","e","chunkId","Promise","all","reduce","promises","u","miniCssF","g","globalThis","this","Function","window","obj","prop","prototype","hasOwnProperty","call","l","url","done","push","script","needAttach","scripts","document","getElementsByTagName","s","getAttribute","createElement","charset","timeout","nc","setAttribute","src","onScriptComplete","prev","event","onerror","onload","clearTimeout","doneFns","parentNode","removeChild","forEach","setTimeout","bind","type","target","head","appendChild","Symbol","toStringTag","value","p","installedChunks","installedChunkData","test","promise","resolve","reject","error","Error","errorType","realSrc","message","name","request","webpackJsonpCallback","parentChunkLoadingFunction","data","moreModules","runtime","some","id","chunkLoadingGlobal","self"],"sourceRoot":""} \ No newline at end of file diff --git a/webpack.stats.json b/webpack.stats.json index b7e78c6..6484815 100644 --- a/webpack.stats.json +++ b/webpack.stats.json @@ -1 +1 @@ -{"name":"build-javascript","namedChunkGroups":{"app":{"name":"app","assets":[{"name":"webpack-runtime-284d8f587ec3a9957b06.js","size":4238},{"name":"styles.798d7058577ffdad1e42.css","size":112358},{"name":"framework-9311b08a6c5b48aac427.js","size":140348},{"name":"app-9442da87d5728df94a7c.js","size":66498}],"filteredAssets":0,"assetsSize":323442,"filteredAuxiliaryAssets":3,"auxiliaryAssetsSize":644554},"component---src-pages-404-js":{"name":"component---src-pages-404-js","assets":[{"name":"component---src-pages-404-js-d1203087144cbdfbf0bc.js","size":313}],"filteredAssets":0,"assetsSize":313,"filteredAuxiliaryAssets":1,"auxiliaryAssetsSize":524},"component---src-pages-art-art-json-json-id-js":{"name":"component---src-pages-art-art-json-json-id-js","assets":[{"name":"styles.798d7058577ffdad1e42.css","size":112358},{"name":"7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30-a2b573f288bb94ad12ca.js","size":164773},{"name":"component---src-pages-art-art-json-json-id-js-4e8a242549dc50ff49f1.js","size":620}],"filteredAssets":0,"assetsSize":277751,"filteredAuxiliaryAssets":2,"auxiliaryAssetsSize":549833},"component---src-pages-art-js":{"name":"component---src-pages-art-js","assets":[{"name":"styles.798d7058577ffdad1e42.css","size":112358},{"name":"7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30-a2b573f288bb94ad12ca.js","size":164773},{"name":"component---src-pages-art-js-72f0f3bdbc61943bc2cb.js","size":520}],"filteredAssets":0,"assetsSize":277651,"filteredAuxiliaryAssets":2,"auxiliaryAssetsSize":548990},"component---src-pages-games-games-json-json-id-js":{"name":"component---src-pages-games-games-json-json-id-js","assets":[{"name":"styles.798d7058577ffdad1e42.css","size":112358},{"name":"7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30-a2b573f288bb94ad12ca.js","size":164773},{"name":"component---src-pages-games-games-json-json-id-js-ad38f6099c7f2a1cb117.js","size":615}],"filteredAssets":0,"assetsSize":277746,"filteredAuxiliaryAssets":2,"auxiliaryAssetsSize":549835},"component---src-pages-games-js":{"name":"component---src-pages-games-js","assets":[{"name":"styles.798d7058577ffdad1e42.css","size":112358},{"name":"7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30-a2b573f288bb94ad12ca.js","size":164773},{"name":"component---src-pages-games-js-dfbada6fbd2ff8012889.js","size":508}],"filteredAssets":0,"assetsSize":277639,"filteredAuxiliaryAssets":2,"auxiliaryAssetsSize":548989},"component---src-pages-index-js":{"name":"component---src-pages-index-js","assets":[{"name":"styles.798d7058577ffdad1e42.css","size":112358},{"name":"7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30-a2b573f288bb94ad12ca.js","size":164773},{"name":"component---src-pages-index-js-186dac701b65cc23788b.js","size":2104}],"filteredAssets":0,"assetsSize":279235,"filteredAuxiliaryAssets":2,"auxiliaryAssetsSize":552685},"component---src-pages-presentations-js":{"name":"component---src-pages-presentations-js","assets":[{"name":"styles.798d7058577ffdad1e42.css","size":112358},{"name":"7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30-a2b573f288bb94ad12ca.js","size":164773},{"name":"component---src-pages-presentations-js-ef338db105d67c97982b.js","size":556}],"filteredAssets":0,"assetsSize":277687,"filteredAuxiliaryAssets":2,"auxiliaryAssetsSize":549091},"component---src-pages-presentations-presentations-json-json-id-js":{"name":"component---src-pages-presentations-presentations-json-json-id-js","assets":[{"name":"styles.798d7058577ffdad1e42.css","size":112358},{"name":"7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30-a2b573f288bb94ad12ca.js","size":164773},{"name":"component---src-pages-presentations-presentations-json-json-id-js-c28b828410e6f33d9245.js","size":639}],"filteredAssets":0,"assetsSize":277770,"filteredAuxiliaryAssets":2,"auxiliaryAssetsSize":549909},"component---src-pages-projects-js":{"name":"component---src-pages-projects-js","assets":[{"name":"styles.798d7058577ffdad1e42.css","size":112358},{"name":"7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30-a2b573f288bb94ad12ca.js","size":164773},{"name":"component---src-pages-projects-js-a15f4187e03e2bc882ac.js","size":2175}],"filteredAssets":0,"assetsSize":279306,"filteredAuxiliaryAssets":2,"auxiliaryAssetsSize":554406},"component---src-pages-software-js":{"name":"component---src-pages-software-js","assets":[{"name":"component---src-pages-software-js-ea75cd86f29da1c9979a.js","size":1357}],"filteredAssets":0,"assetsSize":1357,"filteredAuxiliaryAssets":1,"auxiliaryAssetsSize":3017},"component---src-pages-tech-js":{"name":"component---src-pages-tech-js","assets":[{"name":"styles.798d7058577ffdad1e42.css","size":112358},{"name":"7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30-a2b573f288bb94ad12ca.js","size":164773},{"name":"component---src-pages-tech-js-66907ecb2446d2b384e2.js","size":522}],"filteredAssets":0,"assetsSize":277653,"filteredAuxiliaryAssets":2,"auxiliaryAssetsSize":548998},"component---src-pages-tech-tech-json-json-id-js":{"name":"component---src-pages-tech-tech-json-json-id-js","assets":[{"name":"styles.798d7058577ffdad1e42.css","size":112358},{"name":"7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30-a2b573f288bb94ad12ca.js","size":164773},{"name":"component---src-pages-tech-tech-json-json-id-js-fd719b20aee8818d9dec.js","size":622}],"filteredAssets":0,"assetsSize":277753,"filteredAuxiliaryAssets":2,"auxiliaryAssetsSize":549840},"component---src-pages-websites-js":{"name":"component---src-pages-websites-js","assets":[{"name":"styles.798d7058577ffdad1e42.css","size":112358},{"name":"7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30-a2b573f288bb94ad12ca.js","size":164773},{"name":"component---src-pages-websites-js-e6f8e60d3f29edbfcba7.js","size":526}],"filteredAssets":0,"assetsSize":277657,"filteredAuxiliaryAssets":2,"auxiliaryAssetsSize":549026},"component---src-pages-websites-websites-json-json-id-js":{"name":"component---src-pages-websites-websites-json-json-id-js","assets":[{"name":"styles.798d7058577ffdad1e42.css","size":112358},{"name":"7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30-a2b573f288bb94ad12ca.js","size":164773},{"name":"component---src-pages-websites-websites-json-json-id-js-0a43b2c359f70cc28297.js","size":624}],"filteredAssets":0,"assetsSize":277755,"filteredAuxiliaryAssets":2,"auxiliaryAssetsSize":549863}},"assetsByChunkName":{"app":["webpack-runtime-284d8f587ec3a9957b06.js","styles.798d7058577ffdad1e42.css","framework-9311b08a6c5b48aac427.js","app-9442da87d5728df94a7c.js"],"component---src-pages-404-js":["component---src-pages-404-js-d1203087144cbdfbf0bc.js"],"component---src-pages-art-art-json-json-id-js":["styles.798d7058577ffdad1e42.css","7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30-a2b573f288bb94ad12ca.js","component---src-pages-art-art-json-json-id-js-4e8a242549dc50ff49f1.js"],"component---src-pages-art-js":["styles.798d7058577ffdad1e42.css","7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30-a2b573f288bb94ad12ca.js","component---src-pages-art-js-72f0f3bdbc61943bc2cb.js"],"component---src-pages-games-games-json-json-id-js":["styles.798d7058577ffdad1e42.css","7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30-a2b573f288bb94ad12ca.js","component---src-pages-games-games-json-json-id-js-ad38f6099c7f2a1cb117.js"],"component---src-pages-games-js":["styles.798d7058577ffdad1e42.css","7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30-a2b573f288bb94ad12ca.js","component---src-pages-games-js-dfbada6fbd2ff8012889.js"],"component---src-pages-index-js":["styles.798d7058577ffdad1e42.css","7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30-a2b573f288bb94ad12ca.js","component---src-pages-index-js-186dac701b65cc23788b.js"],"component---src-pages-presentations-js":["styles.798d7058577ffdad1e42.css","7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30-a2b573f288bb94ad12ca.js","component---src-pages-presentations-js-ef338db105d67c97982b.js"],"component---src-pages-presentations-presentations-json-json-id-js":["styles.798d7058577ffdad1e42.css","7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30-a2b573f288bb94ad12ca.js","component---src-pages-presentations-presentations-json-json-id-js-c28b828410e6f33d9245.js"],"component---src-pages-projects-js":["styles.798d7058577ffdad1e42.css","7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30-a2b573f288bb94ad12ca.js","component---src-pages-projects-js-a15f4187e03e2bc882ac.js"],"component---src-pages-software-js":["component---src-pages-software-js-ea75cd86f29da1c9979a.js"],"component---src-pages-tech-js":["styles.798d7058577ffdad1e42.css","7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30-a2b573f288bb94ad12ca.js","component---src-pages-tech-js-66907ecb2446d2b384e2.js"],"component---src-pages-tech-tech-json-json-id-js":["styles.798d7058577ffdad1e42.css","7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30-a2b573f288bb94ad12ca.js","component---src-pages-tech-tech-json-json-id-js-fd719b20aee8818d9dec.js"],"component---src-pages-websites-js":["styles.798d7058577ffdad1e42.css","7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30-a2b573f288bb94ad12ca.js","component---src-pages-websites-js-e6f8e60d3f29edbfcba7.js"],"component---src-pages-websites-websites-json-json-id-js":["styles.798d7058577ffdad1e42.css","7f37a912f8f2e5ed33e17924ddc8b133c3ea7c30-a2b573f288bb94ad12ca.js","component---src-pages-websites-websites-json-json-id-js-0a43b2c359f70cc28297.js"]},"childAssetsByChunkName":{}} \ No newline at end of file +{"name":"build-javascript","namedChunkGroups":{"app":{"name":"app","assets":[{"name":"webpack-runtime-5fb14cc844aad905efef.js","size":4317},{"name":"styles.4de84519df67d9bc71d6.css","size":113649},{"name":"framework-fe45a4eff34f3251ccde.js","size":141002},{"name":"app-41c24a534f93c478f24f.js","size":66567}],"filteredAssets":0,"assetsSize":325535,"filteredAuxiliaryAssets":3,"auxiliaryAssetsSize":647302},"component---src-pages-404-tsx":{"name":"component---src-pages-404-tsx","assets":[{"name":"component---src-pages-404-tsx-616a846c6313980ead8b.js","size":368}],"filteredAssets":0,"assetsSize":368,"filteredAuxiliaryAssets":1,"auxiliaryAssetsSize":560},"component---src-pages-art-art-json-json-id-tsx":{"name":"component---src-pages-art-art-json-json-id-tsx","assets":[{"name":"styles.4de84519df67d9bc71d6.css","size":113649},{"name":"bb2a438c5d749940577b6da90d079ffc6be879e5-d46bc632d9a40ea835fc.js","size":143250},{"name":"component---src-pages-art-art-json-json-id-tsx-5edc4c77927e975ada02.js","size":656}],"filteredAssets":0,"assetsSize":257555,"filteredAuxiliaryAssets":2,"auxiliaryAssetsSize":518137},"component---src-pages-art-tsx":{"name":"component---src-pages-art-tsx","assets":[{"name":"styles.4de84519df67d9bc71d6.css","size":113649},{"name":"bb2a438c5d749940577b6da90d079ffc6be879e5-d46bc632d9a40ea835fc.js","size":143250},{"name":"component---src-pages-art-tsx-6aa6e8ebf5e3e301a735.js","size":544}],"filteredAssets":0,"assetsSize":257443,"filteredAuxiliaryAssets":2,"auxiliaryAssetsSize":517207},"component---src-pages-gallery-tsx":{"name":"component---src-pages-gallery-tsx","assets":[{"name":"component---src-pages-gallery-tsx-482ef72b34404869fafb.js","size":378}],"filteredAssets":0,"assetsSize":378,"filteredAuxiliaryAssets":1,"auxiliaryAssetsSize":563},"component---src-pages-games-games-json-json-id-tsx":{"name":"component---src-pages-games-games-json-json-id-tsx","assets":[{"name":"styles.4de84519df67d9bc71d6.css","size":113649},{"name":"bb2a438c5d749940577b6da90d079ffc6be879e5-d46bc632d9a40ea835fc.js","size":143250},{"name":"component---src-pages-games-games-json-json-id-tsx-af2fe7f1bbff9c002bc2.js","size":650}],"filteredAssets":0,"assetsSize":257549,"filteredAuxiliaryAssets":2,"auxiliaryAssetsSize":518140},"component---src-pages-games-tsx":{"name":"component---src-pages-games-tsx","assets":[{"name":"styles.4de84519df67d9bc71d6.css","size":113649},{"name":"bb2a438c5d749940577b6da90d079ffc6be879e5-d46bc632d9a40ea835fc.js","size":143250},{"name":"component---src-pages-games-tsx-a7cbe020e3366b17fca6.js","size":532}],"filteredAssets":0,"assetsSize":257431,"filteredAuxiliaryAssets":2,"auxiliaryAssetsSize":517208},"component---src-pages-index-tsx":{"name":"component---src-pages-index-tsx","assets":[{"name":"styles.4de84519df67d9bc71d6.css","size":113649},{"name":"bb2a438c5d749940577b6da90d079ffc6be879e5-d46bc632d9a40ea835fc.js","size":143250},{"name":"component---src-pages-index-tsx-04d7db7b20b674f22098.js","size":2888}],"filteredAssets":0,"assetsSize":259787,"filteredAuxiliaryAssets":2,"auxiliaryAssetsSize":525228},"component---src-pages-presentations-presentations-json-json-id-tsx":{"name":"component---src-pages-presentations-presentations-json-json-id-tsx","assets":[{"name":"styles.4de84519df67d9bc71d6.css","size":113649},{"name":"bb2a438c5d749940577b6da90d079ffc6be879e5-d46bc632d9a40ea835fc.js","size":143250},{"name":"component---src-pages-presentations-presentations-json-json-id-tsx-0a058075e95972f501e1.js","size":674}],"filteredAssets":0,"assetsSize":257573,"filteredAuxiliaryAssets":2,"auxiliaryAssetsSize":518221},"component---src-pages-presentations-tsx":{"name":"component---src-pages-presentations-tsx","assets":[{"name":"styles.4de84519df67d9bc71d6.css","size":113649},{"name":"bb2a438c5d749940577b6da90d079ffc6be879e5-d46bc632d9a40ea835fc.js","size":143250},{"name":"component---src-pages-presentations-tsx-bafbf6b4a4a8750b21b0.js","size":579}],"filteredAssets":0,"assetsSize":257478,"filteredAuxiliaryAssets":2,"auxiliaryAssetsSize":517350},"component---src-pages-projects-tsx":{"name":"component---src-pages-projects-tsx","assets":[{"name":"styles.4de84519df67d9bc71d6.css","size":113649},{"name":"bb2a438c5d749940577b6da90d079ffc6be879e5-d46bc632d9a40ea835fc.js","size":143250},{"name":"component---src-pages-projects-tsx-eec5de8bb09262d73b14.js","size":2252}],"filteredAssets":0,"assetsSize":259151,"filteredAuxiliaryAssets":2,"auxiliaryAssetsSize":522810},"component---src-pages-software-tsx":{"name":"component---src-pages-software-tsx","assets":[{"name":"component---src-pages-software-tsx-c4b83ef2f542ba23efe6.js","size":1428}],"filteredAssets":0,"assetsSize":1428,"filteredAuxiliaryAssets":1,"auxiliaryAssetsSize":3162},"component---src-pages-tech-tech-json-json-id-tsx":{"name":"component---src-pages-tech-tech-json-json-id-tsx","assets":[{"name":"styles.4de84519df67d9bc71d6.css","size":113649},{"name":"bb2a438c5d749940577b6da90d079ffc6be879e5-d46bc632d9a40ea835fc.js","size":143250},{"name":"component---src-pages-tech-tech-json-json-id-tsx-d1520a20b9413dd07cd2.js","size":657}],"filteredAssets":0,"assetsSize":257556,"filteredAuxiliaryAssets":2,"auxiliaryAssetsSize":518145},"component---src-pages-tech-tsx":{"name":"component---src-pages-tech-tsx","assets":[{"name":"styles.4de84519df67d9bc71d6.css","size":113649},{"name":"bb2a438c5d749940577b6da90d079ffc6be879e5-d46bc632d9a40ea835fc.js","size":143250},{"name":"component---src-pages-tech-tsx-9ee90f481db012c17642.js","size":546}],"filteredAssets":0,"assetsSize":257445,"filteredAuxiliaryAssets":2,"auxiliaryAssetsSize":517216},"component---src-pages-websites-tsx":{"name":"component---src-pages-websites-tsx","assets":[{"name":"styles.4de84519df67d9bc71d6.css","size":113649},{"name":"bb2a438c5d749940577b6da90d079ffc6be879e5-d46bc632d9a40ea835fc.js","size":143250},{"name":"component---src-pages-websites-tsx-9b48b666ace10a338012.js","size":550}],"filteredAssets":0,"assetsSize":257449,"filteredAuxiliaryAssets":2,"auxiliaryAssetsSize":517281},"component---src-pages-websites-websites-json-json-id-tsx":{"name":"component---src-pages-websites-websites-json-json-id-tsx","assets":[{"name":"styles.4de84519df67d9bc71d6.css","size":113649},{"name":"bb2a438c5d749940577b6da90d079ffc6be879e5-d46bc632d9a40ea835fc.js","size":143250},{"name":"component---src-pages-websites-websites-json-json-id-tsx-e1498755bd2c989d20b3.js","size":659}],"filteredAssets":0,"assetsSize":257558,"filteredAuxiliaryAssets":2,"auxiliaryAssetsSize":518170}},"assetsByChunkName":{"app":["webpack-runtime-5fb14cc844aad905efef.js","styles.4de84519df67d9bc71d6.css","framework-fe45a4eff34f3251ccde.js","app-41c24a534f93c478f24f.js"],"component---src-pages-404-tsx":["component---src-pages-404-tsx-616a846c6313980ead8b.js"],"component---src-pages-art-art-json-json-id-tsx":["styles.4de84519df67d9bc71d6.css","bb2a438c5d749940577b6da90d079ffc6be879e5-d46bc632d9a40ea835fc.js","component---src-pages-art-art-json-json-id-tsx-5edc4c77927e975ada02.js"],"component---src-pages-art-tsx":["styles.4de84519df67d9bc71d6.css","bb2a438c5d749940577b6da90d079ffc6be879e5-d46bc632d9a40ea835fc.js","component---src-pages-art-tsx-6aa6e8ebf5e3e301a735.js"],"component---src-pages-gallery-tsx":["component---src-pages-gallery-tsx-482ef72b34404869fafb.js"],"component---src-pages-games-games-json-json-id-tsx":["styles.4de84519df67d9bc71d6.css","bb2a438c5d749940577b6da90d079ffc6be879e5-d46bc632d9a40ea835fc.js","component---src-pages-games-games-json-json-id-tsx-af2fe7f1bbff9c002bc2.js"],"component---src-pages-games-tsx":["styles.4de84519df67d9bc71d6.css","bb2a438c5d749940577b6da90d079ffc6be879e5-d46bc632d9a40ea835fc.js","component---src-pages-games-tsx-a7cbe020e3366b17fca6.js"],"component---src-pages-index-tsx":["styles.4de84519df67d9bc71d6.css","bb2a438c5d749940577b6da90d079ffc6be879e5-d46bc632d9a40ea835fc.js","component---src-pages-index-tsx-04d7db7b20b674f22098.js"],"component---src-pages-presentations-presentations-json-json-id-tsx":["styles.4de84519df67d9bc71d6.css","bb2a438c5d749940577b6da90d079ffc6be879e5-d46bc632d9a40ea835fc.js","component---src-pages-presentations-presentations-json-json-id-tsx-0a058075e95972f501e1.js"],"component---src-pages-presentations-tsx":["styles.4de84519df67d9bc71d6.css","bb2a438c5d749940577b6da90d079ffc6be879e5-d46bc632d9a40ea835fc.js","component---src-pages-presentations-tsx-bafbf6b4a4a8750b21b0.js"],"component---src-pages-projects-tsx":["styles.4de84519df67d9bc71d6.css","bb2a438c5d749940577b6da90d079ffc6be879e5-d46bc632d9a40ea835fc.js","component---src-pages-projects-tsx-eec5de8bb09262d73b14.js"],"component---src-pages-software-tsx":["component---src-pages-software-tsx-c4b83ef2f542ba23efe6.js"],"component---src-pages-tech-tech-json-json-id-tsx":["styles.4de84519df67d9bc71d6.css","bb2a438c5d749940577b6da90d079ffc6be879e5-d46bc632d9a40ea835fc.js","component---src-pages-tech-tech-json-json-id-tsx-d1520a20b9413dd07cd2.js"],"component---src-pages-tech-tsx":["styles.4de84519df67d9bc71d6.css","bb2a438c5d749940577b6da90d079ffc6be879e5-d46bc632d9a40ea835fc.js","component---src-pages-tech-tsx-9ee90f481db012c17642.js"],"component---src-pages-websites-tsx":["styles.4de84519df67d9bc71d6.css","bb2a438c5d749940577b6da90d079ffc6be879e5-d46bc632d9a40ea835fc.js","component---src-pages-websites-tsx-9b48b666ace10a338012.js"],"component---src-pages-websites-websites-json-json-id-tsx":["styles.4de84519df67d9bc71d6.css","bb2a438c5d749940577b6da90d079ffc6be879e5-d46bc632d9a40ea835fc.js","component---src-pages-websites-websites-json-json-id-tsx-e1498755bd2c989d20b3.js"]},"childAssetsByChunkName":{}} \ No newline at end of file diff --git a/websites/allium/index.html b/websites/allium/index.html index 99da4fc..3c12a7a 100644 --- a/websites/allium/index.html +++ b/websites/allium/index.html @@ -1 +1 @@ -Adam Graham • Allium

Allium

November 2015|Web Designer
Adobe Muse
Adobe Photoshop

Allium is a home-based floral design studio launched in 2013 by Kim Stanke. After years of working in both retail stores and special event design shops, Kim started her own business to flex her creative muscles.

Adam designed a new website for Allium as an improvement to the old WordPress site. The goal of the new design was to better promote the business and its floral services.

Allium Screenshot
GitHub
LinkedIn
Email
Dark Mode
Visit Website
\ No newline at end of file +Adam Graham • Allium

Allium

November 2015|Web Designer
Adobe Muse
Adobe Photoshop

Allium is a home-based floral design studio launched in 2013 by Kim Stanke. After years of working in both retail stores and special event design shops, Kim started her own business to flex her creative muscles.

Adam designed a new website for Allium as an improvement to the old WordPress site. The goal of the new design was to better promote the business and its floral services.

Allium Screenshot
GitHub
LinkedIn
Email
Dark Mode
Visit Website
\ No newline at end of file diff --git a/websites/ashantis-jones/index.html b/websites/ashantis-jones/index.html index 6687c88..de1b3e9 100644 --- a/websites/ashantis-jones/index.html +++ b/websites/ashantis-jones/index.html @@ -1 +1 @@ -Adam Graham • Ashantis Jones

Ashantis Jones

June 2016|Web Designer
Adobe Muse
Adobe Photoshop

Ashantis Jones is an event planner from Cleaveland, Ohio that entertains and creates memorable events through detail oriented design and calculated execution. Adam designed Ashantis's portfolio to assist in her job hunt as a graduate of the BFA Theatre Management at DePaul University looking for opportunities in the event management space.

Ashantis Jones Screenshot
GitHub
LinkedIn
Email
Dark Mode
Visit Website
\ No newline at end of file +Adam Graham • Ashantis Jones

Ashantis Jones

June 2016|Web Designer
Adobe Muse
Adobe Photoshop

Ashantis Jones is an event planner from Cleaveland, Ohio that entertains and creates memorable events through detail oriented design and calculated execution. Adam designed Ashantis's portfolio to assist in her job hunt as a graduate of the BFA Theatre Management at DePaul University looking for opportunities in the event management space.

Ashantis Jones Screenshot
GitHub
LinkedIn
Email
Dark Mode
Visit Website
\ No newline at end of file diff --git a/websites/be-super/index.html b/websites/be-super/index.html index a7dea65..0dd567e 100644 --- a/websites/be-super/index.html +++ b/websites/be-super/index.html @@ -1 +1 @@ -Adam Graham • Be Super

Be Super

September 2016|Web Designer
Adobe Muse
Adobe Photoshop

Be Super strives to use comic book characters as educational tools to understand social justice issues. A movement calling for everyone to be the hero within. Adam designed Be Super's website to help promote the cause.

Be Super Screenshot
GitHub
LinkedIn
Email
Dark Mode
Visit Website
\ No newline at end of file +Adam Graham • Be Super

Be Super

September 2016|Web Designer
Adobe Muse
Adobe Photoshop

Be Super strives to use comic book characters as educational tools to understand social justice issues. A movement calling for everyone to be the hero within. Adam designed Be Super's website to help promote the cause.

Be Super Screenshot
GitHub
LinkedIn
Email
Dark Mode
Visit Website
\ No newline at end of file diff --git a/websites/colorly/index.html b/websites/colorly/index.html index 99125be..620d8bc 100644 --- a/websites/colorly/index.html +++ b/websites/colorly/index.html @@ -1 +1 @@ -Adam Graham • Colorly

Colorly

October 2020|Web Designer, Developer
React
Redux
JavaScript
HTML/CSS

Colorly is a versatile collection of color tools for designers and developers encapsulated in one web app - shades, tints, tones, harmonies, contrast, color blindness, gradients, and more!

Colorly Screenshot
Colorly Screenshot
GitHub
LinkedIn
Email
Dark Mode
Visit Website
Source Code
\ No newline at end of file +Adam Graham • Colorly

Colorly

October 2020|Web Designer, Developer
React
Redux
JavaScript
HTML/CSS

Colorly is a versatile collection of color tools for designers and developers encapsulated in one web app - shades, tints, tones, harmonies, contrast, color blindness, gradients, and more!

Colorly Screenshot
Colorly Screenshot
GitHub
LinkedIn
Email
Dark Mode
Visit Website
Source Code
\ No newline at end of file diff --git a/websites/demonthon/index.html b/websites/demonthon/index.html index 5aa49f9..8d1c3e9 100644 --- a/websites/demonthon/index.html +++ b/websites/demonthon/index.html @@ -1 +1 @@ -Adam Graham • DemonTHON

DemonTHON

June 2014|Director of Technology
Adobe Muse
Adobe Photoshop

DemonTHON is a year-long fundraising organization benefiting Ann & Robert H. Lurie Children's Hospital of Chicago that culminates in a 24-hour Dance Marathon at DePaul University.

As the Director of Technology, Adam designed and managed the organization's website from June 2014 to May 2016. The site was awarded "Best Website" by Children's Miracle Network Hospitals for the 2014-15 Dance Marathon year.

DemonTHON Screenshot
GitHub
LinkedIn
Email
Dark Mode
Visit Website
\ No newline at end of file +Adam Graham • DemonTHON

DemonTHON

June 2014|Director of Technology
Adobe Muse
Adobe Photoshop

DemonTHON is a year-long fundraising organization benefiting Ann & Robert H. Lurie Children's Hospital of Chicago that culminates in a 24-hour Dance Marathon at DePaul University.

As the Director of Technology, Adam designed and managed the organization's website from June 2014 to May 2016. The site was awarded "Best Website" by Children's Miracle Network Hospitals for the 2014-15 Dance Marathon year.

DemonTHON Screenshot
GitHub
LinkedIn
Email
Dark Mode
Visit Website
\ No newline at end of file diff --git a/websites/index.html b/websites/index.html index 8a609a1..39fb5d9 100644 --- a/websites/index.html +++ b/websites/index.html @@ -1 +1 @@ -Adam Graham • Websites
GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file +Adam Graham • Websites
GitHub
LinkedIn
Email
Dark Mode
\ No newline at end of file diff --git a/websites/let-it-beard/index.html b/websites/let-it-beard/index.html index 8cc48ff..d54f1f4 100644 --- a/websites/let-it-beard/index.html +++ b/websites/let-it-beard/index.html @@ -1 +1 @@ -Adam Graham • Let It Beard

Let It Beard

November 2014|Web Designer
Adobe Muse
Adobe Photoshop
Adobe Flash

Let It Beard is an animated short film that follows the misadventures of an enigmatic religious family known simply as "The Cult". The Captain and his bevy of devoted followers aim for truth, inner peace, and run various entrepreneurial endeavors on their path to transcendent enlightenment.

The Let It Beard website is a simple one-page design to help promote the animated short film. A random animated background is displayed upon each visit alongside various idle animations. Visit multiple times to see different designs. Requires Adobe Flash.

Let It Beard Screenshot
GitHub
LinkedIn
Email
Dark Mode
Visit Website
\ No newline at end of file +Adam Graham • Let It Beard

Let It Beard

November 2014|Web Designer
Adobe Muse
Adobe Photoshop
Adobe Flash

Let It Beard is an animated short film that follows the misadventures of an enigmatic religious family known simply as "The Cult". The Captain and his bevy of devoted followers aim for truth, inner peace, and run various entrepreneurial endeavors on their path to transcendent enlightenment.

The Let It Beard website is a simple one-page design to help promote the animated short film. A random animated background is displayed upon each visit alongside various idle animations. Visit multiple times to see different designs. Requires Adobe Flash.

Let It Beard Screenshot
GitHub
LinkedIn
Email
Dark Mode
Visit Website
\ No newline at end of file diff --git a/websites/margaret-baughman/index.html b/websites/margaret-baughman/index.html index 7c571f5..527c882 100644 --- a/websites/margaret-baughman/index.html +++ b/websites/margaret-baughman/index.html @@ -1 +1 @@ -Adam Graham • Margaret Baughman

Margaret Baughman

July 2016|Web Designer
Adobe Muse
Adobe Photoshop

Director, choreographer, and empathetic human, Margaret Baughman is enchanted by a world of contradictions that allows her to shake up perspectives through theatre, advocacy, and impeccable organization. Adam designed Margaret's portfolio to help showcase her work.

Margaret Baughman Screenshot
GitHub
LinkedIn
Email
Dark Mode
Visit Website
\ No newline at end of file +Adam Graham • Margaret Baughman

Margaret Baughman

July 2016|Web Designer
Adobe Muse
Adobe Photoshop

Director, choreographer, and empathetic human, Margaret Baughman is enchanted by a world of contradictions that allows her to shake up perspectives through theatre, advocacy, and impeccable organization. Adam designed Margaret's portfolio to help showcase her work.

Margaret Baughman Screenshot
GitHub
LinkedIn
Email
Dark Mode
Visit Website
\ No newline at end of file diff --git a/websites/polykai/index.html b/websites/polykai/index.html index 4884575..b679f3b 100644 --- a/websites/polykai/index.html +++ b/websites/polykai/index.html @@ -1 +1 @@ -Adam Graham • Polykai

Polykai

July 2019|Web Designer, Developer
React
JavaScript
HTML/CSS
VSIX

Polykai is a dark color scheme for code editors inspired by Wimer Hazenberg's Monokai theme. The theme is supported in 20+ code editors and terminals, including a custom VS Code extension.

Polykai Screenshot
GitHub
LinkedIn
Email
Dark Mode
Visit Website
Source Code
\ No newline at end of file +Adam Graham • Polykai

Polykai

July 2019|Web Designer, Developer
React
JavaScript
HTML/CSS
VSIX

Polykai is a dark color scheme for code editors inspired by Wimer Hazenberg's Monokai theme. The theme is supported in 20+ code editors and terminals, including a custom VS Code extension.

Polykai Screenshot
GitHub
LinkedIn
Email
Dark Mode
Visit Website
Source Code
\ No newline at end of file diff --git a/websites/squish-em/index.html b/websites/squish-em/index.html index 4603482..0a504e1 100644 --- a/websites/squish-em/index.html +++ b/websites/squish-em/index.html @@ -1 +1 @@ -Adam Graham • Squish-em!

Squish-em!

April 2015|Web Designer
Adobe Muse
Adobe Photoshop
Adobe Flash

Squish-em! is a simple whack-a-mole re-creation designed for mobile devices. Squish your way to the top of the leaderboards, earn achievements along the way, and brag to your friends when you beat their best score!

The Squish-em! website is a one-page, artistic cover designed to promote the game and direct users to download the mobile app.

Squish-em! Screenshot
GitHub
LinkedIn
Email
Dark Mode
Visit Website
\ No newline at end of file +Adam Graham • Squish-em!

Squish-em!

April 2015|Web Designer
Adobe Muse
Adobe Photoshop
Adobe Flash

Squish-em! is a simple whack-a-mole re-creation designed for mobile devices. Squish your way to the top of the leaderboards, earn achievements along the way, and brag to your friends when you beat their best score!

The Squish-em! website is a one-page, artistic cover designed to promote the game and direct users to download the mobile app.

Squish-em! Screenshot
GitHub
LinkedIn
Email
Dark Mode
Visit Website
\ No newline at end of file diff --git a/websites/taylor-cochran-music/index.html b/websites/taylor-cochran-music/index.html index 33fcb98..548cabf 100644 --- a/websites/taylor-cochran-music/index.html +++ b/websites/taylor-cochran-music/index.html @@ -1 +1 @@ -Adam Graham • Taylor Cochran Music

Taylor Cochran Music

December 2013|Web Designer
Adobe Muse
Adobe Photoshop

Taylor Cochran is a singer/songwriter from Nashville, Tennessee who pursued his songwriting career in early 2013 by gaining experience playing in local bars, venues, and with his church. Through his music, he aspires to send a message of joy, hope, and love.

Adam designed and managed Taylor's website from late 2013 to mid 2014. The website was launched alongside the success of Taylor's debut EP Kickstarter campaign for which he also helped produce the promo video.

Taylor Cochran Music Screenshot
GitHub
LinkedIn
Email
Dark Mode
Visit Website
\ No newline at end of file +Adam Graham • Taylor Cochran Music

Taylor Cochran Music

December 2013|Web Designer
Adobe Muse
Adobe Photoshop

Taylor Cochran is a singer/songwriter from Nashville, Tennessee who pursued his songwriting career in early 2013 by gaining experience playing in local bars, venues, and with his church. Through his music, he aspires to send a message of joy, hope, and love.

Adam designed and managed Taylor's website from late 2013 to mid 2014. The website was launched alongside the success of Taylor's debut EP Kickstarter campaign for which he also helped produce the promo video.

Taylor Cochran Music Screenshot
GitHub
LinkedIn
Email
Dark Mode
Visit Website
\ No newline at end of file diff --git a/websites/zigurous/index.html b/websites/zigurous/index.html index 2210bd3..1270dda 100644 --- a/websites/zigurous/index.html +++ b/websites/zigurous/index.html @@ -1 +1 @@ -Adam Graham • Zigurous

Zigurous

January 2021|Web Designer, Developer, Maintainer
React
Gatsby
JavaScript
HTML/CSS
Firebase

Zigurous is an indie game development studio. Adam has designed and managed the website since he founded the game studio in 2012. Below you can see different examples and the progression of the website over time.

2021 - Current

Zigurous Screenshot

2017 - Abstract Theme

Zigurous Screenshot

2016 - Cube Theme

Zigurous Screenshot

2015 - Adventure Theme

Zigurous Screenshot

2014 - Medieval Theme

Zigurous Screenshot
GitHub
LinkedIn
Email
Dark Mode
Visit Website
\ No newline at end of file +Adam Graham • Zigurous

Zigurous

January 2021|Web Designer, Developer, Maintainer
React
Gatsby
TypeScript
HTML/CSS
Firebase

Zigurous is an indie game development studio. Adam has designed and managed the website since he founded the game studio in 2012. Below you can see different examples and the progression of the website over time.

2021 - Current

Zigurous Screenshot

2017 - Abstract Theme

Zigurous Screenshot

2016 - Cube Theme

Zigurous Screenshot

2015 - Adventure Theme

Zigurous Screenshot

2014 - Medieval Theme

Zigurous Screenshot
GitHub
LinkedIn
Email
Dark Mode
Visit Website
\ No newline at end of file

Blackhole

January 2015|Solo Project
Adobe Flash
ActionScript 3.0

Blackhole is a free-form, avant-garde game that enables players to control particles in unique ways. Individuals explore their own creative design within the art piece, loosely making their own objectives and discovering new ways of controlling this "creative chaos" - a new type of game genre.

Media

GitHub
LinkedIn
Email
Dark Mode
Download
Source Code